Index: btkb/c
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/c	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/c	(working copy)
@@ -0,0 +1,45 @@
+#!/bin/bash
+
+gensched () {
+if [ -f output/sched.rom ];then rm output/sched.rom; fi
+while [ 1 ];do
+	if [ -n "$1" ];then cat sched/$1.dat >> output/sched.rom; else return; fi
+	shift
+done
+}
+
+#enckey="-k 00000000000000000000000000000000"
+
+cd ${0%/*}
+for f in program/*.prog 
+  do if [[ ! $f =~ "bt.prog" && ! $f =~ "patch.prog" && ! $f =~ "sim.prog" ]] ; then progs="$progs $f"; fi; done
+cat program/bt.prog $progs  > output/bt_program23.meta
+
+case $1 in
+*)
+	gensched kb rf
+	sed '2 c define KEYBOARD' -i output/bt_program23.meta;;
+esac
+
+
+for f in format/*.format; do if [[ ! $f =~ "bt.format" && ! $f =~ "command.format" ]] ; then fmts="$fmts $f"; fi; done
+cat format/bt.format $fmts format/command.format > output/bt_format.meta
+perl $UTIL/mergepatch.pl 
+perl $UTIL/memalloc.pl
+cd output
+osiuasm bt_program23 -O-W
+sed 's/\(.*\)\r/\1/' -i bt_program23.meta 
+
+if [[ $1 == "c" ]];then make clean -C ../c51;fi
+make -C ../c51;cp ../c51/output/fwram.rom .
+geneep $enckey
+
+if [[ $1 == "o" ]];then exit;fi
+if [ -f sched.rom ]; then
+	e h;e k
+	e ku; e hu ramcode.rom 0; e su sched.rom;e pu;e cu
+else
+	e ku;e hu
+fi
+
+cd ..
Index: btkb/do.bat
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/do.bat	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/do.bat	(working copy)
@@ -0,0 +1,144 @@
+@set FPGA_PATH=fpgajic\fpga
+@set ROM_PATH=.
+@set MV_PATCH=mv\src\yichip
+@set YC_PATCH_FILE=yc_patch_yc1021.h
+@set enc=1
+@set enckey=0000000000000000
+@rem set device_option=shutter
+@rem set device_option=hci
+@set device_option=kb
+@rem set device_option=mouse
+@rem set device_option=le_kb
+@rem set device_option=dongle
+@rem set device_option=module
+@rem set device_option=prcp
+
+@echo off
+
+setlocal enabledelayedexpansion
+for /f %%f in ('dir /b /o program\*.prog') do @if not %%f==bt.prog if not %%f==patch.prog if not %%f==sim.prog set progs=!progs! program\%%f
+type program\bt.prog %progs% > output\bt_program23.meta
+for /f %%f in ('dir /b /o format\*.format') do @if not %%f==bt.format if not %%f==command.format set fmts=!fmts! format\%%f
+type format\bt.format %fmts% format\command.format > output\bt_format.meta
+perl util/mergepatch.pl output/bt_program23.meta
+perl util/memalloc.pl output/bt_format.meta
+
+perl util/transform_memmap2btreg.pl output/memmap.format format/memblocks.format ..\c51\btreg.h
+
+cd output
+osiuasm bt_program23 -O-W
+
+if "%device_option%" equ "hci" (
+  copy ..\sched\hci_boot.dat ..\output\sched.rom
+) else if "%device_option%" equ "kb" (
+  copy ..\sched\kb.dat +  ..\sched\rf.dat ..\output\sched.rom
+) else if "%device_option%" equ "le_kb" (
+  copy ..\sched\le_kb.dat +  ..\sched\fpga.dat ..\output\sched.rom
+) else if "%device_option%" equ "mouse" (
+  copy ..\sched\patch.dat + ..\sched\rf.dat +  ..\sched\user.dat ..\output\sched.rom
+) else if "%device_option%" equ "module" (
+  copy  ..\sched\DM_module.dat +   ..\sched\109x.dat ..\output\sched.rom
+) else if "%device_option%" equ "shutter" (
+  copy  ..\sched\shutter.dat +  ..\sched\fpga.dat ..\output\sched.rom
+) else if "%device_option%" equ "dongle" (
+  copy ..\sched\dongle.dat +  ..\sched\usb.dat +  ..\sched\fpga.dat ..\output\sched.rom
+) else if "%device_option%" equ "prcp" (
+  copy ..\sched\Le_prcp.dat + ..\sched\fpga.dat ..\output\sched.rom
+) else if "%device_option%" equ "test" (
+  copy ..\sched\test.dat + ..\sched\fpga.dat ..\output\sched.rom
+) else (
+cd ..
+echo **********************************
+echo Error: illegal device_option !
+echo **********************************
+goto end
+) 
+
+if "%1" equ "eep" (
+	goto genromrevc
+)else (
+  goto downloadram
+)
+
+:geneeprom
+@rem echo on
+@echo Start to generate EEPROM code
+copy ..\sched\mouse.dat ..\output\sched.rom
+
+..\util\geneep ramcode.rom fwram.rom sched.rom %enc% %enckey% a
+perl ..\util\a1bugfix.pl
+osiuasm bt_program23 -O-W
+..\util\geneep ramcode.rom fwram.rom sched.rom %enc% %enckey% a
+goto gen_eep_end
+
+
+
+
+:genromrevb
+echo off
+@echo Start to generate EEPROM code
+..\..\regedr\geneep ramcode.rom fwram.rom sched.rom %enc% %enckey% b
+goto gen_eep_end
+
+
+:genromrevc
+echo off
+@echo Start to generate EEPROM code
+
+geneep -n ramcode.rom sched.rom 0 %enckey% c
+cd ..\output
+
+echo eeprom.dat Generated......
+
+
+:gen_eep_end
+cd ..
+echo **********************************
+echo EEPROM Generated.
+echo The Device is %device_option%. 
+echo Use command "e ep" to download EEPROM.
+echo **********************************
+
+@copy .\output\ramcode.rom ..\c51\patch
+@copy .\output\sched.rom ..\c51\patch
+@copy .\output\memmap.format ..\c51\patch
+@copy .\format\keyboard.format ..\c51\patch
+@copy .\sched\*.*	..\c51\patch
+
+goto end
+
+:genrom
+@rem echo on
+perl ..\util\rom2mif.pl romcode
+del ..\..\%FPGA_PATH%\romcode.mif
+copy .\romcode.mif ..\..\%FPGA_PATH%\romcode.mif
+perl ..\util\gen_patch_h.pl >%YC_PATCH_FILE%
+copy .\%YC_PATCH_FILE% ..\..\%MV_PATCH%\%YC_PATCH_FILE%
+copy .\%YC_PATCH_FILE% D:\work\yichip\mv_proj\src\inc\%YC_PATCH_FILE%
+cd ..\..\%FPGA_PATH%
+quartus_cdb btspi -c btspi --update_mif
+quartus_asm --read_settings_files=off --write_settings_files=off btspi -c btspi
+quartus_pgm -c USB-Blaster[USB-0] -m jtag -o "p;.\output\btspi.sof" 
+@echo bitstream_compression=on >1
+@echo memory_map_file=on >> 1
+quartus_cpf -c -o 1 -s EP3C55 -d EPCS16 output\btspi.sof output\btspi.jic  
+@rem quartus_pgm -c USB-Blaster[USB-0] -m jtag -o "pi;.\output\btspi.jic"   
+@del 1
+goto end
+
+
+
+:downloadram
+echo on
+@echo Start to download ram code
+e ku
+e hu
+e su sched.rom
+@echo **********************************
+@echo RAM CODE has been downloaded.
+@echo The Device is %device_option%. 
+@echo **********************************
+cd ..
+
+
+:end
Index: btkb/format/Hid.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/Hid.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/Hid.format	(working copy)
@@ -0,0 +1,21 @@
+
+(
+/*HID TYPE*/
+0x01 HID_TYPE_CONTROL
+0x04 HID_TYPE_GET_REPORT
+0x05 HID_TYPE_SET_REPORT
+0x07 HID_TYPE_SET_PROTOCOL
+0x09 HID_TYPE_SET_IDLE
+0x0a HID_TYPE_DATA
+/*HID REPORT ID*/
+0x01 HID_REPORT_ID_KB
+
+0x00 HID_CONTROL_P_NOOPERATION
+0x01 HID_CONTROL_P_HARDRESET
+0x02 HID_CONTROL_P_SOFTRESET
+0x03 HID_CONTROL_P_SUSPEND
+0x04 HID_CONTROL_P_EXITSUSPEND
+0x05 HID_CONTROL_P_VIRTUALCABLEUNPLUG
+)
+
+
Index: btkb/format/app.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/app.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/app.format	(working copy)
@@ -0,0 +1,234 @@
+
+memalloc(
+
+/* load code */
+1 mem_ucode_status
+2 mem_otp_ucode_flag
+1 mem_spid_tbuf				/* spid buf: 03 addr[23:16] addr[15:8] addr[7:0] */
+0 mem_iicd_tbuf				/* iicd buf: iic_adr addr[15:8] addr[7:0] iic_adr */
+1 mem_addr_hi
+1 mem_addr_mi
+1 mem_addr_lo
+1 mem_iicd_addr
+4 mem_spid_rbuf
+2 mem_ucode_buf
+2 mem_ucode_len
+2 mem_sched_addr
+2 mem_ucode_ptr
+16 mem_ucode_keybuf
+18 mem_check_plap_temp
+
+1 mem_sensor_id
+1 mem_reconnect_flag
+1 mem_switch_fail_master_count
+1 mem_app_evt_timer_count
+
+)
+
+xmemalloc(
+1 mem_app_state
+1 mem_app_handshake_flag
+2 mem_sniff_param_interval
+2 mem_sniff_param_attempt
+2 mem_sniff_param_timeout
+
+/*App Callback Functons*/
+2 mem_cb_check_wakelock
+2 mem_cb_before_hibernate
+2 mem_cb_before_lpm
+2 mem_cb_le_process
+2 mem_cb_bt_process
+2 mem_cb_idle_process
+2 mem_cb_bb_event_process
+2 mem_cb_discovry_timeout
+2 mem_cb_att_write
+2 mem_cb_update_notify_value
+1 mem_device_nums
+
+
+
+
+
+2 mem_eeprom_base
+
+1 mem_unsniff2sniff_timer_count
+//lpm mode
+1 mem_wake_up_delay_timer
+
+1 mem_app_connection_options
+
+//
+2 mem_app_disconn_reason
+2 mem_app_disconn_reason_flag
+1 mem_at_using_flag
+4 mem_lpm_delay_after_sniff
+1 mem_xrecord_mode
+
+2 mem_eeprom_block_size
+
+)
+
+/* ir */
+omemalloc(
+2 mem_ir_ptr
+1 mem_ir_type
+1 mem_ir_cmd
+1 mem_ir_play_count
+2 mem_ir_report_len
+1 mem_ir_pulse_zero
+1 mem_ir_pulse_one
+28 mem_ir_pulses
+1 mem_ir_sequence_len
+128 mem_ir_sequence
+)
+
+0x0000 otp_ucode_flag
+0x07f0 otp_ucode_aeskey
+
+
+/* data stored in eeprom */
+(
+0	eeprom_bdaddr_list
+28	eeprom_last_record
+29	eeprom_le_reconn_local_addr
+35	eeprom_linkkey_list//64
+
+99	eeprom_module_bt_adss//6
+105	eeprom_module_le_adss//6
+111	eeprom_module_pincode_length//1
+112	eeprom_module_pincode//15
+127	eeprom_module_bt_name_length//1
+128	eeprom_module_bt_name//32
+160	eeprom_module_ble_name_length//1
+161	eeprom_module_ble_name//31
+192	eeprom_module_trans_baud//3
+195	eeprom_module_init_flag//2
+197	eeprom_module_end
+
+//dpi eeprom addr
+198 eeprom_mouse_dpi
+)
+
+/*mem_app_handshake_flag*/
+(
+0 APP_HANDSHAKE_NULL
+1 APP_HANDSHAKE_DONE
+
+)
+/*mem_device_option*/
+(
+1 dvc_op_hci
+3 dvc_op_kb
+4 dvc_op_dongle
+5 dvc_op_spp
+6 dvc_op_ukey
+7 dvc_op_ir
+
+9 dvc_op_shutter
+10 dvc_op_module
+11 dvc_op_ble_mouse
+12 dvc_op_ble_kb
+13 dvc_op_ble_prcp
+255 dvc_op_test
+
+7 dvc_op_kbd
+
+//device option hight 4
+6 dvc_op_mouse
+//device option low 2
+(
+0 MODE_3_MOUSE
+1 MODE_4_MOUSE
+)
+)
+
+(
+3 twspi_sclk
+4 twspi_sdio
+)
+
+(
+4 pan_clk_bit
+5 pan_dat_bit
+6 pan_mov_bit
+)
+
+(
+7 otp_uflag_aes
+6 otp_uflag_skip_eep
+5 otp_uflag_skip_flash
+4 otp_uflag_hci
+)
+
+/* ir command */
+(
+1 ircmd_record
+2 ircmd_play
+3 ircmd_write_pulse
+4 ircmd_write_seq
+5 ircmd_write_next
+
+8 ircmd_test_play
+9 ircmd_test_rec
+
+10 ircmd_report_pulse
+11 ircmd_report_seq
+12 ircmd_report_raw
+
+20 ircmd_screen_on
+21 ircmd_screen_off
+)
+
+(
+7 gpio_active_bit
+)
+(
+2 HID_HANDSHAKE_TIMEOUT
+
+)
+
+(
+1 APP_FLAG_RECONNECT
+)
+(
+5 LPM_WAKE_UP_DELAY_TIMER
+)
+
+
+//mem_app_disconn_reason
+//mem_app_disconn_reason_flag
+//bit map
+(
+2 APP_DISC_RSN_SIZE
+)
+(
+0 APP_DISC_BY_BUTTON
+1 APP_DISC_AFTER_PAIRING
+2 APP_DISC_AFTER_RECONN
+3 APP_DISC_AFTER_SNIFF
+4 APP_DISC_AFTER_SETUP_DONE
+5 APP_DISC_AFTER_HANDSHAKE
+6 APP_DISC_BT
+7 APP_DISC_BLE
+8 APP_DISC_L2CAP_REFUSED
+9 APP_DISC_SWITCH_FAIL
+)
+//eeprom init flag
+(
+	0xaa55 EEPROM_INIT_FLAG
+)
+
+(
+	0x01 IPC_TYPE_CMD
+	0x02 IPC_TYPE_EVT
+	0x03 IPC_TYPE_HID
+	0x04 IPC_TYPE_SPP
+	0x05 IPC_TYPE_BLE
+	0x06 IPC_TYPE_24G
+)
+
+(
+	0x01 SYC_TASK_LPM
+	0x02 SYC_TASK_TIMER
+	0x03 SYC_TASK_HIBERNATE
+)
Index: btkb/format/at.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/at.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/at.format	(working copy)
@@ -0,0 +1,51 @@
+memalloc(
+
+	
+)
+
+omemalloc(
+
+)
+
+
+	(
+	0x2b UI_PLUS
+	0x3A UI_COLON
+	0x454c42 UI_BLE
+	0x3d AT_EQU
+	0x3f AT_QUES
+	0 AT_NULL
+	44 AT_COMMA
+	)
+	(
+	0x1A0 AT_baud_115200
+	0x4e2 AT_baud_38400
+	0x1388 AT_baud_9600
+	)
+	(
+		0 AT_FLAG_INQ
+		1 AT_FLAG_LEINQ
+		2 AT_FLAG_NAME
+	)
+	(
+		0 AT_STATE_SET30
+		1 AT_STATE_SET40
+		2 AT_STATE_CMODE
+		3 AT_STATE_ISCONN
+		4 AT_STATE_ROLE
+		5 AT_STATE_SNIFF
+		6 AT_STATE_LE
+	)
+	(
+		0 AT_TASK_UNSINFF
+		1 AT_TASK_SNIFF
+		2 AT_TASK_RECONN
+		3 AT_TASK_INQ
+		4 AT_TASK_SWITCH
+		7 AT_TASK_CMD_FLAG
+	)
+	
+	(
+		0x0A0D AT_CMD_END
+	)
+
Index: btkb/format/bt.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/bt.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/bt.format	(working copy)
@@ -0,0 +1,1012 @@
+
+	width = 32
+	const length = 12000
+
+	/* ========= memory ============== */
+memalloc(
+/* 00-0f most frequently used area  */
+1 mem_le_adv_transmit
+1 mem_le_adv_waitcnt
+1 mem_le_adv_rcv
+1 mem_le_req_rcv
+1 mem_le_scanrsp_rcv
+1 mem_le_conn_rcv
+
+1 mem_inquiryscan_waitcnt
+1 mem_inquiryscan_rcvcnt
+1 mem_pagescan_waitcnt
+1 mem_pagescan_rcvcnt
+1 mem_pagescan_rcvfhscnt
+1 mem_slave_rcvcnt
+1 mem_page_transmit
+1 mem_page_rcv
+1 mem_page_rcv_fhs
+1 mem_master_rcvcnt
+
+/* 10-1f debug area */
+1 mem_fhs_wait_counter
+1 mem_newconnto_counter
+1 mem_inquiry_transmit
+1 mem_inquiry_rcv
+1 mem_fw_ver
+1 mem_current_context
+1 mem_le_ch_mapped
+1 mem_last_freq
+1 mem_rssi
+1 mem_rx_type
+2 mem_rx_hec_err
+2 mem_rx_crc_err
+2 mem_context_ptr
+8 mem_display
+8 mem_bcd
+
+		/* context swappable area */
+1 mem_state
+1 mem_mode
+2 mem_tsniff
+4 mem_sniff_anchor
+6 mem_clk_offset
+2 mem_rx_window
+3 mem_plap
+1 mem_puap
+2 mem_pnap
+1 mem_conn_handle
+1 mem_arq
+1 mem_lmp_to_send
+1 mem_lmi_opcode
+1 mem_lmo_reason
+1 mem_op
+1 mem_state_map
+4 mem_supervision_timer
+2 mem_supervision_to
+1 mem_name_offset
+1 mem_key_size
+1 mem_conn_sm
+12 mem_aco
+16 mem_kc
+1 mem_conn_timer
+1 mem_sniff_attempt
+1 mem_sniff_timeout
+2 mem_dsniff
+1 mem_amaddr
+1 mem_lmo_opcode1
+1 mem_lmi_opcode1
+1 mem_lmo_reason1
+1 mem_lmo_tid1
+1 mem_lmo_opcode2
+1 mem_lmi_opcode2
+1 mem_lmo_reason2
+1 mem_lmo_tid2
+
+3 mem_hci_version
+2 mem_acl_pktlen
+1 mem_sco_pktlen
+2 mem_acl_pktcnt
+2 mem_sco_pktcnt
+
+1 mem_current_sniff_attempt
+1 mem_current_sniff_timeout
+1 mem_nfreq_index_inq
+1 mem_nfreq_index_page
+1 mem_ninqy_index
+1 mem_fhs_misc
+1 mem_tx_lch
+2 mem_tx_len
+
+
+
+
+/* lpo related */
+4 mem_subsniff_instant
+1 mem_subsniff_rate
+2 mem_subsniff_tcmax
+1 mem_subsniff_tsniff
+1 mem_lpm_adjust
+6 mem_sync_clke
+1 mem_lpm_current_mult
+4 mem_gpio_wakeup_low
+4 mem_gpio_wakeup_high
+	
+
+/* sco & esco */
+1 mem_air_mode
+1 mem_sco_asso_handle
+2 mem_sco_handle
+1 mem_esco_desco
+1 mem_esco_type
+1 mem_neogotiation_state
+1 mem_saved_amaddr
+1 mem_esco_arq
+1 mem_esco_saved_arq
+30 mem_sco_obuf
+30 mem_sco_ibuf
+1 mem_sco_poll
+
+
+
+//page
+1 mem_npage_index
+1 mem_page_mode
+4 mem_page_clk
+
+
+/* test related */
+2 mem_tst_pktcnt_sync
+2 mem_tst_pktcnt_hec
+2 mem_tst_pktcnt_crc
+2 mem_tst_pktcnt_dmh
+3 mem_tmp_buffer_head
+80 mem_tmp_buffer
+
+
+1 mem_tester_emulate
+0 mem_temp_payload
+1 test_mode_scenario
+1 test_mode_hopping_mode
+1 test_mode_tx_freq
+1 test_mode_rx_freq
+1 test_mode_power_mode
+1 test_mode_poll_period
+1 test_mode_packet_type
+2 test_mode_data_length
+1 mem_test_mode_old_debug_config
+1 mem_tester_cnt
+
+
+/*temp mem*/
+1 mem_temp_am_addr
+1 mem_temp_arq
+8 mem_pdatatemp
+
+
+//
+2 mem_len
+4 mem_clkn_bt
+4 mem_clke_bt
+4 mem_dpll_clkn
+1 mem_connection_options
+
+1 mem_nameres_cnt
+2 mem_txptr
+2 mem_slot_offset
+
+//extm
+1 extm_fhs_misc
+1 extm_newconn_am_addr
+3 extm_class
+3 extm_lap
+1 extm_uap
+3 extm_nap
+
+
+//debug
+1 mem_debug_config
+1 mem_lch_code
+1 mem_fhs_am_addr
+2 mem_dpll_error
+36 mem_bdaddr_list_buff
+1 mem_select_list_item
+0 mem_temp_reconn_record
+1 mem_record_bt_mode
+6 mem_temp_lap
+2 mem_list_item_ptr
+
+100 mem_eir
+)
+
+
+xmemalloc(
+/* patch enable 0x4000-0x403f  */
+
+1 mem_patch00
+1 mem_patch01
+1 mem_patch02
+1 mem_patch03
+1 mem_patch04
+1 mem_patch05
+1 mem_patch06
+1 mem_patch07
+1 mem_patch08
+1 mem_patch09
+1 mem_patch0a
+1 mem_patch0b
+1 mem_patch0c
+1 mem_patch0d
+1 mem_patch0e
+1 mem_patch0f
+1 mem_patch10
+1 mem_patch11
+1 mem_patch12
+1 mem_patch13
+1 mem_patch14
+1 mem_patch15
+1 mem_patch16
+1 mem_patch17
+1 mem_patch18
+1 mem_patch19
+1 mem_patch1a
+1 mem_patch1b
+1 mem_patch1c
+1 mem_patch1d
+1 mem_patch1e
+1 mem_patch1f
+1 mem_patch20
+1 mem_patch21
+1 mem_patch22
+1 mem_patch23
+1 mem_patch24
+1 mem_patch25
+1 mem_patch26
+1 mem_patch27
+1 mem_patch28
+1 mem_patch29
+1 mem_patch2a
+1 mem_patch2b
+1 mem_patch2c
+1 mem_patch2d
+1 mem_patch2e
+1 mem_patch2f
+1 mem_patch30
+1 mem_patch31
+1 mem_patch32
+1 mem_patch33
+1 mem_patch34
+1 mem_patch35
+1 mem_patch36
+1 mem_patch37
+1 mem_patch38
+1 mem_patch39
+1 mem_patch3a
+1 mem_patch3b
+1 mem_patch3c
+1 mem_patch3d
+1 mem_patch3e
+1 mem_patch3f
+
+	/* 3 device contexts  */
+240 mem_context
+1 mem_current_amaddr
+1 mem_lpm_mode
+1 mem_device_option
+1 mem_scan_mode
+4 mem_last_clkn
+
+	/* parameters */
+8 mem_features
+3 mem_lap
+1 mem_uap
+2 mem_nap
+1 mem_npage
+3 mem_glap
+3 mem_class
+2 mem_iscan_window
+2 mem_iscan_interval
+2 mem_pscan_window
+2 mem_pscan_interval
+2 mem_page_interval
+2 mem_page_window
+2 mem_page_to
+2 mem_inq_window
+1 mem_fcomp_mul
+1 mem_fcomp_div
+2 mem_rx_window_init
+2 mem_rx_window_sniff
+2 mem_rf_init_ptr
+
+	/* connection related */
+1 mem_last_type
+1 mem_last_type_esco
+1 mem_last_type_saved
+2 mem_retransmission_cnt
+4 mem_next_btclk
+
+1 mem_seqi
+1 mem_rf_rccal
+1 mem_handle_num
+1 mem_max_slot
+1 mem_eir_enable
+
+/* AFH related */
+4 mem_afh_instant
+2 mem_afh_error_total
+1 mem_afh_cfg
+1 mem_afh_new_mod
+5 mem_afh_map_lo
+5 mem_afh_map_hi
+1 mem_afh_used
+2 mem_afh_index
+11 mem_afh_map_new
+80 mem_afh_map
+4 mem_afh_timer
+10 mem_afh_classify_channel_map
+
+
+	/* lpm related */
+2 mem_chip_functions
+2 mem_lpm_wake_lock
+2 mem_lpm_interval
+1 mem_lpm_overhead
+1 mem_lpm_hibernate_switch
+1 mem_esco_addr
+1 mem_sniff_unint_lost
+1 mem_ptt
+4 mem_sleep_counter   //should be 0x41fc in REVC
+4 mem_sleep_counter_all
+6 mem_sleep_clkn
+3 mem_sniff_rcv
+3 mem_sniff_lost
+3 mem_clks_per_lpo
+
+1 mem_lpm_mult
+1 mem_lpm_mult_timeout
+1 mem_lpm_mult_cnt
+
+/* 8139-813b lpm_ctrl[31:12] */
+3 mem_lpm_config				
+
+1 mem_lpm_xtalcnt
+1 mem_lpm_buckcnt
+1 mem_lpm_ldocnt
+1 mem_lpm_isogate
+1 mem_lpm_isogate_final
+16 mem_saved_gpio	// should be 0x421e in REVC
+3 mem_saved_gsel
+8 mem_saved_mark
+1 mem_saved_spidctrl
+2 mem_patch_ptr
+2 mem_patch_len
+
+32 mem_timers
+
+/*LINK KEY*/
+1 mem_link_key_exists
+3 mem_link_key_eeprom_head
+16 mem_link_key
+
+
+/* HCI */
+1 mem_hci_cmd
+1 mem_hci_conn_handle
+3 mem_hci_plap
+1 mem_hci_puap
+2 mem_hci_pnap
+
+/*Peripherals*/
+1 mem_uartd_rxitems_got_data
+1 mem_uartd_rxitems_threshold
+2 mem_uartd_rx_timeout
+
+)
+
+0x4c00 mem_savelist
+
+ifdef RAM_VERSION
+0x4b17 rom_lpm_sleep
+0x4b1d rom_lpm_enter_sleep
+0x4b16 rom_lpm_write_ctrl
+0x6b1a rom_otpd_read_data
+0x6ada rom_otp_write
+else
+0x3b17 rom_lpm_sleep
+0x59e0 rom_save_ucode
+
+0x4219 rom_mem_lpm_xtalcnt
+0x423b rom_mem_patch_ptr
+0x423d rom_mem_patch_len
+
+0x5b1a rom_otpd_read_data
+0x5ada rom_otp_write
+endif
+	/* context */
+(
+0x01 coffset_mode
+0x02 coffset_tsniff
+0x04 coffset_sniff_anchor
+0x08 coffset_clk_offset
+0x0e coffset_rx_window
+0x10 coffset_plap
+0x16 coffset_conn_handle
+0x17 coffset_arq
+	/* 3.0 only */
+0x18 coffset_lmp_to_send
+0x1b coffset_op
+0x1c coffset_state_map
+	/* le only */
+0x18 coffset_le_ch
+0x19 coffset_le_hop
+0x1a coffset_le_event_cnt
+
+80 context_size
+3 context_num
+)
+
+(
+0 lpm_flag_wake
+1 lpm_flag_loadcode
+)
+
+/* ========= parameters ============== */
+(
+0x0050 param_newconn_arq
+0x0007 param_esco_addr
+0x0010 param_conn_handle
+0x01f0 param_conn_handle_comp
+0x0020 param_newconnto
+0x0008 param_pagerespto
+0x0a00 param_snooze_setup_orig
+0x5353 param_snooze_ahead_orig
+0x00ff param_ninquiry
+0x2000 param_page_to
+0x0005 param_max_slot
+0x0010 param_sco_poll
+
+/* 6Mhz clock setting */
+ifdef CLK6M
+0x0721 param_tx_setup
+0x06e8 param_rx_setup
+0x04e8 param_rx_setup_earlier
+0x0300 param_rf_setup
+0x01d8 param_clke_cal
+0x0500 param_conn_access 
+0x0400 param_conn_access_wider
+200 param_pll_setup
+else
+/* 12Mhz clock setting */
+0x0e43 param_tx_setup
+0x09d0 param_rx_setup_earlier
+0x0600 param_rf_setup
+0x03bb param_clke_cal
+0x0600 param_conn_access 
+0x0800 param_conn_access_wider
+0x0500 param_pll_setup		// 120 is minimum
+0x0d00 param_rx_setup	// 114us before sync
+2000 param_dpll_start_delay
+endif
+
+110 param_lpm_fix
+10 param_lpo_extra
+200 param_lpm_adjmax
+
+ifdef SIM
+20 param_hibernate_clks
+3 param_chgpump_delay
+else
+-1 param_hibernate_clks
+3000 param_chgpump_delay
+endif
+
+3 param_featrue_ssp
+0x0101 param_lmpext_ssp_enable
+339 param_acl_pktlen
+30   param_sco_pktlen
+1     param_acl_pktcnt		/*buffer acl pkt cnt*/
+7     param_sco_pktcnt
+
+
+0x8fffff param_features0
+0x9d83fe param_features1  // not support afh
+0x8359     param_features2
+0x000033 param_unap
+0x001177 param_lap
+0x9e8b33 param_glap
+0x002540 param_class//0x180208 //0x002580//402500//240404
+0x12e904 param_hci_version
+0x000a04 param_lmp_version//0x0a04
+0x12e9 param_lmp_subversion
+0x0012 param_tisw
+0x0012 param_tpsw
+0x1000 param_tisi
+0x0800 param_tpsi
+0x0020 param_page_window
+0x0020 param_inq_window
+0x1c80 param_supervision_to
+39 param_fcomp_div
+2 param_fcomp_mul
+6     param_name_len
+0x535442 param_name
+0x344950 param_name1
+
+
+)
+
+/* ======= packet types  ========= */
+(
+0x0      type_null    
+0x1      type_poll   
+0x2      type_fhs    
+0x3      type_dm1    
+0x4      type_dh1    
+0x5      type_hv1    
+0x6      type_hv2    
+0x7      type_hv3    
+0x8      type_3dh1     
+0x9      type_aux1   
+0xa      type_dm3    
+0xb      type_dh3    
+0xe      type_dm5    
+0xf      type_dh5    
+0x10     type_id
+0x11     type_shutdown
+0x13     type_lmp
+)
+
+/* ========== flag[6] =============== */
+(
+0        always        /* always 1 */
+1        true          /* set/rstn by verify,compare,icompare (true) */
+2        positive      /* set/rstn by all alu operations (opcode = 0x03,0x13,0x0f,0x1f), if alu output >= 0 */
+3        timeout       /* read only, the timeout from timers */
+5        zero          /* set/rstn by all alu operations (opcode = 0x03,0x13,0x0f,0x1f), if alu output == 0 */
+6        crc_failed    /* level, cleared by hop_start */
+7        enable_white  /* outside mux decide whether to load bt_clk or response_X */
+8        enable_parity /* level */
+9        enable_crc    /* level */
+10       enable_hec    /* level */
+11       decode_fec1   /* level */
+12       decode_fec2   /* level */
+13       decode_fec0   /* level */
+14       encrypt       /* level */
+15       crc16       /* for caculate ccitt crc16 */
+16       swfine	/* =0 stop_watch count based on oneslot =1 on 1 clock */
+20       rqst_freq    /* pulse, to start calculating frequency */
+21       recalc        /* pulse, to recalculate the fhs_parity */
+22       init_encrypt  /* pulse, issued to initialize encrption */
+23       mhalfbnd    /* half slot boundary of clke_rt, or when clke_bt[0] toggles */
+24       sync          /* sync found as a result of correlation,set/rstn by correlate opcode */
+25       user10    /* user10 */
+26       kc_p_activate  /* pulse to recalc the kc_p */
+27       encode_fec1   /* level */
+28       encode_fec2   /* level */
+29       encode_fec0   /* level */
+30       packet_end    /* pulse */
+32       is_tx         /* level */
+33       is_rx         /* level */
+34       halfslot     /* pulse, read only, when clkn_bt[0] toggles */
+35       oneslot      /* pulse, read only, when clkn_bt[1] toggles */
+36       mslotbnd     /* pulse, read only, when clke_bt[1] toggles */
+37       expire       /* level, read only, when selected clock source exceed timeup value */
+38       meet         /* level, read only, when selected clock source meet timeup value */
+39       tx_clear     /* level, read only, indicate tx pipe is cleared */
+40       user         /* user0 */
+41       master        /* user1 */
+42       slave2         /* user2 */
+43       wake           /* user3 */
+44       user2        /* user4 */
+45       match         /* user5 */
+46       attempt        /* user6 */
+47       user3          /* user7 */
+48       clknt         /* user8 */
+49	   user7 	/* user9 */
+50       synchronize   /* synchronize lpo and regular version of the clock */
+51       lpo_edge  /* read only, 3 clocks after risling edge of lpo clock */
+52       blank         /* C0 only, means pdata == 0 */
+53       modone          /* set divide operation is done */
+54       le		/* bluetooth 4.0 LE enable */
+55       aes_ready	/* set when aes is ok */
+63       never         /* read only, always 0 */
+)
+
+default flag = always
+
+/* ========== reg[6] =============== */
+(
+0        mark   /* for keeping strobes, more permanent */
+1        type   /* save and verify during rx */     /* rw */
+2        temp   /* general purpose register, 64 bits */
+3        contru  /* contr uart */
+4        am_addr      /* verify during rx, read and send during tx */ /* ro */
+5        contw        /* last mem_addr during write */
+6        contr        /* last mem_addr during read */
+7        queue    /* the index of qset*,qisolate* commands, ie, if queue = 3, qset/qisolate operate on bit3 */
+8        debug    /* can be wired out for observation */
+9        access   /* the 72 bit access word */
+10       contwu   /* contw uart */
+11       timeup        /* when does certain counter expire */
+12       pwindow       /* bit 71-61 of pdata; because on rx, bits shifts in from 71 down */
+13       fhs_parity    /* re-gernated based on bt_adr( {nap,uap,lap} ) when recalc flag is pulsed */
+14       white_init    /* init value of the whitening */
+15       crc24_init        /* init crc24 lfsr, 24 bits */
+16       interrupts    /* set interrupts, 40 bits */
+17       rega          /* general purpose register, 32 bits */
+18       regb          /* general purpose register, 32 bits */
+19       regc          /* general purpose register, 17 bits */
+20       regab         /* concat of {rega,regb}, thus 64 bits */
+21       radio_ctrl   /* radio i/f direct i/o ctrl, check following "radio_ctrl" section */
+21       ctrl_reg     /* 2023 and after */
+22       jtag_addr    /* load jtag address field, lsb */
+23       freq_index   /* 7 bit read only */
+24       jtag_data    /* wdata to and rdata from jtag */
+25       clkn              /* {clkn_bt, clkn_rt} */
+26       clke              /* {clke_bt, clke_rt} */
+27       stop_watch
+28       fhs_misc   /* SR, SP, pscan mode */
+29       fhs_class  /* class field in fhs */
+30       fhs0   /* read only, bit 0-71 of fhs word */
+31       fhs1   /* read only, bit 72-142 of fhs word */
+32       bt_adr /* r/w, the bt_addr to access gen and freq hopping, contain only lap and uap */
+33       bt_clk /* r/w, the bt_clk for freq hopping */
+34       clkn_bt  /* read only, native bluetooth clock, free running 3.2KHz  or controlled by RTHALFSLOT register */
+35       clkn_rt  /* read only, native realtime clock, free running 12MHz, count from 0-3749, or controlled by RTHALFSLOT register */
+36       freq_mode
+/* wire even_train    = freq_mode[4];    // odd even train                            */
+/* wire conn_mode     = 3;    // connection                                           */
+/* wire iqpgscan_mode = 2;    // slave in inquiry and page (not response)             */
+/* wire iqpgresp_mode = 1;    // slave in inquriy and page (response only)            */
+/* wire inqypage_mode = 0;    // master in inquiry and page(response or not response) */
+37       xin   /* x parameter, read only */
+38       N_tx_slot /* the N factor in equations for Xi,Xp,Xprm,Xprs */
+39 	   auxcnt
+40       clke_bt  /* r/w,  external bluetooth clock , free running 3.2KHz or controlled by RTHALFSLOT register */
+41       clke_rt  /* r/w,  external realtime clock, , free running 12MHz, count from 0-3749, or controlled by RTHALFSLOT register */
+43       host_mode         /* generic stuff for kick starts */
+44       lap
+45       uap
+46       nap         
+47       regext		/* r/w extended 12x32bit registers,  indexed by regext_index */
+48       alarm             /* r/w, lpo wake up time, this is also how lpo and current clock keep sync */
+49       lpo_time          /* read only, this is the value to be copied back to clkn/clke after wakeup */
+50       kc_ls             /* secret key,                71: 0 */
+51       kc_ms             /* secret key,               127:72 */
+52       g1l               /* encryption length                */
+53		mask3ff		/* for mask 0x3ff operation */
+54       aes_ctrl		
+56       regext_index   /* index of regext */
+57	     loopcnt
+58      stack			/* current return address */
+59       stack_ptr		/* stack depth */
+61         pc /* direct goto */
+62       null              /* to nowhere */
+63       pdata /* the shift register */
+)
+default reg = pdata
+
+/* regext_index */
+(
+0 regidx_data
+4 regidx_key
+8 regidx_xor
+12 regidx_result
+)
+/* ========== radio_ctrl========= */
+(
+0 TXGFSK
+1 PSK
+2 PSK3M
+3 RESET
+)
+/* assign BPWR = radio_ctrl[0]; */
+/* assign PARAMP = radio_ctrl[1]; */
+/* assign XTALPU = radio_ctrl[2]; */
+/* assign SYNTHPU = radio_ctrl[3]; */
+/* assign TXPU = radio_ctrl[4]; */
+/* assign RXPU = radio_ctrl[5]; */
+/* assign SLCTRL = radio_ctrl[6]; */
+/* assign XTALSEL_MUX_SEL = radio_ctrl[7] */
+
+
+/* =========== destination[4] ============== */
+(
+0 bucket
+1 rxf
+2 back
+3 mod
+)
+default dest = bucket
+
+/* =========== source[4] ============= */
+(
+1 txf
+3 demod
+)
+default source = 0
+
+
+/* ============== mark ============= *//*0 - 47 */
+(
+
+0  mark_fhs_eir  
+1  mark_rxbuf_inuse
+2  mark_tx_l2cap
+3  mark_switch_initiated
+4  mark_accept_switch
+5  mark_loopback
+7  mark_esco
+8  mark_esco_rxok
+9  mark_context
+10 mark_am_addr_broadcast
+11 mark_fhs_already_good
+12 mark_page_trainb
+13 mark_lpm_mult_enable
+14 mark_usb_flag
+15 mark_old_packet
+16 mark_longpacket
+17 mark_testmode
+18 mark_ar2
+19 mark_h5tx_rp
+20 mark_h5tx_crc	
+21 mark_h5tx_retransmit
+22 mark_h5rx_pstart
+23 mark_h5_sync
+24 mark_h5_reinit
+25 mark_bccmd_patch//for bcsp
+26 mark_temp //for bcsp
+27 mark_h5_reset // fo bcsp
+28 mark_inquiry_on
+29 mark_inquiry_state
+30 mark_inquiry_trainb
+31 mark_periodical_diac
+32 mark_all_diac
+33 mark_slave_in_rand_accepted
+34 mark_reconn_recieve_switch
+35 mark_isstr
+36 mark_loadcode
+37 mark_ext_patch
+35 mark_24g
+15 mark_24g_conext
+// REVAB:max 35, REVC:max 63
+
+)
+
+(
+1 reload_type_otp
+2 reload_type_spi
+3 reload_type_iic
+)
+
+
+/* ============== soft timers ============== */
+(
+0 h5_reinit_timer
+1 hci_retransmit_timer
+1 le_adv_interval_timer
+2 inquiry_length_timer
+3 le_scan_interval_timer
+4 page_length_timer
+5 iscan_interval_timer
+6 pscan_interval_timer
+7 lpo_delay_timer
+8 ui_hundred_millisecond_timer
+9 ui_led_blink
+10 switch_wait_timer
+11 enpt_delay_timer
+12 temp_timer
+13 page_interval_timer
+14 uart_rx_timer
+)
+(
+0 ui_led_stop
+1 ui_led_start
+2 ui_led_dark_time
+3 ui_led_light_time
+)
+(
+1 hci_cmd_inquiry
+2 hci_cmd_inquiry_cancel
+3 hci_cmd_remote_name_req
+4 hci_cmd_remote_feature_req
+5 hci_cmd_create_conn
+6 hci_cmd_disconn
+7 hci_cmd_accept_conn
+8 hci_cmd_reject_conn
+9 hci_cmd_pair
+10 hci_cmd_nopair
+11 hci_cmd_linkkey
+12 hci_cmd_nokey
+13 hci_cmd_auth
+14 hci_cmd_stopencrypt
+15 hci_cmd_startencrypt
+16 hci_cmd_setup_sco
+17 hci_cmd_disconn_sco
+18 hci_cmd_in_sniff
+19 hci_cmd_exit_sniff
+20 hci_cmd_remote_version_req
+21 hci_cmd_remote_ext_features_req
+22 hci_cmd_io_cap
+23 hci_cmd_role_discovery
+24 hci_cmd_role_switch
+25 hci_cmd_accept_with_switch
+26 hci_cmd_detach
+27 hci_cmd_le_create_conn
+28 hci_cmd_accept_sco_conn
+80 hci_cmd_wait_remote_feature
+81 hci_cmd_wait_remote_ext_feature
+82 hci_cmd_wait_remote_name
+)
+
+
+
+/* ============== debug ============= */
+(
+0 debug_neg_skew
+1 debug_bitbucket
+2 debug_dont_clear_got_tx
+3 debug_scatter_enabled
+4 debug_tx_fixed_freq
+5 debug_rx_fixed_freq
+6 debug_tx_pattern
+)
+
+/* ============== tester_emulator ============= */
+(
+0 tester_fixed_flow
+1 tester_fixed_flow_polarity
+2 tester_change
+3 tester_exit
+4 tester_pattern_test
+5 tester_whitening_change
+6 tester_fixed_freq
+7 tester_no_whitening
+)
+
+/* ============== mode ==========*/
+(
+0 mode_le
+1 mode_master
+2 afh_enable
+3 afh_change
+4 send_sco_when_slave
+5 first_seqnx
+)
+
+/* ============== state_map ==========*/
+(
+0 smap_lmptidinit
+1 smap_lmptid
+2 smap_encryption
+3 smap_name_res
+4 smap_name_req
+5 smap_edr
+6 smap_rxlmp
+7 smap_rxl2cap
+)
+(
+0 state_inconn
+1 state_insniff
+2 state_insco 
+3 state_inpage
+4 state_conn_comp
+5 state_init_seq
+6 state_combkey
+7 state_linkkey
+)
+(
+0 op_send_sres
+1 op_auth_req
+2 op_inrand_req
+3 op_disconn
+4 op_stop_enc
+5 op_start_enc
+6 op_txl2cap
+7 op_pkt_comp
+)
+
+
+/* ============== arq [3] ================ */
+(
+0 flow
+1 arqn
+2 seqn
+3 wack
+4 flowx              /* out */  /* not really in memory */
+5 arqnx              /* out */
+6 seqnx              /* out */
+7 bcast1             /* first broadcast received */
+)
+
+/* arq          {flow,arqn,seqn}, read/write */
+/* [0] flow r/w  acl full status of the other, store during rx, checked during tx */
+/* [1] arqn r/w  ack of the other during rx (ack tx fifo),                        */
+/* [2] seqn r/w  seqn of the other, check during rx                               */ 
+/* arqx         {flowx,arqnx,seqnx} */
+/* [0] flowx r/o flow back to the other, 1 alow send, 0 not to send, read only tx */
+/* [1] arqnx r/w ack to the other, set by rx, send back on tx                     */
+/* [2] seqnx r/w toggled by arqn, to be send during tx                            */ 
+
+(
+0 llid0
+1 llid1
+2 nesn
+3 sn
+4 md
+5 wak
+)
+
+/* AFH flags */
+(
+0 AFH_CFG_ON
+1 AFH_CFG_TIMER
+2 send_lmp_set_afh
+3 AFH_CFG_REPORT_MODE
+4 AFH_CFG_MASTER_SENT_REQ
+)
+
+/* LLID CODE */
+(	
+1 LLID_L2CAP_CONT
+2 LLID_L2CAP_START
+3 LLID_LMP
+)
+
+/* ============== master_state ==========*/
+(
+0  master_in_idle
+1  master_in_inquiry
+2  master_in_page
+10 master_in_becoming_slave
+15 master_in_conn
+)
+(
+0 newrev_feature_bettx
+1 newrev_feature_betplltx
+2 newrev_feature_skip_retransmit
+3 newrev_feature_init_radio_after_sleep
+4 newrev_feature_no_lpolog
+)
+/*************mem_pincode_state****************/
+(
+0 pincode_state_ilde
+1 pincode_state_wait_pincode
+2 pincode_state_pincode_ready
+)
+
+
+// lpm_write
+(
+1 lpmreg_sel_ctrl
+2 lpmreg_sel_ctrl2
+4 lpmreg_sel_gpiolow
+8 lpmreg_sel_gpiohigh
+16 lpmreg_sel_counter
+)
+
+//scan_mode
+(
+0 inq_scan_mode
+1 page_scan_mode
+)
+//mem_neogotiation_state
+(
+ 0 default_neogotiation_state
+ 1 prarm_neogotiation
+)
+
+//mem_lpm_wake_lock
+(
+
+2 wake_lock_hci_host
+3 wake_link_key_exists
+4 wake_lock_delay
+5 wake_lock_uart_tx
+6 wake_lock_uart_rx
+7 wake_lock_button
+8 wake_lock_cmd
+9 wake_lock_app
+10 wake_lock_lmp_tx
+11 wake_lock_lmp_rx
+12 wake_lock_l2cap_tx
+13 wake_lock_l2cap_rx
+14 wake_lock_ipc_c512bt
+15 wake_lock_ipc_bt2c51
+
+)
+
+(
+0 bt_disabled
+1 ble_disabled
+2 module_disable
+
+)
+
+(
+0x33  REC_3_MODE
+0x34  REC_4_MODE
+)
+
+
+//sniff UART_TX UART_RX
+(
+6 UART_WAKEUP_TX
+7 UART_WAKEUP_RX
+)
+
+
Index: btkb/format/command.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/command.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/command.format	(working copy)
@@ -0,0 +1,1385 @@
+
+/* Parse Command:
+TX: take bits from tx fifo, jam it into shift and a destination (rf,bucket)
+RX: take bits from demod,  jam it into shift and a destination (acl,sco,bucket) */
+
+/* Inject Command:
+TX: 0 into shift, send tail of shift into a destination (rf,bucket)
+RX: 0 into shift, send tail of shift into a destination (acl,sco,bucket) */
+
+format
+  ! 15 romdat
+  % d0
+  % d1
+  % d2
+  % d3
+  [8] d0
+  [8] d1
+  [8] d2
+  [8] d3
+end
+
+format
+  ! 15 enable   /* set flag to 1 */
+  % flag
+  [5] opcode
+  [6] 1
+  [6] flag
+  [6] null
+  [9] 0
+end
+ /* High 5 bytes of channel map */
+format
+  ! 15 pulse   /* set flag to 1 */
+  % flag
+  [5] opcode
+  [6] 1
+  [6] flag
+  [6] null
+  [9] 0
+end
+
+format
+  ! 15 disable   /* set flag to 0 */
+  % flag
+  [5] opcode
+  [6] 2
+  [6] flag
+  [6] null
+  [9] 0
+end
+
+format
+  ! 15 set0  /* set selected bit of reg to 0 */
+  % immediate
+  % reg
+  [5] opcode
+  [6] 9
+  [6] never
+  [6] reg
+  [9] immediate
+end
+
+format
+  ! 15 set1  /* set selected bit of reg to 1 */
+  % immediate
+  % reg
+  [5] opcode
+  [6] 9          /* alu op demux */
+  [6] always
+  [6] reg
+  [9] immediate
+end
+
+format
+  ! 15 setflag  /* set selected bit of the reg to the polarity of the flag */
+  % flag
+  % immediate
+  % reg
+  [5] opcode
+  [6] 9
+  [6] flag
+  [6] reg
+  [9] immediate
+end
+
+format
+  ! 15 nsetflag  /* set the selected bit of the reg to the opposite polarity of the flag */
+  % flag
+  % immediate
+  % reg
+  [5] opcode
+  [6] 0x29
+  [6] flag
+  [6] reg
+  [9] immediate
+end
+
+format
+  ! 15 setflip    /* invert the selected bit of the reg */
+  % immediate
+  % reg
+  [5] opcode
+  [6] 10            /* this is alu op */
+  [6] always
+  [6] reg
+  [9] immediate
+end
+
+format
+  ! 0x1f qset1      /* demux the lowest 4 bit of queue and OR it with regr into regw */
+  % reg             /* in short, set the bit in reg indexed by queue to 1 */
+  [5] opcode
+  [6] 9
+  [6] always
+  [6] reg
+  [9] 0
+end
+  
+format
+  ! 0x1f qset0      /* demux the lowest 4 bit of queue and AND it with regr into regw */
+  % reg             /* in short, set the bit in reg indexed by queue to 0 */
+  [5] opcode
+  [6] 9
+  [6] never
+  [6] reg
+  [9] 0
+end
+
+format 
+  ! 0x1f qsetflag   /* set the bit in reg index by queue to same as flag */
+  % flag
+  % reg
+  [5] opcode
+  [6] 9
+  [6] flag
+  [6] reg
+  [9] 0
+end
+
+format 
+  ! 0x1f nqsetflag   /* set the bit in the reg index by queue to opposite of flag */
+  % flag
+  % reg
+  [5] opcode
+  [6] 0x29
+  [6] flag
+  [6] reg
+  [9] 0
+end
+
+format
+  ! 0x1f qsetflip      /* flip the bit in reg index by queue */
+  % reg
+  [5] opcode
+  [6] 10
+  [6] always
+  [6] reg
+  [9] 0
+end
+
+format
+  ! 1 parse       /* take bits out of source (sco_tx,tx_buffer,rx-elas) into pdata and dest (sco_rx,rx_fifo,tx-elas) */
+  % source
+  % dest
+  % immediate
+  [5] opcode
+  [4] source      /* voice, data, demod */
+  [2] 0
+  [6] 0    
+  [2] 0           /* parse or inject */ 
+  [4] dest        /* acl, sco, mod, bucket */
+  [9] immediate   /* number of bits to parse off */
+end
+
+format
+  ! 1 inject      /* shift data from pdata into destination (tx-elas,rx_fifo,sco_rx) */
+  % destination
+  % immediate
+  [5] opcode
+  [4] 0
+  [2] 0
+  [6] 1
+  [2] 0
+  [4] destination /* acl,sco,mod,bucket */
+  [9] immediate   /* number of bits to be injected */
+end
+
+format
+  ! 1 iinject
+  % destination
+  % regr
+  [5] opcode
+  [6] regr       /* contain the number of bits to inject */
+  [6] 3
+  [2] 0
+  [4] destination /* acl,sco,mod,bucket */
+  [9] 0 
+end
+
+format
+  ! 1 stuff  /* automatic parse, stuff_counter decrement on every bit until hits zero */
+  % source
+  % destination
+  [5] opcode
+  [4] source
+  [2] 0
+  [6] 2
+  [2] 0
+  [4] destination
+  [9] 0
+end
+
+format    /* force immediate value into registers */
+  ! 3 force
+  % immediate
+  % regw
+  [5] opcode
+  [6] 0
+  [6] 0    /* alu operation force */
+  [6] regw  /* destination register */
+  [9] immediate
+end
+
+format    /* force whatever is on shift_reg to regsiters */
+  ! 0x13 iforce
+  % regw
+  [5] opcode
+  [6] 0
+  [6] 0    /* alu operation force */
+  [6] regw  /* destination register */
+  [9] 0
+end
+
+format    /* force immediate value into registers */
+  ! 3 increase
+  % immediate
+  % reg
+  [5] opcode
+  [6] reg
+  [6] 1    /* alu operation add */
+  [6] reg
+  [9] immediate
+end
+
+format
+  ! 3 pincrease
+  % immediate
+  [5] opcode
+  [6] -1  /* pdata */
+  [6] 1   /* alu add */
+  [6] -1  /* back to pdata */
+  [9] immediate
+end
+
+format    /* force immediate value into registers */
+  ! 3 and_into
+  % immediate
+  % reg
+  [5] opcode
+  [6] reg
+  [6] 2    /* alu operation and into */
+  [6] reg
+  [9] immediate
+end
+
+format
+  ! 3 and
+  % regr
+  % immediate
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 2    /* alu operation and into */
+  [6] regw
+  [9] immediate
+end
+  
+format
+  ! 0x13 iand    /* pdata & regr -> regw */
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 2    /* alu operation and into */
+  [6] regw
+  [9] 0
+end
+  
+
+format    /* and whatever is in shiftreg with reg */
+  ! 0x13 iand_into
+  % reg
+  [5] opcode
+  [6] reg
+  [6] 2    /* alu operation and into */
+  [6] reg
+  [9] 0
+end
+
+format
+  ! 3 or_into
+  % immediate
+  % reg
+  [5] opcode
+  [6] reg
+  [6] 3    /* alu operation or into */
+  [6] reg
+  [9] immediate
+end
+
+format
+  ! 3 or
+  % regr
+  % immediate
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 3    /* alu operation or into */
+  [6] regw
+  [9] immediate
+end
+
+format
+  ! 0x13 ior
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 3    /* alu operation or into */
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 0x13 ior_into
+  % reg
+  [5] opcode
+  [6] reg
+  [6] 3    /* alu operation or into */
+  [6] reg
+  [9] 0
+end
+
+format
+  ! 3 skip_to   /* jump to location stored in reg */
+  % reg
+  [5] opcode
+  [6] reg
+  [6] 4   /* alu operation copy */
+  [6] rom_addr
+  [9] 0
+end
+
+format
+  ! 3 copy
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 4   /* alu operation copy */
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 deposit   /* copy the register content thru alu to shift register, not prealigned like preload */
+  % reg
+  [5] opcode
+  [6] reg
+  [6] 4   /* alu operation copy */
+  [6] -1  /* pdata */
+  [9] 0
+end
+
+format
+  ! 3 icopy     /* copy the shift register lsb content directly to register, not aligned */
+  % regw
+  [5] opcode
+  [6] -1  /* pdata */
+  [6]  4  /* alu copy */
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 add
+  % regr
+  % immediate
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 1
+  [6] regw
+  [9] immediate
+end
+
+format
+  ! 0x13 iadd       /* regr + pdata -> regw */
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 1
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 sub          /* immediate - regr -> regw */
+  % regr
+  % immediate
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 12
+  [6] regw
+  [9] immediate
+end
+
+format
+  ! 0x13 isub       /* pdata - regr -> regw */
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 12
+  [6] regw
+  [9] 0
+end
+
+
+format
+  ! 3 flip
+  % immediate
+  % reg
+  [5] opcode
+  [6] reg
+  [6] 5
+  [6] reg
+  [9] immediate
+end
+  
+format
+  ! 0x13 iflip  /* use shift register as immediate to do xor */
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 5
+  [6] regw
+  [9] 0
+end
+  
+format
+  ! 3 xor
+  % regr
+  % immediate
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 5
+  [6] regw
+  [9] immediate
+end
+
+format
+  ! 3 xor_into
+  % immediate
+  % reg
+  [5] opcode
+  [6] reg
+  [6] 5
+  [6] reg
+  [9] immediate
+end
+  
+format
+  ! 0x13 ixor  /* pdata xor regr and store result in regw */
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 5
+  [6] regw
+  [9] 0
+end
+  
+format
+  ! 3 invert
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 8
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 pinvert    /* invert pdata into itself */
+  [5] opcode
+  [6] -1
+  [6] 8
+  [6] -1
+  [9] 0
+end
+
+format
+  ! 3 div                 /* regr div immediate div */
+  % reg
+  % immediate
+  [5] opcode
+  [6] reg
+  [6] 13                   /* generate diven pulse to div */
+  [6] null
+  [9] immediate
+end
+
+format
+  ! 0x13 idiv           /* pdata div regr data ready at most after 41 nops */
+  % reg
+  [5] opcode
+  [6] reg
+  [6] 13                   /* generate diven pulse to div */
+  [6] null
+  [9] 0
+end
+
+format
+  ! 3 remainder            /* harvest div remainder */
+  % regw
+  [5] opcode
+  [6] 0
+  [6] 14
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 quotient             /* harvest div quotient */
+  % regw
+  [5] opcode
+  [6] 0
+  [6] 15
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 rshift
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 6
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 rshift2
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 22
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 rshift3
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 18
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 rshift4
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 35
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 rshift8
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 25
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 rshift16
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 34
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 rshift32
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 30
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 lshift
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 7
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 lshift2
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 23
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 lshift8
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 26
+  [6] regw
+  [9] 0
+end
+
+  
+format
+  ! 3 lshift3
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 19
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 lshift4
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 36
+  [6] regw
+  [9] 0
+end
+  
+
+format
+  ! 3 lshift16
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 32
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 random               /* random number into regw */
+  % reg
+  [5] opcode
+  [6] 0
+  [6] 20
+  [6] reg
+  [9] 0
+end
+
+format                     /* bit reverse within a byte */
+  ! 3 reverse
+  % reg
+  % regw
+  [5] opcode
+  [6] reg
+  [6] 27
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 priority    /* priority encode reg into regw, lsb is the top priority, ie, priority(8'b00010000) = 4 */
+  % reg
+  % regw
+  [5] opcode
+  [6] reg
+  [6] 21
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 7 setsect   /* set a section of pdata */
+  % section    /* 0 sets 17:0 of pdata with set_data, 1 sets 35:18, 2 sets 53:36, 3 sets 71:54 */
+  % set_data
+  [5] opcode
+  [7] 0
+  [2] section
+  [18] set_data
+end
+
+format
+  ! 10 preload   /* load stuff into pdata according to fhs format, check us.v */
+  % reg
+  [5] opcode
+  [6] reg
+  [6] 0
+  [6] -1
+  [9] 0
+end
+
+format  /* load register with pdata content, according to fhs format, check us.v */
+  ! 10 ialigned   /* all bits are in position */
+  % regw
+  [5] opcode
+  [6] -1
+  [6] 0
+  [6] regw
+  [9] 0
+end
+
+format  /* load register to another according to fhs format */
+  ! 10 aligned
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 0
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 4 branch
+  % addr
+  % flag
+  [5] opcode
+  [6] 1
+  [6] flag
+  [15] addr
+end
+
+format
+  ! 4 call
+  % addr
+  % flag
+  [5] opcode
+  [6] 2
+  [6] flag
+  [15] addr
+end
+
+format
+  ! 4 rtn
+  % flag
+  [5] opcode
+  [6] 3
+  [6] flag
+  [15] 0
+end
+
+format
+  ! 0x0c store          /* write to memory, data from pdata, address from immediate then mem_ptr */
+  % num_bytes
+  % addr
+  [5] opcode
+  [6] 0               /* memory */
+  [1] 0
+  [1] 0
+  [4] num_bytes
+  [15] addr
+end
+
+format
+  ! 0x0c hstore          /* write to memory, data from pdata, address from immediate then mem_ptr */
+  % num_bytes
+  % addr
+  [5] opcode
+  [6] 0               /* memory */
+  [1] 1
+  [1] 0
+  [4] num_bytes
+  [15] addr
+end
+
+format
+  ! 0x1c istore        /* write to memory, data from pdata, address from regr then mem_ptr */
+  % num_bytes
+  % reg
+  [5] opcode
+  [6] reg            /* hold address */
+  [1] 0
+  [1] 0
+  [4] num_bytes
+  [15] 0
+end
+
+format
+  ! 0x0d fetch          /* read from memory, data into pdata, address from immediate then mem_ptr */
+  % num_bytes
+  % addr
+  [5] opcode
+  [6] 0               /* memory */
+  [1] 0
+  [1] 0
+  [4] num_bytes
+  [15] addr
+end
+
+format
+  ! 0x0d hfetch          /* read from memory, data into pdata, address from immediate then mem_ptr */
+  % num_bytes
+  % addr
+  [5] opcode
+  [6] 0               /* memory */
+  [1] 1
+  [1] 0
+  [4] num_bytes
+  [15] addr
+end
+
+format
+  ! 0x0d crc         /* read from memory, count from loopcnt, put crc result into pdata */
+  % addr
+  [5] opcode
+  [6] 0
+  [1] 0
+  [1] 0
+  [4] 0
+  [15] addr
+end
+
+format
+  ! 0x1d icrc         /* read from memory, address from reg, count from loopcnt, put crc result into pdata */
+  % reg
+  [5] opcode
+  [6] reg             /* hold address */
+  [1] 0
+  [1] 0
+  [4] 0
+  [15] 0
+end
+
+
+format
+  ! 0x1d ifetch         /* read from memory, data into pdata, address from regr then mem_ptr */
+  % num_bytes
+  % reg
+  [5] opcode
+  [6] reg             /* hold address */
+  [1] 0
+  [1] 0
+  [4] num_bytes
+  [15] 0
+end
+
+format
+  ! 0x0c storet          /* write to memory, data from temp, address from immediate won't increment */
+  % num_bytes
+  % addr
+  [5] opcode
+  [6] 0               /* memory */
+  [1] 0
+  [1] 1
+  [4] num_bytes
+  [15] addr
+end
+
+format
+  ! 0x0c hstoret          /* write to corereg, data from temp, address from immediate won't increment */
+  % num_bytes
+  % addr
+  [5] opcode
+  [6] 0               /* memory */
+  [1] 1
+  [1] 1
+  [4] num_bytes
+  [15] addr
+end
+
+format
+  ! 0x1c istoret        /* write to memory, data from temp, address from regr won't increment */
+  % num_bytes
+  % reg
+  [5] opcode
+  [6] reg            /* hold address */
+  [1] 0
+  [1] 1
+  [4] num_bytes
+  [15] 0
+end
+
+format
+  ! 0x0d fetcht          /* read from memory, data into temp, address from immediate won't increment */
+  % num_bytes
+  % addr
+  [5] opcode
+  [6] 0               /* memory */
+  [1] 0
+  [1] 1
+  [4] num_bytes
+  [15] addr
+end
+
+format
+  ! 0x0d hfetcht          /* read from corereg, data into temp, address from immediate won't increment */
+  % num_bytes
+  % addr
+  [5] opcode
+  [6] 0               /* memory */
+  [1] 1
+  [1] 1
+  [4] num_bytes
+  [15] addr
+end
+
+format
+  ! 0x1d ifetcht         /* read from memory, data into temp, address from regr won't increment */
+  % num_bytes
+  % reg
+  [5] opcode
+  [6] reg             /* hold address */
+  [1] 0
+  [1] 1
+  [4] num_bytes
+  [15] 0
+end
+
+format
+  ! 0x0e jam
+  % immediate
+  % addr
+  [5] opcode
+  [3] 0
+  [16] addr
+  [8] immediate
+end
+
+format
+  ! 0x0e hjam
+  % immediate
+  % addr
+  [5] opcode
+  [3] 0
+  [1] 1   /* msb */
+  [15] addr
+  [8] immediate
+end
+
+format			/* 0x242... */
+  ! 4 nbranch
+  % addr
+  % flag
+  [5] opcode
+  [1] 1
+  [5] 1
+  [6] flag
+  [15] addr
+end
+
+format
+  ! 4 ncall
+  % addr
+  % flag
+  [5] opcode
+  [1] 1
+  [5] 2
+  [6] flag
+  [15] addr
+end
+
+format
+  ! 4 nrtn
+  % flag
+  [5] opcode
+  [1] 1
+  [5] 3
+  [6] flag
+  [15] 0
+end
+
+format
+  ! 4 nop
+  % addr  /* no-op for addr+2 clocks */
+  [5] opcode
+  [6] 0     
+  [6] 0     /* always */ 
+  [15] addr
+end
+
+format
+  ! 4 clear_stack
+  [5] opcode
+  [6] 4
+  [6] 0    /* always */
+  [15] 0
+end
+
+format
+  ! 6 until
+  % reg
+  % flag
+  [5] opcode
+  [6] reg
+  [6] flag
+  [6] 1
+  [9] 0
+end
+  
+format
+  ! 6 correlate   /* quit if 1. flag is true 2, regr time up 3, found sync,(cond_true) */
+  % reg          /* expire counter to check against */
+  % flag
+  [5] opcode
+  [6] reg
+  [6] flag
+  [6] 2           /* correlate */
+  [9] 0           
+end
+
+format
+  ! 5 compare   /* sets cond flag,  if reg equals immediate */
+  % immediate
+  % reg
+  % mask
+  [5] opcode
+  [6] reg
+  [3] 0
+  [9] mask
+  [9] immediate
+end
+
+format
+  ! 0x15 icompare   /* sets cond flag,  if reg equals pdata */
+  % mask
+  % reg
+  [5] opcode
+  [6] reg
+  [3] 0
+  [9] mask
+  [9] 0
+end
+
+format   /* sets cond. flag, if reg equals LS half of shift reg with MS half of reg being mask */
+  ! 5 iverify
+  % reg
+  [5] opcode
+  [6] reg
+  [3] 2
+  [18] 0
+end
+
+format
+  ! 0x15 qisolate1
+  % reg
+  [5] opcode
+  [6] reg
+  [3] 3
+  [18] -1
+end
+
+format
+  ! 0x15 qisolate0
+  % reg
+  [5] opcode
+  [6] reg
+  [3] 3
+  [18] 0
+end
+
+	/* REVAB bug: cannot access bit above 35 */
+format
+  ! 5 isolate1
+  % addr
+  % reg
+  [5] opcode
+  [6] reg
+  [3] 3
+  [9] -1
+  [9] addr
+end
+
+format
+  ! 5 isolate0
+  % addr
+  % reg
+  [5] opcode
+  [6] reg
+  [3] 3
+  [9] 0
+  [9] addr
+end
+
+format
+  ! 11 setarg
+  % immediate
+  [5] opcode
+  [27] immediate
+end
+
+format
+  ! 0x1b arg
+  % immediate
+  % reg
+  [5] opcode
+  [6] reg
+  [21] immediate
+end
+
+  
+format
+  ! 0 sleep
+  [5] opcode
+  [27] 0
+end
+
+format
+  ! 0 snooze
+  [5] opcode
+  [6] -1
+  [21] 0
+end
+
+format
+  ! 0 revision
+  % rev_num
+  [5] opcode
+  [27] rev_num
+end
+
+format
+  ! 0x18 loop   /* branch when loopcnt is NOT zero, and decrease loopcnt */
+  % addr
+  [5] opcode
+  [4] 4
+  [8] 0
+  [15] addr
+end
+
+format
+  ! 0x18 beq   /* branch when pdata is equal to immediate */
+  % imme
+  % addr
+  [5] opcode
+  [4] 0
+  [8] imme
+  [15] addr
+end
+
+format
+  ! 0x18 bne   /* branch when pdata is NOT equal to immediate */
+  % imme
+  % addr
+  [5] opcode
+  [4] 1
+  [8] imme
+  [15] addr
+end
+
+format
+  ! 0x18 rtneq   /* return when pdata is equal to immediate */
+  % imme
+  [5] opcode
+  [4] 2
+  [8] imme
+  [15] 0
+end
+
+format
+  ! 0x18 rtnne   /* return when pdata is NOT equal to immediate */
+  % imme
+  [5] opcode
+  [4] 3
+  [8] imme
+  [15] 0
+end
+
+format
+  ! 0x18 bbit1   /* branch when pdata's imme bit is 1 */
+  % imme
+  % addr
+  [5] opcode
+  [4] 5
+  [8] imme
+  [15] addr
+end
+
+format
+  ! 0x18 bbit0   /* branch when pdata's imme bit is 0 */
+  % imme
+  % addr
+  [5] opcode
+  [4] 6
+  [8] imme
+  [15] addr
+end
+
+format
+  ! 0x18 rtnbit1   /* return when pdata's imme bit is 0 */
+  % imme
+  [5] opcode
+  [4] 7
+  [8] imme
+  [15] 0
+end
+
+format
+  ! 0x18 rtnbit0   /* return when pdata's imme bit is 0 */
+  % imme
+  [5] opcode
+  [4] 8
+  [8] imme
+  [15] 0
+end
+
+format
+  ! 8	bpatch
+  % imme
+  % addr
+  [5] opcode
+  [4] 9
+  [8] imme
+  [15] addr
+end
+
+format
+  ! 0x18 bmark1   /* branch when mark's imme bit is 1 */
+  % imme
+  % addr
+  [5] opcode
+  [4] 10
+  [8] imme
+  [15] addr
+end
+
+format
+  ! 0x18 bmark0   /* branch when mark's imme bit is 0 */
+  % imme
+  % addr
+  [5] opcode
+  [4] 11
+  [8] imme
+  [15] addr
+end
+
+format
+  ! 0x18 rtnmark1   /* return when mark's imme bit is 0 */
+  % imme
+  [5] opcode
+  [4] 12
+  [8] imme
+  [15] 0
+end
+
+format
+  ! 0x18 rtnmark0   /* return when mark's imme bit is 0 */
+  % imme
+  [5] opcode
+  [4] 13
+  [8] imme
+  [15] 0
+end
+
+
+format
+  ! 3 mult                  /* immediate mult regr */  /* the product will be ready 17 clks later */
+  % immediate                                   /* use "product" instruction to get the result */
+  % reg
+  [5] opcode
+  [6] reg
+  [6] 16                   /* generate diven pulse to div */
+  [6] null
+  [9] immediate
+end
+
+format
+  ! 0x13 imult           /* pdata mult regr */  /* the product will be ready after 15 nops */
+  % reg                                         /* use product opcode to get the result */
+  [5] opcode
+  [6] reg
+  [6] 16                   /* generate mult pulse to multiplier */
+  [6] null
+  [9] 0
+end
+
+format
+  ! 3 mul32                  /* immediate mult regr */ 
+  % regr
+  % immediate                                  
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 31           
+  [6] regw
+  [9] immediate
+end
+
+format
+  ! 0x13 imul32           /* pdata mult regr 32x32=64bit */  
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 31                   
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 product              /* harvest mult product */
+  % regw
+  [5] opcode
+  [6] 0
+  [6] 17
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 byteswap
+  % regr
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 33
+  [6] regw
+  [9] 0
+end
+
+format
+  ! 3 shasx          /* SHA256 Sx operation, immediate is Sx */
+  % regr
+  % immediate
+  % regw
+  [5] opcode
+  [6] regr
+  [6] 28
+  [6] regw
+  [9] immediate
+end
+
+
+format
+  ! 0x13 regexrot 	/* regext[0] <- regext[7], regext[1] <- regext[0], regext[2] <- regext[1] ... */
+  [5] opcode
+  [6] 0
+  [6] 29
+  [6] null
+  [9] 0
+end
+
Index: btkb/format/dongle.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/dongle.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/dongle.format	(working copy)
@@ -0,0 +1,13 @@
+
+memalloc(
+1 mem_dongle_count
+6 mem_le_addr_slave1
+6 mem_le_addr_slave2
+1 mem_le_peer_state
+6 mem_app_peer_addr
+
+1 mem_dongle_peers
+1 mem_dongle_pairing_cnt
+2 mem_dongle_signature
+)
+160 context_3
Index: btkb/format/hci.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/hci.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/hci.format	(working copy)
@@ -0,0 +1,649 @@
+
+
+memalloc(
+1 mem_h5rx_ackcnt
+1 mem_check_err_acl_cont
+
+1 mem_rp_packets
+2 mem_packet_type
+
+2 mem_hci_sniff_conn_handle
+2 mem_hci_sniff_max_interval
+2 mem_hci_sniff_min_interval
+2 mem_hci_sniff_attempt
+2 mem_hci_sniff_timeout
+2 mem_voice_setting
+1 mem_retransmission_effort
+2 mem_sco_ptype
+3 mem_extm_uap_restore
+
+2 mem_h5rx_rptr
+1 mem_h5rx_ack
+1 mem_h5tx_ack
+2 mem_h5tx_rptr
+2 mem_h5tx_wptr
+2 mem_h5tx_free
+1 mem_h5rx_tmp
+1 mem_h5tx_seq
+
+2 mem_hci_acl_queue_wptr
+2 mem_hci_acl_queue_rptr
+2 mem_hci_acl_queue_end
+1 mem_hci_acl_queue_wcnt
+1 mem_hci_acl_cnt
+
+2 mem_hci_acl_tx_trigger_wptr //tx via uart
+
+
+1 mem_ucode_id_local
+8 mem_temp //8 bytes
+4 mem_timeup // 4 bytes
+4 mem_rega //4 bytes
+4 mem_regb //4 bytes
+3 mem_regc //3 bytes
+2 mem_contr //2 bytes
+2 mem_contw //2 bytes
+1 mem_ucode_id_remote
+1 mem_check_sum
+1 mem_ucode_temp
+1 mem_ucode_temp1
+1 mem_lock_in_enc//boolean
+
+1 mem_hci_disconn_reason
+
+1 mem_hci_curr_len
+2 mem_hci_curr_target 
+) 
+
+xmemalloc(
+
+2 mem_baud
+1 mem_hci_lt_rx_state
+)
+
+omemalloc(
+
+2 mem_acl_credits
+1 mem_allow_switch
+4 mem_hci_acl_queue_start	/*param_acl_pktcnt+2 byte*/
+4 mem_hci_wake_clk
+
+)
+15 hci_flag_rp
+//mem_hci_options bit map
+(
+0 hci_option_bcsp
+1 hci_option_h4
+2 hci_option_protocol2
+3 hci_option_protocol3
+4 hci_option_uart
+5 hci_option_usb
+6 hci_option_phy2
+7 hci_option_phy3
+)
+// UART baud rate @6MHz
+(
+0 uart_ctrl_bit_enable
+3 uart_ctrl_bit_slip_protocol
+
+)
+
+//bit map of core_uart_ctrl
+(
+
+)
+//bit map of core_uart_status
+(
+0 uart_status_tx_fifo_full
+1 uart_status_tx_fifo_empty
+2 uart_status_tx_busy
+3 uart_status_rx_fifo_empty
+
+)
+//HCI H4 LOG related
+(
+0x4850 mem_hci_log
+8 hci_log_size
+100 hci_log_cnt
+
+)
+//HCI H4 Packet TYPE
+(
+0x01 HCI_H4_TYPE_CMD
+0x02 HCI_H4_TYPE_ACL
+0x04 HCI_H4_TYPE_EVENT
+
+)
+// HCI command opcode group field values
+(
+0x01 HCI_OGF_LINK_CONTROL
+0x02 HCI_OGF_LINK_POLICY
+0x03 HCI_OGF_BASEBAND
+0x04 HCI_OGF_INFO
+0x05 HCI_OGF_STATUS
+0x06 HCI_OGF_TEST
+0x08 HCI_OGF_LOW_ENERGY
+0x3e HCI_OGF_LOGO_TESTING
+0x3f HCI_OGF_VENDOR_SPECIFIC
+)
+
+// HCI link control opcode command field values, OGF=1
+(
+0x01 HCI_INQUIRY 
+0x02 HCI_INQUIRY_CANCEL 
+0x03 HCI_PERIODIC_INQUIRY_MODE 
+0x04 HCI_EXIT_PERIODIC_INQUIRY_MODE 
+0x05 HCI_CREATE_CONNECTION 
+0x06 HCI_DISCONNECT 
+0x07 HCI_ADD_SCO_CONNECTION 
+0x08 HCI_CREATE_CONNECTION_CANCEL
+0x09 HCI_ACCEPT_CONNECTION 
+0x0A HCI_REJECT_CONNECTION 
+0x0B HCI_LINK_KEY_REQUEST_REPLY 
+0x0C HCI_LINK_KEY_REQUEST_NEGATIVE_REPLY 
+0x0D HCI_PIN_CODE_REQUEST_REPLY 
+0x0E HCI_PIN_CODE_REQUEST_NEGATIVE_REPLY 
+0x0F HCI_CHANGE_CONNECTION_PACKET_TYPE 
+0x11 HCI_AUTHENTICATION_REQUESTED 
+0x13 HCI_SET_CONNECTION_ENCRYPTION 
+0x15 HCI_CHANGE_CONNECTION_LINK_KEY 
+0x17 HCI_MASTER_LINK_KEY 
+0x19 HCI_REMOTE_NAME_REQUEST 
+0x1A HCI_REMOTE_NAME_REQUEST_CANCEL
+0x1B HCI_READ_REMOTE_SUPPORTED_FEATURES 
+0x1C HCI_READ_REMOTE_EXT_FEATURES 
+0x1D HCI_READ_REMOTE_VERSION_INFORMATION 
+0x1F HCI_READ_CLOCK_OFFSET 
+0x20 HCI_READ_LMP_HANDLE
+0x28 HCI_SETUP_SCO_CONNECTION
+0x29 HCI_ACCEPT_SCO_CONNECTION
+0x2A HCI_REJECT_SCO_CONNECTION
+0x2B HCI_IO_CAP_REQUEST_REPLY
+0x2C HCI_USER_CONFIRMATION_REQUEST_REPLY
+0x2D HCI_USER_CONFIRMATION_REQUEST_NEGATIVE_REPLY
+0x2E HCI_USER_PASSKEY_REQUEST_REPLY
+0x2F HCI_USER_PASSKEY_REQUEST_NEGATIVE_REPLY
+0x30 HCI_REMOTE_OOB_DATA_REQUEST_REPLY
+0x33 HCI_REMOTE_OOB_DATA_REQUEST_NEGATIVE_REPLY
+0x34 HCI_IO_CAPABILITY_REQUEST_NEGATIVE_REPLY
+0x35 HCI_CREATE_PHYSICAL_LINK
+0x36 HCI_ACCEPT_PHYSICAL_LINK
+0x37 HCI_DISCONNECT_PHYSICAL_LINK
+0x38 HCI_CREATE_LOGICAL_LINK
+0x39 HCI_ACCEPT_LOGICAL_LINK
+0x3A HCI_DISCONNECT_LOGICAL_LINK
+0x3B HCI_LOGICAL_LINK_CANCEL
+0x3C HCI_FLOW_SPEC_MODIFY
+0x3D HCI_ENHANCED_SETUP_SYNCHRONOUS_CONNECTION
+0x3E HCI_ENHANCED_ACCEPT_SYNCHRONOUS_CONNECTION_REQUEST
+0x3F HCI_TRUNCATED_PAGE
+0x40 HCI_TRUNCATED_PAGE_CANCEL
+0x41 HCI_SET_CONNECTIONLESS_SLAVE_BROADCAST
+0x42 HCI_SET_CONNECTIONLESS_SLAVE_BROADCAST_RECEIVE
+0x43 HCI_START_SYNCHRONIZATION_TRAIN
+0x44 HCI_RECEIVE_SYNCHRONIZATION_TRAIN
+0x45 HCI_REMOTE_OOB_EXTENDED_DATA_REQUEST_REPLY
+)
+
+
+// HCI link policy commands OCF value, OGF=2
+(
+0x01 HCI_HOLD_MODE 
+0x03 HCI_SNIFF_MODE 
+0x04 HCI_EXIT_SNIFF_MODE 
+0x05 HCI_PARK_MODE 
+0x06 HCI_EXIT_PARK_MODE 
+0x07 HCI_QOS_SETUP 
+0x09 HCI_ROLE_DISCOVERY 
+0x0B HCI_SWITCH_ROLE 
+0x0C HCI_READ_LINK_POLICY_SETTINGS 
+0x0D HCI_WRITE_LINK_POLICY_SETTINGS 
+0x0e HCI_READ_DEFAULT_LINK_POLICY_SETTINGS
+0x0f HCI_WRITE_DEFAULT_LINK_POLICY_SETTINGS
+0x10 HCI_FLOW_SPECIFICATION
+0x11 HCI_SNIFF_SUBRATING
+)
+
+// HCI host controller and baseband commands OCF values, OGF=3
+(
+0x01 HCI_SET_EVENT_MASK 
+0x03 HCI_RESET 
+0x05 HCI_SET_EVENT_FILTER 
+0x08 HCI_FLUSH 
+0x09 HCI_READ_PIN_TYPE 
+0x0A HCI_WRITE_PIN_TYPE 
+0x0B HCI_CREATE_NEW_UNIT_KEY 
+0x0D HCI_READ_STORED_LINK_KEY 
+0x11 HCI_WRITE_STORED_LINK_KEY 
+0x12 HCI_DELETE_STORED_LINK_KEY 
+0x13 HCI_WRITE_LOCAL_NAME 
+0x14 HCI_READ_LOCAL_NAME 
+0x15 HCI_READ_CONN_ACCEPT_TIMEOUT 
+0x16 HCI_WRITE_CONN_ACCEPT_TIMEOUT 
+0x17 HCI_READ_PAGE_TIMEOUT 
+0x18 HCI_WRITE_PAGE_TIMEOUT 
+0x19 HCI_READ_SCAN_ENABLE 
+0x1A HCI_WRITE_SCAN_ENABLE 
+0x1B HCI_READ_PAGE_SCAN_ACTIVITY 
+0x1C HCI_WRITE_PAGE_SCAN_ACTIVITY 
+0x1D HCI_READ_INQUIRY_SCAN_ACTIVITY 
+0x1E HCI_WRITE_INQUIRY_SCAN_ACTIVITY 
+0x1F HCI_READ_AUTHENTICATION_ENABLE 
+0x20 HCI_WRITE_AUTHENTICATION_ENABLE 
+0x21 HCI_READ_ENCRYPTION_MODE 
+0x22 HCI_WRITE_ENCRYPTION_MODE 
+0x23 HCI_READ_CLASS_OF_DEVICE 
+0x24 HCI_WRITE_CLASS_OF_DEVICE 
+0x25 HCI_READ_VOICE_SETTING 
+0x26 HCI_WRITE_VOICE_SETTING 
+0x27 HCI_READ_AUTOMATIC_FLUSH_TIMEOUT 
+0x28 HCI_WRITE_AUTOMATIC_FLUSH_TIMEOUT 
+0x29 HCI_READ_NUM_BROADCAST_RETRANSMISSIONS 
+0x2A HCI_WRITE_NUM_BROADCAST_RETRANSMISSIONS 
+0x2B HCI_READ_HOLD_MODE_ACTIVITY 
+0x2C HCI_WRITE_HOLD_MODE_ACTIVITY 
+0x2D HCI_READ_TRANSMIT_POWER_LEVEL 
+0x2E HCI_READ_SCO_FLOW_CONTROL_ENABLE 
+0x2F HCI_WRITE_SCO_FLOW_CONTROL_ENABLE 
+0x31 HCI_SET_CONTROLLER_TO_HOST_FLOW_CONTROL 
+0x33 HCI_HOST_BUFFER_SIZE 
+0x35 HCI_HOST_NUM_COMPLETED_PACKETS 
+0x36 HCI_READ_LINK_SUPERVISION_TIMEOUT 
+0x37 HCI_WRITE_LINK_SUPERVISION_TIMEOUT 
+0x38 HCI_READ_NUMBER_OF_SUPPORTED_IAC 
+0x39 HCI_READ_CURRENT_IAC_LAP 
+0x3A HCI_WRITE_CURRENT_IAC_LAP 
+0x3B HCI_READ_PAGE_SCAN_PERIOD_MODE 
+0x3C HCI_WRITE_PAGE_SCAN_PERIOD_MODE 
+0x3D HCI_READ_PAGE_SCAN_MODE 
+0x3E HCI_WRITE_PAGE_SCAN_MODE 
+0x3F HCI_SET_AFH_CHANNEL_CLASSIFICATION 
+
+
+0x42 HCI_READ_INQUIRY_SCAN_TYPE 
+0x43 HCI_WRITE_INQUIRY_SCAN_TYPE 
+0x44 HCI_READ_INQUIRY_MODE 
+0x45 HCI_WRITE_INQUIRY_MODE 
+0x46 HCI_READ_PAGE_SCAN_TYPE 
+0x47 HCI_WRITE_PAGE_SCAN_TYPE 
+
+0x48 HCI_READ_AFH_CHANNEL_ACCESSMENT_MODE 
+0x49 HCI_WRITE_AFH_CHANNEL_ACCESSMENT_MODE 
+0x51 HCI_READ_EXTENDED_INQUIRY_RESPONSE
+0x52 HCI_WRITE_EXTENDED_INQUIRY_RESPONSE
+0x53 HCI_REFRESH_ENCRYPTION_KEY
+0x55 HCI_READ_SIMPLE_PAIRING_MODE
+0x56 HCI_WRITE_SIMPLE_PAIRING_MODE
+0x57 HCI_READ_LOCAL_OOB_DATA
+0x58 HCI_READ_INQUIRY_RESPONSE_TRANSMIT_POWER_LEVEL
+0x59 HCI_WRITE_INQUIRY_TRANSMIT_POWER_LEVEL
+0x60 HCI_SEND_KEYPRESS_NOTIFICATION
+0x5A HCI_READ_DEFAULT_ERRONEOUS_DATA_REPORTING
+0x5B HCI_WRITE_DEFAULT_ERRONEOUS_DATA_REPORTING
+0x5F HCI_ENHANCED_FLUSH
+0x61 HCI_READ_LOGICAL_LINK_ACCEPT_TIMEOUT
+0x62 HCI_WRITE_LOGICAL_LINK_ACCEPT_TIMEOUT
+0x63 HCI_SET_EVENT_MASK_PAGE_2
+0x64 HCI_READ_LOCATION_DATA
+0x65 HCI_WRITE_LOCATION_DATA
+0x66 HCI_READ_FLOW_CONTROL_MODE
+0x67 HCI_WRITE_FLOW_CONTROL_MODE
+0x68 HCI_READ_ENHANCE_TRANSMIT_POWER_LEVEL
+0x69 HCI_READ_BEST_EFFORT_FLUSH_TIMEOUT
+0x6A HCI_WRITE_BEST_EFFORT_FLUSH_TIMEOUT
+0x6B HCI_SHORT_RANGE_MODE
+0x6C HCI_READ_LE_HOST_SUPPORT
+0x6D HCI_WRITE_LE_HOST_SUPPORT
+0x6E HCI_SET_MWS_CHANNEL_PARAMETERS
+0x6F HCI_SET_EXTERNAL_FRAME_CONFIGURATION
+0x70 HCI_SET_MWS_SIGNALING
+0x71 HCI_SET_MWS_TRANSPORT_LAYER
+0x72 HCI_SET_MWS_SCAN_FREQUENCY_TABLE
+0x73 HCI_SET_MWS_PATTERN_CONFIGURATION
+0x74 HCI_SET_RESERVED_LT_ADDR
+0x75 HCI_DELETE_RESERVED_LT_ADDR
+0x76 HCI_SET_CONNECTIONLESS_SLAVE_BROADCAST_DATA
+0x77 HCI_READ_SYNCHRONIZATION_TRAIN_PARAMETERS
+0x78 HCI_WRITE_SYNCHRONIZATION_TRAIN_PARAMETERS
+0x79 HCI_READ_SECURE_CONNECTIONS_HOST_SUPPORT
+0x7A HCI_WRITE_SECURE_CONNECTIONS_HOST_SUPPORT
+0x7B HCI_READ_AUTHENTICATED_PAYLOAD_TIMEOUT
+0x7C HCI_WRITE_AUTHENTICATED_PAYLOAD_TIMEOUT
+0x7D HCI_READ_LOCAL_OOB_EXTENDED_DATA
+0x7E HCI_READ_EXTENDED_PAGE_TIMEOUT
+0x7F HCI_WRITE_EXTENDED_PAGE_TIMEOUT
+0x80 HCI_READ_EXTENDED_INQUIRY_LENGTH
+0x81 HCI_WRITE_EXTENDED_INQUIRY_LENGTH
+)
+
+
+// HCI informational parameters OCF values, OGF=4
+(
+0x01 HCI_READ_LOCAL_VERSION_INFORMATION 
+0x02 HCI_READ_LOCAL_SUPPORTED_COMMANDS
+0x03 HCI_READ_LOCAL_SUPPORTED_FEATURES 
+0x04 HCI_READ_LOCAL_EXT_FEATURES 
+0x05 HCI_READ_BUFFER_SIZE 
+0x07 HCI_READ_COUNTRY_CODE 
+0x09 HCI_READ_BD_ADDR 
+0x0A HCI_REJECT_CONNECTION_REQUEST
+0x0B HCI_READ_LOCAL_SUPPORTED_CODECS
+)
+
+// HCI status parameters OCF values, OGF=5
+(
+0x01 HCI_READ_FAILED_CONTACT_COUNTER 
+0x02 HCI_RESET_FAILED_CONTACT_COUNTER 
+0x03 HCI_GET_LINK_QUALITY 
+0x05 HCI_READ_RSSI 
+0x06 HCI_READ_AFH_CHANNEL_MAP
+0x07 HCI_READ_BD_CLOCK
+0x08 HCI_READ_ENCRYPTION_KEY_SIZE
+0x09 HCI_READ_LOCAL_AMP_INFO
+0x0A HCI_READ_LOCAL_AMP_ASSOC
+0x0B HCI_WRITE_REMOTE_AMP_ASSOC
+0x0C HCI_GET_MWS_TRANSPORT_LAYER_CONFIGURATION
+0x0D HCI_SET_TRIGGERED_CLOCK_CAPTURE
+)
+
+// HCI testing command OCF values, OGF=6
+(
+0x01 HCI_READ_LOOPBACK_MODE 
+0x02 HCI_WRITE_LOOPBACK_MODE 
+0x03 HCI_ENABLE_DEVICE_UNDER_TEST_MODE 
+0x04 HCI_WRITE_SIMPLE_PAIRING_DEBUG_MODE
+0x07 HCI_ENABLE_AMP_RECEIVER_REPORTS
+0x08 HCI_AMP_TEST_END
+0x09 HCI_AMP_TEST
+0x0A HCI_WRITE_SECURE_CONNECTIONS_TEST_MODE
+)
+
+// HCI vendor specific command OCF values -OGF=3F
+(
+0x01 HCI_WRITE_BD_ADDR 
+0x02 HCI_READ_INQUIRY_RESPONSE_TIMEOUT 
+0x03 HCI_WRITE_INQUIRY_RESPONSE_TIMEOUT 
+0x04 HCI_READ_PAGE_SCAN_REPETITION_MODE 
+0x05 HCI_WRITE_PAGE_SCAN_REPETITION_MODE 
+0x06 HCI_READ_PAGE_RESPONSE_TIMEOUT 
+0x07 HCI_WRITE_PAGE_RESPONSE_TIMEOUT 
+0x08 HCI_READ_NEW_CONNECTION_TIMEOUT 
+0x09 HCI_WRITE_NEW_CONNECTION_TIMEOUT 
+0x0a HCI_INITIALIZE_BASEBAND 
+0x0b HCI_WRITE_LOCAL_SUPPORTED_FEATURES 
+0x0c HCI_WRITE_PARK_PARAMETERS 
+0x0d HCI_READ_PARK_PARAMETERS 
+0x0e HCI_WRITE_QUALITY_OF_SERVICE 
+0x0f HCI_NOT_USED 
+0x10 HCI_MODIFY_BEACON_PARAMETERS 
+0x11 HCI_UNPARK_USING_PM_ADDR 
+0x12 HCI_WRITE_HOPPING_CHANNELS 
+0x13 HCI_SLEEP_FOREVER_MODE 
+0x14 HCI_WRITE_AUTO_PAGE_SCAN_ENABLE 
+0x15 HCI_READ_AUTO_PAGE_SCAN_ENABLE 
+0x16 HCI_SET_ENCRYPTION_KEY_SIZE 
+0x17 HCI_INVALIDATE_FLASH_AND_REBOOT 
+0x18 HCI_UPDATE_UART_BAUD_RATE 
+0x19 HCI_WRITE_GPIO_1_4_AS_OUTPUT 
+0x1A HCI_WRITE_GPIO_2_LED 
+0x1B HCI_SET_TESTMODE_TYPE 
+0x1C HCI_WRITE_SCO_PCM_INT_PARAM 
+0x1D HCI_READ_SCO_PCM_INT_PARAM 
+0x1E HCI_WRITE_PCM_DATA_FORMAT_PARAM 
+0x1F HCI_READ_PCM_DATA_FORMAT_PARAM 
+0x20 HCI_WRITE_COMFORT_NOISE_PARAM 
+0x21 HCI_READ_COMFORT_NOISE_PARAM 
+0x22 HCI_WRITE_SCO_TS 
+0x23 HCI_READ_SCO_TS 
+0x24 HCI_WRITE_PCM_LOOPBACK_MODE 
+0x25 HCI_READ_PCM_LOOPBACK_MODE 
+0x26 HCI_SET_TRANSMIT_POWER 
+0x27 HCI_SET_SLEEPMODE_PARAM 
+0x28 HCI_READ_SLEEPMODE_PARAM 
+0x29 HCI_SLEEPMODE_CMD 
+0x2A HCI_DELAY_PERIPHERAL_SCO_STARTUP 
+0x2B HCI_WRITE_RECEIVE_ONLY 
+0x2C HCI_WRITE_RATE_CONTROL 
+0x2D HCI_TX_UNMOD_CARRIER 
+0x2E HCI_DOWNLOAD_MINIDRIVER 
+0x2F HCI_CRYSTAL_PPM 
+0x30 HCI_SET_POWER_AMP_BIAS 
+0x31 HCI_SET_HAM_BEHAVIOR 
+0x32 HCI_SET_AFH_BEHAVIOR 
+0x33 HCI_READ_USER_DEFINED_NVRAM 
+0x34 HCI_ENABLE_RADIO 
+0x35 HCI_READ_DIAGNOSTIC_INFO 
+0x36 HCI_GET_HID_DEVICE_LIST 
+0x37 HCI_ADD_HID_DEVICE 
+0x38 HCI_READ_APP_FW_CONFIG_VERSION 
+0x39 HCI_DELETE_HID_DEVICE 
+0x3B HCI_ENABLE_USB_HID_EMULATION 
+// 0x3A available
+// 0x3B available
+0x3C HCI_SEND_LMPDU 
+0x3D HCI_AUTO_PAIR_REQ 
+0x3E HCI_READ_VS_EXTENSION 
+0x3F HCI_WRITE_VS_EXTENSION 
+
+0x77 HCI_OPCODE_FC77
+0x79 HCI_OPCODE_FC79
+0xC4 HCI_DOWNLOAD_PATCH
+0xCC HCI_OPCODE_FCCC
+
+0x00 HCI_VENDOR_CMD_RESET
+0x01 HCI_VENDOR_CMD_CHIPID
+0x02 HCI_VENDOR_CMD_BAUD
+0x03 HCI_VENDOR_CMD_PATCH
+0x04 HCI_VENDOR_CMD_PATCH_DONE
+0x05 HCI_VENDOR_CMD_ECHO
+0x06 HCI_VENDOR_CMD_BDADDR
+
+0x07 HCI_VENDOR_CMD_ENTER_LPM
+0x08 HCI_VENDOR_CMD_COMMU_READY
+
+0x10 HCI_VENDOR_CMD_MEM
+0x11 HCI_VENDOR_CMD_EEP
+)
+
+//HCI LE controller command OCF values, OGF=8
+(
+0x01 HCI_LE_SET_EVENT_MASK
+0x02 HCI_LE_READ_BUFFER_SIZE
+0x03 HCI_LE_READ_LOCAL_SUPPORTED_FEATURES
+0x05 HCI_LE_SET_RANDOM_ADDRESS
+0x06 HCI_LE_SET_ADVERTISING_PARAMETERS
+0x07 HCI_LE_READ_ADVERTISING_CHANNEL_TX_POWER
+0x08 HCI_LE_SET_ADVERTISING_DATA
+0x09 HCI_LE_SET_SCAN_RESPONSE_DATA
+0x0A HCI_LE_SET_ADVERTISE_ENABLE
+0x0B HCI_LE_SET_SCAN_PARAMETERS
+0x0C HCI_LE_SET_SCAN_ENABLE
+0x0D HCI_LE_CREATE_CONNECTION
+0x0E HCI_LE_CREATE_CONNECTION_CANCEL
+0x0F HCI_LE_READ_WHITE_LIST_SIZE
+0x10 HCI_LE_CLEAR_WHITE_LIST
+0x11 HCI_LE_ADD_DEVICE_TO_WHITE_LIST
+0x12 HCI_LE_REMOVE_DEVICE_FROM_WHITE_LIST
+0x13 HCI_LE_CONNECTION_UPDATE
+0x14 HCI_LE_SET_HOST_CHANNEL_CLASSIFICATION
+0x15 HCI_LE_READ_CHANNEL_MAP
+0x16 HCI_LE_READ_REMOTE_USED_FEATURES
+0x17 HCI_LE_ENCRYPT
+0x18 HCI_LE_RAND
+0x19 HCI_LE_START_ENCRYPTION
+0x1A HCI_LE_LONG_TERM_KEY_REQUEST_REPLY
+0x1B HCI_LE_LONG_TERM_KEY_REQUEST_NEGATIVE_REPLY
+0x1C HCI_LE_READ_SUPPORTED_STATES
+0x1D HCI_LE_RECEIVER_TEST
+0x1E HCI_LE_TRANSMITTER_TEST
+0x1F HCI_LE_TEST_END
+0x20 HCI_LE_REMOTE_CONNECTION_PARAMETER_REQUEST_REPLY
+0x21 HCI_LE_REMOTE_CONNECTION_PARAMETER_REQUEST_NEGATIVE_REPLY
+)
+// HCI event code
+(
+0x01 HCI_EVENT_INQUIRY_COMPLETE
+0x02 HCI_EVENT_INQUIRY_RESULT
+0x03 HCI_EVENT_CONNECTION_COMPLETE
+0x04 HCI_EVENT_CONNECTION_REQUEST
+0x05 HCI_EVENT_DISCONNECTION_COMPLETE
+0x06 HCI_EVENT_AUTHENTICATION_COMPLETE
+0x07 HCI_EVENT_REMOTE_NAME_REQUEST_COMPLETE
+0x08 HCI_EVENT_ENCRYPTION_CHANGE_COMPLETE
+0x09 HCI_EVENT_CHANGE_CONNECTION_LINK_KEY_COMPLETE
+0x0A HCI_EVENT_MASTER_LINK_KEY_COMPLETE
+0x0B HCI_EVENT_READ_REMOTE_FEATURES_COMPLETE
+0x0C HCI_EVENT_READ_REMOTE_VERSION_INFORMATION_COMPLETE
+0x0D HCI_EVENT_QOS_SETUP_COMPLETE
+0x0E HCI_EVENT_COMMAND_COMPLETE
+0x0F HCI_EVENT_COMMAND_STATUS
+0x10 HCI_EVENT_HARDWARE_ERROR
+0x11 HCI_EVENT_FLUSH_OCCURRED
+0x12 HCI_EVENT_ROLE_CHANGE
+0x13 HCI_EVENT_NUM_COMPLETED_PACKETS
+0x14 HCI_EVENT_MODE_CHANGE
+0x15 HCI_EVENT_RETURN_LINK_KEYS
+0x16 HCI_EVENT_PIN_CODE_REQUEST
+0x17 HCI_EVENT_LINK_KEY_REQUEST
+0x18 HCI_EVENT_LINK_KEY_NOTIFICATION
+0x19 HCI_EVENT_LOOPBACK_COMMAND
+0x1A HCI_EVENT_DATA_BUFFER_OVERFLOW
+0x1B HCI_EVENT_MAX_SLOTS_CHANGE
+0x1C HCI_EVENT_READ_CLOCK_OFFSET_COMPLETE
+0x1D HCI_EVENT_CONNECTION_PACKET_TYPE_CHANGED
+0x1E HCI_EVENT_QOS_VIOLATION
+0x1F HCI_EVENT_PAGE_SCAN_MODE_CHANGE
+0x20 HCI_EVENT_PAGE_SCAN_REPETITION_MODE_CHANGE
+0x21 HCI_EVENT_FLOW_SPECIFICATION_COMPLETE
+0x22 HCI_EVENT_INQUIRY_RESULT_WITHRSSI
+0x23 HCI_EVENT_READ_REMOTE_EXT_FEATURES_COMPLETE
+0x2C HCI_EVENT_SCO_CONNECTION_COMPLETE
+0x2D HCI_EVENT_SCO_CONNECTION_CHANGED
+0x2E HCI_EVENT_SNIFF_SUBRATING
+0x2F HCI_EVENT_EXT_INQUIRY_RESULT
+0x30 HCI_EVENT_ENCRYPT_KEY_REFRESH_COMPLETE
+0x31 HCI_EVENT_IO_CAP_REQ
+0x32 HCI_EVENT_IO_CAP_RESPONSE
+0x33 HCI_EVENT_USER_CONFIRMATION_REQUEST
+0x34 HCI_EVENT_UESR_PASSKEY_REQUEST
+0x35 HCI_EVENT_REMOTE_OOB_DATA_REQUEST
+0x36 HCI_EVENT_SIMPLE_PAIRING_COMPLETE
+0x38 HCI_EVENT_LINK_SUPERVISION_TIMEOUT_CHANGED
+0x39 HCI_EVENT_ENHANCED_FLUSH_COMPLETE
+0x3B HCI_EVENT_USER_PASSKEY_NOTIFICATION
+0x3C HCI_EVENT_KEYPRESS_NOTIFICATION
+0x3D HCI_EVENT_REMOTE_HOST_SUPPORTED_FEATURES_NOTIFICATION 
+0x3E HCI_EVENT_LE_META_EVENT
+0x40 HCI_EVENT_PHYSICAL_LINK_COMPLETE
+0x41 HCI_EVENT_CHANNEL_SELECTED
+0x42 HCI_EVENT_DISCONNECTION_PHYSICAL_LINK_COMPLETE
+0x43 HCI_EVENT_PHYSICAL_LINK_LOSS_EARLY_WARNING
+0x44 HCI_EVENT_PHYSICAL_LINK_RECOVERY
+0x45 HCI_EVENT_LOGICAL_LINK_COMPLETE
+0x46 HCI_EVENT_DISCONNECTION_LOGICAL_LINK_COMPLETE
+0x47 HCI_EVENT_FLOW_SPEC_MODIFY_COMPLETE
+0x48 HCI_EVENT_NUMBER_OF_COMPLETED_DATA_BLOCKS
+0x49 HCI_EVENT_AMP_START_TEST
+0x4A HCI_EVENT_AMP_TEST_END
+0x4B HCI_EVENT_AMP_RECEIVER_REPORT
+0x4C HCI_EVENT_SHORT_RANGE_MODE_CHANGE_COMPLETE
+0x4D HCI_EVENT_AMP_STATUS_CHANGE
+0x4E HCI_EVENT_TRIGGERED_CLOCK_CAPTURE
+0x4F HCI_EVENT_SYNCHRONIZATION_TRAIN_COMPLETE
+0x50 HCI_EVENT_SYNCHRONIZATION_TRAIN_RECEIVED
+0x51 HCI_EVENT_CONNECTIONLESS_SLAVE_BROADCAST_RECEIVE
+0x52 HCI_EVENT_CONNECTIONLESS_SLAVE_BROADCAST_TIMEOUT
+0x53 HCI_EVENT_TRUNCATED_PAGE_COMPLETE
+0x54 HCI_EVENT_SLAVE_PAGE_RESPONSE_TIMEOUT
+0x55 HCI_EVENT_CONNECTIONLESS_SLAVE_BROADCAST_CHANNEL_MAP_CHANGE
+0x56 HCI_EVENT_INQUIRY_RESPONSE_NOTIFICATION
+0x57 HCI_EVENT_AUTHENTICATED_PAYLOAD_TIMEOUT_EXPIRED
+
+0xFE HCI_EVENT_LOGO_TESTING
+0xFF HCI_EVENT_VENDOR_SPECIFIC
+)
+(
+0x01 HCI_VENDOR_EVENT_COMMU_READY
+)
+//HCI LE SUBEVENT CODE
+(
+0x01 HCI_LE_SUBEVENT_CONN_COMPLETE
+0x02 HCI_LE_SUBEVENT_ADV_REPORT
+0x03 HCI_LE_SUBEVENT_CONN_UPDATE_COMPLETE
+0x04 HCI_LE_SUBEVENT_REMOTE_FEATURE_COMPLETE
+0x05 HCI_LE_SUBEVENT_LTK_REQUEST
+0x06 HCI_LE_SUBEVENT_REMOTE_CONN_PARAM_REQ
+)
+//HCI ErrorCodes
+(    
+0x00 HCI_SUCCESS
+0x01 HCI_ERROR_UNKNOWN_HCI_COMMAND
+0x02 HCI_ERROR_NO_CONNECTION
+0x03 HCI_ERROR_HARDWARE_FAILURE
+0x04 HCI_ERROR_PAGE_TIMEOUT
+0x05 HCI_ERROR_AUTHENTICATION_FAILURE
+0x06 HCI_ERROR_KEY_MISSING
+0x07 HCI_ERROR_MEMORY_FULL
+0x08 HCI_ERROR_CONNECTION_TIMEOUT
+0x09 HCI_ERROR_MAX_CONNECTIONS
+0x0A HCI_ERROR_MAX_SCO_CONNECTIONS
+0x0B HCI_ERROR_MAX_ACL_CONNECTIONS
+0x0C HCI_ERROR_COMMAND_DISALLOWED
+0x0D HCI_ERROR_HOST_REJECT_LIMITED_RESOURCES
+0x0E HCI_ERROR_HOST_REJECT_SECURITY_REASONS
+0x0F HCI_ERROR_HOST_REJECT_REMOTE_IS_ONLY_PERSONAL
+0x10 HCI_ERROR_HOST_TIMEOUT
+0x11 HCI_ERROR_UNSUPPORTED_FEATURE_OR_PARAMETER_VALUE
+0x12 HCI_ERROR_INVALID_HCI_COMMAND_PARAMETERS
+0x13 HCI_ERROR_REMOTE_USER_ENDED_CONNECTION
+0x14 HCI_ERROR_REMOTE_LOW_RESOURCES
+0x15 HCI_ERROR_REMOTE_POWERING_OFF
+0x16 HCI_ERROR_CONNECTION_TERMINATED_BY_LOCAL_HOST
+0x17 HCI_ERROR_REPEATED_ATTEMPTS
+0x18 HCI_ERROR_PAIRING_NOT_ALLOWED
+0x19 HCI_ERROR_UNKNOWN_LMP_PDU
+0x1A HCI_ERROR_UNSUPPORTED_REMOTE_FEATURE
+0x1B HCI_ERROR_SCO_OFFSET_REJECTED
+0x1C HCI_ERROR_SCO_INTERVAL_REJECTED
+0x1D HCI_ERROR_SCO_AIR_MODE_REJECTED
+0x1E HCI_ERROR_INVALID_LMP_PARAMETER
+0x1F HCI_ERROR_UNSPECIFIED_ERROR
+0x20 HCI_ERROR_UNSUPPORTED_LMP_PARAMETER_VALUE
+0x21 HCI_ERROR_ROLE_CHANGE_NOT_ALLOWD
+0x22 HCI_ERROR_LMP_RESPONSE_TIMEOUT
+0x23 HCI_ERROR_ERROR_TRANSACTION_COLLISION
+0x24 HCI_ERROR_LMP_PDU_NOT_ALLOWED
+0x25 HCI_ERROR_ENCRYPTION_MODE_NOT_ACCEPTABLE
+0x26 HCI_ERROR_UNIT_KEY_USED
+0x27 HCI_ERROR_QOS_NOT_SUPPORTED
+0x28 HCI_ERROR_INSTANT_PASSED
+0x29 HCI_ERROR_PAIRING_W_UNIT_KEY_NOT_SUPPORTED
+0x2a HCI_ERROR_DIFFERENT_TRANSACTION_COLLISION
+0x2c HCI_ERROR_QOS_UNACCEPTABLE_PARAMETER
+0x2d HIC_ERROR_QOS_REJECTED
+0x2e HIC_ERROR_CHANNEL_CLASSIFICATION_NOT_SUPPORTED
+0x2f HIC_ERROR_INSUFFICIENT_SECURITY
+0x30 HIC_ERROR_PARAMETER_OUT_OF_MANDATORY_PANGE
+0x32 HIC_ERROR_ROLE_SWITCH_PENDING
+0x34 HIC_ERROR_RESERVED_SLOT_VIOLATION
+0x35 HIC_ERROR_ROLE_SWITCH_FAILED
+0x36 HIC_ERROR_EXTENDED_INQUIRY_RESPONSE_TOO_LARGE
+0x37 HIC_ERROR_SIMPLE_PAIRING_NOT_SUPPORTED_BY_HOST
+0x38 HIC_ERROR_HOST_BUSY_PAIRING
+)
+
+(
+0x00 HCI_LPM_OFF
+0x01 HCI_LPM_ON
+)
+
+
+(
+33 HOST_WAKE_TIME
+)
+
+(
+1 HCI_RX_WAKE
+0 HCI_RX_READY
+)
+
Index: btkb/format/keyboard.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/keyboard.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/keyboard.format	(working copy)
@@ -0,0 +1,357 @@
+
+omemalloc(
+//Keyboard Work Area
+2 mem_kb_state
+6 mem_kb_report_data
+1 mem_kb_keys
+1 mem_kb_rcv_led_data
+4 mem_kb_fast_wake_last
+//Keyboard Config Area
+1 mem_led_cap_gpio
+1 mem_led_num_gpio
+1 mem_led_scl_gpio
+0 mem_kb_map
+630 mem_kb_uuid_list
+
+// patch area
+10 mem_24g_paring_tx_power_param
+10 mem_5db_tx_power_param
+
+//c51
+1 mem_current_event
+1 mem_ipc_lock_rx_data_bt
+1 mem_ipc_lock_rx_data_c51
+1 mem_ipc_lock_tx_data_bt
+1 mem_ipc_lock_tx_data_c51
+
+
+150 mem_ipc_2bt_fifo_head
+0	mem_ipc_2bt_fifo_end
+100 mem_ipc_2C51_fifo_head
+0	mem_ipc_2C51_fifo_end
+2	mem_ipc_2bt_read_index
+2	mem_ipc_2bt_write_index
+2	mem_ipc_2C51_read_index
+2	mem_ipc_2C51_write_index
+
+2 mem_ipc_tx_evt_buff
+1 mem_ipc_tx_evt
+
+2 mem_ipc_bt_timer
+1 mem_ipc_rx_type
+
+0 mem_rfcomm_tx_buff
+
+1 mem_queue_ele_num
+2 mem_queue_write
+2 mem_queue_read
+0 mem_queue_start
+12 mem_uart_packet
+12 mem_data_ele0
+12 mem_data_ele1
+12 mem_data_ele2
+0 mem_queue_end
+2 mem_queue_temp
+
+
+// patch allocated
+1 mem_24g_rxdata_length
+1 mem_24g_pid
+1 mem_24g_datalen
+1 mem_24g_data_type
+1 mem_24g_txlen
+2 mem_24g_rx_window
+1 mem_24g_ensure
+1 mem_24g_get_ack_fail
+1 mem_24g_retry
+1 mem_24g_ch
+1 mem_24g_current_ch_number
+4 mem_24g_paring_addr
+1 mem_24g_pairing_sm
+4 mem_24g_ch_map1
+4 mem_24g_ch_map2
+4 mem_24g_ch_map3
+4 mem_24g_ch_map4
+4 mem_24g_addr
+2 mem_24g_check_dongle_times
+4 mem_24g_device_addr
+1 mem_24g_no_ack
+3 mem_24g_sta_crc
+1 mem_24g_sta_pid
+1 mem_24g_max_retry
+1 mem_24g_mode
+1 mem_24g_hop_pac_retry
+1 mem_24g_idle_timeout
+1 mem_24g_idle_cnt
+1 mem_24g_auto_paring_switch
+1 mem_24g_enter_lpm_timer
+2 mem_24g_syncword
+1 mem_24g_syncword_crc8
+1 mem_24g_get_syncword_crc8
+2 mem_24g_discard_cnt
+2 mem_cb_24g_data
+9 mem_24g_lasttx
+
+1 mem_power_ctrl_pac_succ_cnt
+1 mem_power_ctrl_level
+
+1 mem_rssi_avg_received
+1 mem_rssi_hex_received
+8 mem_rssi_signal_buf
+8 mem_rssi_noise_buf
+1 mem_rssi_noise_index
+1 mem_rssi_signal_index
+
+1 mem_tx_power
+1 mem_tx_power_temp
+3 mem_cnt
+1 mem_last_txlch
+2 mem_last_txlen
+20 mem_last_txdata
+
+//le
+4 mem_ipc_last_check_timer
+1 mem_prepare_write_len
+2 mem_ipc_c51_timer
+1 mem_le_rx_window
+2 mem_le_find_type_value_start_handle
+2 mem_le_find_type_value_end_handle
+2 mem_le_cur_att_type
+1 mem_le_search_len
+1 mem_le_ll_unknown_type
+1 mem_le_pairing_state
+2 mem_le_local_mtu
+16 mem_le_connection_updata_param
+1 mem_ltk_states
+1 mem_pair_state
+1 mem_empty_count
+1 mem_shutter_find_type_value_flag
+
+1 mem_le51_payload_len
+1 mem_le51_cmd
+
+1 mem_le51_tx_length
+1 mem_le51_txbuff_inuse
+9 mem_le51_txbuf
+
+1 mem_ipc_bt_100ms_timer
+1 mem_ipc_c51_100ms_timer
+
+1 mem_adc_config_flag
+1 mem_adc_channel
+2 mem_adc_0v
+2 mem_adc_3v
+2 mem_adc_current_value
+
+1 mem_hibernate_flag
+2 mem_new_supervision_to
+1 mem_kb_wake_timer
+20 mem_kb_last_data
+1 mem_kb_keycount
+1 mem_led_cap_delay_timer
+3 mem_test
+1 mem_seq
+1 mem_recon_index
+1 mem_power_on_flag
+1 mem_caps_num_lock
+2 mem_att_report1
+2 mem_att_report2
+2 mem_att_report3
+
+1 mem_suspend_flag
+120 mem_32asm_data_end
+1 mem_store_ltk_timer
+1 mem_reconnect_continue
+4 mem_le_pin_code
+1 mem_le_send_security_request_flag
+2 mem_att_report_battery
+4 mem_24g_enter_hibernate
+1 mem_24g_txfail_cnt
+1 mem_mouse_retry_flag
+1 mem_24g_led_flag
+4 mem_ui_timer_last_btclk_temp
+4 mem_ui_check_timer_setup
+2 mem_customize_timer_setup
+1 mem_customize_timer
+1 mem_ios_mode_flag
+4 mem_version_yy_mm_dd
+20 mem_24g_txbuf_new
+7 mem_le_adv_swift_pair
+4 mem_24g_enter_hibernate_setup
+4 mem_24g_enter_hibernate_max
+3 mem_24g_short_sleep_counter
+1 mem_pc_sleep_flag
+1 mem_le_pause_enc_flag
+)
+
+//C51 synchronous task
+(
+3 START_C51_CORE
+)
+
+(
+0 ADC_CONFIG_VINLPM
+1 ADC_CONFIG_HVIN
+2 ADC_CONFIG_GPIO
+)
+
+(
+0 P24G_PAIRING_REQ_HEAD
+1 P24G_PAIRING_COMPLETE_HEAD
+)
+
+(
+0 ENSURE_OFF_24G
+1 ENSURE_ON_24G
+0x4e G24_PAIR_CH
+)
+
+(
+7 RSSI_BUF_LEN_SIGNAL
+255 RSSI_BUF_LEN_NOISE
+0x50 RSSI_THRESH_NOISE
+
+0x77 RSSI_DIS_MIN_24G
+0x82 RSSI_DIS_MAX_24G
+
+0x75 RSSI_DIS_MIN_BLE
+0x80 RSSI_DIS_MAX_BLE
+)
+
+(//bluetooth tx power
+0 TX_POWER_0DB
+1 TX_POWER_3DB
+2 TX_POWER_5DB
+3 TX_POWER_f3DB
+4 TX_POWER_f5DB
+)
+
+/* 24g */
+(
+6 dlen_24g
+14 plen_24g
+90 blen_tx_24g
+106 blen_rx_24g
+42 blen_txack_24g
+58 blen_rxack_24g
+7 retry_24g
+0xaaf08e acc_24g
+0x15c4 crc_data_3byte
+0xbb81 crc_data_6byte
+0x4160 crc_ack
+41390 crc_ack_4byte
+)
+
+(
+1 NO_ACK_24g
+0 with_ack_24g
+)
+
+(
+0 disable_24g
+1 tx_24g
+2 rx_24g
+
+0 bit_ack_24g
+)
+
+
+//mem_24g_data_type
+(
+0x07 bits_data
+//0-2 data type
+3 bit_abort
+4 bit_hop
+5 bit_sync
+//6-7 channel offset
+)
+
+// ble
+(
+0 FLAG_LE_PAIRING_NULL
+1 FLAG_LE_PAIRING_START
+2 FLAG_LE_PAIRING_AFTER_AUTH
+3 FLAG_LE_PAIRING_END
+)
+
+(
+0 PAIR_UNKNOWN
+1 PAIR_ING
+2 PAIR_DONE
+)
+
+(
+0 DEFAULT_STATES
+1 IPHONE_LOST_LTK
+2 MODULE_LOST_LTK
+3 LTK_NOT_LOST
+)
+
+(
+3 QUEUE_ELE_COUNT
+12 QUEUE_ELE_LENGTH
+)
+
+
+8 KB_KSCAN_ROW 
+7 KB_KSCAN_ROW_1
+20 KB_KSCAN_COL
+19 KB_KSCAN_COL_1
+
+/* ks_ctrl */
+(
+0x01 KB_KSCAN_CTRL_ENABLE					
+0x02 KB_KSCAN_CTRL_FREEZE					
+0x04 KB_KSCAN_CTRL_GHOST					
+0x08 KB_KSCAN_CTRL_INT						
+0x10 KB_KSCAN_CTRL_CLKON					
+0x20 KB_KSCAN_CTRL_FIFO_CLR				
+                  
+0 KB_KSCAN_STAT_EMPTY
+1 KB_KSCAN_STAT_FULL 					
+2 KB_KSCAN_STAT_OVERFLOW				
+6 KB_KSCAN_STAT_GHOST 
+
+0 KB_KSCAN_KEY_EVENT_STAT
+0 KB_KSCAN_KEY_PRESS	
+1 KB_KSCAN_KEY_RELEASE
+
+)
+
+
+/* special key codes */
+(
+0x1d KB_KCODE_1_M1
+0x27 KB_KCODE_0
+0x28 KB_KCODE_ENTER
+0x2a KB_KCODE_BKSP
+)
+
+(
+0x01 HID_REPORTID_1
+0x02 HID_REPORTID_2
+0x03 HID_REPORTID_3
+0x04 HID_REPORTID_4
+)
+
+(
+/*DATA OUTPUT report id = 1*/
+0 KB_NUM_LOCK_SELECTED
+1 KB_CAPS_LOCK_SELECTED
+2 KB_SCROLL_LOCK_SELECTED
+)
+
+(
+0x1f  KB_UI_BUTTON_GPIO
+)
+
+(
+0x0007 HANDLE_UUID_CHRCTR_DEVICE_NAME
+0x000e HANDLE_UUID_CHRCTR_MANUFACTURER_NAME
+0x0010 HANDLE_UUID_PNP_ID
+0x0021 HANDLE_UUID_CHRCTR_REPORT_ID1_OUTPUT
+0x002c HANDLE_UUID_BATTERY_LEVEL
+0x002d HANDLE_UUID_END
+)
+
+
Index: btkb/format/l2cap.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/l2cap.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/l2cap.format	(working copy)
@@ -0,0 +1,442 @@
+
+memalloc(
+0 mem_l2cap_mem_start
+// L2CAP RX 
+2 mem_l2cap_rxbuff1_len
+2 mem_l2cap_rxbuff2_len
+2 mem_l2cap_rxbuff_new
+1 mem_l2cap_rxbuff_inuse
+2 mem_l2cap_payload_ptr
+2 mem_l2cap_rx_pkt_length
+2 mem_l2cap_rx_cid
+1 mem_l2cap_rx_done
+
+
+
+// L2CAP TX Signal channel
+2 mem_l2cap_signal_tx_buff_ptr
+2 mem_l2cap_signal_tx_payload_ptr
+2 mem_l2cap_signal_tx_length
+// L2CAP TX SDP channel
+2 mem_sdp_tx_buff_ptr
+2 mem_sdp_tx_payload_ptr
+2 mem_sdp_tx_pkt_length
+// L2CAP TX RFCOMM channel
+2 mem_rfcomm_tx_buff_ptr
+2 mem_rfcomm_tx_payload_ptr
+2 mem_rfcomm_tx_pkt_length
+
+
+
+//L2CAP Util
+
+2 memL2CAP_T1
+
+1 mem_CONTROL_tasks
+1 mem_send_config_req
+
+
+1 mem_config_identifier
+2 mem_config_req_dest_CID
+1 mem_rfcomm_malloc_fail_flag
+
+//L2CAP STATE MACHINE
+1 mem_message_to_uppersm
+1 mem_upper_sm_remote_page
+1 mem_upper_sm_reconn
+1 mem_upper_sm_ss
+
+
+64 mem_tx_malloc_log
+0 mem_l2cap_mem_end
+
+
+2 mem_scid
+2 mem_cmd_length
+2 mem_tt2
+2 mem_tt3
+2 mem_id
+2 mem_psm
+
+
+4 mem_l2cap_sdpres_delay_time
+)
+
+xmemalloc(
+0 mem_l2cap_xmem_start
+//*******************L2CAP TX MULTI-PACKET*********************//
+2 mem_l2cap_tx_multi_offset //0 means single packet
+
+//*******************CHANNEL ID*********************//
+2 mem_sdp_remote_cid
+2 mem_rfcomm_remote_cid
+2 mem_hid_ctrl_remote_cid
+2 mem_hid_int_remote_cid
+//*******************CHANNEL STATE*********************//
+1 mem_sdp_state
+1 mem_rfcomm_state
+1 mem_hid_control_state
+1 mem_hid_interrupt_state
+1 mem_spp_state
+1 mem_ML2CAP_comm_id
+
+//*******************L2CAP malloc********************//
+1 mem_used_map
+0 mem_tx_fifo0
+1 mem_tx_fifo0_map
+2 mem_tx_fifo0_ptr
+0 mem_tx_fifo1
+1 mem_tx_fifo1_map
+2 mem_tx_fifo1_ptr
+0 mem_tx_fifo2
+1 mem_tx_fifo2_map
+2 mem_tx_fifo2_ptr
+0 mem_tx_fifo3
+1 mem_tx_fifo3_map
+2 mem_tx_fifo3_ptr
+0 mem_tx_fifo_end
+256 mem_l2cap_lpm_txbuf
+//*******************MISC*********************//
+1 mem_l2cap_flow_ctrl_flag
+1 mem_l2cap_pending_item
+0 mem_l2cap_xmem_end
+
+)
+
+
+//mem_l2cap_lpm_txbuf
+(
+256 l2cap_lpm_txbuf_len
+)
+
+(
+4 L2CAP_TX_FIFO_SIZE
+8 L2CAP_TX_BUFF_CNT
+
+)
+
+(
+0x0002 L2CAP_SIG_EXT_FEATRUE
+0x0003 L2CAP_SIG_FIX_FEATRUE
+)
+
+(
+0 HS_IDLE
+1 AG_INIT_CALL
+2 HS_INIT_CALL
+)
+(
+0 M_ACL_LINK_ABSENT
+1 M_ACL_LINK_EXIST
+)
+
+(
+0 L2CAP_INUSE_BUFF1
+1 L2CAP_INUSE_BUFF2
+)
+/* upper layer interface w/ lower layer */
+(
+1 MAX_NUM_LINKS_ALLOWED
+1 MAX_NUM_SCO_ALLOWED
+1 ACL_LINK_PRESENT
+0 ACL_LINK_ABSENT
+)
+(
+1 L2CAP_RX_DONE 
+0 L2CAP_RX_CLEAR
+)
+/* Scheduler */
+(
+0 L2CAP_DISCONNECT_INTERRUPT
+1 RFCOMM_wants_service
+2 L2CAP_sig_Tx_buff_full
+3 RFCOMM_Tx_buff_full
+4 SDP_Tx_buff_full
+5 got_complete_L2CAP_pkt	
+6 L2CAP_init_Config_Req
+7 L2CAP_DISCONNECT_CONTROL
+)
+
+/* mem_CONTROL_tasks2 */
+(
+0 UI_NEED_SERVICE
+)
+/* L2CAP logic channel identifiers (2 bytes) p.261 */
+(
+0x0001 L2CAP_signal_channel
+0x0050 L2CAP_SDP_channel
+0x0051 L2CAP_RFCOMM_channel
+0x0052 L2CAP_HID_Control_channel   
+0x0053 L2CAP_HID_Interrupt_channel
+0x0077 L2CAP_AVDTP_signal_channel		//------avdtp
+0x0078 L2CAP_AVDTP_media_channel
+0x0079 L2CAP_AVDTP_report_channel
+0x0080 L2CAP_AVDTP_recovery_channel
+0x00dd L2CAP_AVCTP_Control_channel
+)
+/* L2CAP signalling command codes (1 byte) p.284 */
+(
+0x00 reserved
+0x01 signal_cmd_reject
+0x02 signal_connect_req
+0x03 signal_connect_rsp
+0x04 signal_config_req
+0x05 signal_config_rsp
+0x06 signal_disconnect_req
+0x07 signal_disconnect_rsp
+0x08 signal_echo_req
+0x09 signal_echo_rsp
+0x0a signal_info_req
+0x0b signal_info_rsp
+)
+/* L2CAP signal_command_reject reason code (2 bytes), p.285 */
+(
+0x0000 cmd_not_understood
+0x0001 signalling_MTU_exceeded
+0x0002 invalid_CID_in_req
+)
+/* L2CAP PSM values used in signal_connect_req (2 bytes), p.286 */
+(
+0x0001 PSM_SDP
+0x0003 PSM_RFCOMM
+0x0005 PSM_TCS
+0x0011 PSM_HID_control
+0x0013 PSM_HID_interrupt
+0x0017 PSM_AVCTP
+0x0019 PSM_AVDTP
+)
+/* L2CAP connection response result code (2 bytes), p.288 */
+(
+0x0000 L2CAP_connect_successful
+0x0001 L2CAP_connect_pending
+0x0002 L2CAP_connect_refused_PSM_unsupported
+0x0003 L2CAP_connect_refused_security_block
+0x0004 L2CAP_connect_refused_no_resources
+)
+/* L2CAP connection status values (2 bytes), p.288 */
+(
+0x0000 L2CAP_no_info_available
+0x0001 L2CAP_authentication_pending
+0x0002 L2CAP_authorization_pending
+)
+/* L2CAP configuration response result code (2 bytes), p.292 */
+(
+0x0000 L2CAP_config_success
+0x0001 L2CAP_config_failure_bad_parameters
+0x0002 L2CAP_config_failure_no_reason
+0x0003 L2CAP_config_failure_unknown_options
+)
+/* L2CAP constant definitions */
+(
+128 L2CAP_Rx_buff_size
+48  L2CAP_signal_Tx_buff_size
+128 SDP_Tx_buff_size
+128 RFCOMM_Tx_buff_size
+1 AM_ADDRESS
+3 DM1TYPE
+4 DH1TYPE
+11 DH3TYPE
+8 DVTYPE
+0 channel_state_closed
+1 channel_state_config
+2 channel_state_open
+0x0030 L2CAP_config_MTU_SDP
+0xffff L2CAP_config_ftimeout_SDP
+0x03e3 L2CAP_config_MTU_RFCOMM
+0xffff L2CAP_config_ftimeout_RFCOMM
+260 l2cap_max_pkt_len
+)
+
+(
+0 FAILURE
+1 SUCCESS
+2 IN_PROGRESS
+)
+(
+0x00	IDLE
+0x01	WAIT_4_BB_PAGE
+0x02	WAIT_4_LMP_CONN
+0x03	WAIT_4_SCO_CONN
+0x04	WAIT_4_SCO_KILLED
+)
+
+/*mem_master_mss*/
+(
+0 STOP_ENC
+1 SEND_SWITCH_REQ
+)
+(
+0 HF_HS_READY
+1 HF_AG_READY
+)
+/* mem_hf_state */
+(
+0 HF_STATE_WAITING_RFCOMM_CONN
+1 HF_STATE_HF_SEND_FEATURE
+2 HF_STATE_WAITING_AG_FEATURE_OK
+3 HF_STATE_HF_SEND_INDICATORS
+4 HF_STATE_WAITING_AG_INDICATORS_OK
+5 HF_STATE_HF_SEND_CURR_STATUS
+6 HF_STATE_WAITING_AG_STATUS_OK
+7 HF_STATE_HF_SEND_UPDATE_STATUS
+8 HF_STATE_WAITING_AG_UPDATE_STATUS_OK
+9 HF_STATE_CONNECTED
+0x0a HF_STATE_HF_SEND_RECEIVE_INFO
+0x0b HF_STATE_WAITING_AG_INFO
+0x0c HF_STATE_HF_SEND_AT_CLIP
+0x0d HF_STATE_WAITING_AT_CLIP
+0x0e HF_STATE_HF_SEND_AT_CCWA
+0x0f HF_STATE_WAITING_AT_CCWA
+)
+/*mem_hf_call_state*/
+(
+0 HF_CALL_STATE_INACTIVE
+1 HF_CALL_STATE_SETUP
+2 HF_CALL_STATE_ACTIVE 
+)
+/* mem_pairing_state bit definition */
+(
+0 PAIR_INQUIRY_START
+1 PAIR_INQUIRY_TIME_OUT
+2 PAIR_INQUIRY_FAILED
+3 PAIR_INQUIRY_SUCCESS
+4 PAIR_READY_CONN
+5 PAIR_WAIT_CANCEL_RESPONSE
+6 PAIR_CONN_SUCCESS
+7 PAIR_WAIT_DETACH
+)  
+
+/* mem_pairing_mode bit definition */
+(
+0 FORCE_AUTHENTICATION
+)
+/* mem_hid_protecol_type */
+(
+0 PROTECOL_BOOT /*default*/
+1 PROTECOL_REPORT
+)
+
+/* mem_upper_sm_reconn */
+(
+1 UPPERSM_SEND_SDP_CONN_REQ
+2 UPPERSM_SEND_SDP_CFG_REQ
+3 UPPERSM_SEND_SDP_HF_SS
+4 UPPERSM_SEND_SDP_DISC_REQ
+5 UPPERSM_SEND_RFCOMM_CONN_REQ
+6 UPPERSM_SEND_RFCOMM_CFG_REQ
+7 UPPERSM_SEND_SABM_CMD
+8 UPPERSM_SEND_DISC
+9 UPPERSM_SEND_WAIT
+10 UPPERSM_SEND_HID_CONTROL_CONN_REQ
+11 UPPERSM_SEND_HID_CONTROL_CFG_REQ
+12 UPPERSM_SEND_HID_INTERRUPT_CONN_REQ
+13 UPPERSM_SEND_HID_INTERRUPT_CFG_REQ
+14 UPPERSM_SEND_SDP_HS_SS
+15 UPPERSM_SEND_SDP_PBAP_SS
+16 UPPERSM_SEND_SDP_AVTARG_SS
+)
+/* mem_upper_sm_remote_page */
+(
+1 UPPERSM_RP_SEND_SDP_CONN_REQ
+2 UPPERSM_RP_SEND_SDP_CFG_REQ
+3 UPPERSM_RP_SEND_SDP_HF_SS
+4 UPPERSM_RP_SEND_SDP_HS_SS
+5 UPPERSM_RP_SEND_SDP_PBAP_SS
+6 UPPERSM_RP_SEND_SDP_AVTARG_SS
+7 UPPERSM_RP_SEND_SDP_DISC_REQ
+8 UPPERSM_RP_SEND_AVCTP_CONN_REQ
+9 UPPERSM_RP_SEND_AVCTP_CFG_REQ
+)
+
+/* mem_ML2CAP_flag */
+(
+0 MSCHEDULER_HID_CONTROL_CONN_DONE
+1 MSCHEDULER_HID_INTERRUPT_CONN_DONE
+2 MSCHEDULER_HID_CONTROL_CFG_REQ_DONE
+3 MSCHEDULER_HID_CONTROL_CFG_RSP_DONE
+4 MSCHEDULER_HID_INTERRUPT_CFG_REQ_DONE
+5 MSCHEDULER_HID_INTERRUPT_CFG_RSP_DONE
+6 MSCHEDULER_HID_CONTROL_DISC_DONE
+7 MSCHEDULER_HID_INTERRUPT_DISC_DONE
+)
+/*    ui event    --add by lj*/
+(
+0x00 UI_DATA_EVNET_NONE
+0x01 UI_DATA_EVNET_HID
+0x02 UI_DATA_EVNET_AVDTP_S
+0x03 UI_DATA_EVNET_AVDTP_M
+0x04 UI_DATA_EVNET_AVCTP
+0x05 UI_DATA_EVNET_HS
+0x06 UI_DATA_EVNET_HF
+0x07 UI_DATA_EVNET_SPP
+0x08 UI_DATA_EVNET_OBEX
+)
+/*    ui ack --add by lj*/
+(
+0x00 UI_DATA_TX_NONE
+0x01 UI_DATA_TX_HID
+0x02 UI_DATA_TX_AVDTP_S
+0x03 UI_DATA_TX_AVDTP_M
+0x04 UI_DATA_TX_AVCTP
+0x05 UI_DATA_TX_HS
+0x06 UI_DATA_TX_HF
+0x07 UI_DATA_TX_SPP
+0x08 UI_DATA_TX_OBEX
+0x10 ACL_TX_L2CAP_SIGNAL
+0x11 ACL_TX_SDP
+0x12 ACL_TX_RFCOMM
+
+)
+
+(
+0 L2CAP_SDP_interface_conn
+1 L2CAP_SDP_interface_cfg
+)
+
+(                                   
+0 L2CAP_CHANNEL_STATE_CONN_REQ      
+1 L2CAP_CHANNEL_STATE_CONN_RES      
+2 L2CAP_CHANNEL_STATE_SND_CFG_REQ   
+3 L2CAP_CHANNEL_STATE_SND_CFG_RES   
+4 L2CAP_CHANNEL_STATE_RCV_CFG_REQ   
+5 L2CAP_CHANNEL_STATE_RCV_CFG_RES
+6 L2CAP_CHANNEL_RFCOMM_ONLY_SABM
+7 L2CAP_CHANNEL_RFCOMM_ONLY_UA
+6 L2CAP_CHANNEL_AVDTP_SIGNAL_INIT //set avdtp init complete
+6 L2CAP_CHANNEL_HID_HANDSHAKE_DONE
+0x3f L2CAP_CHANNEL_SETUP_COMPLETE
+0x7f L2CAP_CHANNEL_AVDTP_SIGNAL_COMPLETE
+0xff L2CAP_CHANNEL_RFCOMM_DLCI0_OPENED
+)                                     
+
+/*  AVDTP---lj*/
+(
+0 L2CAP_AVDTP_SIGNAL_CONNECT
+1 L2CAP_AVDTP_SIGNAL_CONFIG
+2 L2CAP_AVDTP_MEDIA_CONNECT
+3 L2CAP_AVDTP_MEDIA_CONFIG
+4 L2CAP_AVDTP_REPORT_CONNECT
+5 L2CAP_AVDTP_REPORT_CONFIG
+6 L2CAP_AVDTP_RECOVERY_CONNECT
+7 L2CAP_AVDTP_RECOVERY_CONFIG
+)
+/*  AVCTP---lj*/
+(
+0 L2CAP_AVCTP_SIGNAL_CONNECT
+1 L2CAP_AVCTP_SIGNAL_CONFIG
+)
+
+127 L2CAP_SIGNAL_MALLOC_SIZE
+
+//1 mem_rfcomm_malloc_fail_flag
+(
+0 RFCOMM_MALLOC_SUCCEED
+1 RFCOMM_MALLOC_FAIL
+)
+
+//mem_l2cap_flow_ctrl_flag
+(
+0 L2CAP_FLOW_CTRL_DISABLE
+1 L2CAP_FLOW_CTRL_ENABLE
+)
+
Index: btkb/format/le.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/le.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/le.format	(working copy)
@@ -0,0 +1,506 @@
+
+memalloc(
+56 mem_le_rxbuf
+
+
+/* security temp */
+4 mem_le_mic
+4 mem_le_peer_mic
+8 mem_le_skdm
+8 mem_le_skds
+16 mem_le_peer_ltk
+16 mem_le_my_ltk
+16 mem_le_mrand
+
+
+/* ========= le context =========== */
+1 mem_le_state
+1 mem_le_mode
+2 mem_le_tsniff
+4 mem_le_anchor
+6 mem_le_clk_offset
+2 mem_le_receive_window
+6 mem_le_plap
+1 mem_le_conn_handle
+1 mem_le_arq
+1 mem_le_ch
+1 mem_le_hop
+2 mem_le_event_count
+4 mem_le_supervision_timer
+2 mem_le_instant
+1 mem_le_channels
+1 mem_le_conn_sm
+1 mem_le_op
+
+	/* these 3 should NOT be seperated */
+4 mem_le_access
+3 mem_le_crcinit
+1 mem_le_window_size
+
+	/* these 3 should NOT be seperated */
+2 mem_le_slave_latency
+2 mem_le_superto
+5 mem_le_channel_map
+
+2 mem_le_no_using
+1 mem_le_peer_sca
+
+/* should be together */
+1 mem_le_att_opcode
+2 mem_le_att_handle
+
+1 mem_le_err_code
+
+16 mem_le_sk
+
+
+/* test */
+1 mem_le_testtype
+2 mem_le_test_sync
+2 mem_le_test_pcnt
+
+6 mem_le_rxon_ts
+
+1 mem_le_rx_ll_opcode
+
+2 mem_le_notify_attr_start
+1 mem_le_notify_len
+
+1 mem_cmd_le_create_conn
+20 mem_le_adv_temp
+1 mem_24g_id
+)
+
+
+xmemalloc(
+2 mem_le_dsniff
+
+// parameters
+2 mem_le_conn_interval
+1 mem_le_scan_enable
+2 mem_le_scan_interval
+2 mem_le_scan_window
+
+1 mem_le_adv_led
+1 mem_le_adv_enable
+1 mem_le_adv_data_len
+31 mem_le_adv_data
+1 mem_le_scan_data_len
+31 mem_le_scan_data
+
+//modified name
+1 mem_le_name_len
+20 mem_le_name
+
+1 mem_le_led_on_time
+//37 mem_le_chmap
+
+
+5 mem_le_new_map
+0 mem_le_new_param
+1 mem_le_new_window
+2 mem_le_new_offset
+2 mem_le_new_interval
+2 mem_le_new_latency
+2 mem_le_new_timeout
+1 mem_le_temp
+
+1 mem_le_txheader
+1 mem_le_txlen
+2 mem_le_txpayload
+2 mem_le_txcid
+1 mem_le_l2cap
+1 mem_le_l2cap_response
+31 mem_le_txbdy
+
+/* smp related */
+5 mem_le_pcnt_tx
+5 mem_le_pcnt_rx
+4 mem_le_last_mic
+4 mem_le_ivm
+4 mem_le_ivs
+16 mem_le_ltk
+1 mem_ltk_exists
+16 mem_le_rconfirm
+16 mem_le_srand
+1 mem_le_iat
+1 mem_le_rat
+7 mem_le_preq
+7 mem_le_pres
+
+/* att related */
+2 mem_le_search_handle_start
+2 mem_le_search_handle_end
+0 mem_le_att_offset
+2 mem_le_search_att_type
+2 mem_le_notify_handle
+2 mem_le_uuid
+
+1 mem_le_handle_data_len
+16 mem_le_handle_data
+
+
+//START of LE adv parameter structure
+0 mem_le_adv_param
+2 mem_le_adv_interval_min
+2 mem_le_adv_interval_max
+1 mem_le_adv_type
+1 mem_le_adv_own_addr_type
+1 mem_le_adv_direct_addr_type
+6 mem_le_adv_direct_addr
+1 mem_le_adv_channel_map
+1 mem_le_adv_filter_policy
+//END of LE adv parameter structure
+
+//START of LE conn parameter structure
+0 mem_le_conn_param
+1 mem_le_conn_peer_addr_type
+6 mem_le_conn_peer_addr
+1 mem_le_conn_own_addr_type
+2 mem_le_conn_interval_min
+2 mem_le_conn_interval_max
+2 mem_le_conn_latency
+2 mem_le_conn_superto
+//START of LE conn parameter structure
+
+//START of LE scan parameter structure
+0 mem_le_scan_params
+1 mem_le_scan_type
+1 mem_le_scan_own_addr_type
+1 mem_le_scan_filter_policy
+//END of LE scan parameter structure
+
+3 mem_le_lap
+1 mem_le_uap
+2 mem_le_nap
+5 mem_le_xtype_fifo
+
+
+//LE attribute list
+500 mem_le_att_list
+1 mem_le_switch_send_data
+4 mem_le_transmit_window
+
+)
+
+(
+20 notify_handle
+2 param_max_slaves
+1636 param_sifs
+0x000a06 param_le_version
+0x1d87 param_le_subversion
+0x000001 param_le_features
+23 param_le_mtu
+16 param_le_scan_interval
+16 param_le_scan_window
+0x1e0 param_clke_cal_le
+0x1000302 param_smp_paring_response		/* for mouse, noinputnooutput */
+0x010410 param_smp_key_dist	
+0x010010 param_smp_key_dist0
+0xa0 param_le_sca
+)
+
+(
+	0x2902  ATT_Configuration
+)
+
+/* mem_le_conn_sm */
+( 
+  0x21 CONN_SM_SEND_WRITE_REQ                      
+  0x25 CONN_SM_WAIT_WRITE_RES
+  0x26 CONN_SM_WAIT_WRITE_RES1
+) 
+/*LE MOUSE-KB*/
+(
+1 LE_CONTEXT_STATE_KB
+2 LE_CONTEXT_STATE_MOUSE
+
+3 USB_MOUSE_DATA_CMD
+
+1 SEND_MOUSE_DATA_CMD
+2 SEND_KB_DATA_CMD
+)
+
+
+  (
+  	0 LE_M_STATE_SLAVE1_STANDBY
+  	1 LE_M_STATE_SLAVE1_ADVERTISING
+  	2 LE_M_STATE_SLAVE1_SCANNING
+  	3 LE_M_STATE_SLAVE1_INITIATING
+  	4 LE_M_STATE_SLAVE1_CONNECTED
+  	5 LE_M_STATE_SLAVE1_RFU_1
+  	6 LE_M_STATE_SLAVE1_RFU_2
+  	7 LE_M_STATE_SLAVE1_RFU_3
+  )
+
+  (
+  	0 LE_M_STATE_SLAVE2_STANDBY
+  	1 LE_M_STATE_SLAVE2_ADVERTISING
+  	2 LE_M_STATE_SLAVE2_SCANNING
+  	3 LE_M_STATE_SLAVE2_INITIATING
+  	4 LE_M_STATE_SLAVE2_CONNECTED
+  	5 LE_M_STATE_SLAVE2_CONNECT_INIT
+  	6 LE_M_STATE_SLAVE2_RFU_2
+  	7 LE_M_STATE_SLAVE2_RFU_3
+  )
+
+  	(
+	0 LE_SM_IDLE
+	1 LE_SM_FBTV_1800
+	2 LE_SM_FBTV_1800_WAIT
+	3 LE_SM_RBT_DEVICE_NAME
+	4 LE_SM_RBT_DEVICE_NAME_WAIT
+	5 LE_SM_FBTV_1801
+	6 LE_SM_FBTV_1801_WAIT
+	7 LE_SM_RBT_DEVICE_CHARACTER
+	8 LE_SM_RBT_DEVICE_CHARACTER_WAIT
+	
+  	)
+
+/* advertising channel PDU type */
+(
+0 ADV_IND
+1 ADV_DIRECT_IND
+2 ADV_NONCONN_IND
+3 SCAN_REQ
+4 SCAN_RSP
+5 CONNECT_REQ
+6 ADV_SCAN_IND
+)
+
+	/* tx packet type */
+	(
+	0x20 XT_LL_CONNECTION_UPDATE_REQ
+	0x21 XT_LL_CHANNEL_MAP_REQ
+	0x22 XT_LL_TERMINATE_IND
+	0x23 XT_LL_ENC_REQ
+	0x24 XT_LL_ENC_RSP
+	0x25 XT_LL_START_ENC_REQ
+	0x26 XT_LL_START_ENC_RSP
+	0x27 XT_LL_UNKNOWN_RSP
+	0x28 XT_LL_FEATURE_REQ
+	0x29 XT_LL_FEATURE_RSP
+	0x2A XT_LL_PAUSE_ENC_REQ
+	0x2B XT_LL_PAUSE_ENC_RSP
+	0x2C XT_LL_VERSION_IND
+	0x2D XT_LL_REJECT_IND
+	0x2E XT_LL_SLAVE_FEATURE_REQ
+	0x2F XT_LL_CONNECTION_PARAM_REQ
+	0x30 XT_LL_CONNECTION_PARAM_RSP
+	0x31 XT_LL_REJECT_IND_EXT
+	0x32 XT_LL_PING_REQ
+	0x33 XT_LL_PING_RSP
+	0x41 XT_SMP_PAIRING_REQUEST
+	0x42 XT_SMP_PAIRING_RESPONSE
+	0x43 XT_SMP_PAIRING_CONFIRM
+	0x44 XT_SMP_PAIRING_RANDOM
+	0x45 XT_SMP_PAIRING_FAILED
+	0x46 XT_SMP_ENCRYPTION_INFORMATION
+	0x47 XT_SMP_MASTER_IDENTIFICATION
+	0x48 XT_SMP_IDENTITY_INFORMATION
+	0x49 XT_SMP_IDENTITY_ADDRESS_INFORMATION
+	0x4A XT_SMP_SIGNING_INFORMATION
+	0x4B XT_SMP_SECURITY_REQUEST
+	0x51 XT_L2CAP_CONN_PARAM_UPDATE_REQ
+	)
+
+
+	/* LE control packet type */
+	(
+	0x00 LL_CONNECTION_UPDATE_REQ
+	0x01 LL_CHANNEL_MAP_REQ
+	0x02 LL_TERMINATE_IND
+	0x03 LL_ENC_REQ
+	0x04 LL_ENC_RSP
+	0x05 LL_START_ENC_REQ
+	0x06 LL_START_ENC_RSP
+	0x07 LL_UNKNOWN_RSP
+	0x08 LL_FEATURE_REQ
+	0x09 LL_FEATURE_RSP
+	0x0A LL_PAUSE_ENC_REQ
+	0x0B LL_PAUSE_ENC_RSP
+	0x0C LL_VERSION_IND
+	0x0D LL_REJECT_IND
+	0x0E LL_SLAVE_FEATURE_REQ
+	0x0F LL_CONNECTION_PARAM_REQ
+	0x10 LL_CONNECTION_PARAM_RSP
+	0x11 LL_REJECT_IND_EXT
+	0x12 LL_PING_REQ
+	0x13 LL_PING_RSP
+	)
+
+	/* Security Manager Protocol Code */
+	(
+	0x01 SMP_PAIRING_REQUEST
+	0x02 SMP_PAIRING_RESPONSE
+	0x03 SMP_PAIRING_CONFIRM
+	0x04 SMP_PAIRING_RANDOM
+	0x05 SMP_PAIRING_FAILED
+	0x06 SMP_ENCRYPTION_INFORMATION
+	0x07 SMP_MASTER_IDENTIFICATION
+	0x08 SMP_IDENTITY_INFORMATION
+	0x09 SMP_IDENTITY_ADDRESS_INFORMATION
+	0x0A SMP_SIGNING_INFORMATION
+	0x0B SMP_SECURITY_REQUEST
+	)
+
+	/* ATT OPCODE */
+	(
+	0x01 ATTOP_ERROR_RESPONSE
+	0x02 ATTOP_EXCHANGE_MTU_REQUEST
+	0x03 ATTOP_EXCHANGE_MTU_RESPONSE
+	0x04 ATTOP_FIND_INFORMATION_REQUEST
+	0x05 ATTOP_FIND_INFORMATION_RESPONSE
+	0x06 ATTOP_FIND_BY_TYPE_VALUE_REQUEST
+	0x07 ATTOP_FIND_BY_TYPE_VALUE_RESPONSE
+	0x08 ATTOP_READ_BY_TYPE_REQUEST
+	0x09 ATTOP_READ_BY_TYPE_RESPONSE
+	0x0A ATTOP_READ_REQUEST
+	0x0B ATTOP_READ_RESPONSE
+	0x0C ATTOP_READ_BLOB_REQUEST
+	0x0D ATTOP_READ_BLOB_RESPONSE
+	0x0E ATTOP_READ_MULTIPLE_REQUEST
+	0x0F ATTOP_READ_MULTIPLE_RESPONSE
+	0x10 ATTOP_READ_BY_GROUP_TYPE_REQUEST
+	0x11 ATTOP_READ_BY_GROUP_TYPE_RESPONSE
+	0x12 ATTOP_WRITE_REQUEST
+	0x13 ATTOP_WRITE_RESPONSE
+	0x16 ATTOP_PREPARE_WRITE_REQUEST
+	0x17 ATTOP_PREPARE_WRITE_RESPONSE
+	0x18 ATTOP_EXECUTE_WRITE_REQUEST
+	0x19 ATTOP_EXECUTE_WRITE_RESPONSE
+	0x1B ATTOP_HANDLE_VALUE_NOTIFICATION
+	0x1D ATTOP_HANDLE_VALUE_INDICATION
+	0x1E ATTOP_HANDLE_VALUE_CONFIRMATION
+	0x52 ATTOP_WRITE_COMMAND
+	0xD2 ATTOP_SIGNED_WRITE_COMMAND
+	0x9e EMPTY_LE_DATA_PRE
+	0x9f EMPTY_LE_DATA
+	0xc1 XT_L2CAP_CMD_REJECT
+	)
+
+	/* ATT error code */
+	(
+	0x01 ATT_ERR_INVALID_HANDLE
+	0x02 ATT_ERR_READ_NOT_PERMITTED
+	0x03 ATT_ERR_WRITE_NOT_PERMITTED
+	0x04 ATT_ERR_INVALID_PDU
+	0x05 ATT_ERR_INSUFFICIENT_AUTHENTICATION
+	0x06 ATT_ERR_REQUEST_NOT_SUPPORTED
+	0x07 ATT_ERR_INVALID_OFFSET
+	0x08 ATT_ERR_INSUFFICIENT_AUTHORIZATION
+	0x09 ATT_ERR_PREPARE_QUEUE_FULL
+	0x0A ATT_ERR_ATTRIBUTE_NOT_FOUND
+	0x0B ATT_ERR_ATTRIBUTE_NOT_LONG
+	0x0C ATT_ERR_INSUFFICIENT_ENCRYPTION_KEY_SIZE
+	0x0D ATT_ERR_INVALID_ATTRIBUTE_VALUE_LENGTH
+	0x0E ATT_ERR_UNLIKELY_ERROR
+	0x0F ATT_ERR_INSUFFICIENT_ENCRYPTION
+	0x10 ATT_ERR_UNSUPPORTED_GROUP_TYPE
+	0x11 ATT_ERR_INSUFFICIENT_RESOURCES
+	)
+	/*	SERVICE UUID	*/
+	(
+	0x1800 UUID_SERVICE_GENERIC_ACC
+	0x1801 UUID_SERVICE_GENERIC_ATT
+	0x180a UUID_SERVICE_DEVICE_INFO
+	0x180f UUID_SERVICE_BATTERY
+	0x1812 UUID_SERVICE_HIDS
+	0x2800 UUID_GATT_PRIMARY_SERVICE
+	0x2801 UUID_GATT_SECONDARY_SERVICE
+	0X2802 UUID_GATT_INCLUDE
+	0X2803 UUID_GATT_CHARACTERISTIC
+	0X2902 UUID_CLIENT_CHARACTERISTIC
+	0X2A00 UUID_CHRCTR_DEVICE_NAME
+	0X2A19 UUID_CHRCTR_BATTERY_LEVEL
+	0X2A22 UUID_CHRCTR_KEYBOARD_INPUT
+	0X2A23 UUID_CHRCTR_SYSTEM_ID 
+	0X2A25 UUID_CHRCTR_SERIAL_NUMBER
+	0X2A26 UUID_CHRCTR_FIRMWARE
+	0X2A32 UUID_CHRCTR_KEYBOARD_OUTPUT
+	0X2A33 UUID_CHRCTR_MOUSE_INPUT
+	0X2A4A UUID_CHRCTR_HID_INFO
+	0X2A4B UUID_CHRCTR_REPORT_MAP
+	0X2A4C UUID_CHRCTR_HID_CTRL_POINT
+	0X2A4D UUID_CHRCTR_REPORT
+	0X2A4E UUID_CHRCTR_PROTOCOL_MODE
+	0X2A50 UUID_PNP_ID
+	)
+
+	//modified_name
+	(
+	0x14 MAX_NAME_LEN
+	0x16 ADV_DATA_NAME_LEN
+	0X20 SPACE
+	
+	)
+	/* GATT Specifications*/
+	(
+	0X2900 CHARACTERTIC_EXTENDED_PROPERTIES
+	0X2901 CHARACTERTIC_USER_DESCRIPTION
+	0X2902 CLIENT_CHARACTERTIC_CONFIGURATION
+	0X2903 SERVER_CHARACTERTIC_CONFIGURATION
+	0X2904 CHARACTERTIC_PRESENTATION_FORMAT
+	0X2905 CHARACTERTIC_AGGREGATE
+	0X2906 VALID_RANGE
+	0X2907 EXTERNAL_REPORT_REFERENCE
+	0X2908 REPORT_REFERENCE
+	0X290B ENVIR_SENSING_CONFIGURATION
+	0X290C ENVIR_SENSING_MEASUREMENT
+	0X290D ENVIR_SENSING_TRIGGER_SETTING
+	)
+	/* LE L2CAP CID */
+	(
+	0x04 LE_L2CAP_CID_ATT
+	0x05 LE_L2CAP_CID_SIGNAL
+	0x06 LE_L2CAP_CID_SMP
+	)
+
+	//LE address type
+	(
+	0 LE_ADDR_TYPE_PUBLIC
+	1 LE_ADDR_TYPE_RANDOM
+	)
+	//LE address type bitmap
+	(
+	7 LE_RECEIVER_ADDR_BIT
+	6 LE_SENDER_ADDR_BIT
+	)
+	//LE SCAN TYPE
+	(
+	0x00 LE_SCAN_TYPE_PASSIVE //no SCAN_REQ shall be sent
+	0x01 LE_SCAN_TYPE_ACTIVE
+	)
+
+	//LE SCAN ENABLE
+	(
+	0x00 LE_SCAN_DISABLE
+	0x01 LE_SCAN_ENABLE
+	0x0101 LE_ACTIVE_SCAN_ENABLE
+	)
+
+
+//	le_state_map 0-2 is reserved for state_inconn,state_insniff and state_sco
+(
+3 lestate_got_first_packet
+4 lestate_encryption
+5 lestate_update_param
+6 lestate_update_map
+7 lestate_version_ind_sent
+)
+
+// 	le mode
+(
+0 lemode_idle
+1 lemode_slave
+3 lemode_master
+)
+
+0xfeff ATT_HANDLE_SPECIAL
+
+// 	sm state
+(
+0 smstate_wait_confirm
+
+)
+
Index: btkb/format/lmp.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/lmp.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/lmp.format	(working copy)
@@ -0,0 +1,216 @@
+
+memalloc(
+
+1 mem_lmo_header_length
+1 mem_lmo_header_opcode
+17 mem_lmo_payload
+1 mem_lmi_accepted_opcode
+1 mem_disconn_reason_send
+1 mem_tx_fixed_freq
+1 mem_rx_fixed_freq
+1 mem_ext_features_page
+2 mem_lmpext_ssp_enable
+1 mem_remote_sppcap
+
+1 mem_lmp_conn_state
+2 mem_soft_timer
+1 mem_pincode_state
+
+1 mem_sres_tid
+1 mem_accptsco_tid
+
+1 mem_auth_enable
+1 mem_wait_encryption
+
+16 mem_sniff_payload
+4 mem_aurand_send_delay_time
+)
+
+xmemalloc(
+3 mem_lmp_version
+2 mem_lmp_subversion
+1 mem_local_name_length
+3 mem_local_name
+64 mem_local_name2
+1 mem_local_name_end
+1 mem_unsniff2sniff_timer
+1 mem_switch_flag
+)
+	(
+	//bit map
+	0 pair_state_inrand
+	1 pair_state_inrand_acpt
+	2 pair_state_send_comb
+	3 pair_state_recv_comb
+	4 pair_state_send_aurand
+	5 pair_state_recv_sres
+	6 pair_state_recv_aurand
+	7 pair_state_send_sres	
+	)
+	/* LMP opcodes */
+	(
+	1 LMP_NAME_REQ 
+	2 LMP_NAME_RES 
+	3 LMP_ACCEPTED 
+	4 LMP_NOT_ACCEPTED 
+	5 LMP_CLKOFFSET_REQ 
+	6 LMP_CLKOFFSET_RES 
+	7 LMP_DETACH 
+	8 LMP_IN_RAND 
+	9 LMP_COMB_KEY 
+	10 LMP_UNIT_KEY 
+	11 LMP_AU_RAND 
+	12 LMP_SRES 
+	13 LMP_TEMP_RAND 
+	14 LMP_TEMP_KEY 
+	15 LMP_ENCRYPTION_MODE_REQ 
+	16 LMP_ENCRYPTION_KEY_SIZE_REQ 
+	17 LMP_START_ENCRYPTION_REQ 
+	18 LMP_STOP_ENCRYPTION_REQ 
+	19 LMP_SWITCH_REQ 
+	20 LMP_HOLD
+	21 LMP_HOLD_REQ
+	23 LMP_SNIFF_REQ 
+	24 LMP_UNSNIFF_REQ 
+	26 LMP_PARK_REQ 
+	27 LMP_SET_BROADCAST_SCAN_WINDOW 
+	28 LMP_MODIFY_BEACON 
+	29 LMP_UNPARK_BD_ADDR_REQ 
+	30 LMP_UNPARK_PM_ADDR_REQ 
+	31 LMP_INCR_POWER_REQ 
+	32 LMP_DECR_POWER_REQ 
+	33 LMP_MAX_POWER 
+	34 LMP_MIN_POWER 
+	35 LMP_AUTO_RATE 
+	36 LMP_PREFERRED_RATE 
+	37 LMP_VERSION_REQ 
+	38 LMP_VERSION_RES 
+	39 LMP_FEATURES_REQ 
+	40 LMP_FEATURES_RES 
+	41 LMP_QUALITY_OF_SERVICE 
+	42 LMP_QUALITY_OF_SERVICE_REQ 
+	43 LMP_SCO_LINK_REQ 
+	44 LMP_REMOVE_SCO_LINK_REQ 
+	45 LMP_MAX_SLOT 
+	46 LMP_MAX_SLOT_REQ 
+	47 LMP_TIMING_ACCURACY_REQ 
+	48 LMP_TIMING_ACCURACY_RES 
+	49 LMP_SETUP_COMPLETE 
+	50 LMP_USE_SEMI_PERMANENT_KEY 
+	51 LMP_HOST_CONNECTION_REQ 
+	52 LMP_SLOT_OFFSET 
+	53 LMP_PAGE_MODE_REQ 
+	54 LMP_PAGE_SCAN_MODE_REQ 
+	55 LMP_SUPERVISION_TIMEOUT 
+	56 LMP_TEST_ACTIVATE
+	57 LMP_TEST_CONTROL
+	58 LMP_ENC_KEY_SIZE_MASK_REQ
+	59 LMP_ENC_KEY_SIZE_MASK_RES
+	60 LMP_SET_AFH
+
+	/* simple pairing support */
+	61 LMP_ENCAPSULATED_HEADER
+	62 LMP_ENCAPSULATED_PAYLOAD
+	63 LMP_SIMPLE_PAIRING_CONFIRM
+	64 LMP_SIMPLE_PAIRING_NUMBER
+	65 LMP_DHKEY_CHECK
+	127 LMP_ESCAPE
+	127 LMP_ESCAPE_4   /* add 2bytes LMP header support  */   
+	)
+	/* LMP EXT opcodes, ORed with bit 7 to make difference to nonEXT */
+	(
+	129 LMP_EXT_ACCEPTED
+	130 LMP_NOT_ACCEPTED_EXT
+	131 LMP_EXT_FEATURES_REQ
+	132 LMP_EXT_FEATURES_RES
+	139 LMP_PACKET_TYPE_TABLE_REQ
+	140 LMP_EXT_ESCO_LINK_REQ
+	141 LMP_EXT_REMOVE_ESCO_REQ
+	144 LMP_EXT_CHN_CLASSIFICATION_REQ
+	145 LMP_EXT_CHN_CLASSIFICATION
+	149 LMP_SNIFF_SUBRATING_REQ
+	150 LMP_SNIFF_SUBRATING_RES
+	151 LMP_PAUSE_ENCRYPTION_REQ
+	152 LMP_RESUME_ENCRYPTION_REQ
+	153 LMP_IO_CAP_REQ
+	154 LMP_IO_CAP_RES
+	)
+	/* LMP reason codes */
+	(
+	0x05 AUTHENTICATION_FAILURE_ERROR
+	0x06 KEY_MISSING
+	0x0b ACL_CONNECTION_ALREADY_EXISTS
+	0x13 OTHER_END_TERMINATED
+	0x15 ABOUT_TO_POEWR_OFF
+	0x16 LOCAL_HOST
+	0x18 PAIRING_NOT_ALLOWED
+	0x19 UNKNOWN_LMP_PDU
+	0x1A UNSUPPORTED_LMP_FEATURE 
+	0x1F UNSPECIFIED_ERROR
+	0x20 UNSUPPORTED_PARAMETERS
+	0x21 SWITCH_NOT_ALLOWED
+	0x23 TRANSACTION_COLLISION
+	0x24 PDU_NOT_ALLOWED
+	0x25 ENCRYPTION_MODE_NOT_ACCEPTABLE
+	0x2e NOT_SUPPORT_CHN_CLASSIFICATION
+	0x37 NOT_SUPPORT_SSP
+	)
+
+	/* test mode scenarios */
+	(
+	0 PAUSE_TEST_MODE
+	1 ZERO_PATTERN
+	2 ONE_PATTERN
+	3 ALT_PATTERN
+	4 PSEUDORANDOM
+	5 CLOSED_LOOP_BACK_ACL
+	6 CLOSED_LOOP_BACK_SCO
+	7 ACL_WITHOUT_WHITENING
+	8 SCO_WITHOUT_WHITENING
+	9 ALT2_PATTERN
+	255 EXIT_TEST_MODE
+	)
+	/* test mode hoppig modes */
+	(
+	0 FIXED_FREQ
+	1 NORMAL_HOP
+	)
+
+	/* mem_lmp_tid indicates which type of LMP will be sent */
+	(
+	0 TID_NORM_REPLY
+	1 TID_NORM_SEND
+	2 TID_ONE
+	3 TID_ZERO
+	4 TID_PAIRING
+	5 TID_ENCRYPTION
+	6 TID_VARIABLE
+	7 TID_RX
+	)
+
+	/* ============== lmp status ==========*/
+	(
+	0 lmp_incoming
+	1 lmp_outgoing
+	2 lmp_reject_msg
+	3 lmp_clear_msg
+	4 upper_reject_msg
+	5 upper_clear_msg
+	)
+
+(
+0x2ee00 TIMER_ONE_MINUTE //96000*2
+80 TIMER_SWITCH_WAITE
+12 TIMER_ENPT_WAITE
+)
+
+(
+0 SWITCH_FLAG_INIT
+1 SWITCH_FLAG_ACCEPT
+2 SWITCH_FLAG_NOT_ACCEPT
+)
+(
+0 NULL_ENCRYP
+1 DONE_ENCRYP
+)
+
Index: btkb/format/memblocks.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/memblocks.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/memblocks.format	(working copy)
@@ -0,0 +1,61 @@
+//
+//
+//Large memory blocks defined in this file.
+//Blocks Shall be defined with absolute address.
+//Blocks' length Shall be specified in comment following Blocks' names.
+//Different blocks MAY be overlap.
+//Blocks defined in this file Shall NOT be overlap with variable in memmap.format.
+
+// USB C51 exchange area
+(
+0xff0 mem_mcmd
+0xff1 mem_mouse_data
+)
+
+//l2cap RX buffers
+(
+0x1000 mem_l2cap_rxbuff1		//0x400
+0x1400 mem_l2cap_rxbuff2		//0x400
+//end address:0x17ff
+)
+//l2cap TX buffers
+(
+0x1800 mem_tx_buff0		//128
+0x1880 mem_tx_buff1		//128
+0x1900 mem_tx_buff2		//128
+0x1980 mem_tx_buff3		//128
+0x1a00 mem_tx_buff4		//128
+0x1a80 mem_tx_buff5		//128
+0x1b00 mem_tx_buff6		//128
+0x1b80 mem_tx_buff7		//128
+//end address: 0x1bff
+)
+
+//uart buffer
+(
+0x1800 mem_h5rx_buf//0x400
+0x1bff mem_h5rx_buf_end
+0x1c00 mem_h5tx_buf
+0x1fff mem_h5tx_buf_end
+)
+
+(
+0x4a00 mem_module_rx_buf//0x400
+0x4fff mem_module_rx_buf_end
+0x1c00 mem_module_tx_buf
+0x1fff mem_module_tx_buf_end
+)
+
+(
+0x1800 mem_ir_record
+0x1c      mem_ir_record_max
+)
+
+ifndef REVD 
+(
+0x4b00 memk
+)
+
+
+endif
+
Index: btkb/format/module.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/module.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/module.format	(working copy)
@@ -0,0 +1,67 @@
+memalloc(
+	2 mem_module_temp_len
+
+)
+omemalloc(	
+	1 mem_at_gpio
+	1 mem_module_wake_up_gpio
+	1 mem_module_state_gpio
+	1 mem_module_connect_state_gpio
+	6 mem_module_version
+
+	4 mem_last_uart_clock
+	2 mem_current_packet_length
+	2 mem_module_prepare_tx_len
+	1 mem_module_state
+	1 mem_module_task
+	6 mem_cmode_addr
+	2 mem_at_scan_time
+	4 mem_prarm_pswd
+	4 mem_prarm_uart
+	3 mem_prarm_blename
+	4 mem_prarm_name
+	3 mem_prarm_bleadss
+	4 mem_prarm_adss
+	4 mem_prarm_vers
+	5 mem_prarm_class
+	6 mem_prarm_clrflg
+	6 mem_prarm_reconn
+	2 mem_prarm_bledis
+	3 mem_prarm_dis
+	4 mem_prarm_stsn
+	3 mem_prarm_atp
+	4 mem_prarm_list
+	4 mem_prarm_role
+	5 mem_prarm_sniff
+	4 mem_prarm_ldev
+	4 mem_prarm_rssi
+	4 mem_prarm_cdev
+	3 mem_prarm_bleinqr
+	4 mem_prarm_inqr
+	5 mem_prarm_cmode
+	4 mem_prarm_mode	
+	7 mem_prarm_dmstate
+	6 mem_prarm_discov
+	3 mem_prarm_ota
+	2 mem_prarm_bleconn
+	4 mem_prarm_conn
+	7 mem_prarm_pageout
+	7 mem_prarm_recfail
+
+
+
+	//2 mem_rx_count
+	300 mem_module_uuid_list
+	
+)
+	(
+		110  DM_REFCOM_BUFF_LEN
+		20 DM_LE_BUFF_LEN
+	)
+	(
+		0x200 UART_AIR_CONTROL_THRESHOLD
+		0x150 UART_RX_CONTROL_THRESHOLD
+	)
+
+
+
Index: btkb/format/mouse.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/mouse.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/mouse.format	(working copy)
@@ -0,0 +1,236 @@
+
+memalloc(
+2 mem_init_cnt
+)
+//dpi eeprom addr
+(
+198 mouse_dpi_eeprom_addr
+)
+(
+199 mouse_last_device
+)
+omemalloc(
+// Mouse Work Area
+2 mem_mouse_x
+2 mem_mouse_y
+1 mem_mouse_z
+1 mem_mouse_key
+1 mem_mouse_z_last
+1 mem_mouse_z_before
+1 mem_mouse_z_now
+1 mem_mouse_z_data
+1 mem_mouse_move_flag
+1 mem_reconnect_timeout
+2 mem_mouse_direct_timeout
+2 mem_mouse_no_data_timeout
+2 mem_mouse_blank_data_timeout
+2 mem_mouse_discovery_timer
+2 mem_mouse_direct_timer
+2 mem_mouse_no_data_timer
+2 mem_mouse_blank_data_timer
+1 mem_mouse_send_blank_timer
+1 mem_mouse_dpi
+1 mem_mouse_dpi_button_state
+1 mem_mouse_test_cnt
+2 mem_le_hibernate_timer
+1 mem_mouse_mode_state
+
+// Mouse Config Area
+1 mem_sensor_type
+1 mem_lbutton_gpio
+1 mem_rbutton_gpio
+1 mem_mbutton_gpio
+1 mem_dpi_button_gpio
+1 mem_sensor_data_gpio
+1 mem_whee_a_data_gpio
+1 mem_whee_b_data_gpio
+1 mem_conn_cnt
+650 mem_mouse_uuid_list
+
+
+)
+
+//Mouse sensor ID1
+(
+0x30 P3204_ID
+0x31 P3065_ID
+)
+//Mouse sensor ID2
+(
+0x00 P3212_ID2
+0x70 P3065_ID2
+)
+
+//Mouse Button
+(
+0x01 MOUSE_BUTTON_L
+0x02 MOUSE_BUTTON_R
+0x03 MOUSE_BUTTON_LR
+0x04 MOUSE_BUTTON_M
+0x05 MOUSE_BUTTON_LM
+0x06 MOUSE_BUTTON_RM
+0x07 MOUSE_BUTTON_LRM
+)
+
+//mem_24g_rx_packet_flag
+(
+0 FLAG_24G_NOT_RX_PACKET
+1 FLAG_24G_RX_PACKET
+)
+
+//mem_24g_mode
+(
+0 MODE_24G_OFF
+1 MODE_24G_TX
+2 MODE_24G_RX
+3 MODE_24G_PAIRING
+
+)
+// device_led_gpio
+(
+0X05 DEVICE1_LED_GPIO
+0X08 DEVICE2_LED_GPIO
+0X01 DEVICE3_LED_GPIO
+)
+
+//bt mode device number
+(
+0X01 MODE_BT_DEVICE1
+0X02 MODE_BT_DEVICE2
+0X03 MODE_BT_DEVICE3
+0X04 MODE_24G_DEVICE
+)
+
+//mem_24g_pairing_sm
+(
+0 STATE_24G_PAIRING_NULL
+1 STATE_24G_PAIRING_1
+2 STATE_24G_PAIRING_2
+3 STATE_24G_PAIRING_3
+0X11 STATE_24G_PAIRING_1_WAITING_ACK
+0X12 STATE_24G_PAIRING_2_WAITING_ACK
+0X13 STATE_24G_PAIRING_3_WAITING_ACK
+0XFF STATE_24G_PAIRING_SUCCESS
+)
+
+
+//mem_mouse_find_type_value_flag
+(
+0X00 LE_FIND_TYPE_VALUE_HID_BIT
+0X01 LE_FIND_TYPE_VALUE_BATTERY_BIT
+0X02 LE_FIND_TYPE_VALUE_DEVICE_INFO_BIT
+0x03 LE_FIND_TYPE_VALUE_GATT_BIT
+
+)
+
+(
+1 MOUSE_SHUTDOWN
+
+)
+//mem_mouse_flag
+(
+0 MOUSE_CPI_FLAG
+1 MOUSE_SELECT_RECONN_FLAG
+2 MOUSE_CANCEL_RECONN_FLAG
+3 MOUSE_SELECT_BUTTON_CANCEL_RECONN_FLAG
+4 MOUSE_BLE_RECON_FLAG
+)
+
+(
+194 MOUSE_SHUTDOWN_FLAG
+)
+(
+0x00 DPI_BUTTON_STATE_DOWN
+0x01 DPI_BUTTON_STATE_UP
+
+)
+(
+  0x8971 rf_adc_mode
+  0x8972 rf_adc_gc
+  0x8973 rf_adc_ch
+)
+(
+2 MOUSE_ADC_GC
+)
+
+(
+1 ONE_TRADITION_MOUSE
+2 ONE_BLE_MOUSE
+)
+
+
+(
+1 SENSOR_TYPE_A7530
+2 SENSOR_TYPE_P3204
+3 SENSOR_TYPE_P3610
+)
+0x00 PAN_REG_PID_L
+0x01 PAN_REG_PID_H
+0x02 PAN_REG_MOTION_STAUS
+0x03 PAN_REG_DELTA_X
+0x04 PAN_REG_DELTA_Y
+0x05 PAN_REG_OPRATION_MODE
+0x06 PAN_REG_CONFIG
+0x07 PAN_REG_IMAGE_QUALITY
+0x08 PAN_REG_OPRATION_STATE
+0x09 PAN_REG_WRITE_PROTECT
+0x0A PAN_REG_SLEEP_1
+0x0B PAN_REG_ENTER_TIME
+0x0C PAN_REG_SLEEP_2
+0x0D PAN_REG_IMAGE_THRESHOLD
+0x0E PAN_REG_IMAGE_RECGNITION
+
+7 pan_bit_motion
+
+(
+1000 MOUSE_LPM_CLR_LOCK_TIME
+0x06 MOUSE_DPI_ADDRESS
+0x05 MOUSE_P3610_DPI_REG
+0x02 MOUSE_DPI_MAX_DECR
+)
+(
+80 MOUSE_SEND_BLANK_TIMER
+)
+
+
+//mem_mouse_mode_state
+(
+0x00 MOUSE_MODE_STATE_IDLE
+0x01 MOUSE_MODE_STATE_BT
+0x02 MOUSE_MODE_STATE_BLE
+)
+//ui led blink
+(
+200 FLAG_LED_RECONNECT_BLINK
+1000 FLAG_LED_BLINK_DISCOVERY
+)
+//rf param
+(
+0xFF RF_2M_IF 
+0x7F RF_1M_IF
+0x00 RF_0M_IF
+)
+(
+0 FLAG_ADC_CHANNEL1_GPIO5
+10 FLAG_MOUSE_CHECK_VDD_COUNT
+1 FLAG_VDD_LOW
+0 FLAG_VDD_NOT_LOW
+
+191 EEPROM_ADDR_VDD_FLAG
+193 EEPROM_ADDR_VDD_LOW_FLAG
+)
+
+//sniff param
+(
+0x000c   SNIFF_INTERVAL_7500US
+0x000e   SNIFF_INTERVAL_8750US
+0x0010	SNIFF_INTERVAL_10MS
+)
+
+//low vdd
+(
+33 FLAG_LOW_VDD_MULTIPLIER
+31 FLAG_LOW_VDD_DIVISOR
+)
+
+
Index: btkb/format/patch.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/patch.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/patch.format	(working copy)
@@ -0,0 +1,523 @@
+
+(
+	  0 patch00_0
+	  1 patch00_1
+	  2 patch00_2
+	  3 patch00_3
+	  4 patch00_4
+	  5 patch00_5
+	  6 patch00_6
+	  7 patch00_7
+	  8 patch01_0
+	  9 patch01_1
+	 10 patch01_2
+	 11 patch01_3
+	 12 patch01_4
+	 13 patch01_5
+	 14 patch01_6
+	 15 patch01_7
+	 16 patch02_0
+	 17 patch02_1
+	 18 patch02_2
+	 19 patch02_3
+	 20 patch02_4
+	 21 patch02_5
+	 22 patch02_6
+	 23 patch02_7
+	 24 patch03_0
+	 25 patch03_1
+	 26 patch03_2
+	 27 patch03_3
+	 28 patch03_4
+	 29 patch03_5
+	 30 patch03_6
+	 31 patch03_7
+	 32 patch04_0
+	 33 patch04_1
+	 34 patch04_2
+	 35 patch04_3
+	 36 patch04_4
+	 37 patch04_5
+	 38 patch04_6
+	 39 patch04_7
+	 40 patch05_0
+	 41 patch05_1
+	 42 patch05_2
+	 43 patch05_3
+	 44 patch05_4
+	 45 patch05_5
+	 46 patch05_6
+	 47 patch05_7
+	 48 patch06_0
+	 49 patch06_1
+	 50 patch06_2
+	 51 patch06_3
+	 52 patch06_4
+	 53 patch06_5
+	 54 patch06_6
+	 55 patch06_7
+	 56 patch07_0
+	 57 patch07_1
+	 58 patch07_2
+	 59 patch07_3
+	 60 patch07_4
+	 61 patch07_5
+	 62 patch07_6
+	 63 patch07_7
+	 64 patch08_0
+	 65 patch08_1
+	 66 patch08_2
+	 67 patch08_3
+	 68 patch08_4
+	 69 patch08_5
+	 70 patch08_6
+	 71 patch08_7
+	 72 patch09_0
+	 73 patch09_1
+	 74 patch09_2
+	 75 patch09_3
+	 76 patch09_4
+	 77 patch09_5
+	 78 patch09_6
+	 79 patch09_7
+	 80 patch0a_0
+	 81 patch0a_1
+	 82 patch0a_2
+	 83 patch0a_3
+	 84 patch0a_4
+	 85 patch0a_5
+	 86 patch0a_6
+	 87 patch0a_7
+	 88 patch0b_0
+	 89 patch0b_1
+	 90 patch0b_2
+	 91 patch0b_3
+	 92 patch0b_4
+	 93 patch0b_5
+	 94 patch0b_6
+	 95 patch0b_7
+	 96 patch0c_0
+	 97 patch0c_1
+	 98 patch0c_2
+	 99 patch0c_3
+	100 patch0c_4
+	101 patch0c_5
+	102 patch0c_6
+	103 patch0c_7
+	104 patch0d_0
+	105 patch0d_1
+	106 patch0d_2
+	107 patch0d_3
+	108 patch0d_4
+	109 patch0d_5
+	110 patch0d_6
+	111 patch0d_7
+	112 patch0e_0
+	113 patch0e_1
+	114 patch0e_2
+	115 patch0e_3
+	116 patch0e_4
+	117 patch0e_5
+	118 patch0e_6
+	119 patch0e_7
+	120 patch0f_0
+	121 patch0f_1
+	122 patch0f_2
+	123 patch0f_3
+	124 patch0f_4
+	125 patch0f_5
+	126 patch0f_6
+	127 patch0f_7
+	128 patch10_0
+	129 patch10_1
+	130 patch10_2
+	131 patch10_3
+	132 patch10_4
+	133 patch10_5
+	134 patch10_6
+	135 patch10_7
+	136 patch11_0
+	137 patch11_1
+	138 patch11_2
+	139 patch11_3
+	140 patch11_4
+	141 patch11_5
+	142 patch11_6
+	143 patch11_7
+	144 patch12_0
+	145 patch12_1
+	146 patch12_2
+	147 patch12_3
+	148 patch12_4
+	149 patch12_5
+	150 patch12_6
+	151 patch12_7
+	152 patch13_0
+	153 patch13_1
+	154 patch13_2
+	155 patch13_3
+	156 patch13_4
+	157 patch13_5
+	158 patch13_6
+	159 patch13_7
+	160 patch14_0
+	161 patch14_1
+	162 patch14_2
+	163 patch14_3
+	164 patch14_4
+	165 patch14_5
+	166 patch14_6
+	167 patch14_7
+	168 patch15_0
+	169 patch15_1
+	170 patch15_2
+	171 patch15_3
+	172 patch15_4
+	173 patch15_5
+	174 patch15_6
+	175 patch15_7
+	176 patch16_0
+	177 patch16_1
+	178 patch16_2
+	179 patch16_3
+	180 patch16_4
+	181 patch16_5
+	182 patch16_6
+	183 patch16_7
+	184 patch17_0
+	185 patch17_1
+	186 patch17_2
+	187 patch17_3
+	188 patch17_4
+	189 patch17_5
+	190 patch17_6
+	191 patch17_7
+	192 patch18_0
+	193 patch18_1
+	194 patch18_2
+	195 patch18_3
+	196 patch18_4
+	197 patch18_5
+	198 patch18_6
+	199 patch18_7
+	200 patch19_0
+	201 patch19_1
+	202 patch19_2
+	203 patch19_3
+	204 patch19_4
+	205 patch19_5
+	206 patch19_6
+	207 patch19_7
+	208 patch1a_0
+	209 patch1a_1
+	210 patch1a_2
+	211 patch1a_3
+	212 patch1a_4
+	213 patch1a_5
+	214 patch1a_6
+	215 patch1a_7
+	216 patch1b_0
+	217 patch1b_1
+	218 patch1b_2
+	219 patch1b_3
+	220 patch1b_4
+	221 patch1b_5
+	222 patch1b_6
+	223 patch1b_7
+	224 patch1c_0
+	225 patch1c_1
+	226 patch1c_2
+	227 patch1c_3
+	228 patch1c_4
+	229 patch1c_5
+	230 patch1c_6
+	231 patch1c_7
+	232 patch1d_0
+	233 patch1d_1
+	234 patch1d_2
+	235 patch1d_3
+	236 patch1d_4
+	237 patch1d_5
+	238 patch1d_6
+	239 patch1d_7
+	240 patch1e_0
+	241 patch1e_1
+	242 patch1e_2
+	243 patch1e_3
+	244 patch1e_4
+	245 patch1e_5
+	246 patch1e_6
+	247 patch1e_7
+	248 patch1f_0
+	249 patch1f_1
+	250 patch1f_2
+	251 patch1f_3
+	252 patch1f_4
+	253 patch1f_5
+	254 patch1f_6
+	255 patch1f_7
+	  0 patch20_0
+	  1 patch20_1
+	  2 patch20_2
+	  3 patch20_3
+	  4 patch20_4
+	  5 patch20_5
+	  6 patch20_6
+	  7 patch20_7
+	  8 patch21_0
+	  9 patch21_1
+	 10 patch21_2
+	 11 patch21_3
+	 12 patch21_4
+	 13 patch21_5
+	 14 patch21_6
+	 15 patch21_7
+	 16 patch22_0
+	 17 patch22_1
+	 18 patch22_2
+	 19 patch22_3
+	 20 patch22_4
+	 21 patch22_5
+	 22 patch22_6
+	 23 patch22_7
+	 24 patch23_0
+	 25 patch23_1
+	 26 patch23_2
+	 27 patch23_3
+	 28 patch23_4
+	 29 patch23_5
+	 30 patch23_6
+	 31 patch23_7
+	 32 patch24_0
+	 33 patch24_1
+	 34 patch24_2
+	 35 patch24_3
+	 36 patch24_4
+	 37 patch24_5
+	 38 patch24_6
+	 39 patch24_7
+	 40 patch25_0
+	 41 patch25_1
+	 42 patch25_2
+	 43 patch25_3
+	 44 patch25_4
+	 45 patch25_5
+	 46 patch25_6
+	 47 patch25_7
+	 48 patch26_0
+	 49 patch26_1
+	 50 patch26_2
+	 51 patch26_3
+	 52 patch26_4
+	 53 patch26_5
+	 54 patch26_6
+	 55 patch26_7
+	 56 patch27_0
+	 57 patch27_1
+	 58 patch27_2
+	 59 patch27_3
+	 60 patch27_4
+	 61 patch27_5
+	 62 patch27_6
+	 63 patch27_7
+	 64 patch28_0
+	 65 patch28_1
+	 66 patch28_2
+	 67 patch28_3
+	 68 patch28_4
+	 69 patch28_5
+	 70 patch28_6
+	 71 patch28_7
+	 72 patch29_0
+	 73 patch29_1
+	 74 patch29_2
+	 75 patch29_3
+	 76 patch29_4
+	 77 patch29_5
+	 78 patch29_6
+	 79 patch29_7
+	 80 patch2a_0
+	 81 patch2a_1
+	 82 patch2a_2
+	 83 patch2a_3
+	 84 patch2a_4
+	 85 patch2a_5
+	 86 patch2a_6
+	 87 patch2a_7
+	 88 patch2b_0
+	 89 patch2b_1
+	 90 patch2b_2
+	 91 patch2b_3
+	 92 patch2b_4
+	 93 patch2b_5
+	 94 patch2b_6
+	 95 patch2b_7
+	 96 patch2c_0
+	 97 patch2c_1
+	 98 patch2c_2
+	 99 patch2c_3
+	100 patch2c_4
+	101 patch2c_5
+	102 patch2c_6
+	103 patch2c_7
+	104 patch2d_0
+	105 patch2d_1
+	106 patch2d_2
+	107 patch2d_3
+	108 patch2d_4
+	109 patch2d_5
+	110 patch2d_6
+	111 patch2d_7
+	112 patch2e_0
+	113 patch2e_1
+	114 patch2e_2
+	115 patch2e_3
+	116 patch2e_4
+	117 patch2e_5
+	118 patch2e_6
+	119 patch2e_7
+	120 patch2f_0
+	121 patch2f_1
+	122 patch2f_2
+	123 patch2f_3
+	124 patch2f_4
+	125 patch2f_5
+	126 patch2f_6
+	127 patch2f_7
+	128 patch30_0
+	129 patch30_1
+	130 patch30_2
+	131 patch30_3
+	132 patch30_4
+	133 patch30_5
+	134 patch30_6
+	135 patch30_7
+	136 patch31_0
+	137 patch31_1
+	138 patch31_2
+	139 patch31_3
+	140 patch31_4
+	141 patch31_5
+	142 patch31_6
+	143 patch31_7
+	144 patch32_0
+	145 patch32_1
+	146 patch32_2
+	147 patch32_3
+	148 patch32_4
+	149 patch32_5
+	150 patch32_6
+	151 patch32_7
+	152 patch33_0
+	153 patch33_1
+	154 patch33_2
+	155 patch33_3
+	156 patch33_4
+	157 patch33_5
+	158 patch33_6
+	159 patch33_7
+	160 patch34_0
+	161 patch34_1
+	162 patch34_2
+	163 patch34_3
+	164 patch34_4
+	165 patch34_5
+	166 patch34_6
+	167 patch34_7
+	168 patch35_0
+	169 patch35_1
+	170 patch35_2
+	171 patch35_3
+	172 patch35_4
+	173 patch35_5
+	174 patch35_6
+	175 patch35_7
+	176 patch36_0
+	177 patch36_1
+	178 patch36_2
+	179 patch36_3
+	180 patch36_4
+	181 patch36_5
+	182 patch36_6
+	183 patch36_7
+	184 patch37_0
+	185 patch37_1
+	186 patch37_2
+	187 patch37_3
+	188 patch37_4
+	189 patch37_5
+	190 patch37_6
+	191 patch37_7
+	192 patch38_0
+	193 patch38_1
+	194 patch38_2
+	195 patch38_3
+	196 patch38_4
+	197 patch38_5
+	198 patch38_6
+	199 patch38_7
+	200 patch39_0
+	201 patch39_1
+	202 patch39_2
+	203 patch39_3
+	204 patch39_4
+	205 patch39_5
+	206 patch39_6
+	207 patch39_7
+	208 patch3a_0
+	209 patch3a_1
+	210 patch3a_2
+	211 patch3a_3
+	212 patch3a_4
+	213 patch3a_5
+	214 patch3a_6
+	215 patch3a_7
+	216 patch3b_0
+	217 patch3b_1
+	218 patch3b_2
+	219 patch3b_3
+	220 patch3b_4
+	221 patch3b_5
+	222 patch3b_6
+	223 patch3b_7
+	224 patch3c_0
+	225 patch3c_1
+	226 patch3c_2
+	227 patch3c_3
+	228 patch3c_4
+	229 patch3c_5
+	230 patch3c_6
+	231 patch3c_7
+	232 patch3d_0
+	233 patch3d_1
+	234 patch3d_2
+	235 patch3d_3
+	236 patch3d_4
+	237 patch3d_5
+	238 patch3d_6
+	239 patch3d_7
+	240 patch3e_0
+	241 patch3e_1
+	242 patch3e_2
+	243 patch3e_3
+	244 patch3e_4
+	245 patch3e_5
+	246 patch3e_6
+	247 patch3e_7
+	248 patch3f_0
+	249 patch3f_1
+	250 patch3f_2
+	251 patch3f_3
+	252 patch3f_4
+	253 patch3f_5
+	254 patch3f_6
+	255 patch3f_7
+
+)
+//ota
+(
+0x80 cmd_read_eep
+0x81 cmd_write_eep
+0x82 cmd_crc_eep
+0x83 cmd_size_eep
+)
Index: btkb/format/prcp.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/prcp.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/prcp.format	(working copy)
@@ -0,0 +1,45 @@
+
+//prcp opcode
+(
+
+0x00 COMMON_RES
+0x01 READ_REGISTERS_REQ
+0x02 READ_REGISTERS_RES
+0x03 WRITE_REGISTERS_REQ
+0x04 I2C_CONFIG_REQ
+0x05 I2C_READ_REQ
+0x06 I2C_READ_RES
+0x07 I2C_WRITE_REQ
+0x08 SPI_CONFIG_REQ
+0x09 SPI_READ_REQ
+0x0a SPI_READ_RES
+0x0b SPI_WRITE_REQ
+0x0c PWM_CONFIG_REQ
+0x0d PWM_WRITE_REQ
+0x0e GPIO_CONFIG_REQ
+0x0f GPIO_READ_REQ
+0x10 GPIO_READ_RES
+0x11 GPIO_WRITE_REQ
+0x12 OTA_WRITE_REQ
+0X13 OTA_END_CMD
+
+)
+(
+1 PRCP_LE
+2 PRCP_SSP
+0x14 PRCP_TX_LE 
+0x17 PRCP_RX_LE
+20 PRCP_TX_DATA_LEN
+)
+memalloc(
+20 mem_prcp_data
+1 mem_prcp
+1 mem_prcp_tx_len
+//ota
+2 rx_buf_data_ptr
+)
+xmemalloc(
+//ota
+2 mem_eeprom_ota_base_addr  /*the start- writing addr in eeprom  */
+)
+
Index: btkb/format/regs.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/regs.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/regs.format	(working copy)
@@ -0,0 +1,291 @@
+(
+  0x8000 core_chipid
+  0x8003 core_kick
+  0x8005 core_lpm_wr
+  0x8006 core_misc_ctrl
+  0x8007 core_otp_rdata
+  0x8009 core_pcmoutfifo
+  0x8010 core_reset
+  0x8011 core_encrypt
+  0x8015 core_uart_txd
+  0x8022 core_ucode_hi
+  0x8023 core_ucode_ctrl
+  0x8024 core_ucode_low
+  0x8025 core_ucode_data
+  0x8040 core_halfslot
+  0x8042 core_clksel
+  0x8043 core_uart_clksel
+  0x8043 core_config 
+  0x8044 core_xtal_stable_time
+  0x8045 core_otp_addr
+  0x8046 core_otp_din
+  0x8047 core_otp_ctrl
+  0x8048 core_otpd_addr
+  0x804a core_otpd_len
+  0x804b core_otpd_ctrl
+  0x804c core_lpm_reg
+  0x804f core_lpm_isogate
+  0x8050 core_clkoff
+  0x8052 core_uart_baud
+  0x8054 core_uart_rsaddr
+  0x8056 core_uart_readdr
+  0x8058 core_uart_rrptr
+  0x805a core_uart_tsaddr
+  0x805c core_uart_teaddr
+  0x805e core_uart_twptr
+  0x8060 core_uart_trptrp
+  0x8062 core_uart_ctrl
+  0x8063 core_kscn_ksctrl
+  0x8064 core_kscn_rctc
+  0x8065 core_kscn_scancycle_timer_l
+  0x8066 core_kscn_scancycle_timer_h
+  0x8067 core_kscn_m_debounce          
+  0x8068 core_kscn_modkey
+  0x806f core_kscn_rowmask
+  0x8070 core_gpio_oe0
+  0x8071 core_gpio_oe1
+  0x8072 core_gpio_oe2
+  0x8073 core_gpio_oe3
+  0x8074 core_gpio_out0
+  0x8075 core_gpio_out1
+  0x8076 core_gpio_out2
+  0x8077 core_gpio_out3
+  0x8078 core_gpio_pu0
+  0x8079 core_gpio_pu1
+  0x807a core_gpio_pu2
+  0x807b core_gpio_pu3
+  0x807c core_gpio_pd0
+  0x807d core_gpio_pd1
+  0x807e core_gpio_pd2
+  0x807f core_gpio_pd3
+  0x8080 core_gpio_sel
+  0x8081 core_gpio_sel1
+  0x8082 core_gpio_sel2
+  0x8083 core_gpio_key0
+  0x8084 core_gpio_key1
+  0x8085 core_gpio_key2
+  0x8086 core_spid_ctrl
+  0x8087 core_spid_delay
+  0x8088 core_spid_txlen
+  0x808a core_spid_txaddr
+  0x808c core_spid_rxaddr
+  0x808e core_spid_rxlen
+  0x8090 core_iicd_ctrl
+  0x8091 core_iicd_scl_low
+  0x8092 core_iicd_scl_high
+  0x8093 core_iicd_start_setup
+  0x8094 core_iicd_start_hold
+  0x8095 core_iicd_stop_setup
+  0x8096 core_iicd_data_setup
+  0x8097 core_iicd_data_hold
+  0x8098 core_iicd_txlen
+  0x809a core_iicd_txaddr
+  0x809c core_iicd_rxaddr
+  0x809e core_iicd_rxlen
+  0x80a0 core_pwm_pcnt0
+  0x80a2 core_pwm_ncnt0
+  0x80a4 core_pwm_pcnt1
+  0x80a6 core_pwm_ncnt1
+  0x80b0 core_enc_ctrl
+  0x80b1 core_cvsd_ctrl
+  0x80b2 core_codec_ctrl
+  0x80b3 core_dec_ctrl
+  0x80b4 core_bist_ctrl
+
+
+
+  
+  0x8108 core_misc_status
+  0x8109 core_qdec_cntx
+  0x810a core_qdec_cnty
+  0x810b core_qdec_cntz
+  0x810c core_uart_status
+  0x810d core_uart_rbaud
+  0x810e core_uart_txitems
+  0x8110 core_uart_trptr
+  0x8112 core_uart_rxitems
+  0x8114 core_uart_rdptr
+  0x8116 core_uart_rwptr
+  0x8119 core_kscn_kstat
+  0x811a core_kscn_event
+  0x811b core_kscn_event_num
+  0x811c core_gpio_in
+  0x811d core_gpio_in1
+  0x8124 core_current_otp_addr
+  0x8126 core_otpd_remain
+  0x8128 core_spid_remain
+  0x812a core_iicd_remain
+  0x812c core_dma_status
+  0x812d core_perf_status
+  0x812e core_adc_in
+  0x8134 core_pcminfifo
+  0x8135 core_pcminfifo_remain
+  0x8136 core_pcmoutfifo_remain
+  0x8138 core_lpm_ctrl
+  0x813c core_lpm_xtalcnt
+  0x813d core_lpm_buckcnt
+  0x813e core_lpm_ldocnt
+  0x813f core_lpm_latch
+  0x8140 core_gpio_wakeup_low
+  0x8144 core_gpio_wakeup_high
+  0x8149 core_clk_counter
+  0x8150 core_adc_sum
+// dummy regs  
+
+  0x8203 core_ice_ctrl
+  0x8204 core_ice_status
+  0x8205 core_ice_break0
+  0x8207 core_ice_break1
+  
+  0x8280 core_docd_ctrl
+  0x8288 core_docd_paddr
+  0x828a core_docd_pdata
+
+  0x8300 iic_prer_low		
+  0x8301 iic_slave_addr	
+  0x8302 iic_ctr					
+  0x8303 iic_cr					
+  0x8304 iic_rxr					
+  0x8305 iic_txr					
+  0x8306 iic_sr					
+  0x8307 iic_fifo				
+
+  0x8400   mem_b_box          /* entire bank */
+  0x8500   mem_e_box          /* entire bank */
+  0x8600   mem_l_box          /* entire bank */
+
+ifdef REVD
+  0x8700 memk
+endif
+
+  0x8900 rfen_rx
+  0x8901 rfen_tx
+  0x8902 rfen_mdm
+  0x8903 rfen_sn
+  0x8904 rfen_msc
+  0x8905 rfen_ck
+  0x8906 rfen_adc
+  0x8907 rfen_mod
+  0x8912 rf_agc_ctrl
+  0x8914 rfen_ulp
+
+  0x894b rf_rx_vctrl_reg1
+  0x894c rf_rx_vctrl_reg2
+  0x894d rf_rx_lna_ctrim
+
+  0x8950 rf_bpf_ctrim
+  0x8951 rf_bpf_ib
+  0x8952 rf_adc_rccal
+  0x8952 rf_rccal_ctrl
+  0x8953 rf_rccal_sel
+  0x8955 rf_tx_pa
+  0x895f rf_pll_rstn
+  0x8964 rf_sdm_en
+  0x8960 rf_pll_intg
+  0x8961 rf_pll_frac
+  0x8963 rf_pll_frachi
+  0x896c rf_afc_cap
+  0x8967 rf_clkpll_bias
+  0x896f rf_clkpll_en
+  0x8968 rf_clkpll_int
+  0x8969 rf_clkpll_frac
+  0x896d rf_balun_ctrim
+  0x8972 rf_saradc_ctrl
+  0x8973 rfen_chgpump
+  0x8980 rf_rccal_result
+  0x8981 rf_afc_d2a
+  0x8982 rf_rssi
+
+
+0x8c00 core_usb_config		
+0x8c01 core_usb_int_mask	
+0x8c10 core_usb_trig	
+0x8c11 core_usb_stall		
+0x8c12 core_usb_clear		
+0x8c18 core_usb_ep
+0x8c18 core_usb_dfifo0 
+0x8c19 core_usb_dfifo1  
+0x8c1a core_usb_dfifo2 
+0x8c20 core_usb_ep_len
+0x8c26 core_usb_status		
+0x8c27 core_usb_fifo_empty
+0x8c28 core_usb_fifo_full
+
+
+ifdef FPGA
+0 rx_freq_offset
+else
+4 rx_freq_offset
+endif
+2 tx_freq_offset
+
+/* bit difinitions */
+  4 whiteoff_bit
+  6 clksel_rc
+  5 clksel_dpll
+  4 clksel_xtal
+  5 adc_rccal
+  0 bpf_rccal
+  1 demod_clkoff
+
+(
+  7 cold_wake
+  3 gpio_latch
+  4 enable_retmem
+  0xef isogate_mask
+  0xe0 cs_mask
+)
+
+// misc ctrl
+(
+  0x01 otpd_start
+  0x02 spid_start
+  0x04 iicd_start
+  0x08 lock_otp
+  0x10 x_sethi
+  0x20 y_sethi
+  0x40 z_sethi
+  0x80 ccnt_start
+)
+// dma status bit
+(
+  0 otpd_crcok
+  1 otpd_done
+  2 spid_crcok
+  3 spid_done
+  4 iicd_crcok
+  5 iicd_done
+)
+
+0x8b uart_ctrl_default //BCSP
+0x81 uart_ctrl_h4 //H4
+0x81 uart_ctrl_normal
+0x81 uart_ctrl_57600
+2 uart_baud_len
+0x01 uartclk_dpll
+0x1a0 uart_baud_115200
+0xbb uart_baud_256000
+0x340 uart_baud_57600
+0x2dc6c00 uart_clk
+
+//core_clkoff
+(
+	0 CLOCK_OFF_AUTH_ROM
+	1 CLOCK_OFF_UC_ROM
+	2 CLOCK_OFF_DEBUG_UART
+	3 CLOCK_OFF_SCHED_RAM
+	4 CLOCK_OFF_TRANCE_FIFO
+	5 CLOCK_OFF_CORDIC
+	6 CLOCK_OFF_OTPD
+	7 CLOCK_OFF_I2C
+	8 CLICK_OFF_8051
+	9 CLOCK_OFF_KEYSCAN
+	0x0a CLOCK_OFF_USB
+	0x0b CLOCK_OFF_QDECODER
+	0x0c CLOCK_OFF_SPI
+	0x0d CLOCK_OFF_PWM
+	0x0e CLOCK_OFF_CODEC
+	0x0f CLOCK_OFF_UART
+)
+
+
Index: btkb/format/rfcomm.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/rfcomm.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/rfcomm.format	(working copy)
@@ -0,0 +1,375 @@
+/*****************************************************************************/
+/* RCS HEADER -- DO NOT ERASE                                                */
+/* $Author: Administrator $                                                           */
+/* $Id: bt_rfcomm_format.upper,v 1.1 2009-09-28 04:06:17 Administrator Exp $ */
+/* Orisil Technology                                                      */
+/*****************************************************************************/
+
+/**********/
+/* memory */
+/**********/
+
+memalloc(
+1 memRemoteRPNBitRate
+1 memRemotePRNDataBits
+1 memRemotePRNStopBit
+1 memRemotePRNParity
+1 memRemotePRNFlowControl
+1 memRemotePRNXon
+1 memRemotePRNXoff
+
+
+3 mem_mod2div_temp
+2 mem_contw_temp
+2 mem_attrib_list
+
+//rfcomm head
+1 mem_current_adss
+1 mem_current_channel
+1 mem_current_frame_type
+1 mem_current_fcs
+2 mem_current_length
+2 mem_rfcomm_uih_payload_ptr
+
+//rfcomm uih
+1 mem_uih_cmd_type
+2 mem_uih_length
+2 mem_param_payload_ptr
+
+
+//rfcomm modem status
+1 mem_ms_param
+
+//rfcomm pn
+1 mem_pn_credit_flow_type_info
+1 mem_pn_priority
+1 mem_pn_acknowledg_timer
+1 mem_pn_max_retrans
+
+1 mem_rfcomm_send_adss
+1 mem_rfcomm_send_frame_type
+1 mem_rfcomm_send_fcs
+1 mem_rfcomm_send_offset
+
+)
+
+xmemalloc(
+1 mem_pn_dlci
+2 mem_pn_max_frame_size
+
+1 memFCStemp1
+1 memFCStemp2
+1 memFCStemp3
+
+1 mem_rfcomm_initiator
+
+1 mem_remote_spp_channel
+
+1 mem_HIUfcs_SPP
+1 mem_HIUfcs_SPP_WCredits
+
+1 mem_rfcomm_send_more_pkt
+
+1 mem_remote_credits
+1 mem_credit_given
+
+//rfcomm modem status
+1 mem_ms_channel
+
+)
+
+/************************************************************************/
+  
+
+ 
+/************/
+/* constant */
+/************/
+
+/* RFCOMM state for Headset (memRFCOMM_State) */ 
+  (
+    0 RFCOMM_IDLE           /* before the responsor HS receive SABM            */
+    1 RFCOMM_W4_DLCI0_OPEN
+    2 RFCOMM_W4_DLCI0_CLOSE
+    3 RFCOMM_START_DLCI0    /* After respond SABM frame (DLCI=0)               */
+    4 RFCOMM_W4_DLCI_OPEN
+    5 RFCOMM_W4_DLCI_CLOSE
+    6 RFCOMM_DLCI_OPENED    
+   
+  )
+  
+/* RFCOMM timer constants   */
+  (
+    1000  RFCOMM_T1         /* Used by SABM and DISC frames,100*20ms = 20s     */     
+    1000  RFCOMM_T2         /* Used by commands send in UIH on DLCI0,          */
+    300   RFCOMM_T3_RINGON  /* 6s for ring fade time                           */
+  
+  )
+
+/* Command Type */
+  (
+    0x3F RSP_RX_SABM        /*responsor expect SABM from initiator             */
+    0x3F INI_TX_SABM
+	
+    0x73 RSP_TX_UA          /*responsor send out UA command                    */
+    0x73 UA_WFBIT_SET	    /* UA control field with F bit set                 */
+	
+    0xEF RSP_RX_UIH         /*responsor expect UIH from initiator              */
+
+    0xEF RSP_TX_UIH         /*responsor send UIH to initiator                  */
+     
+    0x1F RSP_TX_DM          /*responsor send DM to initiator                   */
+    0x1F DM_WFBIT_SET       /* DM control field with F bit set                 */
+    0x0F DM_WFBIT_CLEAR     /* DM control field with F bit clear               */
+
+    0x53 RSP_RX_DISC        /*responsor expect DISC from initiator             */
+    0x53 INI_TX_DISC	    /*initiator send DISC control type command         */
+     
+    0xFF RSP_RX_UIH_WDATA   /*UIH data with credit flow control info           */
+    
+    
+  )
+
+/* Multiplexor commands and responses frames */
+  (
+    0x83 PN_COMMAND           /* Bit 0 EA C/R Type = 000001         */
+    0x81 PN_RESPONSOR         /* Bit 0 EA C/R Type = 000001         */
+    
+    0xE3 MSC_COMMAND          /* Bit 0 EA C/R Type = 000111         */
+    0xE1 MSC_RESPONSOR
+ 
+    0x13 NSC_COMMAND          /* Bit 0 EA C/R Type = 001000         */
+    0x11 NSC_RESPONSOR        /* Bit 0 EA C/R Type = 001000         */
+
+    0x23 TEST_COMMAND         /* Bit 0 EA C/R Type = 000111         */
+    0x21 TEST_RESPONSOR 
+    
+    0x93 RPN_COMMAND          /* Bit 0 EA C/R Type = 001001         */
+    0x91 RPN_RESPONSOR 
+    
+    0x53 RLS_COMMAND          /* Bit 0 EA C/R Type = 001010         */
+    0x51 RLS_RESPONSOR 
+
+    0xA3 FCON_COMMAND         /* Bit 0 EA C/R Type = 000101         */
+    0xA1 FCON_RESPONSOR 
+    
+    0x63 FCOFF_COMMAND        /* Bit 0 EA C/R Type = 000110         */
+    0x61 FCOFF_RESPONSOR 
+    	
+    0x03 RLS_OVERRUN
+    0x05 RLS_PARITY_ERROR
+    0x09 RLS_FRAMING_ERROR
+  )
+
+/* memLocalCredit */
+  (
+    0x01 RFCOMM_CREDIT
+  )
+
+  (
+  	0x007f RFCOMM_MAX_FRAME_SIZE
+  )
+
+/* UIH received Data length */
+  (
+    0  LENGTH_ZERO
+    
+    6  LENGTH_OK
+    7  LENGTH_HOT
+    8  LENGTH_RING
+    9  LENGTH_ERROR
+    9  LENGTH_AGVOL_ONEBYTE
+    10 LENGTH_AGVOL_TWOBYTE
+    10 LENGTH_VOL_ONEBYTE
+    11 LENGTH_VOL_TWOBYTE
+    12 LENGTH_BRSF
+    13 LENGTH_PLUS_CIEV
+    15 LENGTH_INBANDRING
+    14 LENGTH_CIEV_CALL
+    17 LENGTH_CRING
+    20 LENGTH_BRSF_OK
+    24 LENGTH_CIND0
+    28 LENGTH_CIEV_TWO
+    32 LENGTH_CIND_OK
+    59 LENGTH_CIND_OK2
+    100 LENGTH_DISCARD
+  )
+  
+/************/
+/* flags    */
+/************/
+  
+/* memRFCOMM_L2CAP_Interface */
+  (
+    0 RFCOMM_TX_W4BUF_FLAG    /* Wait for Tx buffer empty flag */
+    1 RFCOMM_CLOSE_LINK_FLAG
+  )
+  
+
+    
+/* memRemoteMSC		*/
+  (
+    0 MSC_EA_BIT
+    1 MSC_FC_BIT
+    2 MSC_RTC_BIT
+    3 MSC_RTR_BIT
+    6 MSC_IC_BIT
+    7 MSC_DV_BIT
+  )
+
+/* memRemoteRLS         */
+  (
+    0x0C OVERRUN_ERROR
+    0x0A PARITY_ERROR
+    0x09 FRAMING_RERROR
+  )
+  
+/* memRemoteRPNBitRate  */
+  (
+    0x00 BITS2400
+    0x01 BITS4800
+    0x02 BITS7200
+    0x03 BITS9600
+    0x04 BITS19200
+    0x05 BITS38400
+    0x06 BITS57600
+    0x07 BITS115200
+    0x08 BITS230400
+  )
+  
+/* memRemotePRNDataBits	*/
+  (
+    0x00 DATABITS5
+    0x01 DATABITS6
+    0x02 DATABITS7
+    0x03 DATABITS8
+  )
+  
+/* memRemotePRNStopBit	*/
+  (
+    0    ONESTOP
+    1    ONEHALFSTOP
+  )
+  
+/* memRemotePRNParity   */
+  (
+    0    ODDPARITY
+    1    EVENPARITY
+    2    MARKPARITY
+    3    SPACEPARITY
+    
+    7    PARITY_ENABLE_BIT
+  )
+
+/* RPN bit mask(in)     */
+  (
+     0   BIT_RATE_MASK_BIT
+     1   DATA_BITS_MASK_BIT
+     2   STOP_BITS_MASK_BIT
+     3   PARITY_MASK_BIT
+     4   PARITY_TYPE_MASK_BIT
+     5   XON_CHAR_MASK_BIT
+     6   XOFF_CHAR_MASK_BIT
+  )
+  
+/* RPN bit mask(in) 2    */
+  (
+     0   XON_XOFF_INPUT_MASK_BIT
+     1   XON_XOFF_OUTPUT_MASK_BIT
+     2	 RTR_INPUT_MASK_BIT
+     3   RTR_OUTPUT_MASK_BIT
+     4   RTC_INPUT_MASK_BIT
+     5   RTC_OUTPUT_MASK_BIT
+
+  )
+
+/* memRFCOMM_Request	*/
+  (
+    0 SEND_MSC_CMD_REQ_FLAG
+    1 SEND_AT_CKPD_REQ_FLAG
+    2 SEND_RING_REQ_FLAG
+    3 SEND_SABM_CMD
+  )
+  
+/* memRFCOMM_Misc_Flag  */
+  (
+    0 MSC_CDM_ALREADY_SEND_FLAG
+    1 CREDIT_FLOW_USED_FLAG
+    2 DONT_EMBEDDED_CREDIT_FLAG 
+    3 MSC_EXCHANGE_DONE_FLAG
+    4 FLOW_CONTROL_FCOFF_BIT            /* set when receive FCoff, clear when FCon   */
+  )
+  
+/* memRemoteMSC		*/
+  (
+    1 FLOW_CONTROL_FC_BIT		/* received MSC FC bits                      */
+  
+  )
+/* Address filed        */
+  (
+    0 ADDR_EA_BIT
+    1 ADDR_CR_BIT
+    2 ADDR_D_BIT
+  )
+//should be same as descripted in SDP
+(
+    1 SPP_SLAVE_CHANNEL
+    7 OBEX_SERVER_CHANNEL
+    8 HF_SERVER_CHANNEL 
+    9 HS_SERVER_CHANNEL
+)
+/* memRFCOMM_Flag */
+(
+	0 USING_HF_PROFILE
+	1 USING_HS_PROFILE
+	2 USING_SPP_PROFILE
+)
+/*RFCOMM Frame Type*/
+(
+	0x3f RFCOMM_FRAME_TYPE_SABM
+	0x73 RFCOMM_FRAME_TYPE_UA
+	0xEF RFCOMM_FRAME_TYPE_UIH
+	0xFF RFCOMM_FRAME_TYPE_UIH_CREDITS
+	0x53 RFCOMM_FRAME_TYPE_DISCONN
+)
+/*RFCOMM UIH CMD TYPE*/
+(
+	0x41 UIH_PARAM_NEG_CMD
+	0x40 UIH_PARAM_NEG_RES
+	0x71 UIH_MODEM_STATUS_CMD
+	0x70 UIH_MODEM_STATUS_RES
+	0x49 UIH_PARAM_CMD_REMOVE_PORT
+)
+
+/*bits in rfcomm address*/
+(
+	0 RFCOMM_ADDRESS_EXT_LEN
+	1 RFCOMM_ADDRESS_CR
+	2 RFCOMM_ADDRESS_DERECTION
+
+
+)
+
+	(                                   
+	0 RFCOMM_CHANNEL_STATE_PN_CMD
+	1 RFCOMM_CHANNEL_STATE_PN_RES
+	2 RFCOMM_CHANNEL_STATE_SABM
+	3 RFCOMM_CHANNEL_STATE_UA
+	4 RFCOMM_CHANNEL_STATE_SND_MS_CMD
+	5 RFCOMM_CHANNEL_STATE_RCV_MS_CMD
+	6 RFCOMM_CHANNEL_STATE_SND_MS_RES
+	7 RFCOMM_CHANNEL_STATE_RCV_MS_RES
+	0xff RFCOMM_CHANNEL_SETUP_COMPLETE
+	) 
+
+	/*mem_rfcomm_send_more_pkt*/
+	(
+	1 MORE_PKT_MSC_CMD_HF
+	2 MORE_PKT_MSC_CMD_HS
+	3 MORE_PKT_MSC_CMD_SPP
+	4 MORE_PKT_MSC_CMD_OBEX
+	)
+
+	(
+	127 RFCOMM_MALLOC_SIZE
+	)
\ No newline at end of file
Index: btkb/format/sdp.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/sdp.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/sdp.format	(working copy)
@@ -0,0 +1,62 @@
+
+memalloc(
+0 mem_sdp_mem_start
+4 mem_uuid_search_pat
+2 mem_sdp_continue_byte
+1 mem_sdp_pduid
+2 mem_sdp_transactionid
+2 mem_sdp_attribute_maxbyte
+2 mem_sdp_record_maxcnt
+8 mem_sdp_error_code
+4 mem_sdp_record_handle
+1 mem_sdp_search_failed
+1 mem_sdp_LACAP_found
+1 mem_sdp_RFCOMM_found
+24 mem_handle_list
+1 mem_handle_humber
+0 mem_sdp_mem_end
+)
+xmemalloc(
+2 memui_uuid_table
+22 mem_all_uuid_16bits
+34 mem_all_uuid_128bits
+)
+(
+0 AGORHS_SERVICE
+1 GENAUDIO_SERVICE
+2 HANDSFREE_SERVICE
+)
+
+(
+1 SDP_ERROR_RESPONSE
+2 SDP_SERVICE_SEARCH_REQUEST
+3 SDP_SERVICE_SEARCH_RESPONSE
+4 SDP_SERVICE_ATTRIBUTE_REQUEST
+5 SDP_SERVICE_ATTRIBUTE_RESPONSE
+6 SDP_SERVICE_SEARCH_ATTRIBUTE_REQUEST
+7 SDP_SERVICE_SEARCH_ATTRIBUTE_RESPONSE
+)
+
+(
+0 ATTRIBUTEID_0000
+1 ATTRIBUTEID_0001
+2 ATTRIBUTEID_0004
+3 ATTRIBUTEID_0009
+4 ATTRIBUTEID_0100
+5 ATTRIBUTEID_0302
+6 ATTRIBUTEID_0006
+7 ATTRIBUTEID_0311
+)
+/* mem_sdp_search_profile */
+(
+1	SDP_SS_HEADSET
+2  	SDP_SS_HANDSFREE
+)
+(
+0x06 sdp_pduid_serviceSearchAttrib
+)
+0x2600 sdp_max_amount
+767 SDP_MALLOC_SIZE
+0x6e sdp_tid_spp //any number
+
+ 
Index: btkb/format/security.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/security.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/security.format	(working copy)
@@ -0,0 +1,72 @@
+
+memalloc(
+/* moved from bt.format for 3dh5 1021bytes packet buffer */
+17 mem_rxbuf
+
+16 mem_random_number
+16 mem_round_key
+16 mem_kinit
+
+16 mem_input_store
+16 mem_x
+15 mem_y
+1 mem_y15
+1 mem_pin_length
+16 mem_pin
+17 mem_key_store
+1 mem_key_store_end
+2 memp_ar_key
+2 memp_ar_input
+10 mem_ar_hround
+
+
+1 mem_ec_infinite
+1 mem_ec_loopc
+
+0 memdat
+/* ecc calculation */
+
+
+24 mem_ax
+24 mem_ay
+24 mem_az
+24 mem_bx
+24 mem_by
+24 mem_bz
+24 mem_cx
+23 mem_cy
+1 mem_cy5
+24 mem_cz
+24 mem_k
+16 mem_align
+
+0 mem_tmp1
+24 memahbak
+8 mem_tmp5
+16 memahsave
+16  mem_tmp2
+0  memahsave_end 
+1  mem_addr_padding 
+7   mem_addr_value         /* 12 bytes     */ 
+0 mem_tmp3
+5 mem_t1
+3  mem_addr_value_end   
+16 mem_addr_iocap_end
+0 mem_tmp0
+8 mem_t0
+16 mem_tmp0a
+24 mem_t2
+24 mem_t3
+24 mem_t7
+24 mem_p		
+24 mem_a
+24 mem_b
+24 mem_gx
+24 mem_gy
+32 memh0
+
+
+
+)
+
+
Index: btkb/format/shutter.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/shutter.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/shutter.format	(working copy)
@@ -0,0 +1,48 @@
+
+
+omemalloc(
+4 mem_shutter_send_data
+1 mem_shutter_key_temp
+1 mem_shutter_send_length
+4 mem_shutter_clkn_bt_last
+1 mem_shutter_key
+1 mem_shutter_flag
+1 mem_shutter_cable_unplug_conut
+1 mem_shutter_hid_disconn_count
+1 mem_shutter_1key_send_sm
+
+1 mem_shutter_iphonekey_gpio
+1 mem_shutter_androidkey_gpio
+1 mem_shutter_key_number
+650 mem_shutter_uuid_list
+)
+
+(
+0 FLAG_SHUTTER_DEFAULT
+1 FLAG_SHUTTER_IPHONEKEY_SEND
+2 FLAG_SHUTTER_ANDROIDKEY_SEND
+)
+
+(
+0 FLAG_SHUTTER_IPHONEKEY_PRESS
+1 FLAG_SHUTTER_ANDROIDKEY_PRESS
+)
+
+(
+1  FLAG_SHUTTER_HID_DISCONN_TIMEOUT
+5 FLAG_SHUTTER_CABLE_UNPLUG_TIMEOUT
+)
+
+(
+1 FLAG_SHUTTER_1KEY
+2 FLAG_SHUTTER_2KEY
+)
+
+(
+0 FLAG_SHUTTER_1KEY_SEND_NULL
+1 FLAG_SHUTTER_1KEY_SEND_STEP1
+2 FLAG_SHUTTER_1KEY_SEND_STEP2
+3 FLAG_SHUTTER_1KEY_SEND_STEP3
+4 FLAG_SHUTTER_1KEY_SEND_STEP4
+)
+
Index: btkb/format/simple_pairing.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/simple_pairing.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/simple_pairing.format	(working copy)
@@ -0,0 +1,132 @@
+/* simple pairing page */
+
+memalloc(
+
+//4 mem_hci_ssp_mode
+0 mem_sp_state_start
+1 mem_sp_state
+1 mem_master_sp_state
+1 mem_sp_flag
+1 mem_master_sp_flag
+1 mem_sp_calc
+1 mem_sp_dh_ready
+1 mem_sp_localsm
+1 mem_pairing_auth
+
+0 mem_sp_flag_start
+1 mem_sp_local_key_send_count
+1 mem_sp_remote_key_recv_count
+1 mem_sp_remote_key_invalid
+1 mem_sp_dhkey_invalid
+
+3 mem_sp_iocap_local
+3 mem_sp_iocap_remote
+
+4 mem_sp_gkey
+
+0 mem_sp_pubkey_remote
+24 mem_sp_pubkey_remote_x
+0 mem_sp_pubkey_remote_x_end
+24 mem_sp_pubkey_remote_y
+24 mem_sp_dhkey
+0 mem_sp_dhkey_end
+16 mem_sp_random_local
+0 mem_sp_random_local_end
+16 mem_sp_random_remote
+0 mem_sp_random_remote_end
+0 memresult
+0 mem_sp_calc_result
+4 memh
+4 memg
+4 memf
+4 meme
+0 mem_sp_calc_result_high
+4 memd
+4 memc
+4 memb
+4 mema
+16 mem_sp_check_result
+16 mem_sp_confirm_remote
+16 mem_sp_prarm_stack
+)
+
+xmemalloc(
+1 mem_sp_local_key_invalid
+24 mem_sp_private_key
+0 mem_sp_pubkey_local
+24 mem_sp_pubkey_local_x
+0 mem_sp_pubkey_local_x_end
+24 mem_sp_pubkey_local_y
+1 mem_ssp_enable
+)
+/* simple pairing status flag */
+(
+  0x00   SP_FLAG_STANDBY
+  0x01   SP_FLAG_COMMIT
+)
+
+/* simple pairing calc flag */
+(
+  0x00   SP_CALC_STANDBY
+  0x01   SP_CALC_PUBKEY
+  0x02   SP_CALC_DHKEY
+)
+
+/* simple pairing state */
+(
+  0x00   SP_STAT_NULL
+  0x01   SP_STAT_KEY_RECV
+  0x02   SP_STAT_KEY_GENERATE
+  0x03   SP_STAT_KEY_SEND
+  0x04   SP_STAT_COMMIT_CALC
+  0x05   SP_STAT_COMMIT_SEND
+  0x06   SP_STAT_RANDOM_RECV
+  0x07   SP_STAT_RANDOM_SEND
+  0x08   SP_STAT_CONFIRM_RECV
+  0x09   SP_STAT_CONFIRM_CHECK
+  0x0A   SP_STAT_CONFIRM_CALC
+  0x0B   SP_STAT_CONFIRM_SEND
+  0x0C   SP_STAT_LINK_KEY_CALC
+  0x0F   SP_STAT_DONE
+  0x10   SP_STAT_FEATURE_EXT_SEND
+  0x11   SP_STAT_GKEY_CALC
+  /*simple pairing master only*/
+  0x12   SP_MASTER_STAT_START_SKIP
+  0x13   SP_MASTER_STAT_START_DONE
+  0x14   SP_STAT_COMMITMENT_COMPARE
+  0x15   SP_STATE_END
+)
+
+
+/* simple paring invalid flag */
+(
+  0x00   SP_KEY_INVALID
+  0x01   SP_KEY_VALID
+)
+
+/* encapsulated defination for P-192 key */
+(
+  0x01  ENCAPSULATED_MAJOR_TYPE_P192
+  0x01  ENCAPSULATED_MINOR_TYPE_P192
+  0x30  ENCAPSULATED_LEN_P192
+)
+
+/* bluetooth 2.1 support flag */
+(
+  0x00  SIMPLE_PAIRING_ENABLE
+  0x01  ENCRYPTION_PAUSE_ENABLE
+  0x02  EXTENDED_INQUIRY_RESPOSE_ENABLE
+  0x03  SNIFF_SUBRATING_ENABLE
+)
+
+/*mem_sp_localsm*/
+(
+  0x00 DEFAULT_STATEMACHINE
+  0x01 LOCAL_STATEMACHINE
+)
+
+(
+ 0x00 DEFALT_PAIRING_AUTH
+ 0x01 PAIRING_AUTH
+)
+  
Index: btkb/format/ui.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/ui.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/ui.format	(working copy)
@@ -0,0 +1,434 @@
+/*****************************************************************************/
+/* RCS HEADER -- DO NOT ERASE                                                */
+/* $Author: Administrator $                                                           */
+/* $Id: bt_ui_format.upper,v 1.1 2009-09-28 04:06:17 Administrator Exp $     */
+/************************************************************************/
+
+
+	/* ========= memory ============== */
+memalloc(
+2 mem_UI_data_txbuff_length
+
+1 mem_ipc_skip_continue_proc
+0 mem_ui_timer_temp  //length 4
+4 mem_ipc_rega_temp
+) 
+
+xmemalloc(
+//UI Work area
+1 mem_ipc_lock_bt
+1 mem_ipc_lock_c51
+5 mem_ipc_fifo_bt2c51
+5 mem_ipc_fifo_c512bt
+1 mem_led_switch
+1 mem_ui_button_timer
+1 mem_ui_button_last_state
+4 mem_ui_timer_last_btclk
+2 mem_discovery_timeout_timer_count
+1 mem_hid_handshake_timer_count
+1 memui_reconnect_mode
+2 mem_ui_state_map
+
+//UI Config area
+1 mem_ui_profile_supported
+1 mem_led_gpio
+2 mem_led_dark_time
+2 mem_led_light_time
+1 mem_ui_button_timeout
+1 mem_ui_button_gpio
+2 mem_discovery_timeout
+
+)
+/************/
+/* constant */
+/************/
+
+//mem_ui_state_map
+(
+0 UI_STATE_BT_CONNECTED
+1 UI_STATE_BT_SETUP_COMPLETE
+2 UI_STATE_BT_HID_CONN
+3 UI_STATE_BT_HID_HANDSHAKE
+4 UI_STATE_BT_SPP_CONN
+5 UI_STATE_BT_SNIFF
+6 UI_STATE_BT_DISCOVERY
+7 UI_STATE_BT_RECONNECT
+8 UI_STATE_BT_SLAVE_ROLE
+9 UI_STATE_BLE_CONNECTED
+10 UI_STATE_BLE_WRITE_RCV
+11 UI_STATE_BLE_ADV
+12 UI_STATE_BTN_DOWN
+13 UI_STATE_LED_BLINK
+14 UI_STATE_LED_ON
+)
+
+/* UI state for Headset (memui_HS_State) */ 
+   (
+    0 UI_HEADSET_DISCONNECT
+    1 UI_HEADSET_IDLE                   /* before the responsor HS receive SABM      */
+    2 UI_HEADSET_W4CONNECT
+    3 UI_HEADSET_RINGING
+    4 UI_HEADSET_CONNECTED
+    5 UI_HEADSET_PARING
+  )
+/* memui_BB_State */
+(
+  0 UI_BB_OFF
+  1 UI_BB_IDLE
+  2 UI_BB_DISCOVERY
+  3 UI_BB_CONNECTED_ACTIVE_NO_SCO
+  4 UI_BB_CONNECTED_ACTIVE_WITH_SCO
+  5 UI_BB_CONNECTED_ACTIVE_WAIT_SNIFF
+  6 UI_BB_CONNECTED_SNIFF
+  7 UI_BB_RECONNECT
+  8 UI_BB_CONNECTED_SNIFF_WITH_SCO
+)
+
+/************/
+/* flags    */
+/************/
+  
+/* memui_Misc_Flags */
+  (
+    5 NO_IDLE_TURN_OFF
+    7 ANSWER_RING_FLAG               /* 1 Answer,0 no*/
+  )
+
+/* mem_UI_SCH_Interface */
+  (
+    0  UI_HS_PAIRING 
+    2  UI_REQ_CLOSE_RFCOMM
+    3  UI_LINK_LOST
+    4  UI_REQ_OPEN_SCO
+    6  UI_REQ_CLOSE_SCO
+  )
+  
+/* memui_PassOverKey */
+  (
+    0  ANSWER_RING_BIT
+    0  AG_SEND_RING_BIT
+    1  VOL_UP_BIT
+    2  VOL_DOWN_BIT
+    3  INI_CALL_BIT
+    4  DAIL_LAST_CALL
+    5  END_CALL_BIT
+    6  NOKIA_VOICE_ACTIVE 
+    7  REJECT_CALL_BIT
+  )
+  
+/* memui_reconnect_mode */
+(
+  0 NO_RECONNECTION
+  1 RECONNECT_HID
+  2 RECONNECT_HF
+  3 RECONNECT_HS
+  4 RECONNECT_HID_HF
+  5 RECONNECT_HID_HS
+)
+/* memui_Commands */
+(
+0x00 BT_CMD_STANDBY
+0x01 BT_CMD_START_DISCOVERY
+0x02 BT_CMD_STOP_DISCOVERY
+0x03 BT_CMD_RECONNECT
+0x04 BT_CMD_DISCONNECT
+0x05 BT_CMD_ENTER_SNIFF
+0x06 BT_CMD_EXIT_SNIFF
+0x07 BT_CMD_ENTER_SNIFF_SUBRATING
+0x08 BT_CMD_EXIT_SNIFF_SUBRATING
+0x09 BT_CMD_SNIFF_TEST
+0x0a BT_CMD_SET_PIN_CODE
+0x0b BT_CMD_START_INQUIRY
+0x0c BT_CMD_STOP_INQUIRY
+0x0d BT_CMD_START_ADV
+0x0e BT_CMD_STOP_ADV
+0x0f BT_CMD_START_DIRECT_ADV
+0x10 BT_CMD_STOP_DIRECT_ADV
+0x11 BT_CMD_LE_DISCONNECT
+0x12 BT_CMD_LE_UPDATE_CONN
+0x13 BT_CMD_LED_OFF
+0x14 BT_CMD_LED_ON
+0x15 BT_CMD_LED_BLINK
+0x16 BT_CMD_LE_START_CONN
+0x17 BT_CMD_LE_START_SCAN
+0x18 BT_CMD_LE_STOP_SCAN
+0x19 BT_CMD_ENTER_HIBERNATE
+0x1b BT_CMD_LE_SMP_SECURITY_REQUEST
+0x1c BT_CMD_LE_START_WRITE
+0x1d BT_CMD_ROLE_SWITCH
+0x1e BT_CMD_BB_RECONN_CANCEL
+0x1f BT_CMD_STORE_RECONN_INFO_LE
+0x20 BT_CMD_STORE_RECONN_INFO_BT
+0x21 BT_CMD_START_24G
+0x22 BT_CMD_STOP_24G
+0x23 BT_CMD_PAIR_24G
+0x28 BT_CMD_UPDATE_SUPERVISION_TO
+0x29 BT_CMD_LE_SET_PINCODE
+0x2a BT_CMD_SET_RECONNECT_INIT
+0x2b BT_CMD_START_ADV_REC
+0x2c BT_CMD_START_ADV_DISCOVERY
+)
+
+(
+0x00 BT_EVT_NULL
+0x01 BT_EVT_BB_CONNECTED
+0x02 BT_EVT_BB_DISCONNECTED
+0x03 BT_EVT_RECONN_STARTED
+0x04 BT_EVT_RECONN_FAILED
+0x05 BT_EVT_SETUP_COMPLETE
+0x06 BT_EVT_HID_CONNECTED
+0x07 BT_EVT_HID_DISCONNECTED
+0x08 BT_EVT_SPP_CONNECTED
+0x09 BT_EVT_SPP_DISCONNECTED
+0x0A BT_EVT_PINCODE_REQ
+0x0B BT_EVT_ENTER_SNIFF
+0x0C BT_EVT_EXIT_SNIFF
+0x0D BT_EVT_ENTER_SNIFF_SUB
+0x0E BT_EVT_EXIT_SNIFF_SUB
+0x0F BT_EVT_DISCOVERY_STOPED
+0x10 BT_EVT_BUTTON_LONG_PRESSED
+0x12 BT_EVT_HID_HANDSHAKE
+0X13 BT_EVT_RECONN_PAGE_TIMEOUT
+0x14 BT_EVT_LE_CONNECTED
+0X15 BT_EVT_LE_DISCONNECTED
+0x16 BT_EVT_ML2CAP_CONN_REFUSED
+0x17 BT_EVT_BUTTON_ENTER_HIBERNATE
+0x18 BT_EVT_LINKKEY_GENERATE
+0x19 BT_EVT_SWITCH_NOT_ACCEPT
+0x20 BT_EVT_SWITCH_ACCEPT
+0x21 BT_EVT_SNIFF_NOT_ACCEPT
+0x22 BT_EVT_SNIFF_ACCEPT
+0x23 BT_EVT_UNSNIFF_ACCEPT
+0x24 BT_EVT_UNSNIFF_NOT_ACCEPT
+0x25 BT_EVT_BUTTON_ADJUST_DPI
+0x26 BT_EVT_SEND_UNSNIFF_ACCEPT
+0x27 BT_EVT_VIRTUAL_CABLE_UNPLUG
+0x28 BT_EVT_LE_WRITE_REQUEST
+0x29 BT_EVT_LE_ENC_INFO
+0x2a BT_EVT_SWITCH_FAIL_MASTER
+0x2b BT_EVT_SWITCH_SUCCESS_MASTER
+0x2c BT_EVT_BUTTON_DOWN
+0x2d BT_EVT_BUTTON_UP
+0x2e BT_EVT_REMOTE_UNSNIFF
+0x2f BT_EVT_RESET
+0x30 BT_EVT_WAKEUP
+0x31 BT_EVT_24G_PAIRING_COMPLETE
+0x32 BT_EVT_24G_ATTEMPT_FAIL
+0x33 BT_EVT_HIBERNATE_WAKE
+0x34 BT_EVT_LE_PROTOCOL_CONNECTED
+0x35 BT_EVT_LE_PINCODE_REQ
+0x37 BT_EVT_RECONNECT_STANDY
+0x39 BT_EVT_CLEAR_LINKKEY
+0x3c BT_EVT_24G_ATTEMPT_SUCCESS
+0x50 BT_EVT_TIMER_INIT
+0xF0 BT_EVT_TIMER_MASK
+0x51 BT_EVT_TIMER_100MS
+0x52 BT_EVT_TIMER_200MS
+0x53 BT_EVT_TIMER_300MS
+0x54 BT_EVT_TIMER_400MS
+0x55 BT_EVT_TIMER_500MS
+0x56 BT_EVT_TIMER_600MS
+0x57 BT_EVT_TIMER_700MS
+0x58 BT_EVT_TIMER_800MS
+0x59 BT_EVT_TIMER_900MS
+0x5A BT_EVT_TIMER_1KMS
+0x5B BT_EVT_TIMER_1K1MS
+0x5C BT_EVT_TIMER_1K2MS
+0x5D BT_EVT_TIMER_1K3MS
+0x5E BT_EVT_TIMER_1K4MS
+0x5F BT_EVT_TIMER_1K5MS
+)
+//switch
+(
+0 OFF
+1 ON
+)
+/* memui_mem_lock */
+(
+    0 MEM_UNLOCK
+    1 MEM_LOCK
+)
+/* memui_flag0 */
+(
+    0 UI_USER_DATA_FLAG
+    1 UI_WII_WAITING_SLEEP
+    2 UI_KEYBOARD_SNIFF_SKIP
+)
+/* mem_master_type */
+(
+    0 MTYPE_HID_DEFAULT
+    1 MTYPE_HID_SSP
+    2 MTYPE_SPP
+)
+
+	(	
+	0x01 RECIEVE_SDP_CONN_RES
+	0x02 RECIEVE_SDP_CFG_REQ
+	0x03 RECIEVE_SDP_CFG_RES
+	0x04 RECIEVE_RFCOMM_CONN_RES
+	0x05 RECIEVE_RFCOMM_CFG_REQ
+	0x06 RECIEVE_RFCOMM_CFG_RES
+	0x07 RECIEVE_HID_CTRL_CONN_RES
+	0x08 RECIEVE_HID_CTRL_CFG_REQ
+	0x09 RECIEVE_HID_CTRL_CFG_RES
+	0x0A RECIEVE_HID_INT_CONN_RES
+	0x0B RECIEVE_HID_INT_CFG_REQ
+	0x0C RECIEVE_HID_INT_CFG_RES
+	0x0D RECIEVE_AVCTP_CONN_RES
+	0x0E RECIEVE_AVCTP_CFG_REQ
+	0x0F RECIEVE_AVCTP_CFG_RES
+	0x10 RECIEVE_AVDTP_SIGNAL_CONN_RES
+	0x11 RECIEVE_AVDTP_SIGNAL_CFG_REQ
+	0x12 RECIEVE_AVDTP_SIGNAL_CFG_RES
+	0x13 RECIEVE_AVDTP_MEDIA_CONN_RES
+	0x14 RECIEVE_AVDTP_MEDIA_CFG_REQ
+	0x15 RECIEVE_AVDTP_MEDIA_CFG_RES
+	0x16 RECIEVE_SS_REASULT_HS                  
+	0x17 RECIEVE_SS_REASULT_HF                  
+	0x18 RECIEVE_SS_REASULT_AVTARG		          
+	0x19 RECIEVE_SS_REASULT_OBEX		            
+	0x1A RECIEVE_DLCI0_UA
+	0x1B RECIEVE_HS_PARAM_NEG_RES
+	0x1C RECIEVE_HS_UA
+	0x1D RECIEVE_HS_MODEM_STATUS_RES
+	0x1E RECIEVE_HS_MODEm_STATUS_CMD
+	0x1F RECIEVE_HF_PARAM_NEG_RES   
+	0x20 RECIEVE_HF_UA              
+	0x21 RECIEVE_HF_MODEM_STATUS_RES
+	0x22 RECIEVE_HF_MODEm_STATUS_CMD 
+	0x23 RECIEVE_OBEX_PARAM_NEG_RES     
+	0x24 RECIEVE_OBEX_UA              
+	0x25 RECIEVE_OBEX_MODEM_STATUS_RES
+	0x26 RECIEVE_OBEX_MODEm_STATUS_CMD    
+	0x27 RECIEVE_SPP_PARAM_NEG_RES   
+	0x28 RECIEVE_SPP_UA              
+	0x29 RECIEVE_SPP_MODEM_STATUS_RES
+	0x2A RECIEVE_SPP_MODEm_STATUS_CMD
+	0x2b RECIEVE_SDP_DISCONN_RES
+	)
+
+
+
+	(
+	0 UPPERSM_RP_IDLE
+	1 UPPERSM_RP_SDP_CONN
+	2 UPPERSM_RP_SDP_CONN_WAIT
+	3 UPPERSM_RP_SDP_CFG
+	4 UPPERSM_RP_SDP_CFG_WAIT
+	5 UPPERSM_RP_SS_AVTARG
+	6 UPPERSM_RP_SS_AVTARG_WAIT
+	7 UPPERSM_RP_SS_OBEX
+	8 UPPERSM_RP_SS_OBEX_WAIT
+	9 UPPERSM_RP_SDP_DISCONN
+	10 UPPERSM_RP_SDP_DISCONN_WAIT
+	11 UPPERSM_RP_AVDTP_CONN_WAIT
+	12 UPPERSM_RP_AVCTP_CONN
+	13 UPPERSM_RP_AVCTP_CONN_WAIT
+	14 UPPERSM_RP_AVCTP_CFG
+	15 UPPERSM_RP_AVCTP_CFG_WAIT
+	16 UPPERSM_RP_OBEX_CMD_PN
+	17 UPPERSM_RP_OBEX_CMD_PN_WAIT
+	18 UPPERSM_RP_OBEX_SABM
+	19 UPPERSM_RP_OBEX_SABM_WAIT
+	20 UPPERSM_RP_OBEX_CMD_MS
+	21 UPPERSM_RP_OBEX_CMD_MS_WAIT
+	)
+	(		/*mem_upper_sm_reconn*/
+	0 UPPERSM_RECONN_IDLE		
+	1 UPPERSM_RECONN_SDP_CONN		
+	2 UPPERSM_RECONN_SDP_CONN_WAIT		
+	3 UPPERSM_RECONN_SDP_CFG		
+	4 UPPERSM_RECONN_SDP_CFG_WAIT		
+	5 UPPERSM_RECONN_SS_HS
+	6 UPPERSM_RECONN_SS_HS_WAIT
+	7 UPPERSM_RECONN_SS_HF
+	8 UPPERSM_RECONN_SS_HF_WAIT
+	9 UPPERSM_RECONN_SS_AVTARG		
+	10 UPPERSM_RECONN_SS_AVTARG_WAIT		    
+	11 UPPERSM_RECONN_SS_OBEX		            
+	12 UPPERSM_RECONN_SS_OBEX_WAIT		      
+	13 UPPERSM_RECONN_SDP_DISCONN		        
+	14 UPPERSM_RECONN_SDP_DISCONN_WAIT      
+	15 UPPERSM_RECONN_HID_CTRL_CONN		      
+	16 UPPERSM_RECONN_HID_CTRL_CONN_WAIT		
+	17 UPPERSM_RECONN_HID_CTRL_CFG		      
+	18 UPPERSM_RECONN_HID_CTRL_CFG_WAIT     
+	19 UPPERSM_RECONN_HID_INT_CONN		      
+	20 UPPERSM_RECONN_HID_INT_CONN_WAIT		  
+	21 UPPERSM_RECONN_HID_INT_CFG		        
+	22 UPPERSM_RECONN_HID_INT_CFG_WAIT      
+	23 UPPERSM_RECONN_RFCOMM_CONN		        
+	24 UPPERSM_RECONN_RFCOMM_CONN_WAIT		  
+	25 UPPERSM_RECONN_RFCOMM_CFG		        
+	26 UPPERSM_RECONN_RFCOMM_CFG_WAIT       
+	27 UPPERSM_RECONN_RFCOMM_SABM		        
+	28 UPPERSM_RECONN_RFCOMM_SABM_WAIT		  
+	29 UPPERSM_RECONN_SPP_CMD_PN		        
+	30 UPPERSM_RECONN_SPP_CMD_PN_WAIT		    
+	31 UPPERSM_RECONN_SPP_SABM		          
+	32 UPPERSM_RECONN_SPP_SABM_WAIT		      
+	33 UPPERSM_RECONN_SPP_CMD_MS		        
+	34 UPPERSM_RECONN_SPP_CMD_MS_WAIT       
+	35 UPPERSM_RECONN_HF_CMD_PN		          
+	36 UPPERSM_RECONN_HF_CMD_PN_WAIT		    
+	37 UPPERSM_RECONN_HF_SABM		            
+	38 UPPERSM_RECONN_HF_SABM_WAIT		      
+	39 UPPERSM_RECONN_HF_CMD_MS		          
+	40 UPPERSM_RECONN_HF_CMD_MS_WAIT        
+	41 UPPERSM_RECONN_AVDTPs_CONN		        
+	42 UPPERSM_RECONN_AVDTPs_CONN_WAIT		  
+	43 UPPERSM_RECONN_AVDTPs_CFG		        
+	44 UPPERSM_RECONN_AVDTPs_CFG_WAIT       
+	45 UPPERSM_RECONN_AVDTPm_CONN		        
+	46 UPPERSM_RECONN_AVDTPm_CONN_WAIT		  
+	47 UPPERSM_RECONN_AVDTPm_CFG		        
+	48 UPPERSM_RECONN_AVDTPm_CFG_WAIT       
+	49 UPPERSM_RECONN_AVCTP_CONN		        
+	50 UPPERSM_RECONN_AVCTP_CONN_WAIT		    
+	51 UPPERSM_RECONN_AVCTP_CFG		          
+	52 UPPERSM_RECONN_AVCTP_CFG_WAIT		    
+	53 UPPERSM_RECONN_OBEX_CMD_PN		        
+	54 UPPERSM_RECONN_OBEX_CMD_PN_WAIT		  
+	55 UPPERSM_RECONN_OBEX_SABM		          
+	56 UPPERSM_RECONN_OBEX_SABM_WAIT		    
+	57 UPPERSM_RECONN_OBEX_CMD_MS		        
+	58 UPPERSM_RECONN_OBEX_CMD_MS_WAIT     
+	59 UPPERSM_RECONN_SS_SPP
+	60 UPPERSM_RECONN_SS_SPP_WAIT
+	)
+	(/*mem_UI_profile_supported*/
+	0 support_HID
+	1 support_A2DP
+	2 support_AVRCP
+	3 support_HF
+	4 support_HS
+	5 support_PBAP
+	6 support_SPP
+	)
+	/*mem_upper_sm_ss*/
+	(
+	0 UPPERSM_SS_HS
+	1 UPPERSM_SS_HF
+	2 UPPERSM_SS_AVTARG
+	3 UPPERSM_SS_OBEX
+	)
+
+	(
+	160 UI_HUNDRED_MILLISECOND_TIME
+	0XFF UI_BUTTON_GPIO_DISABLE
+	)
+	(
+	0x01 UI_BB_INCONNECT
+	0x10 UI_BB_DISCONNECT
+	)
+(
+0x00 UI_BUTTON_STATE_DOWN
+0x01 UI_BUTTON_STATE_UP
+)
+
+//mem_ipc_skip_continue_proc
+(
+	0 IPC_CONTINUE_PROCESS
+	1 IPC_SKIP_CONTINUE_PROCESS
+)
+
Index: btkb/format/usb.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/usb.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/usb.format	(working copy)
@@ -0,0 +1,141 @@
+
+memalloc(
+1 mem_usb_status
+1 mem_usb_fifo_empty
+1 mem_usb_read_len
+64 mem_usb_rxbuf
+2 mem_usb_cnt
+1 mem_usb_tx_enable
+1 mem_usb_tx_count
+1 mem_usb_set_protocol_count
+1 mem_usb_desc
+1 mem_usb_state
+2 mem_usb_idle_cnt
+2 mem_usb_idle_timeout
+2 mem_usb_trig_timeout
+
+0 mem_usb_setup
+1 mem_usb_setup_bmRequestType
+1 mem_usb_setup_bRequest
+1 mem_usb_setup_bValue
+1 mem_usb_setup_bValueH
+2 mem_usb_setup_wIndex
+1 mem_usb_setup_bLength
+1 mem_usb_setup_bLengthH
+
+
+8 mem_usb0_setup
+2 mem_bufptr
+1 mem_remain
+20 mem_devicedesc
+200 mem_hidreportdesc_kb
+200 mem_hidreportdesc_m
+100 mem_confdesc
+5 mem_string0
+30 mem_string1
+30 mem_string2
+30 mem_string3
+)
+
+(
+0x20 HCI_CLASS_REQUEST_TYPE      // SetReport HID Request
+0x21 HID_CLASS_REQUEST_TYPE 
+0x00 ZERO_CLASS_REQUEST_TYPE 
+)
+//Standard Request Codes
+(
+0x00 GET_STATUS                // Code for Get Status
+0x01 CLEAR_FEATURE             // Code for Clear Feature
+0x03 SET_FEATURE              // Code for Set Feature
+0x05 SET_ADDRESS              // Code for Set Address
+0x06 GET_DESCRIPTOR           // Code for Get Descriptor
+0x07 SET_DESCRIPTOR           // Code for Set Descriptor(not used)
+0x08 GET_CONFIGURATION        // Code for Get Configuration
+0x09 SET_CONFIGURATION        // Code for Set Configuration
+0x0A GET_INTERFACE            // Code for Get Interface
+0x0B SET_INTERFACE            // Code for Set Interface
+0x0C SYNCH_FRAME              // Code for Synch Frame(not used)
+)
+//Standard Descriptor Types
+(
+0x01 DSC_DEVICE               // Device Descriptor
+0x02 DSC_CONFIG               // Configuration Descriptor
+0x03 DSC_STRING               // String Descriptor
+0x04 DSC_INTERFACE            // Interface Descriptor
+0x05 DSC_ENDPOINT             // Endpoint Descriptor
+)
+//HID Descriptor Types
+(
+0x21 DSC_HID			      // HID Class Descriptor
+0x22 DSC_HID_REPORT			  // HID Report Descriptor
+)
+//Define bmRequestType bitmaps
+(
+0x00 IN_DEVICE                // Request made to device,
+                              // direction is IN
+0x80 OUT_DEVICE               // Request made to device,
+                              // direction is OUT
+0x01 IN_INTERFACE             // Request made to interface,
+                              // direction is IN
+0x81 OUT_INTERFACE            // Request made to interface,
+                              // direction is OUT
+0x02 IN_ENDPOINT              // Request made to endpoint,
+                              // direction is IN
+0x82 OUT_ENDPOINT             // Request made to endpoint,
+)
+//HID Request Codes
+(
+0x01 GET_REPORT 		       // Code for Get Report
+0x02 GET_IDLE				   // Code for Get Idle
+0x03 GET_PROTOCOL			   // Code for Get Protocol
+0x09 SET_REPORT				   // Code for Set Report
+0x0A SET_IDLE				   // Code for Set Idle
+0x0B SET_PROTOCOL			   // Code for Set Protocol
+0xF2 HID_REPORT_ID           
+64 EP0_PACKET_SIZE         
+6 EP1_PACKET_SIZE         
+16 HID_REPORT_SIZE         
+0x001B HID_REPORT_DESCRIPTOR_SIZE    
+)
+//math cordic
+(
+	
+
+0 TYPE_SIN		
+1 TYPE_ATAN	
+2 TYPE_MULT	
+3 TYPE_DIV		
+4 TYPE_ASIN	
+5 TYPE_SQRT	
+6 TYPE_COS		
+7 TYPE_TAN		 
+)
+   
+(
+0 DFIFO0_IN_EMPTY
+1 DFIFO1_IN_EMPTY
+2 DFIFO2_IN_EMPTY
+3 DFIFO3_IN_EMPTY
+4 DFIFO0_OUT_EMPTY
+5 DFIFO1_OUT_EMPTY
+6 DFIFO2_OUT_EMPTY
+7 DFIFO3_OUT_EMPTY
+)
+
+
+
+
+(
+4 USB_STATUS_SETUP
+6 USB_STATUS_NAK
+)
+
+(
+1 USB_GOT_REPORT_REQ
+2 USB_CONNECTED
+3 USB_SLEEP
+4 USB_RESUME
+5 USB_SETIDLE_1
+)
+
+
Index: btkb/format/utility.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/utility.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/utility.format	(working copy)
@@ -0,0 +1,86 @@
+/**
+*  @file:bt_utility_format.upper
+*  @author: lei.zhu
+*  utility header file. inlcude timer
+*  Copyright:  (C)Hanlynn Technology    
+*/
+
+memalloc(
+
+/*
+    temp parameter
+*/
+2 mem_hold_contr
+2 mem_hold_contw
+1 mem_fifo_temp
+
+
+1 mem_c51_flag
+1 mem_c51_lpm_lock
+1 mem_c51_wait_lpm
+1 mem_wakup_from_power_flag
+1 mem_lmp_bb_disconnect_reason
+100 mem_c51_eeprom_buf
+100 mem_c51_ipc_txbuf
+100 mem_c51_ipc_rxbuf
+4 mem_c51_iicd_buf
+34 mem_24g_rxbuf
+32 mem_24g_txbuf
+34 mem_24g_txpayload
+32 mem_24g_rxpayload
+32 mem_24g_common_temp
+1 mem_packet_length_temp
+2 mem_le_cur_handle_start
+2 mem_le_cur_handle_end
+1 mem_le_search_res
+)
+
+
+
+
+
+
+(
+/*mem_util_timer_flag0_7*/
+    0   UTIL_TIMER_0_USED
+    1   UTIL_TIMER_1_USED
+    2   UTIL_TIMER_2_USED
+    3   UTIL_TIMER_3_USED
+    4   UTIL_TIMER_4_USED
+    5   UTIL_TIMER_5_USED
+    6   UTIL_TIMER_6_USED
+    7   UTIL_TIMER_7_USED
+/*mem_util_timer_flag8_15*/
+    0   UTIL_TIMER_8_USED
+    1   UTIL_TIMER_9_USED
+    2   UTIL_TIMER_10_USED
+    3   UTIL_TIMER_11_USED
+    4   UTIL_TIMER_12_USED
+    5   UTIL_TIMER_13_USED
+    6   UTIL_TIMER_14_USED
+    7   UTIL_TIMER_15_USED
+)
+
+//util fifo param
+(
+
+5 UTIL_FIFO_LEN
+-1 UTIL_FIFO_OFFSET
+)
+
+
+//power control
+(
+99  POWER_CTRL_MAX_PACKET_CNT
+
+10 POWER_CTRL_RETRANS_THRESH_UP0
+0 POWER_CTRL_RETRANS_THRESH_DOWN0
+
+20 POWER_CTRL_RETRANS_THRESH_UP1
+5 POWER_CTRL_RETRANS_THRESH_DOWN1
+
+100 POWER_CTRL_RETRANS_THRESH_UP2
+10 POWER_CTRL_RETRANS_THRESH_DOWN2
+)
+
+
Index: btkb/format/var.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/var.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/format/var.format	(working copy)
@@ -0,0 +1,442 @@
+/************************************************************************/
+/* RCS HEADER -- DO NOT ERASE                                           */
+/* $Author: Administrator $                                                     */
+/* $Id: bt_var.osi,v 1.1 2009-09-28 04:06:18 Administrator Exp $   */
+/* Orisil Technology                                                 */
+/************************************************************************/
+
+
+/* packet types */
+(
+  0x02 FHS_PACKET 
+  0x03 DM1_PACKET 
+  0x03 DM1_LMP_PACKET 
+  0x04 DH1_PACKET 
+  0x05 HV1_PACKET 
+  0x06 HV2_PACKET 
+  0x07 HV3_PACKET 
+  0x08 DV_PACKET 
+  0x09 AUX1_PACKET 
+  0x0a DM3_PACKET 
+  0x0b DH3_PACKET 
+  0x0e DM5_PACKET 
+  0x0f DH5_PACKET 
+)
+
+
+/* mem_lmp_respond */
+(
+  0 RESPOND_TO_ALL
+  1 PASS_EVERYTHING
+  2 PASS_ONLY_UNKNOWNS
+  3 RESPOND_TO_LMPS
+)
+/* SCO algorithm defines */
+(
+  0 ULAW
+  1 ALAW
+  2 CVSD
+)
+/* encryption modes */
+(
+  0 NO_ENCRYPTION
+  1 PT_PT_ENCRYPTION
+  2 PT_BROADCAST_ENCRYPTION
+)
+
+/* bits used in mem_lmp_state1 variable */
+(
+  0 LMP_STATE_DETACH
+  1 LMP_STATE_HOLD
+  2 LMP_STATE_SNIFF
+  3 LMP_STATE_PARK
+  4 LMP_STATE_WAIT_SCO_CREATE
+  5 LMP_STATE_WAIT_SCO_KILL
+  6 LMP_STATE_SCO3
+  7 LMP_STATE_WAIT_SCO_START
+)
+/* mem_lmp_state2 */
+(
+  0 LMP_WAIT_FOR_SNIFF_ACCEPT
+  1 LMP_WAIT_FOR_PARK_ACCEPT
+  2 LMP_SEND_UNPARK_ACCEPTED
+  3 LMP_SEND_ENCRYPTION_START
+  4 LMP_SEND_ENCRYPTION_STOP
+  5 MESSAGE_QUEUE
+  7 LMP_STATE_WAIT_BEACON
+)
+/* mem_lmp_state3 */
+(
+ 0 INQUIRY_STATE_CHECK
+ 1 HOST_DELAY_MESSAGE
+ 2 VARIABLE_DELAY
+ 3 TEST_MODE_START_LOOPBACK
+ 4 TEST_MODE_START_PATTERN
+ 5 PARSE_TEST_CONTROL_MESSAGE
+ 6 H_AUTH_SEND_COMB_KEY
+)
+/* mem_rx_status */
+(
+  0 FROM_MASTER
+)
+/* mem_ms_flag */
+(
+  0 MS_RECEIVE_SWITCH_REQ
+  1 MS_SEND_SETUP_COMPLATE
+)
+/* mem_conn_sm */
+(
+  0 CONN_SM_STANDBY
+  1 CONN_SM_WAIT_PAGE
+  2 CONN_SM_SEND_FEATURES
+  3 CONN_SM_WAIT_FEATURES_RES
+  4 CONN_SM_SEND_CONN_REQ
+  5 CONN_SM_WAIT_CONN_ACCEPT
+  6 CONN_SM_AUTH_PAIR
+  7 CONN_SM_AUTH_PAIR_WAIT
+  8 CONN_SM_WAIT_MUTAL_AUTH
+  9 CONN_SM_ENCRYPT
+  0xa CONN_SM_ENCRYPT_WAIT
+  0xb CONN_SM_ENCRYPT_WAIT_CLEAR
+  0xc CONN_SM_SEND_SETUP_COMPLETE
+  0xd CONN_SM_WAIT_SETUP_COMPLETE 
+  0xe CONN_SM_SEND_SWITCH
+  0xf CONN_SM_DETACH_DELAY
+  0x10 CONN_SM_WAIT_SWITCH_AFTER_HOST_CONNECTION
+  0x11 CONN_SM_DELAY_RESTART_CONNECTION
+  0x12 CONN_SM_SEND_VERSION
+  0X13 CONN_SM_WAIT_VERSION
+  0x14 CONN_SM_SEND_FEATURES_EXT
+  0x15 CONN_SM_WAIT_FEATURES_EXT
+  0x16 CONN_SM_PAIRING
+  0x17 CONN_SM_AUTH
+  0x18 CONN_SM_PAIRING_WAIT
+  0x19 CONN_SM_AUTH_WAIT
+  0x1a CONN_SM_DONE
+  0x1b CONN_SM_WAIT_DONE
+)
+
+/* btStateConn1 */
+(
+  0 CONN_STANDBY
+  1 CONN_MASTER_SEND_CONN_REQ
+  2 CONN_MASTER_WAIT_FOR_CONN_ACCEPTED
+  3 CONN_MASTER_AUTH
+  4 CONN_MASTER_WAIT_FOR_FEATURES
+  5 CONN_MASTER_WAIT_FOR_SETUP_COMPLETE
+  6 CONN_MASTER_WAIT_FOR_MAX_SLOT
+  7 CONN_SLAVE_CONN_REQUESTED
+  8 CONN_SLAVE_WAIT_FOR_SETUP_COMPLETE
+  9 CONN_SLAVE_AUTH
+  10 CONN_USING_HOST_OPCODE
+  11 CONN_SLAVE_AUTH_WAIT
+  12 CONN_SLAVE_ENCRYPT_WAIT
+)
+
+/* mem_lmp_conn_state */
+(
+  0 RECEIVED_CONN_REQ
+  1 SENT_CONN_REQ
+  2 RECEIVED_SETUP_COMPLETE
+  3 SENT_SETUP_COMPLETE
+  4 HOST_CONNECTION_MADE
+  6 INIT_COMPLETE
+  7 SNIFF_NEGOTIATE
+)
+/* btStateAuth1 */
+(
+  0 WAIT_FOR_KINIT
+  1 WAIT_FOR_LKA
+  2 WAIT_FOR_LKB
+  3 WAIT_FOR_SRES
+  4 EXAMINE_RECEIVED_SRES
+  5 SEND_AU_RAND
+  6 WAIT_FOR_KC
+  7 DELAYED_ENCRYPT_RESPONSE
+)
+/* btStateAuth2 */
+(
+  0 SENT_SRES
+  1 RECEIVED_IN_RAND
+  2 SENT_AU_RAND
+  3 AUTHENTICATION_FAILED
+  4 AUTHENTICATION_PASSED
+  5 STARTED_AUTH
+  6 SENT_COMB_KEY
+  7 SENT_IN_RAND
+)
+/* btStateAuth3 */
+(
+  0 RECEIVED_AU_RAND
+  1 RECEIVED_SRES
+  2 MUTUALLY_AUTHENTICATE
+)
+/* btStateHost */
+(
+  0 H_AUTH_STARTED
+  2 H_ENCRYPTION_MODE_REQ_PT
+  3 H_ENCRYPTION_KEY_SIZE
+  4 H_ENCRYPTION_START
+  5 H_ENCRYPTION_STOP
+  6 H_AUTH_SECOND_TRY
+)
+/* btStateEncrypt2 */
+(
+  0 RECEIVED_ENCRYPT_MODE_REQ_PT
+  1 RECEIVED_ENCRYPT_KEY_SIZE
+  2 RECEIVED_ENCRYPT_START
+  3 RECEIVED_ENCRYPT_STOP
+  4 STARTED_ENCRYPT_START
+)
+/* mem_ms_state */
+(
+  0x00 MS_STANDBY
+  0x11 M_MINIT_1
+  0x12 M_MINIT_2
+  0x20 M_SINIT_0
+  0x30 S_MINIT_0
+  0x31 S_MINIT_1
+  0x32 S_MINIT_2
+  0x41 S_SINIT_1
+  0x42 S_SINIT_2
+  0x43 S_SINIT_3
+)
+/* mem_test_mode */
+(
+  0 TEST_MODE_ALLOWED
+  1 TEST_MODE_ACTIVE
+)
+/* values for mem_tester_emulate */
+(
+  0x00 NO_TEST_MODE
+  0x00 CONTINUOUS_TRANSMIT
+  0x10 TRANSMIT_TEST
+  0x08 LOOPBACK
+)
+
+/* mem_tx_misc */
+(
+  1 SEND_TX_ADDR
+)
+/* BBHWREG_page_stat */
+(
+  5 PAGE_MODE_END
+)
+/* host_return_parameters_status codes */
+(
+  0x00 HOST_RETURN_SUCCESS
+  0x01 HOST_RETURN_SLAVE_CANT_ISSUE
+  0x02 HOST_RETURN_NO_CONNECTION
+  0x04 HOST_RETURN_PAGE_TIMEOUT
+  0x05 HOST_RETURN_INQUIRY_TIMEOUT
+  0x08 HOST_RETURN_CONNECTION_TIMEOUT
+  0x09 HOST_RETURN_MAX_NUM_CONNECTIONS
+  0x0a HOST_RETURN_MAX_NUM_SCO
+  0x0b HOST_RETURN_MAX_NUM_ACL
+  0x0c HOST_RETURN_SECURITY_REASONS
+  0x10 HOST_RETURN_HOST_TIMEOUT
+  0x11 HOST_RETURN_UNSUPPORTED_FEATURE_PARAMETER
+  0x13 HOST_RETURN_OTHER_END_USER
+  0x14 HOST_RETURN_OTHER_END_LOW_RESOURCE
+  0x15 HOST_RETURN_OTHER_END_POWER_OFF
+  0x16 HOST_RETURN_LOCAL_HOST
+  0x18 HOST_RETURN_PAIRING_NOT_ALLOWED
+  0x19 HOST_RETURN_UNKNOWN_PDU
+  0x1a HOST_RETURN_UNSUPPORTED_REMOTE_FEATURE
+  0x1d HOST_RETURN_SCO_AIR_MODE_REJECTED
+  0x20 HOST_RETURN_UNSUPPORTED_LMP_VALUE
+  0x21 HOST_RETURN_AUTHENTICATION_FAILURE
+  0x22 HOST_RETURN_CHANGED_EXISTING_SCO
+  0x23 HOST_RETURN_HOST_REJECTED
+  0x24 HOST_RETURN_UNSPECIFIED_ERROR
+  0x25 HOST_RESET
+  0x26 HOST_RETURN_BAD_HANDLE
+
+  0x00 HOST_RETURN_ACCEPT_COMMAND
+  0x01 HOST_RETURN_REJECT_COMMAND
+)
+/* host_present */
+(
+  0 HOST_IS_PRESENT
+  1 BCI_IS_PRESENT
+  2 DONT_INIT_RADIO
+)
+/* mem_master_state */
+(
+  0 MASTER_STATE_STANDBY
+  1 MASTER_INQUIRY
+)
+/* misc */
+(
+  92 SECOND_SWITCH_REQ
+  93 SLAVE_DELAY_DETACH
+  94 MASTER_DELAY_DETACH
+  95 UNSNIFF_DELAY_DETACH
+  0 WE_STARTED_AS_MASTER
+  1 WE_STARTED_AS_SLAVE
+)
+/* mem_host_commands */
+(
+  0x01 HOST_INQUIRY
+  0x02 HOST_INQUIRY_CANCEL
+  0x03 HOST_CREATE_CONNECTION
+  0x04 HOST_DISCONNECT_CONNECTION
+  0x05 HOST_ADD_SCO_REQUEST
+  0x06 HOST_REMOTE_NAME_REQUEST
+  0x07 HOST_WRITE_SUPPORTED_FEATURES
+  0x08 HOST_SET_TX_LEVEL
+  0x09 HOST_SET_RX_LEVEL
+  0x0a HOST_SNIFF_REQUEST
+  0x0b HOST_UNSNIFF_REQUEST
+  0x0c HOST_WRITE_LINK_SUPERVISION_TIMEOUT
+  0x0e HOST_WRITE_SCAN_ENABLE
+  0x0f HOST_READ_AUDIO_QUALITY
+  0x10 HOST_ENABLE_DEVICE_UNDER_TEST
+  0x14 HOST_BUTTON_CONFIGURE
+  0x15 HOST_SET_LOW_BATTERY_LEVEL
+  0x16 HOST_WRITE_LOCAL_NAME
+  0x17 HOST_WRITE_LOCAL_PIN
+  0x18 HOST_KILL_SCO_REQUEST
+  0x19 HOST_QOS_REQ
+
+  0x1a HOST_FEATURES_REQUEST
+  0x1b HOST_VERSION_REQUEST
+  0x1c HOST_TIMING_REQUEST
+  0x1d HOST_CLK_OFFSET_REQUEST
+  0x1e HOST_AUTHENTICATE
+  0x1f HOST_START_ENCRYPTION
+  0x20 HOST_STOP_ENCRYPTION
+  0x21 HOST_HOLD_REQUEST
+  0x22 HOST_HOLD_FORCE
+  0x23 HOST_PARK_REQUEST
+  0x24 HOST_MOD_BEACON
+  0x25 HOST_SET_BROADCAST_SCAN_WINDOW
+  0x26 HOST_UNPARK_PM_REQUEST
+  0x27 HOST_UNPARK_BD_REQUEST
+  0x28 HOST_SLAVE_REQUEST_UNPARK
+  0x29 HOST_DECREASE_POWER_REQUEST
+  0x2a HOST_INCREASE_POWER_REQUEST
+  0x2b HOST_SEND_PREFERRED_RATE
+  0x2c HOST_MAX_SLOT_REQ
+  0x2d HOST_MAX_SLOT_FORCE
+  0x2e HOST_PAGE_MODE_REQUEST
+  0x2f HOST_PAGE_SCAN_MODE_REQUEST
+  0x30 HOST_MASTER_SLAVE_SWITCH
+  0x31 HOST_SEND_AUTO_RATE
+  0x32 HOST_PAGE_CANCEL
+  0x33 HOST_CHANGE_LINK_KEY
+  0x34 HOST_RADIO_READ
+  0x35 HOST_RADIO_WRITE
+  0x36 HOST_REMOTE_SLAVE_INIT_UNPARK_REQUESTED
+
+  0x40 HOST_REMOTE_CONNECTION_REQUESTED
+  0x41 HOST_REMOTE_DETACH
+  0x42 HOST_REMOTE_SCO_CREATE_REQUESTED
+  0x43 HOST_REMOTE_SCO_KILL_REQUESTED
+  0x44 HOST_REMOTE_PARK_REQUESTED
+  0x45 HOST_REMOTE_UNPARK_REQUESTED
+  0x46 HOST_REMOTE_SNIFF_REQUESTED
+  0x47 HOST_REMOTE_UNSNIFF_REQUESTED
+  0x48 HOST_REMOTE_HOLD_REQUESTED
+  0x49 HOST_REMOTE_AUTHENTICATION
+  0x4a HOST_REMOTE_START_ENCRYPTION_REQUESTED
+  0x4b HOST_REMOTE_STOP_ENCRYPTION_REQUESTED
+  0x4c HOST_MODE_CHANGE_EVENT
+  0x4d HOST_REMOTE_TEST_ACTIVATE
+  0x4e HOST_REMOTE_TEST_CONTROL
+  0x4f HOST_REMOTE_TIMING_REQUEST
+)
+/* BCI interface (not used if not compiled in ) */
+(
+  0x01 BCI_INQUIRY
+  0x02 BCI_INQUIRY_CANCEL
+  0x03 BCI_CREATE_CONNECTION
+  0x04 BCI_DISCONNECT
+  0x05 BCI_ADD_SCO_CONNECTION
+  0x06 BCI_REMOTE_NAME_REQUEST
+  0x07 BCI_WRITE_SUPPORTED_FEATURES
+  0x08 BCI_SET_TX_POWER_LEVEL
+  0x09 BCI_SET_RX_POWER_LEVEL
+  0x0a BCI_SNIFF_MODE
+  0x0b BCI_EXIT_SNIFF_MODE
+  0x0c BCI_WRITE_LINK_SUPERVISION_TIMEOUT
+  0x0d BCI_WRITE_PAGE_TIMEOUT
+  0x0e BCI_WRITE_SCAN_ENABLE
+  0x0f BCI_GET_AUDIO_QUALITY
+  0x10 BCI_ENABLE_DEVICE_UNDER_TEST
+  0x11 BCI_SEND_DATA
+  0x12 BCI_REGISTER_SERVICE_RECORD
+  0x13 BCI_SERVICE_SEARCH_ATTRIB_REQ
+  0x14 BCI_BUTTON_CONFIGURE
+  0x15 BCI_SET_LOW_BATTERY_LEVEL
+  0x16 BCI_WRITE_LOCAL_NAME
+  0x17 BCI_WRITE_LOCAL_PIN
+  0x18 BCI_REMOVE_SCO_CONNECTION
+  0x19 BCI_QUALITY_OF_SERVICE
+  0x40 BCI_REMOTE_CONNECTION_REQUEST
+  0x41 BCI_REMOTE_DETACH
+  0x42 BCI_REMOTE_ADD_SCO_REQUEST
+  0x43 BCI_REMOTE_REMOVE_SCO_REQUEST
+  0x44 BCI_REMOTE_PARK_REQUEST
+  0x45 BCI_REMOTE_UNPARK_REQUEST
+  0x46 BCI_REMOTE_SNIFF_REQUEST
+  0x47 BCI_REMOTE_UNSNIFF_REQUEST
+  0x48 BCI_REMOTE_HOLD_REQUEST
+  0x49 BCI_REMOTE_AUTHENTICATION_PAIRING_REQUEST
+  0x4a BCI_REMOTE_START_ENCRYPTION_REQUEST
+  0x4b BCI_REMOTE_STOP_ENCRYPTION_REQUEST
+  0x4c BCI_MODE_CHANGE_EVENT
+)
+/* mode changes */
+(
+  0 MODE_CHANGE_ACTIVE
+  1 MODE_CHANGE_SNIFFING
+  2 MODE_CHANGE_PARKED
+  3 MODE_CHANGE_HOLDING
+  4 MODE_CHANGE_SCO_ADDED
+  5 MODE_CHANGE_SCO_REMOVED
+  6 MODE_CHANGE_ACL_CONNECTION
+  7 MODE_CHANGE_DISCONNECT
+  8 MODE_CHANGE_SCO_CHANGED
+  9 MODE_CHANGE_ENCRYPTING
+  10 MODE_CHANGE_NOT_ENCRYPTING
+  11 MODE_CHANGE_BUTTON_UP
+  12 MODE_CHANGE_BUTTON_DOWN
+  13 MODE_CHANGE_BATTERY_LOW
+  14 MODE_CHANGE_RESET
+  15 MODE_CHANGE_INQUIRY_CANCELED_RMTCMD
+  16 MODE_ACTIVE_MSSWITCH_PASSED
+  17 MODE_ACTIVE_MSSWITCH_FAILED
+)
+/* mem_battery - low nibble is level information, upper nibble is status info */
+(
+  6 BATTERY_CHECK_LEVEL
+  7 BATTERY_SENT_STATUS
+)
+/* mem_radio_version */
+(
+  0x02 RADIO_2001
+  0x12 RADIO_2002
+  0x32 RADIO_2002_DDM
+  0x42 RADIO_1008A1
+  0x52 RADIO_1018A0
+)
+/* mem_slave_initiated_conn */
+(
+  0 SLAVE_INIT_AUTHENTICATION
+  1 SLAVE_INIT_ENCRYPTION
+  2 SLAVE_INIT_MASTER_SLAVE_SWITCH
+)
+/* connection_options */
+(
+  0 CONNECTION_AUTH
+  1 CONNECTION_ENCRYPT
+  2 CONNECTION_SWITCH
+  3 CONNECTION_ACL
+  4 CONNECTION_FEATURE_EXT
+)
+/* mem_debug_config */
+(
+  7 AA_INSERTION
+)
+
Index: btkb/output/eeprom.dat
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/output/eeprom.dat	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/output/eeprom.dat	(working copy)
@@ -0,0 +1,7953 @@
+00
+02
+aa
+55
+b2
+19
+c5
+12
+80
+10
+c0
+00
+00
+2c
+c0
+01
+00
+30
+c0
+01
+80
+38
+c0
+02
+80
+42
+c0
+48
+01
+b5
+c0
+49
+01
+7b
+c0
+4a
+01
+81
+c0
+4a
+81
+6b
+c0
+58
+02
+99
+c0
+58
+81
+2f
+c0
+59
+01
+43
+c0
+59
+81
+5d
+c0
+5b
+01
+66
+c0
+5c
+81
+37
+20
+20
+3b
+f1
+c0
+19
+02
+a7
+c0
+1d
+d3
+b0
+c0
+1f
+02
+2d
+c0
+1f
+82
+31
+c0
+25
+03
+14
+c0
+25
+82
+a0
+c0
+26
+02
+aa
+c0
+27
+02
+b0
+c0
+2b
+02
+b7
+c0
+2d
+02
+c3
+c0
+30
+82
+be
+c0
+31
+82
+e3
+c0
+32
+03
+08
+c0
+32
+83
+3e
+c0
+34
+84
+a0
+c0
+35
+04
+84
+c0
+35
+84
+86
+c0
+37
+04
+ab
+c0
+37
+83
+1f
+c0
+43
+81
+03
+c0
+46
+82
+4c
+c0
+47
+02
+63
+c0
+47
+82
+35
+c0
+5e
+82
+43
+c0
+66
+81
+bf
+c0
+67
+81
+0f
+c0
+68
+01
+19
+20
+20
+3b
+f1
+68
+10
+81
+3b
+60
+00
+8b
+81
+70
+80
+06
+08
+20
+20
+30
+03
+20
+40
+77
+19
+20
+55
+bc
+f1
+20
+40
+78
+13
+68
+00
+c7
+dc
+20
+3a
+30
+13
+68
+00
+c7
+93
+20
+3a
+00
+32
+20
+20
+30
+13
+20
+40
+00
+9d
+20
+40
+00
+8f
+20
+40
+00
+47
+20
+40
+00
+3d
+20
+20
+30
+15
+68
+09
+47
+f4
+68
+00
+c3
+d8
+7d
+3a
+04
+0b
+60
+09
+47
+f4
+20
+60
+00
+00
+20
+40
+33
+92
+20
+40
+34
+07
+20
+40
+30
+24
+20
+40
+04
+cc
+20
+20
+30
+22
+68
+00
+c7
+dc
+20
+3a
+00
+4b
+68
+00
+c7
+93
+20
+7a
+00
+00
+20
+40
+00
+fe
+20
+74
+00
+00
+1f
+f0
+fe
+00
+1f
+e2
+0c
+00
+20
+40
+00
+df
+60
+00
+cb
+a7
+c0
+00
+80
+5f
+c0
+03
+00
+69
+1f
+e2
+04
+00
+18
+c2
+22
+00
+68
+00
+c0
+40
+c3
+00
+00
+5c
+1a
+22
+0c
+00
+c6
+84
+80
+00
+18
+42
+7e
+00
+c0
+02
+80
+6b
+20
+20
+3b
+f1
+1a
+22
+0c
+00
+d8
+a0
+00
+f8
+20
+20
+00
+d7
+20
+40
+00
+df
+20
+40
+00
+df
+60
+00
+8b
+7d
+20
+40
+00
+64
+20
+20
+7c
+33
+20
+40
+00
+e2
+18
+c2
+04
+00
+18
+50
+84
+00
+60
+09
+4b
+9a
+20
+60
+00
+00
+d8
+a0
+4d
+57
+20
+20
+00
+d7
+18
+c2
+22
+00
+68
+00
+cb
+a9
+1f
+e0
+84
+01
+18
+41
+04
+03
+60
+08
+cb
+a9
+1f
+ef
+fe
+07
+d8
+a0
+4b
+ad
+98
+a0
+8a
+00
+1a
+22
+0c
+00
+20
+40
+00
+df
+18
+c2
+22
+00
+1f
+e0
+ff
+ff
+1f
+e2
+72
+00
+1f
+e0
+fe
+07
+60
+00
+cc
+82
+1a
+22
+0c
+00
+20
+40
+00
+df
+18
+c2
+22
+00
+c0
+00
+80
+81
+c0
+01
+00
+89
+c0
+01
+80
+8b
+c0
+02
+00
+8d
+68
+01
+4c
+b8
+e0
+a1
+00
+00
+1a
+22
+0c
+00
+20
+40
+00
+d9
+20
+40
+56
+1e
+24
+7a
+00
+00
+70
+0b
+7d
+1b
+20
+20
+56
+20
+68
+01
+4c
+ba
+20
+20
+00
+82
+68
+01
+4c
+bc
+20
+20
+00
+82
+68
+01
+4d
+3e
+20
+20
+00
+82
+68
+0a
+4d
+4b
+1c
+42
+7e
+00
+98
+46
+7e
+00
+68
+09
+4d
+4f
+98
+46
+fc
+00
+20
+40
+7e
+fd
+18
+07
+fe
+00
+20
+7a
+00
+00
+1c
+42
+04
+00
+60
+0a
+4d
+4b
+68
+00
+cd
+51
+1f
+e0
+fe
+01
+60
+00
+cd
+51
+20
+60
+00
+00
+68
+0a
+4c
+59
+1c
+42
+7e
+00
+98
+46
+7e
+00
+d8
+40
+06
+40
+98
+46
+fc
+00
+20
+40
+7e
+fd
+18
+07
+fe
+00
+20
+7a
+00
+00
+1c
+42
+04
+00
+60
+0a
+4c
+59
+68
+09
+4b
+a5
+18
+50
+84
+00
+98
+40
+fe
+00
+1f
+f0
+fe
+00
+60
+01
+4b
+a5
+1f
+f0
+fe
+00
+1f
+e1
+7e
+03
+c1
+80
+00
+00
+68
+00
+cc
+8f
+c2
+80
+00
+ba
+c2
+80
+80
+bc
+da
+20
+00
+00
+20
+40
+00
+ce
+70
+89
+71
+8f
+68
+00
+cc
+90
+60
+10
+89
+73
+20
+40
+00
+bd
+da
+20
+00
+01
+20
+20
+00
+ce
+70
+89
+71
+bf
+20
+20
+00
+bd
+70
+89
+71
+af
+68
+10
+80
+53
+79
+20
+7e
+07
+60
+10
+80
+53
+68
+10
+89
+73
+1f
+e1
+fe
+30
+60
+10
+89
+73
+70
+89
+06
+74
+70
+89
+06
+7c
+70
+89
+72
+aa
+20
+00
+13
+88
+68
+19
+01
+50
+68
+10
+80
+53
+79
+3f
+fe
+07
+60
+10
+80
+53
+18
+50
+84
+00
+60
+09
+4c
+95
+20
+60
+00
+00
+d8
+40
+00
+21
+68
+00
+cc
+90
+98
+46
+04
+00
+1a
+22
+7e
+00
+79
+20
+04
+07
+24
+3a
+00
+d5
+79
+3f
+84
+07
+d8
+a0
+80
+78
+20
+20
+69
+f4
+20
+40
+00
+df
+1f
+e2
+72
+00
+20
+40
+00
+db
+20
+20
+00
+64
+20
+40
+00
+df
+e0
+a0
+80
+00
+c2
+00
+00
+db
+20
+60
+00
+00
+20
+40
+00
+e2
+e8
+c0
+80
+00
+20
+60
+00
+00
+58
+00
+4b
+36
+98
+c6
+7c
+00
+24
+62
+80
+00
+d8
+c0
+4a
+a0
+20
+60
+00
+00
+df
+20
+00
+03
+d8
+c0
+4b
+a2
+18
+c2
+22
+00
+68
+01
+4b
+a0
+1f
+f0
+fe
+00
+1f
+e2
+0a
+00
+1a
+22
+0c
+00
+e8
+c0
+80
+00
+e0
+a0
+80
+00
+20
+40
+00
+f6
+c2
+00
+00
+ee
+18
+a2
+7e
+00
+1f
+f0
+fe
+00
+60
+01
+4b
+a0
+20
+60
+00
+00
+58
+00
+4b
+9a
+98
+a6
+7c
+00
+24
+62
+80
+00
+d8
+a0
+4b
+36
+20
+60
+00
+00
+68
+01
+4b
+9e
+68
+09
+4b
+a0
+20
+20
+01
+00
+68
+01
+4b
+9a
+68
+09
+4b
+9c
+98
+46
+7c
+00
+20
+22
+e9
+b1
+20
+20
+32
+0b
+1c
+42
+7e
+00
+60
+02
+4d
+47
+68
+08
+c7
+ef
+68
+00
+cd
+4a
+98
+46
+7c
+00
+24
+41
+01
+0a
+20
+20
+7c
+06
+68
+0a
+4d
+47
+60
+0a
+47
+ec
+60
+0a
+4c
+59
+60
+0a
+4d
+4b
+20
+60
+00
+00
+da
+20
+47
+df
+20
+40
+7f
+9f
+20
+7a
+00
+00
+1f
+e2
+26
+00
+20
+40
+01
+15
+20
+20
+3e
+a5
+c1
+0c
+00
+00
+c0
+0a
+04
+bd
+c0
+0a
+82
+9e
+20
+20
+3e
+7d
+60
+08
+82
+59
+68
+00
+cc
+8d
+1f
+e0
+fe
+01
+60
+00
+cc
+8d
+68
+00
+82
+59
+20
+7a
+00
+00
+1f
+e0
+ff
+ff
+60
+00
+82
+59
+20
+40
+01
+23
+20
+20
+01
+1d
+68
+00
+cc
+15
+20
+7a
+00
+00
+1f
+e0
+ff
+ff
+60
+00
+cc
+15
+20
+60
+00
+00
+1a
+62
+7e
+00
+1f
+e1
+7e
+f0
+c1
+28
+00
+00
+1a
+62
+7e
+00
+20
+7a
+00
+00
+60
+00
+cb
+a4
+20
+20
+00
+e7
+70
+41
+6e
+7f
+20
+40
+3c
+f3
+68
+00
+cc
+97
+20
+7a
+00
+00
+70
+4c
+97
+00
+1c
+42
+7e
+00
+60
+02
+4c
+59
+20
+60
+00
+00
+68
+00
+c2
+19
+24
+7a
+00
+00
+70
+80
+42
+06
+58
+00
+0f
+0c
+20
+40
+3d
+a7
+58
+03
+0d
+40
+20
+40
+3b
+f3
+37
+d9
+82
+00
+1e
+22
+60
+00
+20
+40
+3b
+36
+20
+00
+13
+88
+20
+20
+3d
+9d
+c6
+11
+80
+00
+68
+01
+47
+f4
+c2
+84
+bd
+1e
+20
+40
+3c
+ab
+68
+01
+c2
+10
+20
+7a
+00
+00
+68
+00
+c1
+31
+20
+7a
+00
+00
+20
+40
+52
+7e
+24
+7a
+00
+00
+20
+40
+3d
+ca
+24
+7a
+00
+00
+20
+40
+3b
+36
+68
+00
+c7
+dc
+20
+3a
+3d
+25
+68
+00
+c7
+93
+20
+7a
+00
+00
+20
+20
+3d
+25
+20
+40
+00
+fe
+24
+74
+00
+00
+20
+40
+00
+fb
+24
+74
+00
+00
+70
+0b
+7f
+01
+70
+0b
+7e
+01
+20
+40
+01
+62
+20
+20
+00
+fe
+20
+40
+01
+55
+24
+74
+00
+00
+68
+00
+8b
+7f
+24
+7a
+00
+00
+20
+20
+3d
+2d
+68
+00
+8b
+7e
+20
+00
+00
+0a
+c0
+80
+01
+62
+20
+60
+00
+00
+20
+40
+01
+55
+24
+74
+00
+00
+68
+00
+8b
+7f
+24
+7a
+00
+00
+20
+20
+3d
+4f
+20
+40
+01
+6d
+20
+20
+3a
+af
+68
+00
+c2
+19
+24
+3a
+01
+73
+20
+40
+3d
+91
+20
+00
+75
+30
+20
+00
+75
+30
+20
+00
+75
+30
+20
+40
+3b
+0a
+70
+80
+42
+04
+68
+10
+89
+6b
+1f
+e1
+7e
+cf
+60
+10
+89
+6b
+1f
+e1
+fe
+30
+60
+10
+89
+6b
+20
+60
+00
+00
+60
+08
+80
+17
+18
+40
+a2
+04
+20
+20
+3a
+86
+60
+08
+80
+17
+18
+40
+a2
+00
+20
+20
+3a
+b6
+20
+40
+01
+7e
+58
+00
+05
+00
+20
+40
+3b
+f3
+70
+89
+06
+01
+70
+89
+00
+3c
+70
+89
+01
+e0
+70
+89
+6d
+12
+20
+00
+00
+0a
+70
+89
+02
+01
+70
+89
+02
+3d
+20
+00
+00
+0a
+70
+89
+03
+b7
+20
+00
+00
+0a
+70
+89
+02
+7d
+68
+00
+cb
+ef
+c0
+ff
+81
+99
+68
+02
+ca
+91
+e0
+a2
+80
+00
+e8
+c2
+80
+00
+e0
+a2
+80
+00
+70
+89
+56
+df
+20
+40
+01
+a4
+70
+89
+55
+df
+20
+60
+00
+00
+68
+02
+ca
+87
+e0
+a2
+80
+00
+e8
+c2
+80
+00
+e0
+a2
+80
+00
+68
+00
+cc
+7d
+20
+5a
+01
+a2
+60
+10
+89
+56
+70
+89
+55
+d0
+20
+60
+00
+00
+58
+00
+00
+c2
+20
+60
+00
+00
+20
+00
+00
+04
+70
+89
+55
+d1
+20
+00
+00
+04
+70
+89
+55
+d2
+20
+00
+00
+04
+70
+89
+55
+d4
+20
+00
+00
+04
+20
+60
+00
+00
+70
+89
+55
+d4
+20
+00
+00
+04
+70
+89
+55
+d2
+20
+00
+00
+04
+70
+89
+55
+d1
+20
+00
+00
+04
+70
+89
+55
+d0
+70
+89
+56
+c0
+20
+60
+00
+00
+20
+30
+ba
+6f
+20
+40
+01
+ac
+20
+20
+3a
+6f
+78
+34
+7c
+00
+68
+12
+01
+38
+79
+34
+7e
+1a
+60
+12
+00
+4c
+20
+40
+3d
+b0
+70
+00
+a2
+01
+20
+60
+00
+00
+68
+00
+c4
+19
+1f
+e0
+fe
+02
+60
+00
+c3
+f9
+70
+0b
+7e
+00
+70
+01
+77
+06
+20
+40
+3f
+a4
+58
+00
+01
+be
+60
+01
+42
+8a
+58
+00
+01
+28
+60
+01
+42
+92
+58
+00
+02
+34
+60
+01
+42
+90
+58
+00
+00
+47
+60
+01
+42
+8c
+58
+00
+01
+b8
+60
+01
+42
+88
+58
+00
+4a
+a0
+1f
+f0
+fe
+00
+60
+01
+4b
+9a
+60
+01
+4b
+9c
+20
+40
+3e
+0b
+58
+00
+4b
+36
+1f
+f0
+fe
+00
+60
+01
+4b
+9e
+60
+01
+4b
+a0
+68
+00
+cc
+97
+c0
+2d
+01
+f0
+20
+35
+81
+ee
+68
+01
+4c
+91
+1f
+f0
+fe
+00
+60
+01
+4c
+91
+68
+01
+4c
+93
+1f
+f0
+fe
+00
+60
+01
+4c
+93
+20
+40
+01
+fb
+68
+04
+02
+a0
+24
+3a
+01
+e8
+68
+01
+4a
+d4
+1f
+f0
+fe
+00
+20
+3a
+01
+e8
+60
+01
+4c
+93
+20
+40
+04
+c9
+70
+4b
+a4
+2f
+20
+40
+00
+e7
+70
+4c
+97
+00
+70
+82
+80
+03
+20
+60
+00
+00
+70
+4b
+a4
+30
+20
+20
+01
+ea
+1c
+e2
+7e
+00
+20
+3a
+02
+3b
+20
+40
+5b
+63
+20
+40
+4d
+99
+58
+00
+00
+00
+60
+04
+40
+40
+60
+01
+47
+f4
+1c
+42
+7e
+00
+60
+02
+4c
+59
+70
+4b
+a4
+33
+20
+20
+01
+ea
+20
+40
+68
+8a
+58
+00
+07
+e0
+da
+20
+02
+a0
+d8
+40
+00
+0e
+20
+40
+68
+d3
+20
+40
+68
+8d
+68
+00
+82
+a0
+c2
+80
+bb
+f1
+68
+04
+02
+a2
+20
+7a
+00
+00
+68
+00
+cc
+8f
+c2
+80
+02
+0f
+c2
+80
+82
+1d
+68
+01
+02
+a2
+1f
+f0
+fe
+00
+60
+01
+4c
+91
+68
+01
+02
+a8
+1f
+f0
+fe
+00
+60
+01
+4c
+93
+20
+60
+00
+00
+68
+09
+02
+a6
+68
+01
+02
+ac
+18
+42
+24
+00
+1f
+e2
+22
+00
+1f
+f0
+fe
+00
+60
+01
+4c
+93
+1a
+22
+7e
+00
+98
+46
+26
+00
+1a
+63
+a6
+00
+1a
+42
+7e
+00
+9a
+66
+7e
+00
+1f
+f0
+fe
+00
+60
+01
+4c
+91
+20
+60
+00
+00
+68
+09
+02
+a4
+68
+01
+02
+aa
+18
+42
+24
+00
+1f
+e2
+22
+00
+98
+46
+26
+00
+1a
+6b
+26
+00
+1a
+42
+7e
+00
+9a
+66
+7e
+00
+1f
+f0
+fe
+00
+60
+01
+4c
+91
+1a
+63
+a6
+00
+1a
+22
+7e
+00
+9a
+66
+7e
+00
+1f
+f0
+fe
+00
+60
+01
+4c
+93
+20
+60
+00
+00
+70
+00
+16
+27
+70
+89
+0f
+36
+70
+89
+0b
+5f
+20
+20
+53
+d4
+70
+89
+0f
+2e
+70
+89
+0b
+ff
+20
+20
+53
+d9
+20
+60
+00
+00
+68
+01
+4b
+a0
+60
+01
+4b
+9e
+68
+01
+4b
+9c
+60
+01
+4b
+9a
+70
+0b
+7e
+03
+20
+40
+01
+62
+70
+4c
+97
+5a
+20
+40
+3d
+b8
+68
+12
+01
+38
+79
+3f
+fe
+0f
+60
+12
+00
+4c
+20
+40
+3d
+b0
+d8
+5f
+ff
+ff
+20
+20
+3c
+da
+ea
+2a
+80
+00
+18
+41
+7e
+ff
+24
+3a
+02
+48
+18
+4c
+fe
+00
+e2
+22
+80
+00
+1a
+20
+a2
+04
+ea
+20
+80
+00
+24
+7a
+00
+00
+20
+20
+7f
+9c
+20
+40
+7c
+20
+da
+20
+47
+e4
+20
+40
+7f
+9f
+1f
+e2
+04
+00
+20
+40
+7c
+24
+18
+42
+7e
+00
+20
+7a
+00
+00
+c0
+10
+82
+5c
+c0
+11
+02
+5e
+c0
+11
+85
+5c
+c0
+06
+82
+6c
+c0
+16
+02
+6c
+c0
+15
+82
+77
+c0
+15
+02
+91
+c0
+09
+7c
+85
+20
+20
+7c
+5a
+70
+4b
+ef
+ff
+20
+20
+05
+8f
+79
+3f
+80
+23
+70
+4b
+ef
+ff
+20
+20
+05
+47
+70
+0b
+7d
+22
+20
+20
+56
+20
+68
+00
+80
+7c
+20
+3a
+02
+68
+20
+40
+61
+d9
+68
+00
+80
+7c
+24
+3a
+7c
+8c
+68
+00
+8b
+7d
+c5
+84
+fc
+87
+c0
+08
+82
+61
+20
+20
+7c
+7b
+20
+40
+3e
+ff
+20
+40
+7c
+d5
+70
+41
+31
+00
+18
+0a
+7e
+00
+60
+00
+c4
+f9
+70
+43
+dc
+05
+58
+18
+12
+03
+60
+01
+c3
+e2
+d8
+40
+00
+07
+20
+40
+02
+7d
+20
+20
+7c
+ae
+70
+43
+dc
+04
+58
+00
+00
+ff
+60
+01
+c3
+e2
+d8
+40
+00
+00
+20
+40
+02
+7d
+20
+20
+7c
+ae
+68
+00
+c3
+f9
+98
+40
+fe
+00
+1f
+e0
+fe
+0b
+1f
+e6
+7c
+1f
+24
+21
+02
+8d
+60
+00
+c3
+d9
+d8
+a0
+43
+e5
+18
+42
+7e
+00
+24
+5a
+02
+8a
+68
+00
+c3
+f9
+1f
+e2
+72
+00
+d8
+c0
+43
+fa
+20
+20
+7e
+45
+1f
+e2
+72
+00
+d8
+c0
+4d
+6b
+20
+20
+7e
+45
+68
+00
+c3
+f9
+1f
+e0
+fe
+0b
+60
+00
+c3
+d9
+20
+60
+00
+00
+68
+01
+47
+f4
+c2
+84
+bf
+90
+c2
+83
+fc
+d5
+c5
+11
+85
+47
+70
+43
+d8
+00
+20
+40
+3f
+7e
+70
+0b
+7d
+37
+20
+20
+7c
+27
+20
+40
+3b
+36
+20
+20
+3c
+dc
+e8
+c0
+80
+00
+60
+00
+cc
+b7
+20
+60
+00
+00
+70
+4d
+7e
+00
+20
+20
+04
+c2
+20
+40
+54
+bd
+68
+08
+80
+17
+20
+40
+3a
+82
+20
+40
+3a
+87
+78
+28
+7c
+00
+d9
+60
+15
+7c
+20
+20
+54
+7f
+70
+44
+3e
+01
+70
+44
+3f
+00
+20
+20
+53
+4e
+20
+40
+53
+dd
+20
+40
+02
+ad
+20
+20
+54
+c1
+20
+36
+81
+84
+20
+40
+53
+ee
+20
+20
+3a
+91
+68
+00
+cc
+60
+60
+02
+46
+f9
+68
+00
+c4
+db
+c0
+00
+82
+b5
+20
+20
+54
+e0
+70
+44
+db
+00
+20
+20
+54
+ef
+68
+00
+83
+c0
+c4
+02
+80
+00
+68
+01
+03
+da
+68
+09
+03
+e0
+98
+46
+7e
+00
+24
+61
+00
+00
+20
+20
+55
+7e
+68
+00
+83
+d7
+c3
+82
+80
+00
+68
+00
+83
+41
+20
+3a
+56
+26
+20
+20
+58
+90
+68
+08
+83
+d7
+28
+4c
+00
+05
+20
+60
+80
+00
+68
+00
+83
+40
+1f
+e3
+fe
+00
+98
+42
+fe
+00
+c4
+01
+80
+00
+79
+3f
+84
+05
+79
+40
+04
+03
+60
+08
+83
+d7
+28
+40
+06
+03
+24
+60
+80
+00
+68
+00
+c4
+40
+c0
+02
+82
+d4
+68
+00
+cd
+7e
+c0
+00
+82
+d8
+20
+60
+00
+00
+68
+00
+83
+c0
+79
+20
+7e
+04
+60
+00
+83
+c0
+20
+60
+00
+00
+70
+4d
+7e
+00
+df
+e0
+00
+00
+60
+02
+44
+6f
+60
+00
+c4
+8b
+60
+02
+c4
+65
+79
+20
+7e
+27
+60
+02
+c4
+6a
+68
+00
+83
+c0
+79
+3f
+fe
+04
+60
+00
+83
+c0
+20
+60
+00
+00
+68
+00
+c4
+40
+c0
+03
+82
+fd
+c0
+07
+83
+01
+c0
+03
+02
+f0
+c0
+01
+02
+ed
+c0
+09
+82
+eb
+c0
+05
+82
+eb
+20
+20
+56
+3a
+18
+00
+04
+01
+20
+20
+58
+92
+58
+00
+00
+0a
+60
+01
+03
+ef
+20
+20
+56
+93
+70
+0b
+7d
+12
+20
+40
+7c
+33
+18
+00
+04
+01
+20
+34
+d8
+92
+70
+0b
+7d
+34
+20
+40
+7c
+27
+68
+00
+cc
+69
+c0
+01
+02
+f9
+20
+20
+02
+fb
+70
+0b
+7d
+46
+20
+40
+56
+20
+18
+00
+04
+01
+20
+20
+58
+92
+68
+00
+cc
+68
+e0
+a0
+80
+00
+18
+00
+04
+02
+20
+20
+58
+92
+18
+a0
+8b
+ff
+68
+04
+4c
+6c
+e0
+a4
+00
+00
+e8
+c4
+00
+00
+e0
+a4
+00
+00
+18
+00
+02
+02
+20
+20
+58
+8a
+68
+00
+c4
+44
+c0
+04
+d7
+19
+c0
+01
+03
+0d
+c0
+03
+d7
+0d
+20
+20
+56
+56
+59
+00
+03
+02
+60
+01
+c4
+b5
+58
+00
+00
+01
+e0
+a0
+80
+00
+58
+01
+00
+10
+e0
+a1
+80
+00
+20
+20
+56
+f1
+09
+80
+00
+18
+78
+28
+7c
+00
+db
+60
+06
+64
+1f
+ef
+7e
+00
+1f
+f1
+7e
+00
+e0
+a1
+80
+00
+20
+23
+37
+5c
+78
+36
+fc
+00
+68
+00
+80
+17
+1f
+e0
+a2
+00
+20
+20
+54
+af
+e8
+c1
+80
+00
+60
+01
+83
+f9
+c0
+29
+03
+25
+c0
+01
+03
+3c
+c0
+09
+03
+2b
+20
+20
+59
+07
+70
+4d
+38
+01
+68
+01
+03
+fa
+c0
+10
+83
+29
+20
+20
+59
+ed
+d8
+c0
+03
+49
+20
+20
+02
+9b
+68
+01
+03
+fa
+1f
+e6
+7c
+21
+20
+42
+83
+29
+68
+01
+03
+fa
+1f
+e6
+7c
+2d
+20
+42
+83
+3a
+68
+01
+03
+fa
+68
+09
+4c
+bc
+18
+40
+84
+01
+98
+46
+7c
+00
+20
+22
+83
+37
+20
+20
+59
+ca
+70
+0b
+7d
+34
+20
+40
+7c
+27
+20
+20
+59
+ca
+70
+41
+31
+01
+20
+60
+00
+00
+70
+0b
+7d
+03
+20
+20
+56
+20
+68
+00
+c4
+44
+c0
+0d
+84
+76
+c0
+0e
+84
+76
+c0
+08
+84
+0a
+c0
+04
+83
+bc
+c0
+02
+83
+aa
+c0
+03
+83
+5e
+c0
+09
+d8
+5c
+c0
+01
+83
+4f
+c0
+05
+83
+52
+c0
+06
+83
+4a
+20
+20
+56
+66
+68
+01
+03
+fa
+c0
+03
+83
+4d
+20
+20
+57
+d6
+70
+03
+fc
+07
+20
+20
+57
+29
+68
+01
+4c
+6a
+e0
+a1
+00
+00
+20
+20
+58
+8a
+68
+01
+03
+fa
+c0
+07
+03
+55
+20
+20
+57
+c6
+68
+00
+cc
+69
+c0
+80
+57
+c6
+68
+00
+cc
+7c
+c0
+01
+d7
+c6
+18
+a2
+04
+00
+70
+4c
+69
+01
+18
+42
+0a
+00
+70
+03
+fc
+05
+20
+20
+57
+29
+20
+40
+57
+7b
+20
+74
+00
+00
+68
+09
+44
+c0
+58
+00
+18
+12
+98
+46
+7c
+00
+20
+22
+83
+77
+58
+00
+18
+0f
+98
+46
+7c
+00
+20
+22
+83
+79
+58
+00
+18
+0a
+98
+46
+7c
+00
+20
+22
+83
+7d
+58
+00
+18
+01
+98
+46
+7c
+00
+20
+22
+83
+7b
+20
+20
+57
+54
+68
+00
+cc
+7f
+d8
+40
+00
+00
+f9
+20
+04
+00
+98
+41
+7e
+00
+c0
+80
+57
+28
+68
+00
+cc
+7f
+f9
+20
+7e
+00
+60
+00
+cc
+7f
+20
+20
+03
+7f
+d8
+e0
+00
+00
+20
+20
+03
+6e
+d8
+e0
+00
+01
+20
+20
+03
+6e
+d8
+e0
+00
+03
+20
+20
+03
+6e
+d8
+e0
+00
+02
+20
+20
+03
+6e
+68
+01
+44
+c0
+1f
+e2
+22
+00
+68
+09
+44
+c4
+18
+42
+24
+00
+20
+40
+03
+86
+20
+22
+83
+91
+20
+20
+57
+28
+d8
+c0
+45
+04
+e8
+c1
+00
+00
+20
+7a
+00
+00
+e8
+c1
+80
+00
+e8
+c1
+00
+00
+9a
+26
+7c
+00
+20
+62
+80
+00
+18
+c0
+8d
+fd
+e8
+c0
+80
+00
+98
+c0
+8c
+00
+20
+20
+03
+87
+18
+c0
+8d
+f9
+e8
+c1
+00
+00
+60
+01
+4c
+61
+20
+40
+03
+9f
+20
+3a
+57
+28
+18
+c0
+8d
+fc
+e8
+c1
+00
+00
+1f
+e0
+ff
+ff
+60
+01
+4c
+63
+70
+44
+44
+07
+68
+02
+4c
+61
+60
+02
+44
+45
+18
+00
+04
+09
+20
+20
+58
+92
+e8
+c1
+00
+00
+e8
+c0
+80
+00
+98
+c0
+8c
+00
+e8
+c1
+00
+00
+20
+7a
+00
+00
+e8
+c1
+00
+00
+9a
+46
+7c
+00
+20
+62
+80
+00
+e8
+c0
+80
+00
+98
+c0
+8c
+00
+20
+20
+03
+a2
+d9
+60
+00
+03
+18
+00
+7e
+01
+60
+00
+c4
+45
+20
+40
+5a
+74
+20
+40
+5a
+7d
+20
+3a
+57
+46
+24
+21
+03
+ba
+78
+54
+7c
+00
+e0
+a1
+00
+00
+e8
+c1
+00
+00
+e0
+a1
+00
+00
+19
+60
+97
+ff
+20
+22
+d7
+46
+e8
+c0
+80
+00
+98
+c0
+8c
+00
+20
+20
+03
+ae
+18
+c0
+8c
+02
+20
+20
+03
+b7
+68
+09
+44
+c0
+58
+00
+2a
+00
+98
+46
+7c
+00
+20
+22
+83
+fc
+58
+00
+2a
+50
+98
+46
+7c
+00
+20
+22
+84
+07
+58
+00
+28
+03
+98
+46
+7c
+00
+24
+22
+d7
+28
+68
+01
+44
+bc
+60
+01
+02
+a0
+78
+34
+7c
+00
+20
+40
+04
+4e
+24
+21
+03
+d8
+68
+09
+02
+a0
+20
+40
+04
+56
+c0
+00
+83
+d8
+20
+40
+04
+52
+24
+22
+83
+d6
+78
+54
+7c
+00
+20
+40
+03
+da
+20
+40
+04
+3c
+20
+40
+04
+56
+20
+40
+03
+e2
+20
+20
+03
+d8
+20
+40
+04
+3c
+20
+20
+03
+c9
+20
+34
+57
+28
+20
+20
+04
+74
+68
+01
+02
+a0
+60
+01
+44
+46
+68
+00
+cc
+67
+1f
+e2
+72
+00
+20
+40
+04
+6b
+d8
+a0
+44
+48
+20
+40
+7e
+45
+20
+20
+04
+6e
+68
+09
+4c
+65
+18
+4c
+fe
+00
+c0
+82
+83
+f4
+20
+40
+04
+68
+68
+01
+02
+a0
+e0
+a1
+00
+00
+20
+40
+04
+6e
+58
+00
+45
+04
+98
+40
+8c
+00
+e8
+c0
+80
+00
+18
+c2
+04
+00
+1f
+e2
+72
+00
+1f
+e0
+fe
+05
+60
+00
+c4
+45
+20
+40
+04
+68
+18
+42
+0c
+00
+20
+40
+7e
+45
+20
+20
+04
+6e
+20
+40
+04
+68
+68
+01
+02
+a0
+e0
+a1
+00
+00
+68
+01
+4c
+65
+e0
+a1
+00
+00
+20
+40
+04
+6e
+70
+44
+45
+07
+20
+60
+00
+00
+20
+40
+5b
+08
+e8
+c0
+80
+00
+1f
+e2
+72
+00
+1f
+e0
+fe
+02
+60
+00
+c4
+45
+18
+c0
+8d
+fb
+e8
+c1
+00
+00
+e0
+a1
+00
+00
+18
+c0
+8c
+03
+20
+40
+7e
+45
+20
+20
+58
+8a
+d8
+40
+2a
+50
+20
+40
+5b
+0c
+20
+20
+03
+fd
+d9
+60
+00
+02
+68
+01
+44
+bc
+60
+01
+02
+a0
+70
+0d
+5c
+00
+78
+34
+7c
+00
+20
+40
+04
+4e
+24
+21
+04
+32
+68
+09
+02
+a0
+20
+40
+04
+56
+c0
+00
+84
+35
+20
+40
+04
+52
+24
+22
+84
+2e
+68
+00
+8d
+5c
+c0
+00
+84
+35
+24
+34
+04
+1f
+78
+54
+7c
+00
+68
+00
+cc
+67
+1f
+e0
+fe
+04
+60
+00
+c4
+45
+20
+40
+04
+6e
+20
+20
+04
+29
+68
+00
+cc
+67
+1f
+e6
+7c
+10
+20
+22
+84
+35
+68
+00
+c4
+45
+1f
+e6
+7c
+10
+20
+22
+84
+35
+68
+01
+02
+a0
+1f
+e0
+ff
+ff
+60
+01
+0d
+5a
+20
+40
+04
+45
+68
+01
+02
+a0
+60
+01
+0d
+58
+20
+40
+04
+40
+19
+60
+97
+ff
+20
+22
+84
+30
+20
+40
+04
+3c
+20
+20
+04
+0f
+70
+0d
+5c
+01
+20
+20
+04
+2e
+68
+01
+02
+a0
+60
+01
+0d
+5a
+20
+20
+04
+39
+68
+01
+02
+a0
+1f
+e0
+ff
+ff
+60
+01
+0d
+5a
+20
+20
+04
+39
+20
+34
+57
+28
+20
+40
+04
+45
+20
+20
+04
+74
+68
+09
+02
+a0
+18
+40
+84
+01
+60
+09
+02
+a0
+20
+60
+00
+00
+68
+00
+cc
+67
+60
+00
+81
+03
+1f
+e2
+72
+00
+20
+40
+04
+6b
+20
+20
+7e
+45
+20
+40
+04
+68
+68
+01
+0d
+58
+e0
+a1
+00
+00
+68
+01
+0d
+5a
+e0
+a1
+00
+00
+68
+00
+81
+03
+1f
+e2
+72
+00
+20
+40
+7e
+45
+20
+20
+04
+6e
+68
+09
+02
+a0
+68
+01
+44
+be
+98
+46
+7c
+00
+20
+60
+00
+00
+68
+01
+44
+c0
+68
+09
+4c
+65
+98
+46
+7c
+00
+20
+60
+00
+00
+d8
+c0
+45
+04
+18
+42
+22
+00
+e8
+c1
+00
+00
+20
+3a
+04
+61
+e8
+c9
+00
+00
+60
+09
+4c
+65
+9a
+26
+7c
+00
+20
+22
+84
+63
+e8
+c0
+80
+00
+98
+c0
+8c
+00
+20
+20
+04
+58
+58
+00
+00
+01
+20
+60
+00
+00
+e8
+c0
+80
+00
+60
+00
+cc
+67
+20
+40
+04
+71
+58
+00
+00
+00
+20
+60
+00
+00
+68
+01
+02
+b9
+1f
+e2
+0a
+00
+20
+60
+00
+00
+68
+01
+02
+b7
+1f
+e2
+0c
+00
+20
+60
+00
+00
+18
+a2
+7e
+00
+60
+01
+02
+b9
+20
+60
+00
+00
+18
+c2
+7e
+00
+60
+01
+02
+b7
+20
+60
+00
+00
+20
+40
+04
+68
+20
+20
+58
+8a
+68
+00
+cb
+ab
+1f
+e0
+84
+01
+18
+41
+04
+03
+60
+08
+cb
+ab
+1f
+ef
+fe
+07
+d8
+c0
+4b
+ad
+98
+c0
+8c
+00
+68
+00
+cc
+82
+1f
+e0
+ff
+fb
+1f
+e2
+72
+00
+d8
+a0
+44
+45
+20
+40
+7e
+45
+68
+08
+cc
+82
+20
+20
+58
+92
+20
+40
+56
+1c
+20
+20
+58
+b0
+1a
+62
+7e
+00
+c0
+01
+84
+96
+c0
+05
+04
+9a
+c0
+00
+04
+91
+c0
+09
+04
+98
+c0
+01
+04
+9d
+1f
+e6
+7c
+0d
+20
+21
+58
+c0
+60
+00
+cc
+68
+70
+0b
+7d
+27
+20
+20
+56
+20
+20
+40
+59
+24
+68
+01
+44
+37
+1f
+ef
+84
+04
+60
+09
+4d
+4f
+20
+60
+00
+00
+70
+4c
+7c
+00
+20
+20
+59
+38
+70
+0b
+7d
+33
+20
+20
+56
+20
+70
+4d
+7e
+01
+70
+0b
+7d
+2b
+20
+20
+56
+20
+58
+00
+00
+14
+60
+01
+03
+ef
+20
+60
+00
+00
+68
+00
+c4
+3e
+28
+20
+06
+01
+20
+20
+84
+a4
+20
+20
+58
+a7
+68
+00
+c4
+3f
+20
+3a
+04
+a7
+20
+20
+58
+a7
+68
+00
+c4
+3e
+79
+3f
+fe
+04
+60
+00
+c4
+3e
+20
+60
+00
+00
+e8
+c0
+80
+00
+c0
+00
+84
+b2
+c0
+02
+04
+b8
+c0
+04
+84
+b0
+20
+20
+58
+f8
+70
+4c
+69
+03
+20
+20
+59
+74
+70
+4d
+3d
+01
+60
+00
+c4
+ae
+e8
+c3
+00
+00
+e0
+a3
+00
+00
+70
+0b
+7d
+42
+20
+20
+56
+20
+20
+40
+74
+a8
+20
+22
+84
+bb
+20
+20
+59
+68
+70
+4c
+69
+02
+20
+20
+59
+6a
+70
+4c
+7d
+00
+20
+40
+3f
+86
+20
+40
+3f
+7e
+20
+40
+3f
+a4
+20
+20
+3e
+cc
+70
+42
+13
+00
+70
+44
+8b
+00
+70
+4c
+7c
+00
+70
+4c
+69
+00
+70
+4c
+7f
+00
+70
+4c
+7d
+00
+20
+20
+3e
+d0
+58
+00
+00
+00
+60
+02
+4b
+a9
+20
+60
+00
+00
+c6
+91
+80
+00
+68
+02
+4d
+40
+60
+02
+4d
+72
+20
+40
+04
+f2
+24
+34
+04
+e5
+70
+4c
+15
+0a
+20
+40
+05
+13
+68
+00
+cb
+ef
+c1
+ff
+80
+00
+70
+4c
+3d
+02
+68
+00
+cd
+45
+24
+7a
+00
+00
+20
+40
+01
+55
+24
+74
+00
+00
+68
+00
+8b
+7f
+24
+7a
+00
+00
+20
+40
+3c
+ab
+68
+01
+c2
+10
+20
+7a
+00
+00
+68
+00
+c1
+31
+20
+7a
+00
+00
+68
+01
+cd
+7a
+20
+40
+7e
+8a
+60
+0a
+41
+fc
+20
+20
+3c
+da
+20
+40
+01
+55
+24
+74
+00
+00
+68
+00
+8b
+7f
+24
+7a
+00
+00
+20
+40
+3c
+ab
+68
+01
+c2
+10
+20
+7a
+00
+00
+68
+00
+c1
+31
+20
+7a
+00
+00
+68
+00
+cc
+15
+24
+3a
+04
+e1
+68
+02
+4d
+72
+20
+20
+04
+e2
+68
+00
+cb
+ef
+c0
+ff
+85
+65
+20
+40
+04
+f9
+20
+54
+05
+10
+20
+54
+05
+d4
+70
+4b
+e6
+01
+20
+60
+00
+00
+78
+54
+7c
+00
+70
+4b
+e2
+02
+68
+00
+cd
+57
+c0
+02
+05
+03
+c0
+02
+85
+06
+c0
+03
+85
+0c
+c0
+03
+05
+09
+68
+00
+cd
+45
+24
+5a
+34
+df
+20
+60
+00
+00
+70
+4d
+57
+00
+70
+4b
+e1
+0a
+20
+20
+05
+0e
+70
+4d
+57
+03
+70
+4b
+e1
+04
+20
+20
+05
+0e
+70
+4d
+57
+02
+70
+4b
+e1
+03
+20
+20
+05
+0e
+70
+4b
+e2
+01
+70
+4b
+e1
+08
+70
+4b
+e7
+00
+20
+20
+34
+df
+68
+04
+cd
+57
+60
+04
+8c
+d5
+20
+60
+00
+00
+70
+4b
+e8
+00
+d9
+60
+0d
+00
+34
+73
+02
+00
+20
+40
+05
+3a
+24
+37
+85
+23
+20
+40
+05
+4a
+68
+00
+cb
+e0
+1f
+e0
+fe
+01
+60
+00
+cb
+e0
+70
+4d
+45
+00
+68
+00
+cb
+ef
+c0
+ff
+85
+39
+20
+40
+05
+35
+70
+4b
+e7
+00
+70
+4b
+e6
+00
+20
+60
+00
+00
+70
+4d
+45
+01
+68
+00
+cb
+e7
+1f
+e0
+fe
+01
+60
+00
+cb
+e7
+68
+00
+cb
+ef
+c0
+ff
+85
+45
+68
+00
+cb
+e7
+c0
+7f
+85
+47
+68
+00
+cb
+e7
+d8
+40
+00
+10
+98
+46
+7c
+00
+20
+21
+05
+f3
+68
+00
+cb
+e8
+1f
+e0
+fe
+01
+60
+00
+cb
+e8
+20
+00
+00
+0a
+c0
+83
+85
+14
+20
+20
+05
+f3
+58
+00
+00
+00
+60
+04
+8c
+d5
+60
+04
+cd
+57
+20
+60
+00
+00
+20
+20
+05
+7f
+78
+57
+fc
+00
+20
+40
+06
+4b
+18
+00
+2a
+00
+68
+02
+4c
+00
+98
+00
+12
+00
+68
+08
+80
+17
+20
+40
+3a
+82
+20
+40
+3a
+87
+20
+40
+06
+0b
+20
+57
+86
+45
+20
+60
+00
+00
+70
+4d
+45
+00
+20
+60
+00
+00
+70
+4d
+45
+00
+70
+0b
+7d
+32
+20
+20
+7c
+27
+20
+40
+05
+b4
+68
+00
+8c
+b3
+c1
+81
+00
+00
+68
+00
+cb
+df
+20
+7a
+00
+00
+98
+00
+72
+00
+d8
+c0
+0c
+b5
+d8
+a0
+0d
+17
+20
+40
+7e
+45
+68
+00
+8c
+b4
+2f
+e1
+f0
+08
+24
+60
+80
+00
+68
+00
+8c
+b5
+c0
+7f
+85
+5a
+60
+00
+cc
+b7
+20
+60
+00
+00
+70
+4d
+7d
+01
+20
+60
+00
+00
+79
+20
+00
+23
+20
+40
+05
+61
+20
+40
+05
+1f
+70
+4b
+ef
+01
+20
+60
+00
+00
+70
+4b
+e0
+00
+70
+4b
+e9
+4e
+68
+02
+4b
+eb
+20
+20
+05
+c6
+20
+40
+05
+61
+68
+00
+cb
+e6
+c0
+00
+b4
+df
+68
+00
+cb
+ef
+c0
+00
+85
+6d
+c0
+01
+05
+70
+c0
+01
+85
+73
+20
+20
+3b
+f1
+70
+4b
+ef
+11
+70
+0d
+37
+aa
+20
+20
+05
+75
+70
+4b
+ef
+12
+70
+0d
+37
+55
+20
+20
+05
+75
+70
+4b
+ef
+13
+70
+0d
+37
+22
+70
+0d
+38
+02
+68
+02
+4c
+06
+60
+02
+0d
+39
+70
+0d
+3d
+00
+da
+20
+0d
+37
+d8
+40
+00
+07
+20
+40
+05
+af
+20
+40
+05
+d4
+20
+40
+04
+f7
+20
+20
+34
+df
+68
+00
+cb
+ef
+c1
+7f
+80
+00
+c0
+08
+85
+85
+c0
+09
+05
+87
+c0
+09
+85
+89
+20
+60
+00
+00
+70
+4b
+ef
+02
+20
+20
+05
+1f
+70
+4b
+ef
+03
+20
+20
+05
+1f
+70
+4b
+ef
+ff
+70
+0b
+7d
+31
+20
+40
+7c
+27
+68
+02
+0d
+19
+20
+40
+05
+c6
+20
+20
+05
+1f
+79
+20
+00
+23
+20
+40
+05
+c7
+20
+40
+05
+f3
+68
+00
+cb
+ef
+c1
+ff
+80
+00
+20
+40
+05
+a1
+58
+00
+00
+00
+60
+01
+4c
+04
+20
+40
+3c
+ab
+20
+00
+07
+d0
+68
+00
+cc
+04
+c0
+7f
+85
+47
+20
+40
+05
+3a
+24
+37
+85
+aa
+20
+40
+05
+35
+79
+20
+00
+23
+70
+0b
+7d
+3c
+20
+20
+7c
+27
+70
+0d
+37
+ff
+68
+00
+cb
+e2
+60
+00
+8d
+38
+68
+02
+4c
+06
+60
+02
+0d
+39
+d8
+40
+00
+06
+da
+20
+0d
+37
+20
+40
+05
+af
+20
+20
+05
+d4
+68
+01
+4c
+04
+1f
+e0
+fe
+01
+60
+01
+4c
+04
+20
+40
+05
+f3
+20
+20
+05
+97
+60
+08
+cb
+e1
+18
+42
+72
+00
+d8
+a0
+0c
+d5
+1a
+22
+0c
+00
+20
+20
+7e
+45
+68
+00
+8c
+b4
+1f
+e9
+7e
+00
+60
+00
+cb
+df
+1f
+e0
+fe
+01
+d8
+c0
+0c
+b4
+98
+c0
+8c
+00
+e8
+c1
+80
+00
+60
+01
+cc
+0b
+20
+60
+00
+00
+68
+08
+cc
+3c
+58
+00
+4c
+2b
+98
+40
+8a
+00
+1a
+22
+7e
+00
+e0
+a0
+80
+00
+18
+40
+84
+01
+18
+41
+04
+07
+60
+08
+cc
+3c
+20
+60
+00
+00
+60
+02
+4c
+00
+da
+20
+00
+00
+df
+20
+00
+04
+d8
+c0
+4c
+00
+e8
+c0
+80
+00
+9a
+20
+a2
+00
+c2
+00
+05
+ca
+1a
+22
+7e
+00
+60
+01
+4c
+16
+68
+00
+cc
+16
+68
+08
+cc
+17
+98
+40
+fe
+00
+60
+00
+cc
+18
+20
+60
+00
+00
+68
+00
+cb
+e1
+1f
+e0
+fe
+02
+60
+00
+cb
+e3
+68
+00
+cb
+e2
+60
+00
+8c
+f5
+68
+00
+cb
+e1
+1f
+e9
+fe
+00
+68
+08
+cb
+e0
+18
+41
+04
+03
+18
+43
+84
+00
+98
+41
+fe
+00
+68
+08
+cc
+0a
+98
+40
+fe
+00
+e0
+a0
+80
+00
+68
+00
+cb
+ef
+c0
+ff
+85
+e6
+68
+00
+cb
+e2
+e0
+a0
+80
+00
+68
+00
+cb
+e1
+98
+00
+72
+00
+68
+00
+cb
+e2
+c0
+00
+85
+f1
+d8
+c0
+0c
+d5
+20
+40
+7e
+45
+68
+00
+8c
+d5
+c0
+01
+85
+ef
+20
+60
+00
+00
+70
+0c
+d5
+02
+20
+60
+00
+00
+d8
+c0
+0c
+d6
+20
+20
+7e
+45
+68
+08
+cb
+ea
+20
+40
+05
+f9
+18
+40
+84
+01
+18
+41
+04
+03
+60
+08
+cb
+ea
+20
+60
+00
+00
+68
+00
+cc
+00
+1f
+e1
+7e
+03
+1f
+ef
+a2
+04
+58
+00
+4b
+f0
+9a
+20
+fe
+00
+98
+40
+8c
+00
+e8
+c0
+80
+00
+60
+00
+cb
+e9
+20
+60
+00
+00
+78
+44
+fc
+00
+78
+43
+fc
+00
+58
+55
+55
+55
+98
+00
+1e
+00
+68
+00
+cb
+e9
+1f
+ed
+84
+00
+79
+20
+04
+01
+18
+43
+1c
+00
+20
+60
+00
+00
+20
+40
+06
+02
+78
+26
+fc
+00
+78
+30
+fc
+00
+78
+50
+7c
+00
+78
+28
+7c
+00
+68
+01
+4b
+e4
+98
+00
+36
+00
+37
+c1
+84
+00
+24
+2c
+06
+45
+78
+46
+fc
+00
+78
+25
+fc
+00
+78
+23
+fc
+00
+78
+24
+fc
+00
+09
+80
+00
+08
+19
+89
+7e
+00
+60
+00
+cc
+19
+68
+08
+cc
+18
+98
+46
+7c
+00
+24
+22
+86
+45
+09
+80
+00
+08
+19
+89
+7e
+00
+60
+00
+8c
+b3
+68
+00
+8c
+b3
+68
+08
+cb
+e2
+a8
+40
+0e
+00
+24
+20
+86
+45
+09
+80
+00
+08
+19
+89
+7e
+00
+e0
+a0
+80
+00
+1f
+e9
+7e
+00
+1f
+e1
+72
+1f
+20
+22
+86
+2f
+09
+80
+00
+08
+19
+89
+7e
+00
+e0
+a0
+80
+00
+c2
+00
+06
+2b
+18
+a2
+22
+00
+09
+80
+00
+08
+19
+89
+7e
+00
+60
+00
+cc
+2a
+1a
+22
+0a
+00
+09
+80
+00
+18
+78
+28
+7c
+00
+db
+60
+06
+64
+1f
+ef
+7e
+00
+1f
+f1
+7e
+00
+e0
+a1
+80
+00
+78
+45
+fc
+00
+20
+23
+06
+45
+78
+37
+fc
+00
+68
+00
+80
+17
+1f
+e0
+a2
+00
+20
+40
+3a
+b6
+78
+46
+fc
+00
+20
+40
+3a
+7a
+68
+00
+cc
+2a
+1f
+e2
+22
+00
+20
+20
+05
+bd
+78
+4d
+fc
+00
+78
+45
+fc
+00
+20
+20
+37
+5c
+20
+40
+3a
+7a
+68
+08
+cb
+e9
+20
+20
+3a
+91
+20
+40
+53
+d2
+68
+02
+4c
+00
+98
+00
+12
+00
+20
+40
+06
+02
+20
+40
+06
+48
+79
+20
+2a
+00
+78
+2e
+fc
+00
+78
+30
+7c
+00
+78
+50
+fc
+00
+19
+31
+7e
+00
+1f
+ec
+fe
+00
+1f
+f1
+fe
+00
+08
+00
+86
+28
+78
+4e
+fc
+00
+78
+2d
+fc
+00
+78
+23
+fc
+00
+78
+24
+fc
+00
+68
+00
+cc
+18
+08
+00
+86
+08
+68
+00
+cb
+e3
+98
+00
+72
+00
+d8
+c0
+0c
+f5
+e8
+c0
+80
+00
+08
+00
+86
+08
+c2
+00
+06
+61
+78
+24
+7c
+00
+08
+00
+86
+18
+78
+44
+7c
+00
+37
+d3
+82
+00
+20
+00
+00
+64
+78
+4e
+fc
+00
+78
+4d
+fc
+00
+20
+20
+3a
+7a
+b6
+61
+aa
+55
+40
+00
+00
+40
+2d
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+35
+00
+00
+00
+4f
+02
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+04
+c8
+00
+5c
+40
+04
+3a
+ce
+00
+00
+80
+e0
+00
+00
+00
+00
+00
+20
+00
+a0
+01
+00
+00
+00
+00
+00
+aa
+55
+02
+00
+4f
+4d
+20
+00
+aa
+55
+01
+00
+31
+41
+01
+aa
+55
+02
+00
+13
+42
+40
+03
+aa
+55
+01
+00
+f7
+41
+0a
+aa
+55
+02
+00
+f5
+41
+10
+00
+aa
+55
+01
+00
+33
+41
+00
+aa
+55
+02
+00
+b1
+4c
+00
+00
+aa
+55
+03
+00
+4a
+41
+40
+25
+00
+aa
+55
+06
+00
+40
+41
+36
+08
+c2
+08
+66
+22
+aa
+55
+0f
+00
+02
+47
+0e
+42
+54
+33
+2e
+30
+20
+4b
+65
+79
+62
+6f
+61
+72
+64
+aa
+55
+03
+00
+80
+42
+0e
+00
+01
+aa
+55
+01
+00
+84
+42
+01
+aa
+55
+01
+00
+47
+47
+0a
+aa
+55
+01
+00
+dc
+47
+00
+aa
+55
+01
+00
+f6
+47
+01
+aa
+55
+01
+00
+72
+41
+01
+aa
+55
+01
+00
+dc
+07
+00
+aa
+55
+01
+00
+a2
+00
+00
+aa
+55
+01
+00
+dd
+07
+00
+aa
+55
+01
+00
+16
+00
+27
+aa
+55
+01
+00
+fd
+47
+ff
+aa
+55
+01
+00
+f7
+47
+ff
+aa
+55
+01
+00
+6e
+41
+80
+aa
+55
+02
+00
+a2
+4b
+02
+01
+aa
+55
+ee
+01
+04
+45
+01
+00
+00
+28
+02
+01
+18
+02
+00
+03
+28
+01
+20
+03
+00
+05
+2a
+01
+00
+04
+00
+02
+29
+02
+00
+00
+05
+00
+00
+28
+02
+00
+18
+06
+00
+03
+28
+01
+02
+07
+00
+00
+2a
+0e
+42
+54
+34
+2e
+32
+20
+4b
+65
+79
+62
+6f
+61
+72
+64
+08
+00
+03
+28
+01
+02
+09
+00
+01
+2a
+02
+c1
+03
+0a
+00
+03
+28
+01
+02
+0b
+00
+04
+2a
+08
+06
+00
+06
+00
+64
+00
+2c
+01
+0c
+00
+00
+28
+02
+0a
+18
+0d
+00
+03
+28
+01
+02
+0e
+00
+29
+2a
+06
+59
+69
+43
+68
+69
+70
+0f
+00
+03
+28
+01
+02
+10
+00
+50
+2a
+07
+02
+e8
+04
+21
+70
+01
+00
+11
+00
+00
+28
+02
+12
+18
+12
+00
+03
+28
+01
+06
+13
+00
+4e
+2a
+01
+01
+14
+00
+03
+28
+01
+12
+15
+00
+4d
+2a
+08
+00
+00
+00
+00
+00
+00
+00
+00
+16
+00
+02
+29
+02
+00
+00
+17
+00
+08
+29
+02
+01
+01
+18
+00
+03
+28
+01
+12
+19
+00
+4d
+2a
+05
+00
+00
+00
+00
+00
+1a
+00
+02
+29
+02
+00
+00
+1b
+00
+08
+29
+02
+03
+01
+1c
+00
+03
+28
+01
+12
+1d
+00
+4d
+2a
+02
+00
+00
+1e
+00
+02
+29
+02
+00
+00
+1f
+00
+08
+29
+02
+02
+01
+20
+00
+03
+28
+01
+0e
+21
+00
+4d
+2a
+02
+00
+00
+22
+00
+02
+29
+02
+00
+00
+23
+00
+08
+29
+02
+01
+02
+24
+00
+03
+28
+01
+0a
+25
+00
+4b
+2a
+a0
+05
+01
+09
+06
+a1
+01
+85
+01
+75
+01
+95
+08
+05
+07
+19
+e0
+29
+e7
+15
+00
+25
+01
+81
+02
+95
+01
+75
+08
+81
+03
+95
+05
+75
+01
+05
+08
+19
+01
+29
+05
+91
+02
+95
+01
+75
+03
+91
+03
+95
+06
+75
+08
+15
+00
+26
+ff
+00
+05
+07
+19
+00
+29
+ff
+81
+00
+c0
+05
+0c
+09
+01
+a1
+01
+85
+02
+19
+00
+2a
+ff
+03
+15
+00
+26
+ff
+03
+95
+01
+75
+10
+81
+00
+c0
+05
+01
+09
+02
+a1
+01
+85
+03
+09
+01
+a1
+00
+05
+09
+19
+01
+29
+08
+15
+00
+25
+01
+75
+01
+95
+08
+81
+02
+05
+01
+09
+30
+09
+31
+16
+01
+80
+26
+ff
+7f
+75
+10
+95
+02
+81
+06
+09
+38
+15
+81
+25
+7f
+75
+08
+95
+01
+81
+06
+05
+0c
+0a
+38
+02
+95
+01
+81
+06
+c0
+c0
+26
+00
+03
+28
+01
+02
+27
+00
+4a
+2a
+04
+11
+01
+00
+01
+28
+00
+03
+28
+01
+04
+29
+00
+4c
+2a
+01
+00
+2a
+00
+00
+28
+02
+0f
+18
+2b
+00
+03
+28
+01
+12
+2c
+00
+19
+2a
+01
+64
+2d
+00
+02
+29
+02
+00
+00
+00
+00
+aa
+55
+01
+00
+6a
+4c
+17
+aa
+55
+01
+00
+f9
+46
+50
+aa
+55
+01
+00
+c2
+44
+14
+aa
+55
+06
+00
+f9
+44
+11
+46
+34
+54
+77
+dd
+aa
+55
+01
+00
+7e
+4c
+00
+aa
+55
+06
+00
+b8
+4c
+15
+00
+1d
+00
+19
+00
+aa
+55
+02
+00
+3e
+4d
+2c
+00
+aa
+55
+01
+00
+60
+4c
+50
+aa
+55
+10
+00
+6c
+4c
+0c
+00
+05
+00
+12
+b4
+08
+00
+08
+00
+08
+00
+00
+00
+2c
+01
+aa
+55
+0c
+00
+19
+44
+0b
+42
+54
+20
+4b
+65
+79
+62
+6f
+61
+72
+64
+aa
+55
+01
+00
+e4
+44
+07
+aa
+55
+01
+00
+dd
+44
+01
+aa
+55
+0c
+00
+d9
+43
+1f
+02
+01
+05
+03
+19
+c1
+03
+03
+03
+12
+18
+aa
+55
+07
+00
+6b
+4d
+06
+ff
+06
+00
+03
+00
+80
+aa
+55
+0e
+00
+f9
+43
+1f
+0c
+09
+42
+54
+20
+4b
+65
+79
+62
+6f
+61
+72
+64
+aa
+55
+04
+00
+53
+4d
+20
+21
+12
+24
+aa
+55
+04
+00
+91
+4c
+9f
+3e
+cd
+4d
+aa
+55
+01
+00
+8f
+4c
+04
+aa
+55
+01
+00
+10
+4c
+01
+aa
+55
+01
+00
+e2
+4b
+02
+aa
+55
+01
+00
+0f
+4c
+40
+aa
+55
+01
+00
+0a
+4c
+00
+aa
+55
+02
+00
+e4
+4b
+c0
+12
+aa
+55
+10
+00
+f0
+4b
+00
+13
+2c
+42
+06
+15
+36
+48
+0f
+1a
+3a
+4c
+11
+23
+31
+4d
+aa
+55
+01
+00
+ef
+4b
+ff
+aa
+55
+04
+00
+eb
+4b
+20
+15
+10
+05
+aa
+55
+01
+00
+7d
+4c
+c2
+aa
+55
+0a
+00
+37
+0d
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+aa
+55
+04
+00
+40
+4d
+00
+48
+5d
+00
+aa
+55
+07
+00
+76
+4d
+ff
+ff
+ff
+ff
+e8
+fd
+00
+aa
+55
+08
+00
+16
+42
+8f
+10
+ce
+00
+0a
+0b
+ef
+0f
+aa
+55
+01
+00
+f8
+41
+00
+aa
+55
+08
+00
+a3
+00
+00
+00
+00
+00
+00
+00
+00
+00
+aa
+55
+02
+00
+5d
+41
+02
+24
+aa
+55
+08
+00
+4d
+41
+12
+00
+00
+02
+12
+00
+00
+02
+aa
+55
+02
+00
+5b
+41
+20
+00
+aa
+55
+04
+00
+57
+41
+20
+00
+00
+20
+aa
+55
+04
+00
+5f
+41
+80
+03
+00
+06
+aa
+55
+02
+00
+98
+4c
+00
+13
+aa
+55
+02
+00
+9b
+42
+30
+3f
+aa
+55
+01
+00
+aa
+42
+20
+aa
+55
+7f
+00
+70
+4f
+07
+ff
+0a
+fb
+0b
+ff
+1a
+fb
+1b
+fb
+1c
+fb
+1d
+f6
+1e
+f2
+1f
+ee
+20
+ea
+21
+e6
+22
+e2
+23
+de
+24
+da
+25
+d6
+26
+d2
+27
+ce
+28
+ca
+29
+c6
+2a
+c2
+2b
+bd
+2c
+b9
+2d
+b5
+2e
+b1
+2f
+ad
+30
+a9
+31
+80
+32
+80
+33
+80
+34
+c0
+35
+c1
+36
+c2
+37
+c3
+38
+c4
+39
+c5
+3a
+c6
+3b
+c7
+3c
+06
+3d
+07
+3e
+46
+3f
+85
+40
+86
+41
+87
+42
+c6
+43
+c7
+44
+d6
+45
+d7
+46
+e6
+47
+f5
+48
+00
+49
+f8
+4a
+7f
+4e
+ec
+4f
+5e
+55
+d0
+56
+c0
+57
+4c
+58
+6c
+59
+50
+68
+e4
+69
+00
+6a
+00
+6b
+30
+ff
+aa
+55
+02
+00
+63
+41
+70
+4f
+aa
+55
+0a
+00
+91
+4a
+55
+d0
+56
+c0
+57
+4c
+58
+6c
+59
+50
+aa
+55
+0a
+00
+87
+4a
+55
+d0
+56
+c0
+57
+4c
+58
+6c
+59
+50
+a2
+b3
Index: btkb/output/memmap.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/output/memmap.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/output/memmap.format	(working copy)
@@ -0,0 +1,1124 @@
+0x0000 mem_le_adv_transmit
+0x0001 mem_le_adv_waitcnt
+0x0002 mem_le_adv_rcv
+0x0003 mem_le_req_rcv
+0x0004 mem_le_scanrsp_rcv
+0x0005 mem_le_conn_rcv
+0x0006 mem_inquiryscan_waitcnt
+0x0007 mem_inquiryscan_rcvcnt
+0x0008 mem_pagescan_waitcnt
+0x0009 mem_pagescan_rcvcnt
+0x000a mem_pagescan_rcvfhscnt
+0x000b mem_slave_rcvcnt
+0x000c mem_page_transmit
+0x000d mem_page_rcv
+0x000e mem_page_rcv_fhs
+0x000f mem_master_rcvcnt
+0x0010 mem_fhs_wait_counter
+0x0011 mem_newconnto_counter
+0x0012 mem_inquiry_transmit
+0x0013 mem_inquiry_rcv
+0x0014 mem_fw_ver
+0x0015 mem_current_context
+0x0016 mem_le_ch_mapped
+0x0017 mem_last_freq
+0x0018 mem_rssi
+0x0019 mem_rx_type
+0x001a mem_rx_hec_err
+0x001c mem_rx_crc_err
+0x001e mem_context_ptr
+0x0020 mem_display
+0x0028 mem_bcd
+0x0030 mem_state
+0x0031 mem_mode
+0x0032 mem_tsniff
+0x0034 mem_sniff_anchor
+0x0038 mem_clk_offset
+0x003e mem_rx_window
+0x0040 mem_plap
+0x0043 mem_puap
+0x0044 mem_pnap
+0x0046 mem_conn_handle
+0x0047 mem_arq
+0x0048 mem_lmp_to_send
+0x0049 mem_lmi_opcode
+0x004a mem_lmo_reason
+0x004b mem_op
+0x004c mem_state_map
+0x004d mem_supervision_timer
+0x0051 mem_supervision_to
+0x0053 mem_name_offset
+0x0054 mem_key_size
+0x0055 mem_conn_sm
+0x0056 mem_aco
+0x0062 mem_kc
+0x0072 mem_conn_timer
+0x0073 mem_sniff_attempt
+0x0074 mem_sniff_timeout
+0x0075 mem_dsniff
+0x0077 mem_amaddr
+0x0078 mem_lmo_opcode1
+0x0079 mem_lmi_opcode1
+0x007a mem_lmo_reason1
+0x007b mem_lmo_tid1
+0x007c mem_lmo_opcode2
+0x007d mem_lmi_opcode2
+0x007e mem_lmo_reason2
+0x007f mem_lmo_tid2
+0x0080 mem_hci_version
+0x0083 mem_acl_pktlen
+0x0085 mem_sco_pktlen
+0x0086 mem_acl_pktcnt
+0x0088 mem_sco_pktcnt
+0x008a mem_current_sniff_attempt
+0x008b mem_current_sniff_timeout
+0x008c mem_nfreq_index_inq
+0x008d mem_nfreq_index_page
+0x008e mem_ninqy_index
+0x008f mem_fhs_misc
+0x0090 mem_tx_lch
+0x0091 mem_tx_len
+0x0093 mem_subsniff_instant
+0x0097 mem_subsniff_rate
+0x0098 mem_subsniff_tcmax
+0x009a mem_subsniff_tsniff
+0x009b mem_lpm_adjust
+0x009c mem_sync_clke
+0x00a2 mem_lpm_current_mult
+0x00a3 mem_gpio_wakeup_low
+0x00a7 mem_gpio_wakeup_high
+0x00ab mem_air_mode
+0x00ac mem_sco_asso_handle
+0x00ad mem_sco_handle
+0x00af mem_esco_desco
+0x00b0 mem_esco_type
+0x00b1 mem_neogotiation_state
+0x00b2 mem_saved_amaddr
+0x00b3 mem_esco_arq
+0x00b4 mem_esco_saved_arq
+0x00b5 mem_sco_obuf
+0x00d3 mem_sco_ibuf
+0x00f1 mem_sco_poll
+0x00f2 mem_npage_index
+0x00f3 mem_page_mode
+0x00f4 mem_page_clk
+0x00f8 mem_tst_pktcnt_sync
+0x00fa mem_tst_pktcnt_hec
+0x00fc mem_tst_pktcnt_crc
+0x00fe mem_tst_pktcnt_dmh
+0x0100 mem_tmp_buffer_head
+0x0103 mem_tmp_buffer
+0x0153 mem_tester_emulate
+0x0154 mem_temp_payload
+0x0154 test_mode_scenario
+0x0155 test_mode_hopping_mode
+0x0156 test_mode_tx_freq
+0x0157 test_mode_rx_freq
+0x0158 test_mode_power_mode
+0x0159 test_mode_poll_period
+0x015a test_mode_packet_type
+0x015b test_mode_data_length
+0x015d mem_test_mode_old_debug_config
+0x015e mem_tester_cnt
+0x015f mem_temp_am_addr
+0x0160 mem_temp_arq
+0x0161 mem_pdatatemp
+0x0169 mem_len
+0x016b mem_clkn_bt
+0x016f mem_clke_bt
+0x0173 mem_dpll_clkn
+0x0177 mem_connection_options
+0x0178 mem_nameres_cnt
+0x0179 mem_txptr
+0x017b mem_slot_offset
+0x017d extm_fhs_misc
+0x017e extm_newconn_am_addr
+0x017f extm_class
+0x0182 extm_lap
+0x0185 extm_uap
+0x0186 extm_nap
+0x0189 mem_debug_config
+0x018a mem_lch_code
+0x018b mem_fhs_am_addr
+0x018c mem_dpll_error
+0x018e mem_bdaddr_list_buff
+0x01b2 mem_select_list_item
+0x01b3 mem_temp_reconn_record
+0x01b3 mem_record_bt_mode
+0x01b4 mem_temp_lap
+0x01ba mem_list_item_ptr
+0x01bc mem_eir
+0x0220 mem_ucode_status
+0x0221 mem_otp_ucode_flag
+0x0223 mem_spid_tbuf/* spid buf: 03 addr[23:16] addr[15:8] addr[7:0] */
+0x0224 mem_iicd_tbuf/* iicd buf: iic_adr addr[15:8] addr[7:0] iic_adr */
+0x0224 mem_addr_hi
+0x0225 mem_addr_mi
+0x0226 mem_addr_lo
+0x0227 mem_iicd_addr
+0x0228 mem_spid_rbuf
+0x022c mem_ucode_buf
+0x022e mem_ucode_len
+0x0230 mem_sched_addr
+0x0232 mem_ucode_ptr
+0x0234 mem_ucode_keybuf
+0x0244 mem_check_plap_temp
+0x0256 mem_sensor_id
+0x0257 mem_reconnect_flag
+0x0258 mem_switch_fail_master_count
+0x0259 mem_app_evt_timer_count
+0x025a mem_dongle_count
+0x025b mem_le_addr_slave1
+0x0261 mem_le_addr_slave2
+0x0267 mem_le_peer_state
+0x0268 mem_app_peer_addr
+0x026e mem_dongle_peers
+0x026f mem_dongle_pairing_cnt
+0x0270 mem_dongle_signature
+0x0272 mem_h5rx_ackcnt
+0x0273 mem_check_err_acl_cont
+0x0274 mem_rp_packets
+0x0275 mem_packet_type
+0x0277 mem_hci_sniff_conn_handle
+0x0279 mem_hci_sniff_max_interval
+0x027b mem_hci_sniff_min_interval
+0x027d mem_hci_sniff_attempt
+0x027f mem_hci_sniff_timeout
+0x0281 mem_voice_setting
+0x0283 mem_retransmission_effort
+0x0284 mem_sco_ptype
+0x0286 mem_extm_uap_restore
+0x0289 mem_h5rx_rptr
+0x028b mem_h5rx_ack
+0x028c mem_h5tx_ack
+0x028d mem_h5tx_rptr
+0x028f mem_h5tx_wptr
+0x0291 mem_h5tx_free
+0x0293 mem_h5rx_tmp
+0x0294 mem_h5tx_seq
+0x0295 mem_hci_acl_queue_wptr
+0x0297 mem_hci_acl_queue_rptr
+0x0299 mem_hci_acl_queue_end
+0x029b mem_hci_acl_queue_wcnt
+0x029c mem_hci_acl_cnt
+0x029d mem_hci_acl_tx_trigger_wptr//tx via uart
+0x029f mem_ucode_id_local
+0x02a0 mem_temp//8 bytes
+0x02a8 mem_timeup// 4 bytes
+0x02ac mem_rega//4 bytes
+0x02b0 mem_regb//4 bytes
+0x02b4 mem_regc//3 bytes
+0x02b7 mem_contr//2 bytes
+0x02b9 mem_contw//2 bytes
+0x02bb mem_ucode_id_remote
+0x02bc mem_check_sum
+0x02bd mem_ucode_temp
+0x02be mem_ucode_temp1
+0x02bf mem_lock_in_enc//boolean
+0x02c0 mem_hci_disconn_reason
+0x02c1 mem_hci_curr_len
+0x02c2 mem_hci_curr_target
+0x02c4 mem_l2cap_mem_start
+0x02c4 mem_l2cap_rxbuff1_len
+0x02c6 mem_l2cap_rxbuff2_len
+0x02c8 mem_l2cap_rxbuff_new
+0x02ca mem_l2cap_rxbuff_inuse
+0x02cb mem_l2cap_payload_ptr
+0x02cd mem_l2cap_rx_pkt_length
+0x02cf mem_l2cap_rx_cid
+0x02d1 mem_l2cap_rx_done
+0x02d2 mem_l2cap_signal_tx_buff_ptr
+0x02d4 mem_l2cap_signal_tx_payload_ptr
+0x02d6 mem_l2cap_signal_tx_length
+0x02d8 mem_sdp_tx_buff_ptr
+0x02da mem_sdp_tx_payload_ptr
+0x02dc mem_sdp_tx_pkt_length
+0x02de mem_rfcomm_tx_buff_ptr
+0x02e0 mem_rfcomm_tx_payload_ptr
+0x02e2 mem_rfcomm_tx_pkt_length
+0x02e4 memL2CAP_T1
+0x02e6 mem_CONTROL_tasks
+0x02e7 mem_send_config_req
+0x02e8 mem_config_identifier
+0x02e9 mem_config_req_dest_CID
+0x02eb mem_rfcomm_malloc_fail_flag
+0x02ec mem_message_to_uppersm
+0x02ed mem_upper_sm_remote_page
+0x02ee mem_upper_sm_reconn
+0x02ef mem_upper_sm_ss
+0x02f0 mem_tx_malloc_log
+0x0330 mem_l2cap_mem_end
+0x0330 mem_scid
+0x0332 mem_cmd_length
+0x0334 mem_tt2
+0x0336 mem_tt3
+0x0338 mem_id
+0x033a mem_psm
+0x033c mem_l2cap_sdpres_delay_time
+0x0340 mem_le_rxbuf
+0x0378 mem_le_mic
+0x037c mem_le_peer_mic
+0x0380 mem_le_skdm
+0x0388 mem_le_skds
+0x0390 mem_le_peer_ltk
+0x03a0 mem_le_my_ltk
+0x03b0 mem_le_mrand
+0x03c0 mem_le_state
+0x03c1 mem_le_mode
+0x03c2 mem_le_tsniff
+0x03c4 mem_le_anchor
+0x03c8 mem_le_clk_offset
+0x03ce mem_le_receive_window
+0x03d0 mem_le_plap
+0x03d6 mem_le_conn_handle
+0x03d7 mem_le_arq
+0x03d8 mem_le_ch
+0x03d9 mem_le_hop
+0x03da mem_le_event_count
+0x03dc mem_le_supervision_timer
+0x03e0 mem_le_instant
+0x03e2 mem_le_channels
+0x03e3 mem_le_conn_sm
+0x03e4 mem_le_op
+0x03e5 mem_le_access
+0x03e9 mem_le_crcinit
+0x03ec mem_le_window_size
+0x03ed mem_le_slave_latency
+0x03ef mem_le_superto
+0x03f1 mem_le_channel_map
+0x03f6 mem_le_no_using
+0x03f8 mem_le_peer_sca
+0x03f9 mem_le_att_opcode
+0x03fa mem_le_att_handle
+0x03fc mem_le_err_code
+0x03fd mem_le_sk
+0x040d mem_le_testtype
+0x040e mem_le_test_sync
+0x0410 mem_le_test_pcnt
+0x0412 mem_le_rxon_ts
+0x0418 mem_le_rx_ll_opcode
+0x0419 mem_le_notify_attr_start
+0x041b mem_le_notify_len
+0x041c mem_cmd_le_create_conn
+0x041d mem_le_adv_temp
+0x0431 mem_24g_id
+0x0432 mem_lmo_header_length
+0x0433 mem_lmo_header_opcode
+0x0434 mem_lmo_payload
+0x0445 mem_lmi_accepted_opcode
+0x0446 mem_disconn_reason_send
+0x0447 mem_tx_fixed_freq
+0x0448 mem_rx_fixed_freq
+0x0449 mem_ext_features_page
+0x044a mem_lmpext_ssp_enable
+0x044c mem_remote_sppcap
+0x044d mem_lmp_conn_state
+0x044e mem_soft_timer
+0x0450 mem_pincode_state
+0x0451 mem_sres_tid
+0x0452 mem_accptsco_tid
+0x0453 mem_auth_enable
+0x0454 mem_wait_encryption
+0x0455 mem_sniff_payload
+0x0465 mem_aurand_send_delay_time
+0x0469 mem_module_temp_len
+0x046b mem_init_cnt
+0x046d mem_prcp_data
+0x0481 mem_prcp
+0x0482 mem_prcp_tx_len
+0x0483 rx_buf_data_ptr
+0x0485 memRemoteRPNBitRate
+0x0486 memRemotePRNDataBits
+0x0487 memRemotePRNStopBit
+0x0488 memRemotePRNParity
+0x0489 memRemotePRNFlowControl
+0x048a memRemotePRNXon
+0x048b memRemotePRNXoff
+0x048c mem_mod2div_temp
+0x048f mem_contw_temp
+0x0491 mem_attrib_list
+0x0493 mem_current_adss
+0x0494 mem_current_channel
+0x0495 mem_current_frame_type
+0x0496 mem_current_fcs
+0x0497 mem_current_length
+0x0499 mem_rfcomm_uih_payload_ptr
+0x049b mem_uih_cmd_type
+0x049c mem_uih_length
+0x049e mem_param_payload_ptr
+0x04a0 mem_ms_param
+0x04a1 mem_pn_credit_flow_type_info
+0x04a2 mem_pn_priority
+0x04a3 mem_pn_acknowledg_timer
+0x04a4 mem_pn_max_retrans
+0x04a5 mem_rfcomm_send_adss
+0x04a6 mem_rfcomm_send_frame_type
+0x04a7 mem_rfcomm_send_fcs
+0x04a8 mem_rfcomm_send_offset
+0x04a9 mem_sdp_mem_start
+0x04a9 mem_uuid_search_pat
+0x04ad mem_sdp_continue_byte
+0x04af mem_sdp_pduid
+0x04b0 mem_sdp_transactionid
+0x04b2 mem_sdp_attribute_maxbyte
+0x04b4 mem_sdp_record_maxcnt
+0x04b6 mem_sdp_error_code
+0x04be mem_sdp_record_handle
+0x04c2 mem_sdp_search_failed
+0x04c3 mem_sdp_LACAP_found
+0x04c4 mem_sdp_RFCOMM_found
+0x04c5 mem_handle_list
+0x04dd mem_handle_humber
+0x04de mem_sdp_mem_end
+0x04de mem_rxbuf
+0x04ef mem_random_number
+0x04ff mem_round_key
+0x050f mem_kinit
+0x051f mem_input_store
+0x052f mem_x
+0x053f mem_y
+0x054e mem_y15
+0x054f mem_pin_length
+0x0550 mem_pin
+0x0560 mem_key_store
+0x0571 mem_key_store_end
+0x0572 memp_ar_key
+0x0574 memp_ar_input
+0x0576 mem_ar_hround
+0x0580 mem_ec_infinite
+0x0581 mem_ec_loopc
+0x0582 memdat
+0x0582 mem_ax
+0x059a mem_ay
+0x05b2 mem_az
+0x05ca mem_bx
+0x05e2 mem_by
+0x05fa mem_bz
+0x0612 mem_cx
+0x062a mem_cy
+0x0641 mem_cy5
+0x0642 mem_cz
+0x065a mem_k
+0x0672 mem_align
+0x0682 mem_tmp1
+0x0682 memahbak
+0x069a mem_tmp5
+0x06a2 memahsave
+0x06b2 mem_tmp2
+0x06c2 memahsave_end
+0x06c2 mem_addr_padding
+0x06c3 mem_addr_value/* 12 bytes     */ 
+0x06ca mem_tmp3
+0x06ca mem_t1
+0x06cf mem_addr_value_end
+0x06d2 mem_addr_iocap_end
+0x06e2 mem_tmp0
+0x06e2 mem_t0
+0x06ea mem_tmp0a
+0x06fa mem_t2
+0x0712 mem_t3
+0x072a mem_t7
+0x0742 mem_p
+0x075a mem_a
+0x0772 mem_b
+0x078a mem_gx
+0x07a2 mem_gy
+0x07ba memh0
+0x07da mem_sp_state_start
+0x07da mem_sp_state
+0x07db mem_master_sp_state
+0x07dc mem_sp_flag
+0x07dd mem_master_sp_flag
+0x07de mem_sp_calc
+0x07df mem_sp_dh_ready
+0x07e0 mem_sp_localsm
+0x07e1 mem_pairing_auth
+0x07e2 mem_sp_flag_start
+0x07e2 mem_sp_local_key_send_count
+0x07e3 mem_sp_remote_key_recv_count
+0x07e4 mem_sp_remote_key_invalid
+0x07e5 mem_sp_dhkey_invalid
+0x07e6 mem_sp_iocap_local
+0x07e9 mem_sp_iocap_remote
+0x07ec mem_sp_gkey
+0x07f0 mem_sp_pubkey_remote
+0x07f0 mem_sp_pubkey_remote_x
+0x0808 mem_sp_pubkey_remote_x_end
+0x0808 mem_sp_pubkey_remote_y
+0x0820 mem_sp_dhkey
+0x0838 mem_sp_dhkey_end
+0x0838 mem_sp_random_local
+0x0848 mem_sp_random_local_end
+0x0848 mem_sp_random_remote
+0x0858 mem_sp_random_remote_end
+0x0858 memresult
+0x0858 mem_sp_calc_result
+0x0858 memh
+0x085c memg
+0x0860 memf
+0x0864 meme
+0x0868 mem_sp_calc_result_high
+0x0868 memd
+0x086c memc
+0x0870 memb
+0x0874 mema
+0x0878 mem_sp_check_result
+0x0888 mem_sp_confirm_remote
+0x0898 mem_sp_prarm_stack
+0x08a8 mem_UI_data_txbuff_length
+0x08aa mem_ipc_skip_continue_proc
+0x08ab mem_ui_timer_temp//length 4
+0x08ab mem_ipc_rega_temp
+0x08af mem_usb_status
+0x08b0 mem_usb_fifo_empty
+0x08b1 mem_usb_read_len
+0x08b2 mem_usb_rxbuf
+0x08f2 mem_usb_cnt
+0x08f4 mem_usb_tx_enable
+0x08f5 mem_usb_tx_count
+0x08f6 mem_usb_set_protocol_count
+0x08f7 mem_usb_desc
+0x08f8 mem_usb_state
+0x08f9 mem_usb_idle_cnt
+0x08fb mem_usb_idle_timeout
+0x08fd mem_usb_trig_timeout
+0x08ff mem_usb_setup
+0x08ff mem_usb_setup_bmRequestType
+0x0900 mem_usb_setup_bRequest
+0x0901 mem_usb_setup_bValue
+0x0902 mem_usb_setup_bValueH
+0x0903 mem_usb_setup_wIndex
+0x0905 mem_usb_setup_bLength
+0x0906 mem_usb_setup_bLengthH
+0x0907 mem_usb0_setup
+0x090f mem_bufptr
+0x0911 mem_remain
+0x0912 mem_devicedesc
+0x0926 mem_hidreportdesc_kb
+0x09ee mem_hidreportdesc_m
+0x0ab6 mem_confdesc
+0x0b1a mem_string0
+0x0b1f mem_string1
+0x0b3d mem_string2
+0x0b5b mem_string3
+0x0b79 mem_hold_contr
+0x0b7b mem_hold_contw
+0x0b7d mem_fifo_temp
+0x0b7e mem_c51_flag
+0x0b7f mem_c51_lpm_lock
+0x0b80 mem_c51_wait_lpm
+0x0b81 mem_wakup_from_power_flag
+0x0b82 mem_lmp_bb_disconnect_reason
+0x0b83 mem_c51_eeprom_buf
+0x0be7 mem_c51_ipc_txbuf
+0x0c4b mem_c51_ipc_rxbuf
+0x0caf mem_c51_iicd_buf
+0x0cb3 mem_24g_rxbuf
+0x0cd5 mem_24g_txbuf
+0x0cf5 mem_24g_txpayload
+0x0d17 mem_24g_rxpayload
+0x0d37 mem_24g_common_temp
+0x0d57 mem_packet_length_temp
+0x0d58 mem_le_cur_handle_start
+0x0d5a mem_le_cur_handle_end
+0x0d5c mem_le_search_res
+0x4000 mem_patch00
+0x4001 mem_patch01
+0x4002 mem_patch02
+0x4003 mem_patch03
+0x4004 mem_patch04
+0x4005 mem_patch05
+0x4006 mem_patch06
+0x4007 mem_patch07
+0x4008 mem_patch08
+0x4009 mem_patch09
+0x400a mem_patch0a
+0x400b mem_patch0b
+0x400c mem_patch0c
+0x400d mem_patch0d
+0x400e mem_patch0e
+0x400f mem_patch0f
+0x4010 mem_patch10
+0x4011 mem_patch11
+0x4012 mem_patch12
+0x4013 mem_patch13
+0x4014 mem_patch14
+0x4015 mem_patch15
+0x4016 mem_patch16
+0x4017 mem_patch17
+0x4018 mem_patch18
+0x4019 mem_patch19
+0x401a mem_patch1a
+0x401b mem_patch1b
+0x401c mem_patch1c
+0x401d mem_patch1d
+0x401e mem_patch1e
+0x401f mem_patch1f
+0x4020 mem_patch20
+0x4021 mem_patch21
+0x4022 mem_patch22
+0x4023 mem_patch23
+0x4024 mem_patch24
+0x4025 mem_patch25
+0x4026 mem_patch26
+0x4027 mem_patch27
+0x4028 mem_patch28
+0x4029 mem_patch29
+0x402a mem_patch2a
+0x402b mem_patch2b
+0x402c mem_patch2c
+0x402d mem_patch2d
+0x402e mem_patch2e
+0x402f mem_patch2f
+0x4030 mem_patch30
+0x4031 mem_patch31
+0x4032 mem_patch32
+0x4033 mem_patch33
+0x4034 mem_patch34
+0x4035 mem_patch35
+0x4036 mem_patch36
+0x4037 mem_patch37
+0x4038 mem_patch38
+0x4039 mem_patch39
+0x403a mem_patch3a
+0x403b mem_patch3b
+0x403c mem_patch3c
+0x403d mem_patch3d
+0x403e mem_patch3e
+0x403f mem_patch3f
+0x4040 mem_context
+0x4130 mem_current_amaddr
+0x4131 mem_lpm_mode
+0x4132 mem_device_option
+0x4133 mem_scan_mode
+0x4134 mem_last_clkn
+0x4138 mem_features
+0x4140 mem_lap
+0x4143 mem_uap
+0x4144 mem_nap
+0x4146 mem_npage
+0x4147 mem_glap
+0x414a mem_class
+0x414d mem_iscan_window
+0x414f mem_iscan_interval
+0x4151 mem_pscan_window
+0x4153 mem_pscan_interval
+0x4155 mem_page_interval
+0x4157 mem_page_window
+0x4159 mem_page_to
+0x415b mem_inq_window
+0x415d mem_fcomp_mul
+0x415e mem_fcomp_div
+0x415f mem_rx_window_init
+0x4161 mem_rx_window_sniff
+0x4163 mem_rf_init_ptr
+0x4165 mem_last_type
+0x4166 mem_last_type_esco
+0x4167 mem_last_type_saved
+0x4168 mem_retransmission_cnt
+0x416a mem_next_btclk
+0x416e mem_seqi
+0x416f mem_rf_rccal
+0x4170 mem_handle_num
+0x4171 mem_max_slot
+0x4172 mem_eir_enable
+0x4173 mem_afh_instant
+0x4177 mem_afh_error_total
+0x4179 mem_afh_cfg
+0x417a mem_afh_new_mod
+0x417b mem_afh_map_lo
+0x4180 mem_afh_map_hi
+0x4185 mem_afh_used
+0x4186 mem_afh_index
+0x4188 mem_afh_map_new
+0x4193 mem_afh_map
+0x41e3 mem_afh_timer
+0x41e7 mem_afh_classify_channel_map
+0x41f1 mem_chip_functions
+0x41f3 mem_lpm_wake_lock
+0x41f5 mem_lpm_interval
+0x41f7 mem_lpm_overhead
+0x41f8 mem_lpm_hibernate_switch
+0x41f9 mem_esco_addr
+0x41fa mem_sniff_unint_lost
+0x41fb mem_ptt
+0x41fc mem_sleep_counter//should be 0x41fc in REVC
+0x4200 mem_sleep_counter_all
+0x4204 mem_sleep_clkn
+0x420a mem_sniff_rcv
+0x420d mem_sniff_lost
+0x4210 mem_clks_per_lpo
+0x4213 mem_lpm_mult
+0x4214 mem_lpm_mult_timeout
+0x4215 mem_lpm_mult_cnt
+0x4216 mem_lpm_config
+0x4219 mem_lpm_xtalcnt
+0x421a mem_lpm_buckcnt
+0x421b mem_lpm_ldocnt
+0x421c mem_lpm_isogate
+0x421d mem_lpm_isogate_final
+0x421e mem_saved_gpio// should be 0x421e in REVC
+0x422e mem_saved_gsel
+0x4231 mem_saved_mark
+0x4239 mem_saved_spidctrl
+0x423a mem_patch_ptr
+0x423c mem_patch_len
+0x423e mem_timers
+0x425e mem_link_key_exists
+0x425f mem_link_key_eeprom_head
+0x4262 mem_link_key
+0x4272 mem_hci_cmd
+0x4273 mem_hci_conn_handle
+0x4274 mem_hci_plap
+0x4277 mem_hci_puap
+0x4278 mem_hci_pnap
+0x427a mem_uartd_rxitems_got_data
+0x427b mem_uartd_rxitems_threshold
+0x427c mem_uartd_rx_timeout
+0x427e mem_app_state
+0x427f mem_app_handshake_flag
+0x4280 mem_sniff_param_interval
+0x4282 mem_sniff_param_attempt
+0x4284 mem_sniff_param_timeout
+0x4286 mem_cb_check_wakelock
+0x4288 mem_cb_before_hibernate
+0x428a mem_cb_before_lpm
+0x428c mem_cb_le_process
+0x428e mem_cb_bt_process
+0x4290 mem_cb_idle_process
+0x4292 mem_cb_bb_event_process
+0x4294 mem_cb_discovry_timeout
+0x4296 mem_cb_att_write
+0x4298 mem_cb_update_notify_value
+0x429a mem_device_nums
+0x429b mem_eeprom_base
+0x429d mem_unsniff2sniff_timer_count
+0x429e mem_wake_up_delay_timer
+0x429f mem_app_connection_options
+0x42a0 mem_app_disconn_reason
+0x42a2 mem_app_disconn_reason_flag
+0x42a4 mem_at_using_flag
+0x42a5 mem_lpm_delay_after_sniff
+0x42a9 mem_xrecord_mode
+0x42aa mem_eeprom_block_size
+0x42ac mem_baud
+0x42ae mem_hci_lt_rx_state
+0x42af mem_l2cap_xmem_start
+0x42af mem_l2cap_tx_multi_offset//0 means single packet
+0x42b1 mem_sdp_remote_cid
+0x42b3 mem_rfcomm_remote_cid
+0x42b5 mem_hid_ctrl_remote_cid
+0x42b7 mem_hid_int_remote_cid
+0x42b9 mem_sdp_state
+0x42ba mem_rfcomm_state
+0x42bb mem_hid_control_state
+0x42bc mem_hid_interrupt_state
+0x42bd mem_spp_state
+0x42be mem_ML2CAP_comm_id
+0x42bf mem_used_map
+0x42c0 mem_tx_fifo0
+0x42c0 mem_tx_fifo0_map
+0x42c1 mem_tx_fifo0_ptr
+0x42c3 mem_tx_fifo1
+0x42c3 mem_tx_fifo1_map
+0x42c4 mem_tx_fifo1_ptr
+0x42c6 mem_tx_fifo2
+0x42c6 mem_tx_fifo2_map
+0x42c7 mem_tx_fifo2_ptr
+0x42c9 mem_tx_fifo3
+0x42c9 mem_tx_fifo3_map
+0x42ca mem_tx_fifo3_ptr
+0x42cc mem_tx_fifo_end
+0x42cc mem_l2cap_lpm_txbuf
+0x43cc mem_l2cap_flow_ctrl_flag
+0x43cd mem_l2cap_pending_item
+0x43ce mem_l2cap_xmem_end
+0x43ce mem_le_dsniff
+0x43d0 mem_le_conn_interval
+0x43d2 mem_le_scan_enable
+0x43d3 mem_le_scan_interval
+0x43d5 mem_le_scan_window
+0x43d7 mem_le_adv_led
+0x43d8 mem_le_adv_enable
+0x43d9 mem_le_adv_data_len
+0x43da mem_le_adv_data
+0x43f9 mem_le_scan_data_len
+0x43fa mem_le_scan_data
+0x4419 mem_le_name_len
+0x441a mem_le_name
+0x442e mem_le_led_on_time
+0x442f mem_le_new_map
+0x4434 mem_le_new_param
+0x4434 mem_le_new_window
+0x4435 mem_le_new_offset
+0x4437 mem_le_new_interval
+0x4439 mem_le_new_latency
+0x443b mem_le_new_timeout
+0x443d mem_le_temp
+0x443e mem_le_txheader
+0x443f mem_le_txlen
+0x4440 mem_le_txpayload
+0x4442 mem_le_txcid
+0x4444 mem_le_l2cap
+0x4445 mem_le_l2cap_response
+0x4446 mem_le_txbdy
+0x4465 mem_le_pcnt_tx
+0x446a mem_le_pcnt_rx
+0x446f mem_le_last_mic
+0x4473 mem_le_ivm
+0x4477 mem_le_ivs
+0x447b mem_le_ltk
+0x448b mem_ltk_exists
+0x448c mem_le_rconfirm
+0x449c mem_le_srand
+0x44ac mem_le_iat
+0x44ad mem_le_rat
+0x44ae mem_le_preq
+0x44b5 mem_le_pres
+0x44bc mem_le_search_handle_start
+0x44be mem_le_search_handle_end
+0x44c0 mem_le_att_offset
+0x44c0 mem_le_search_att_type
+0x44c2 mem_le_notify_handle
+0x44c4 mem_le_uuid
+0x44c6 mem_le_handle_data_len
+0x44c7 mem_le_handle_data
+0x44d7 mem_le_adv_param
+0x44d7 mem_le_adv_interval_min
+0x44d9 mem_le_adv_interval_max
+0x44db mem_le_adv_type
+0x44dc mem_le_adv_own_addr_type
+0x44dd mem_le_adv_direct_addr_type
+0x44de mem_le_adv_direct_addr
+0x44e4 mem_le_adv_channel_map
+0x44e5 mem_le_adv_filter_policy
+0x44e6 mem_le_conn_param
+0x44e6 mem_le_conn_peer_addr_type
+0x44e7 mem_le_conn_peer_addr
+0x44ed mem_le_conn_own_addr_type
+0x44ee mem_le_conn_interval_min
+0x44f0 mem_le_conn_interval_max
+0x44f2 mem_le_conn_latency
+0x44f4 mem_le_conn_superto
+0x44f6 mem_le_scan_params
+0x44f6 mem_le_scan_type
+0x44f7 mem_le_scan_own_addr_type
+0x44f8 mem_le_scan_filter_policy
+0x44f9 mem_le_lap
+0x44fc mem_le_uap
+0x44fd mem_le_nap
+0x44ff mem_le_xtype_fifo
+0x4504 mem_le_att_list
+0x46f8 mem_le_switch_send_data
+0x46f9 mem_le_transmit_window
+0x46fd mem_lmp_version
+0x4700 mem_lmp_subversion
+0x4702 mem_local_name_length
+0x4703 mem_local_name
+0x4706 mem_local_name2
+0x4746 mem_local_name_end
+0x4747 mem_unsniff2sniff_timer
+0x4748 mem_switch_flag
+0x4749 mem_eeprom_ota_base_addr/*the start- writing addr in eeprom  */
+0x474b mem_pn_dlci
+0x474c mem_pn_max_frame_size
+0x474e memFCStemp1
+0x474f memFCStemp2
+0x4750 memFCStemp3
+0x4751 mem_rfcomm_initiator
+0x4752 mem_remote_spp_channel
+0x4753 mem_HIUfcs_SPP
+0x4754 mem_HIUfcs_SPP_WCredits
+0x4755 mem_rfcomm_send_more_pkt
+0x4756 mem_remote_credits
+0x4757 mem_credit_given
+0x4758 mem_ms_channel
+0x4759 memui_uuid_table
+0x475b mem_all_uuid_16bits
+0x4771 mem_all_uuid_128bits
+0x4793 mem_sp_local_key_invalid
+0x4794 mem_sp_private_key
+0x47ac mem_sp_pubkey_local
+0x47ac mem_sp_pubkey_local_x
+0x47c4 mem_sp_pubkey_local_x_end
+0x47c4 mem_sp_pubkey_local_y
+0x47dc mem_ssp_enable
+0x47dd mem_ipc_lock_bt
+0x47de mem_ipc_lock_c51
+0x47df mem_ipc_fifo_bt2c51
+0x47e4 mem_ipc_fifo_c512bt
+0x47e9 mem_led_switch
+0x47ea mem_ui_button_timer
+0x47eb mem_ui_button_last_state
+0x47ec mem_ui_timer_last_btclk
+0x47f0 mem_discovery_timeout_timer_count
+0x47f2 mem_hid_handshake_timer_count
+0x47f3 memui_reconnect_mode
+0x47f4 mem_ui_state_map
+0x47f6 mem_ui_profile_supported
+0x47f7 mem_led_gpio
+0x47f8 mem_led_dark_time
+0x47fa mem_led_light_time
+0x47fc mem_ui_button_timeout
+0x47fd mem_ui_button_gpio
+0x47fe mem_discovery_timeout
+0x4800 mem_ir_ptr
+0x4802 mem_ir_type
+0x4803 mem_ir_cmd
+0x4804 mem_ir_play_count
+0x4805 mem_ir_report_len
+0x4807 mem_ir_pulse_zero
+0x4808 mem_ir_pulse_one
+0x4809 mem_ir_pulses
+0x4825 mem_ir_sequence_len
+0x4826 mem_ir_sequence
+0x4800 mem_acl_credits
+0x4802 mem_allow_switch
+0x4803 mem_hci_acl_queue_start/*param_acl_pktcnt+2 byte*/
+0x4807 mem_hci_wake_clk
+0x4800 mem_kb_state
+0x4802 mem_kb_report_data
+0x4808 mem_kb_keys
+0x4809 mem_kb_rcv_led_data
+0x480a mem_kb_fast_wake_last
+0x480e mem_led_cap_gpio
+0x480f mem_led_num_gpio
+0x4810 mem_led_scl_gpio
+0x4811 mem_kb_map
+0x4811 mem_kb_uuid_list
+0x4a87 mem_24g_paring_tx_power_param
+0x4a91 mem_5db_tx_power_param
+0x4a9b mem_current_event
+0x4a9c mem_ipc_lock_rx_data_bt
+0x4a9d mem_ipc_lock_rx_data_c51
+0x4a9e mem_ipc_lock_tx_data_bt
+0x4a9f mem_ipc_lock_tx_data_c51
+0x4aa0 mem_ipc_2bt_fifo_head
+0x4b36 mem_ipc_2bt_fifo_end
+0x4b36 mem_ipc_2C51_fifo_head
+0x4b9a mem_ipc_2C51_fifo_end
+0x4b9a mem_ipc_2bt_read_index
+0x4b9c mem_ipc_2bt_write_index
+0x4b9e mem_ipc_2C51_read_index
+0x4ba0 mem_ipc_2C51_write_index
+0x4ba2 mem_ipc_tx_evt_buff
+0x4ba4 mem_ipc_tx_evt
+0x4ba5 mem_ipc_bt_timer
+0x4ba7 mem_ipc_rx_type
+0x4ba8 mem_rfcomm_tx_buff
+0x4ba8 mem_queue_ele_num
+0x4ba9 mem_queue_write
+0x4bab mem_queue_read
+0x4bad mem_queue_start
+0x4bad mem_uart_packet
+0x4bb9 mem_data_ele0
+0x4bc5 mem_data_ele1
+0x4bd1 mem_data_ele2
+0x4bdd mem_queue_end
+0x4bdd mem_queue_temp
+0x4bdf mem_24g_rxdata_length
+0x4be0 mem_24g_pid
+0x4be1 mem_24g_datalen
+0x4be2 mem_24g_data_type
+0x4be3 mem_24g_txlen
+0x4be4 mem_24g_rx_window
+0x4be6 mem_24g_ensure
+0x4be7 mem_24g_get_ack_fail
+0x4be8 mem_24g_retry
+0x4be9 mem_24g_ch
+0x4bea mem_24g_current_ch_number
+0x4beb mem_24g_paring_addr
+0x4bef mem_24g_pairing_sm
+0x4bf0 mem_24g_ch_map1
+0x4bf4 mem_24g_ch_map2
+0x4bf8 mem_24g_ch_map3
+0x4bfc mem_24g_ch_map4
+0x4c00 mem_24g_addr
+0x4c04 mem_24g_check_dongle_times
+0x4c06 mem_24g_device_addr
+0x4c0a mem_24g_no_ack
+0x4c0b mem_24g_sta_crc
+0x4c0e mem_24g_sta_pid
+0x4c0f mem_24g_max_retry
+0x4c10 mem_24g_mode
+0x4c11 mem_24g_hop_pac_retry
+0x4c12 mem_24g_idle_timeout
+0x4c13 mem_24g_idle_cnt
+0x4c14 mem_24g_auto_paring_switch
+0x4c15 mem_24g_enter_lpm_timer
+0x4c16 mem_24g_syncword
+0x4c18 mem_24g_syncword_crc8
+0x4c19 mem_24g_get_syncword_crc8
+0x4c1a mem_24g_discard_cnt
+0x4c1c mem_cb_24g_data
+0x4c1e mem_24g_lasttx
+0x4c27 mem_power_ctrl_pac_succ_cnt
+0x4c28 mem_power_ctrl_level
+0x4c29 mem_rssi_avg_received
+0x4c2a mem_rssi_hex_received
+0x4c2b mem_rssi_signal_buf
+0x4c33 mem_rssi_noise_buf
+0x4c3b mem_rssi_noise_index
+0x4c3c mem_rssi_signal_index
+0x4c3d mem_tx_power
+0x4c3e mem_tx_power_temp
+0x4c3f mem_cnt
+0x4c42 mem_last_txlch
+0x4c43 mem_last_txlen
+0x4c45 mem_last_txdata
+0x4c59 mem_ipc_last_check_timer
+0x4c5d mem_prepare_write_len
+0x4c5e mem_ipc_c51_timer
+0x4c60 mem_le_rx_window
+0x4c61 mem_le_find_type_value_start_handle
+0x4c63 mem_le_find_type_value_end_handle
+0x4c65 mem_le_cur_att_type
+0x4c67 mem_le_search_len
+0x4c68 mem_le_ll_unknown_type
+0x4c69 mem_le_pairing_state
+0x4c6a mem_le_local_mtu
+0x4c6c mem_le_connection_updata_param
+0x4c7c mem_ltk_states
+0x4c7d mem_pair_state
+0x4c7e mem_empty_count
+0x4c7f mem_shutter_find_type_value_flag
+0x4c80 mem_le51_payload_len
+0x4c81 mem_le51_cmd
+0x4c82 mem_le51_tx_length
+0x4c83 mem_le51_txbuff_inuse
+0x4c84 mem_le51_txbuf
+0x4c8d mem_ipc_bt_100ms_timer
+0x4c8e mem_ipc_c51_100ms_timer
+0x4c8f mem_adc_config_flag
+0x4c90 mem_adc_channel
+0x4c91 mem_adc_0v
+0x4c93 mem_adc_3v
+0x4c95 mem_adc_current_value
+0x4c97 mem_hibernate_flag
+0x4c98 mem_new_supervision_to
+0x4c9a mem_kb_wake_timer
+0x4c9b mem_kb_last_data
+0x4caf mem_kb_keycount
+0x4cb0 mem_led_cap_delay_timer
+0x4cb1 mem_test
+0x4cb4 mem_seq
+0x4cb5 mem_recon_index
+0x4cb6 mem_power_on_flag
+0x4cb7 mem_caps_num_lock
+0x4cb8 mem_att_report1
+0x4cba mem_att_report2
+0x4cbc mem_att_report3
+0x4cbe mem_suspend_flag
+0x4cbf mem_32asm_data_end
+0x4d37 mem_store_ltk_timer
+0x4d38 mem_reconnect_continue
+0x4d39 mem_le_pin_code
+0x4d3d mem_le_send_security_request_flag
+0x4d3e mem_att_report_battery
+0x4d40 mem_24g_enter_hibernate
+0x4d44 mem_24g_txfail_cnt
+0x4d45 mem_mouse_retry_flag
+0x4d46 mem_24g_led_flag
+0x4d47 mem_ui_timer_last_btclk_temp
+0x4d4b mem_ui_check_timer_setup
+0x4d4f mem_customize_timer_setup
+0x4d51 mem_customize_timer
+0x4d52 mem_ios_mode_flag
+0x4d53 mem_version_yy_mm_dd
+0x4d57 mem_24g_txbuf_new
+0x4d6b mem_le_adv_swift_pair
+0x4d72 mem_24g_enter_hibernate_setup
+0x4d76 mem_24g_enter_hibernate_max
+0x4d7a mem_24g_short_sleep_counter
+0x4d7d mem_pc_sleep_flag
+0x4d7e mem_le_pause_enc_flag
+0x4800 mem_at_gpio
+0x4801 mem_module_wake_up_gpio
+0x4802 mem_module_state_gpio
+0x4803 mem_module_connect_state_gpio
+0x4804 mem_module_version
+0x480a mem_last_uart_clock
+0x480e mem_current_packet_length
+0x4810 mem_module_prepare_tx_len
+0x4812 mem_module_state
+0x4813 mem_module_task
+0x4814 mem_cmode_addr
+0x481a mem_at_scan_time
+0x481c mem_prarm_pswd
+0x4820 mem_prarm_uart
+0x4824 mem_prarm_blename
+0x4827 mem_prarm_name
+0x482b mem_prarm_bleadss
+0x482e mem_prarm_adss
+0x4832 mem_prarm_vers
+0x4836 mem_prarm_class
+0x483b mem_prarm_clrflg
+0x4841 mem_prarm_reconn
+0x4847 mem_prarm_bledis
+0x4849 mem_prarm_dis
+0x484c mem_prarm_stsn
+0x4850 mem_prarm_atp
+0x4853 mem_prarm_list
+0x4857 mem_prarm_role
+0x485b mem_prarm_sniff
+0x4860 mem_prarm_ldev
+0x4864 mem_prarm_rssi
+0x4868 mem_prarm_cdev
+0x486c mem_prarm_bleinqr
+0x486f mem_prarm_inqr
+0x4873 mem_prarm_cmode
+0x4878 mem_prarm_mode
+0x487c mem_prarm_dmstate
+0x4883 mem_prarm_discov
+0x4889 mem_prarm_ota
+0x488c mem_prarm_bleconn
+0x488e mem_prarm_conn
+0x4892 mem_prarm_pageout
+0x4899 mem_prarm_recfail
+0x48a0 mem_module_uuid_list
+0x4800 mem_mouse_x
+0x4802 mem_mouse_y
+0x4804 mem_mouse_z
+0x4805 mem_mouse_key
+0x4806 mem_mouse_z_last
+0x4807 mem_mouse_z_before
+0x4808 mem_mouse_z_now
+0x4809 mem_mouse_z_data
+0x480a mem_mouse_move_flag
+0x480b mem_reconnect_timeout
+0x480c mem_mouse_direct_timeout
+0x480e mem_mouse_no_data_timeout
+0x4810 mem_mouse_blank_data_timeout
+0x4812 mem_mouse_discovery_timer
+0x4814 mem_mouse_direct_timer
+0x4816 mem_mouse_no_data_timer
+0x4818 mem_mouse_blank_data_timer
+0x481a mem_mouse_send_blank_timer
+0x481b mem_mouse_dpi
+0x481c mem_mouse_dpi_button_state
+0x481d mem_mouse_test_cnt
+0x481e mem_le_hibernate_timer
+0x4820 mem_mouse_mode_state
+0x4821 mem_sensor_type
+0x4822 mem_lbutton_gpio
+0x4823 mem_rbutton_gpio
+0x4824 mem_mbutton_gpio
+0x4825 mem_dpi_button_gpio
+0x4826 mem_sensor_data_gpio
+0x4827 mem_whee_a_data_gpio
+0x4828 mem_whee_b_data_gpio
+0x4829 mem_conn_cnt
+0x482a mem_mouse_uuid_list
+0x4800 mem_shutter_send_data
+0x4804 mem_shutter_key_temp
+0x4805 mem_shutter_send_length
+0x4806 mem_shutter_clkn_bt_last
+0x480a mem_shutter_key
+0x480b mem_shutter_flag
+0x480c mem_shutter_cable_unplug_conut
+0x480d mem_shutter_hid_disconn_count
+0x480e mem_shutter_1key_send_sm
+0x480f mem_shutter_iphonekey_gpio
+0x4810 mem_shutter_androidkey_gpio
+0x4811 mem_shutter_key_number
+0x4812 mem_shutter_uuid_list
Index: btkb/output/program.lis
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/output/program.lis	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/output/program.lis	(working copy)
@@ -0,0 +1,28559 @@
+              include "bt_format "
+              org 0x0000
+0000 c5128010 bmark1 mark_ext_patch ,patch_ext 
+0001 c000002c beq patch00_0 ,p_soft_reset 
+0002 c0010030 beq patch00_2 ,p_soft_reset_2 
+0003 c0018038 beq patch00_3 ,p_main_loop 
+0004 c0028042 beq patch00_5 ,p_main_loop_end 
+0005 c04801b5 beq patch12_0 ,p_shutdown_radio 
+0006 c049017b beq patch12_2 ,p_set_freq_rx 
+0007 c04a0181 beq patch12_4 ,p_set_freq_tx 
+0008 c04a816b beq patch12_5 ,p_initialize_radio_cont 
+0009 c0580299 beq patch16_0 ,p_lpm_sleep 
+000a c058812f beq patch16_1 ,p_lpm_recover_clk 
+000b c0590143 beq patch16_2 ,p_lpm_dispatch 
+000c c059815d beq patch16_3 ,p_lpm_dispatch_next 
+000d c05b0166 beq patch16_6 ,p_lpm_dispatch_unconn 
+000e c05c8137 beq patch17_1 ,p_lpm_cal_xtal_startup 
+000f 20203bf1 branch assert 
+
+patch_ext:
+0010 c01902a7 beq patch26_2 ,p_le_init_conn 
+0011 c01dd3b0 beq patch27_3 ,le_slave_unsync + 3 
+0012 c01f022d beq patch27_6 ,p_le_enable 
+0013 c01f8231 beq patch27_7 ,p_le_disable 
+0014 c0250314 beq patch29_2 ,p_lerx_nopayload 
+0015 c02582a0 beq patch29_3 ,p_le_transmit_receive_sifs 
+0016 c02602aa beq patch29_4 ,p_le_transmit 
+0017 c02702b0 beq patch29_6 ,p_le_send_adv_ind 
+0018 c02b02b7 beq patch2a_6 ,p_le_update_param 
+0019 c02d02c3 beq patch2b_2 ,p_le_check_wak 
+001a c03082be beq patch2c_1 ,p_le_prepare_tx 
+001b c03182e3 beq patch2c_3 ,p_le_prepare_tx_cmd 
+001c c0320308 beq patch2c_4 ,p_le_prepare_smp 
+001d c032833e beq patch2c_5 ,p_le_prepare_att 
+001e c03484a0 beq patch2d_1 ,p_le_send_non_l2cap 
+001f c0350484 beq patch2d_2 ,p_le_parse 
+0020 c0358486 beq patch2d_3 ,p_le_parse_ll 
+0021 c03704ab beq patch2d_6 ,p_le_parse_smp 
+0022 c037831f beq patch2d_7 ,p_le_parse_att 
+0023 c0438103 beq patch30_7 ,p_ui_timer_check 
+0024 c046824c beq patch31_5 ,p_check_51cmd_once 
+0025 c0470263 beq patch31_6 ,p_check_51cmd_once_continue 
+0026 c0478235 beq patch31_7 ,p_check_enter_hibernate 
+0027 c05e8243 beq patch37_5 ,p_fifo_in 
+0028 c06681bf beq patch39_5 ,p_kb_init 
+0029 c067810f beq patch39_7 ,p_app_process_bb_event 
+002a c0680119 beq patch3a_0 ,p_kb_bb_event_timer 
+002b 20203bf1 branch assert 
+
+p_soft_reset:
+002c 6810813b hfetch 1 ,0x813b 
+002d 60008b81 store 1 ,mem_wakup_from_power_flag 
+002e 70800608 hjam lock_otp ,core_misc_ctrl 
+002f 20203003 branch soft_reset + 2 
+
+p_soft_reset_2:
+0030 20407719 call sp_initialize 
+0031 2055bcf1 call lpm_recover_clk ,wake 
+
+p_sp_cal_loop:
+0032 20407813 call sp_calc_sequence 
+0033 6800c7dc fetch 1 ,mem_ssp_enable 
+0034 203a3013 branch main_loop ,blank 
+0035 6800c793 fetch 1 ,mem_sp_local_key_invalid 
+0036 203a0032 branch p_sp_cal_loop ,blank 
+0037 20203013 branch main_loop 
+
+p_main_loop:
+0038 2040009d call p_ipc_timer_check 
+0039 2040008f call p_ui_check_timer_setup 
+003a 20400047 call p_ipc_rx 
+003b 2040003d call p_bt_status_handle 
+003c 20203015 branch main_loop + 2 
+
+p_bt_status_handle:
+003d 680947f4 fetcht 2 ,mem_ui_state_map 
+003e 6800c3d8 fetch 1 ,mem_le_adv_enable 
+003f 7d3a040b nsetflag blank ,ui_state_ble_adv ,temp 
+0040 600947f4 storet 2 ,mem_ui_state_map 
+0041 20600000 rtn 
+
+p_main_loop_end:
+0042 20403392 call inquiry_scan_dispatch 
+0043 20403407 call page_scan_dispatch 
+0044 20403024 call connection_dispatch 
+0045 204004cc call p_g24_dispatch 
+0046 20203022 branch main_loop + 15 
+
+p_ipc_rx:
+0047 6800c7dc fetch 1 ,mem_ssp_enable 
+0048 203a004b branch p_ipc_rx0 ,blank 
+0049 6800c793 fetch 1 ,mem_sp_local_key_invalid 
+004a 207a0000 rtn blank 
+
+p_ipc_rx0:
+004b 204000fe call p_check_ipc_2bt 
+004c 20740000 rtn user 
+004d 1ff0fe00 byteswap pdata ,pdata 
+004e 1fe20c00 copy pdata ,contr 
+004f 204000df call p_ipc_rx_byte 
+0050 6000cba7 store 1 ,mem_ipc_rx_type 
+0051 c000805f beq ipc_type_cmd ,p_ipc_rx_cmd 
+0052 c0030069 beq ipc_type_24g ,p_ipc_rx_24g 
+0053 1fe20400 copy pdata ,temp 
+0054 18c22200 copy contr ,rega 
+0055 6800c040 fetch 1 ,mem_context 
+0056 c300005c bbit0 state_inconn ,p_ipc_abondon_rx_data 
+0057 1a220c00 copy rega ,contr 
+0058 c6848000 rtnmark0 mark_context 
+0059 18427e00 copy temp ,pdata 
+005a c002806b beq ipc_type_ble ,p_ipc_rx_ble 
+005b 20203bf1 branch assert 
+
+p_ipc_abondon_rx_data:
+005c 1a220c00 copy rega ,contr 
+005d d8a000f8 arg mem_tst_pktcnt_sync ,contw 
+005e 202000d7 branch p_ipc_rx_cpy 
+
+p_ipc_rx_cmd:
+005f 204000df call p_ipc_rx_byte 
+0060 204000df call p_ipc_rx_byte 
+0061 60008b7d store 1 ,mem_fifo_temp 
+0062 20400064 call p_ipc_next_rx 
+0063 20207c33 branch ui_ipc_send_cmd 
+
+p_ipc_next_rx:
+0064 204000e2 call p_ipc_rx_updata_contr 
+0065 18c20400 copy contr ,temp 
+0066 18508400 byteswap temp ,temp 
+0067 60094b9a storet 2 ,mem_ipc_2bt_read_index 
+0068 20600000 rtn 
+
+p_ipc_rx_24g:
+0069 d8a04d57 arg mem_24g_txbuf_new ,contw 
+006a 202000d7 branch p_ipc_rx_cpy 
+
+p_ipc_rx_ble:
+006b 18c22200 copy contr ,rega 
+
+p_ipc_rx_ble_read_fifo:
+006c 6800cba9 fetch 1 ,mem_queue_write 
+006d 1fe08401 add pdata ,1 ,temp 
+006e 18410403 and temp ,0x03 ,temp 
+006f 6008cba9 storet 1 ,mem_queue_write 
+0070 1feffe07 mul32 pdata ,7 ,pdata 
+0071 d8a04bad arg mem_uart_packet ,contw 
+0072 98a08a00 iadd contw ,contw 
+0073 1a220c00 copy rega ,contr 
+0074 204000df call p_ipc_rx_byte 
+0075 18c22200 copy contr ,rega 
+0076 1fe0ffff increase -1 ,pdata 
+0077 1fe27200 copy pdata ,loopcnt 
+0078 1fe0fe07 increase 7 ,pdata 
+0079 6000cc82 store 1 ,mem_le51_tx_length 
+007a 1a220c00 copy rega ,contr 
+007b 204000df call p_ipc_rx_byte 
+007c 18c22200 copy contr ,rega 
+007d c0008081 beq 01 ,p_report1 
+007e c0010089 beq 02 ,p_report2 
+007f c001808b beq 03 ,p_report3 
+0080 c002008d beq 04 ,p_report4 
+
+p_report1:
+0081 68014cb8 fetch 2 ,mem_att_report1 
+
+p_set_report:
+0082 e0a10000 istore 2 ,contw 
+0083 1a220c00 copy rega ,contr 
+0084 204000d9 call p_ipc_copy 
+0085 2040561e call le_xtype_fifo_is_near_full 
+0086 247a0000 nrtn blank 
+0087 700b7d1b jam attop_handle_value_notification ,mem_fifo_temp 
+0088 20205620 branch le_xtype_fifo_in 
+
+p_report2:
+0089 68014cba fetch 2 ,mem_att_report2 
+008a 20200082 branch p_set_report 
+
+p_report3:
+008b 68014cbc fetch 2 ,mem_att_report3 
+008c 20200082 branch p_set_report 
+
+p_report4:
+008d 68014d3e fetch 2 ,mem_att_report_battery 
+008e 20200082 branch p_set_report 
+
+p_ui_check_timer_setup:
+008f 680a4d4b fetcht 4 ,mem_ui_check_timer_setup 
+0090 1c427e00 copy clkn_bt ,pdata 
+0091 98467e00 isub temp ,pdata 
+0092 68094d4f fetcht 2 ,mem_customize_timer_setup 
+0093 9846fc00 idiv temp 
+0094 20407efd call wait_div_end 
+0095 1807fe00 quotient pdata 
+0096 207a0000 rtn blank 
+0097 1c420400 copy clkn_bt ,temp 
+0098 600a4d4b storet 4 ,mem_ui_check_timer_setup 
+0099 6800cd51 fetch 1 ,mem_customize_timer 
+009a 1fe0fe01 increase 1 ,pdata 
+009b 6000cd51 store 1 ,mem_customize_timer 
+009c 20600000 rtn 
+
+p_ipc_timer_check:
+009d 680a4c59 fetcht 4 ,mem_ipc_last_check_timer 
+009e 1c427e00 copy clkn_bt ,pdata 
+009f 98467e00 isub temp ,pdata 
+00a0 d8400640 arg 1600 ,temp 
+00a1 9846fc00 idiv temp 
+00a2 20407efd call wait_div_end 
+00a3 1807fe00 quotient pdata 
+00a4 207a0000 rtn blank 
+00a5 1c420400 copy clkn_bt ,temp 
+00a6 600a4c59 storet 4 ,mem_ipc_last_check_timer 
+00a7 68094ba5 fetcht 2 ,mem_ipc_bt_timer 
+00a8 18508400 byteswap temp ,temp 
+00a9 9840fe00 iadd temp ,pdata 
+00aa 1ff0fe00 byteswap pdata ,pdata 
+00ab 60014ba5 store 2 ,mem_ipc_bt_timer 
+00ac 1ff0fe00 byteswap pdata ,pdata 
+00ad 1fe17e03 and pdata ,0x3 ,pdata 
+00ae c1800000 rtnne 0 
+00af 6800cc8f fetch 1 ,mem_adc_config_flag 
+00b0 c28000ba bbit1 adc_config_vinlpm ,p_adc_check_vinlpm 
+00b1 c28080bc bbit1 adc_config_hvin ,p_adc_check_hvin 
+
+p_adc_check_gpio:
+00b2 da200000 arg 0 ,rega 
+00b3 204000ce call p_setup_adc_gpio_pu_setup 
+00b4 7089718f hjam 0x8f ,rf_adc_mode 
+00b5 6800cc90 fetch 1 ,mem_adc_channel 
+00b6 60108973 hstore 1 ,rf_adc_ch 
+00b7 204000bd call p_read_adc 
+00b8 da200001 arg 1 ,rega 
+00b9 202000ce branch p_setup_adc_gpio_pu_setup 
+
+p_adc_check_vinlpm:
+00ba 708971bf hjam 0xbf ,rf_adc_mode 
+00bb 202000bd branch p_read_adc 
+
+p_adc_check_hvin:
+00bc 708971af hjam 0xaf ,rf_adc_mode 
+
+p_read_adc:
+00bd 68108053 hfetch 1 ,core_uart_baud + 1 
+00be 79207e07 set1 7 ,pdata 
+00bf 60108053 hstore 1 ,core_uart_baud + 1 
+00c0 68108973 hfetch 1 ,rf_adc_ch 
+00c1 1fe1fe30 or_into 0x30 ,pdata 
+00c2 60108973 hstore 1 ,rf_adc_ch 
+00c3 70890674 hjam 0x74 ,rfen_adc 
+00c4 7089067c hjam 0x7c ,rfen_adc 
+00c5 708972aa hjam 0xaa ,rf_adc_gc 
+00c6 20001388 nop 5000 
+00c7 68190150 hfetcht 2 ,core_adc_sum 
+00c8 68108053 hfetch 1 ,core_uart_baud + 1 
+00c9 793ffe07 set0 7 ,pdata 
+00ca 60108053 hstore 1 ,core_uart_baud + 1 
+00cb 18508400 byteswap temp ,temp 
+00cc 60094c95 storet 2 ,mem_adc_current_value 
+00cd 20600000 rtn 
+
+p_setup_adc_gpio_pu_setup:
+00ce d8400021 arg 0x21 ,temp 
+00cf 6800cc90 fetch 1 ,mem_adc_channel 
+00d0 98460400 isub temp ,temp 
+00d1 1a227e00 copy rega ,pdata 
+00d2 79200407 set1 gpio_active_bit ,temp 
+00d3 243a00d5 nbranch p_setup_adc_gpio_pu_setup_exit ,blank 
+00d4 793f8407 set0 gpio_active_bit ,temp 
+
+p_setup_adc_gpio_pu_setup_exit:
+00d5 d8a08078 arg core_gpio_pu0 ,contw 
+00d6 202069f4 branch gpio_set_bit 
+
+p_ipc_rx_cpy:
+00d7 204000df call p_ipc_rx_byte 
+00d8 1fe27200 copy pdata ,loopcnt 
+
+p_ipc_copy:
+00d9 204000db call p_ipc_cpy_loop 
+00da 20200064 branch p_ipc_next_rx 
+
+p_ipc_cpy_loop:
+00db 204000df call p_ipc_rx_byte 
+00dc e0a08000 istore 1 ,contw 
+00dd c20000db loop p_ipc_cpy_loop 
+00de 20600000 rtn 
+
+p_ipc_rx_byte:
+00df 204000e2 call p_ipc_rx_updata_contr 
+00e0 e8c08000 ifetch 1 ,contr 
+00e1 20600000 rtn 
+
+p_ipc_rx_updata_contr:
+00e2 58004b36 setarg mem_ipc_2bt_fifo_end 
+00e3 98c67c00 isub contr ,null 
+00e4 24628000 nrtn zero 
+00e5 d8c04aa0 arg mem_ipc_2bt_fifo_head ,contr 
+00e6 20600000 rtn 
+
+p_ipc_tx_evt:
+00e7 df200003 arg 3 ,loopcnt 
+00e8 d8c04ba2 arg mem_ipc_tx_evt_buff ,contr 
+
+p_ipc_tx_cpy:
+00e9 18c22200 copy contr ,rega 
+00ea 68014ba0 fetch 2 ,mem_ipc_2c51_write_index 
+00eb 1ff0fe00 byteswap pdata ,pdata 
+00ec 1fe20a00 copy pdata ,contw 
+00ed 1a220c00 copy rega ,contr 
+
+p_ipc_tx_loop:
+00ee e8c08000 ifetch 1 ,contr 
+00ef e0a08000 istore 1 ,contw 
+00f0 204000f6 call p_ipc_tx_updata_contw 
+00f1 c20000ee loop p_ipc_tx_loop 
+00f2 18a27e00 copy contw ,pdata 
+00f3 1ff0fe00 byteswap pdata ,pdata 
+00f4 60014ba0 store 2 ,mem_ipc_2c51_write_index 
+00f5 20600000 rtn 
+
+p_ipc_tx_updata_contw:
+00f6 58004b9a setarg mem_ipc_2c51_fifo_end 
+00f7 98a67c00 isub contw ,null 
+00f8 24628000 nrtn zero 
+00f9 d8a04b36 arg mem_ipc_2c51_fifo_head ,contw 
+00fa 20600000 rtn 
+
+p_check_ipc_2c51:
+00fb 68014b9e fetch 2 ,mem_ipc_2c51_read_index 
+00fc 68094ba0 fetcht 2 ,mem_ipc_2c51_write_index 
+00fd 20200100 branch p_check_ipc_common 
+
+p_check_ipc_2bt:
+00fe 68014b9a fetch 2 ,mem_ipc_2bt_read_index 
+00ff 68094b9c fetcht 2 ,mem_ipc_2bt_write_index 
+
+p_check_ipc_common:
+0100 98467c00 isub temp ,null 
+0101 2022e9b1 branch enable_usr ,zero 
+0102 2020320b branch disable_usr 
+
+p_ui_timer_check:
+0103 1c427e00 copy clkn_bt ,pdata 
+0104 60024d47 store 4 ,mem_ui_timer_last_btclk_temp 
+0105 6808c7ef fetcht 1 ,mem_ui_timer_last_btclk + 3 
+0106 6800cd4a fetch 1 ,mem_ui_timer_last_btclk_temp + 3 
+0107 98467c00 isub temp ,null 
+0108 2441010a ncall p_ui_timer_reinit ,positive 
+0109 20207c06 branch ui_timer_check + 2 
+
+p_ui_timer_reinit:
+010a 680a4d47 fetcht 4 ,mem_ui_timer_last_btclk_temp 
+010b 600a47ec storet 4 ,mem_ui_timer_last_btclk 
+010c 600a4c59 storet 4 ,mem_ipc_last_check_timer 
+010d 600a4d4b storet 4 ,mem_ui_check_timer_setup 
+010e 20600000 rtn 
+
+p_app_process_bb_event:
+010f da2047df arg mem_ipc_fifo_bt2c51 ,rega 
+0110 20407f9f call fifo_out 
+0111 207a0000 rtn blank 
+0112 1fe22600 copy pdata ,regc 
+0113 20400115 call p_app_event_normal_process 
+0114 20203ea5 branch app_process_bb_event_priority 
+
+p_app_event_normal_process:
+0115 c10c0000 rtneq bt_evt_linkkey_generate 
+0116 c00a04bd beq bt_evt_le_connected ,scale_process_le_conn 
+0117 c00a829e beq bt_evt_le_disconnected ,p_scale_process_le_discon 
+0118 20203e7d branch app_event_normal_process 
+
+p_kb_bb_event_timer:
+0119 60088259 storet 1 ,mem_app_evt_timer_count 
+011a 6800cc8d fetch 1 ,mem_ipc_bt_100ms_timer 
+011b 1fe0fe01 increase 1 ,pdata 
+011c 6000cc8d store 1 ,mem_ipc_bt_100ms_timer 
+
+p_kb_bb_event_100ms_loop:
+011d 68008259 fetch 1 ,mem_app_evt_timer_count 
+011e 207a0000 rtn blank 
+011f 1fe0ffff increase -1 ,pdata 
+0120 60008259 store 1 ,mem_app_evt_timer_count 
+0121 20400123 call p_kb_long_sleep_timer 
+0122 2020011d branch p_kb_bb_event_100ms_loop 
+
+p_kb_long_sleep_timer:
+0123 6800cc15 fetch 1 ,mem_24g_enter_lpm_timer 
+0124 207a0000 rtn blank 
+0125 1fe0ffff increase -1 ,pdata 
+0126 6000cc15 store 1 ,mem_24g_enter_lpm_timer 
+0127 20600000 rtn 
+
+p_c51_user_event:
+0128 1a627e00 copy regc ,pdata 
+0129 1fe17ef0 and_into bt_evt_timer_mask ,pdata 
+012a c1280000 rtneq bt_evt_timer_init 
+012b 1a627e00 copy regc ,pdata 
+012c 207a0000 rtn blank 
+012d 6000cba4 store 1 ,mem_ipc_tx_evt 
+012e 202000e7 branch p_ipc_tx_evt 
+
+p_lpm_recover_clk:
+012f 70416e7f jam 0x7f ,mem_seqi 
+0130 20403cf3 call lpm_recover_clk + 2 
+0131 6800cc97 fetch 1 ,mem_hibernate_flag 
+0132 207a0000 rtn blank 
+0133 704c9700 jam 0 ,mem_hibernate_flag 
+0134 1c427e00 copy clkn_bt ,pdata 
+0135 60024c59 store 4 ,mem_ipc_last_check_timer 
+0136 20600000 rtn 
+
+p_lpm_cal_xtal_startup:
+0137 6800c219 fetch 1 ,mem_lpm_xtalcnt 
+0138 247a0000 nrtn blank 
+0139 70804206 hjam clksel_rc ,core_clksel 
+013a 58000f0c setarg 0xf0c 
+013b 20403da7 call lpm_write_config 
+013c 58030d40 setarg 200000 
+013d 20403bf3 call sleep 
+013e 37d98200 until null ,lpo_edge 
+013f 1e226000 copy lpo_time ,alarm 
+0140 20403b36 call xtal_fast_wake 
+0141 20001388 nop 5000 
+0142 20203d9d branch lpm_cal_xtal_startup + 12 
+
+p_lpm_dispatch:
+0143 c6118000 rtnmark1 mark_24g 
+0144 680147f4 fetch 2 ,mem_ui_state_map 
+0145 c284bd1e bbit1 ui_state_ble_connected ,lpm_dispatch + 2 
+0146 20403cab call lpo_calibration 
+0147 6801c210 fetch 3 ,mem_clks_per_lpo 
+0148 207a0000 rtn blank 
+0149 6800c131 fetch 1 ,mem_lpm_mode 
+014a 207a0000 rtn blank 
+014b 2040527e call l2cap_malloc_is_fifo_empty 
+014c 247a0000 nrtn blank 
+014d 20403dca call lpm_check_wake_lock 
+014e 247a0000 nrtn blank 
+014f 20403b36 call xtal_fast_wake 
+0150 6800c7dc fetch 1 ,mem_ssp_enable 
+0151 203a3d25 branch lpm_dispatch0 ,blank 
+0152 6800c793 fetch 1 ,mem_sp_local_key_invalid 
+0153 207a0000 rtn blank 
+0154 20203d25 branch lpm_dispatch0 
+
+p_check_ipc_for_lpm:
+0155 204000fe call p_check_ipc_2bt 
+0156 24740000 nrtn user 
+0157 204000fb call p_check_ipc_2c51 
+0158 24740000 nrtn user 
+0159 700b7f01 jam 1 ,mem_c51_lpm_lock 
+015a 700b7e01 jam syc_task_lpm ,mem_c51_flag 
+015b 20400162 call p_c51_wait 
+015c 202000fe branch p_check_ipc_2bt 
+
+p_lpm_dispatch_next:
+015d 20400155 call p_check_ipc_for_lpm 
+015e 24740000 nrtn user 
+015f 68008b7f fetch 1 ,mem_c51_lpm_lock 
+0160 247a0000 nrtn blank 
+0161 20203d2d branch lpm_dispatch1 
+
+p_c51_wait:
+0162 68008b7e fetch 1 ,mem_c51_flag 
+0163 2000000a nop 10 
+0164 c0800162 bne 0 ,p_c51_wait 
+0165 20600000 rtn 
+
+p_lpm_dispatch_unconn:
+0166 20400155 call p_check_ipc_for_lpm 
+0167 24740000 nrtn user 
+0168 68008b7f fetch 1 ,mem_c51_lpm_lock 
+0169 247a0000 nrtn blank 
+016a 20203d4f branch lpm_dispatch_unconn + 2 
+
+p_initialize_radio_cont:
+016b 2040016d call p_switchto_dpllclk 
+016c 20203aaf branch initialize_radio_cont + 4 
+
+p_switchto_dpllclk:
+016d 6800c219 fetch 1 ,mem_lpm_xtalcnt 
+016e 243a0173 nbranch p_switchdpll_nocal ,blank 
+016f 20403d91 call lpm_cal_xtal_startup 
+0170 20007530 nop 30000 
+0171 20007530 nop 30000 
+0172 20007530 nop 30000 
+
+p_switchdpll_nocal:
+0173 20403b0a call switchto_dpllclk 
+0174 70804204 hjam clksel_xtal ,core_clksel 
+0175 6810896b hfetch 1 ,rf_clkpll_frac + 2 
+0176 1fe17ecf and_into 0xcf ,pdata 
+0177 6010896b hstore 1 ,rf_clkpll_frac + 2 
+0178 1fe1fe30 or_into 0x30 ,pdata 
+0179 6010896b hstore 1 ,rf_clkpll_frac + 2 
+017a 20600000 rtn 
+
+p_set_freq_rx:
+017b 60088017 storet 1 ,mem_last_freq 
+017c 1840a204 add temp ,rx_freq_offset ,rega 
+017d 20203a86 branch set_freq_rx + 4 
+
+p_set_freq_tx_common:
+017e 60088017 storet 1 ,mem_last_freq 
+017f 1840a200 add temp ,0 ,rega 
+0180 20203ab6 branch rf_write_freq 
+
+p_set_freq_tx:
+0181 2040017e call p_set_freq_tx_common 
+0182 58000500 setarg param_pll_setup 
+0183 20403bf3 call sleep 
+
+p_txon:
+0184 70890601 hjam 0x1 ,rfen_adc 
+0185 7089003c hjam 0x3c ,rfen_rx 
+0186 708901e0 hjam 0xe0 ,rfen_tx 
+0187 70896d12 hjam 0x12 ,0x96d 
+0188 2000000a nop 10 
+0189 70890201 hjam 0x01 ,rfen_mdm 
+018a 7089023d hjam 0x3d ,rfen_mdm 
+018b 2000000a nop 10 
+018c 708903b7 hjam 0xb7 ,rfen_sn 
+018d 2000000a nop 10 
+018e 7089027d hjam 0x7d ,rfen_mdm 
+018f 6800cbef fetch 1 ,mem_24g_pairing_sm 
+0190 c0ff8199 bne state_24g_pairing_success ,p_txpower_0dbm 
+0191 6802ca91 fetch 5 ,mem_5db_tx_power_param 
+0192 e0a28000 istore 5 ,contw 
+0193 e8c28000 ifetch 5 ,contr 
+0194 e0a28000 istore 5 ,contw 
+0195 708956df hjam 0xdf ,0x956 
+0196 204001a4 call p_set_tx_step_power 
+0197 708955df hjam 0xdf ,0x955 
+0198 20600000 rtn 
+
+p_txpower_0dbm:
+0199 6802ca87 fetch 5 ,mem_24g_paring_tx_power_param 
+019a e0a28000 istore 5 ,contw 
+019b e8c28000 ifetch 5 ,contr 
+019c e0a28000 istore 5 ,contw 
+019d 6800cc7d fetch 1 ,mem_pair_state 
+019e 205a01a2 call p_txpower_0dbm_default_set ,blank 
+019f 60108956 hstore 1 ,0x8956 
+01a0 708955d0 hjam 0xd0 ,0x955 
+01a1 20600000 rtn 
+
+p_txpower_0dbm_default_set:
+01a2 580000c2 setarg 0xc2 
+01a3 20600000 rtn 
+
+p_set_tx_step_power:
+01a4 20000004 nop 4 
+01a5 708955d1 hjam 0xd1 ,0x955 
+01a6 20000004 nop 4 
+01a7 708955d2 hjam 0xd2 ,0x955 
+01a8 20000004 nop 4 
+01a9 708955d4 hjam 0xd4 ,0x955 
+01aa 20000004 nop 4 
+01ab 20600000 rtn 
+
+p_tx_ramp_down_common:
+01ac 708955d4 hjam 0xd4 ,0x955 
+01ad 20000004 nop 4 
+01ae 708955d2 hjam 0xd2 ,0x955 
+01af 20000004 nop 4 
+01b0 708955d1 hjam 0xd1 ,0x955 
+01b1 20000004 nop 4 
+01b2 708955d0 hjam 0xd0 ,0x955 
+01b3 708956c0 hjam 0xc0 ,0x956 
+01b4 20600000 rtn 
+
+p_shutdown_radio:
+01b5 2030ba6f branch shutdown_radio + 2 ,is_rx 
+01b6 204001ac call p_tx_ramp_down_common 
+01b7 20203a6f branch shutdown_radio + 2 
+
+p_kb_before_hibernate:
+01b8 78347c00 enable user 
+01b9 68120138 hfetch 4 ,0x8138 
+01ba 79347e1a setflag user ,26 ,pdata 
+01bb 6012004c hstore 4 ,core_lpm_reg 
+01bc 20403db0 call lpm_write_ctrl 
+01bd 7000a201 jam 1 ,mem_lpm_current_mult 
+
+p_kb_bt_lpm_before:
+01be 20600000 rtn 
+
+p_kb_init:
+01bf 6800c419 fetch 1 ,mem_le_name_len 
+01c0 1fe0fe02 increase 2 ,pdata 
+01c1 6000c3f9 store 1 ,mem_le_scan_data_len 
+01c2 700b7e00 jam 0 ,mem_c51_flag 
+01c3 70017706 jam 6 ,mem_connection_options 
+01c4 20403fa4 call app_lpm_mult_enable 
+01c5 580001be setarg p_kb_bt_lpm_before 
+01c6 6001428a store 2 ,mem_cb_before_lpm 
+01c7 58000128 setarg p_c51_user_event 
+01c8 60014292 store 2 ,mem_cb_bb_event_process 
+01c9 58000234 setarg p_mouse_idle 
+01ca 60014290 store 2 ,mem_cb_idle_process 
+01cb 58000047 setarg p_ipc_rx 
+01cc 6001428c store 2 ,mem_cb_le_process 
+01cd 580001b8 setarg p_kb_before_hibernate 
+01ce 60014288 store 2 ,mem_cb_before_hibernate 
+01cf 58004aa0 setarg mem_ipc_2bt_fifo_head 
+01d0 1ff0fe00 byteswap pdata ,pdata 
+01d1 60014b9a store 2 ,mem_ipc_2bt_read_index 
+01d2 60014b9c store 2 ,mem_ipc_2bt_write_index 
+01d3 20403e0b call lpm_disable_exen_output 
+01d4 58004b36 setarg mem_ipc_2c51_fifo_head 
+01d5 1ff0fe00 byteswap pdata ,pdata 
+01d6 60014b9e store 2 ,mem_ipc_2c51_read_index 
+01d7 60014ba0 store 2 ,mem_ipc_2c51_write_index 
+01d8 6800cc97 fetch 1 ,mem_hibernate_flag 
+01d9 c02d01f0 beq 0x5a ,p_device_init_init_hibwake 
+01da 203581ee branch p_deveice_init_wake ,wake 
+01db 68014c91 fetch 2 ,mem_adc_0v 
+01dc 1ff0fe00 byteswap pdata ,pdata 
+01dd 60014c91 store 2 ,mem_adc_0v 
+01de 68014c93 fetch 2 ,mem_adc_3v 
+01df 1ff0fe00 byteswap pdata ,pdata 
+01e0 60014c93 store 2 ,mem_adc_3v 
+01e1 204001fb call p_init_adc_from_otp 
+01e2 680402a0 fetch 8 ,mem_temp 
+01e3 243a01e8 nbranch p_deveice_init_reset ,blank 
+01e4 68014ad4 fetch 2 ,0x4ad4 
+01e5 1ff0fe00 byteswap pdata ,pdata 
+01e6 203a01e8 branch p_deveice_init_reset ,blank 
+01e7 60014c93 store 2 ,mem_adc_3v 
+
+p_deveice_init_reset:
+01e8 204004c9 call p_le_queue_init 
+01e9 704ba42f jam bt_evt_reset ,mem_ipc_tx_evt 
+
+p_device_init_common:
+01ea 204000e7 call p_ipc_tx_evt 
+01eb 704c9700 jam 0 ,mem_hibernate_flag 
+01ec 70828003 hjam start_c51_core ,core_docd_ctrl 
+01ed 20600000 rtn 
+
+p_deveice_init_wake:
+01ee 704ba430 jam bt_evt_wakeup ,mem_ipc_tx_evt 
+01ef 202001ea branch p_device_init_common 
+
+p_device_init_init_hibwake:
+01f0 1ce27e00 copy auxcnt ,pdata 
+01f1 203a023b branch p_enter_hibernate_continue ,blank 
+01f2 20405b63 call init_lmp_work 
+01f3 20404d99 call l2cap_init_work 
+01f4 58000000 setarg 0 
+01f5 60044040 store 8 ,mem_context 
+01f6 600147f4 store 2 ,mem_ui_state_map 
+01f7 1c427e00 copy clkn_bt ,pdata 
+01f8 60024c59 store 4 ,mem_ipc_last_check_timer 
+01f9 704ba433 jam bt_evt_hibernate_wake ,mem_ipc_tx_evt 
+01fa 202001ea branch p_device_init_common 
+
+p_init_adc_from_otp:
+01fb 2040688a call otp_enable_chgpump 
+01fc 580007e0 setarg 0x7e0 
+01fd da2002a0 arg mem_temp ,rega 
+01fe d840000e arg 14 ,temp 
+01ff 204068d3 call otpd_read_data 
+0200 2040688d call otp_disable_chgpump 
+0201 680082a0 fetch 1 ,mem_temp 
+0202 c280bbf1 bbit1 1 ,assert 
+0203 680402a2 fetch 8 ,mem_temp + 2 
+0204 207a0000 rtn blank 
+0205 6800cc8f fetch 1 ,mem_adc_config_flag 
+0206 c280020f bbit1 adc_config_vinlpm ,p_calc_adc_base_vinlpm 
+0207 c280821d bbit1 adc_config_hvin ,p_calc_adc_base_hvin 
+
+p_calc_adc_check_gpio:
+0208 680102a2 fetch 2 ,mem_temp + 2 
+0209 1ff0fe00 byteswap pdata ,pdata 
+020a 60014c91 store 2 ,mem_adc_0v 
+020b 680102a8 fetch 2 ,mem_temp + 8 
+020c 1ff0fe00 byteswap pdata ,pdata 
+020d 60014c93 store 2 ,mem_adc_3v 
+020e 20600000 rtn 
+
+p_calc_adc_base_vinlpm:
+020f 680902a6 fetcht 2 ,mem_temp + 6 
+0210 680102ac fetch 2 ,mem_temp + 12 
+0211 18422400 copy temp ,regb 
+0212 1fe22200 copy pdata ,rega 
+0213 1ff0fe00 byteswap pdata ,pdata 
+0214 60014c93 store 2 ,mem_adc_3v 
+0215 1a227e00 copy rega ,pdata 
+0216 98462600 isub temp ,regc 
+0217 1a63a600 lshift regc ,regc 
+0218 1a427e00 copy regb ,pdata 
+0219 9a667e00 isub regc ,pdata 
+021a 1ff0fe00 byteswap pdata ,pdata 
+021b 60014c91 store 2 ,mem_adc_0v 
+021c 20600000 rtn 
+
+p_calc_adc_base_hvin:
+021d 680902a4 fetcht 2 ,mem_temp + 4 
+021e 680102aa fetch 2 ,mem_temp + 10 
+021f 18422400 copy temp ,regb 
+0220 1fe22200 copy pdata ,rega 
+0221 98462600 isub temp ,regc 
+0222 1a6b2600 rshift2 regc ,regc 
+0223 1a427e00 copy regb ,pdata 
+0224 9a667e00 isub regc ,pdata 
+0225 1ff0fe00 byteswap pdata ,pdata 
+0226 60014c91 store 2 ,mem_adc_0v 
+0227 1a63a600 lshift regc ,regc 
+0228 1a227e00 copy rega ,pdata 
+0229 9a667e00 isub regc ,pdata 
+022a 1ff0fe00 byteswap pdata ,pdata 
+022b 60014c93 store 2 ,mem_adc_3v 
+022c 20600000 rtn 
+
+p_le_enable:
+022d 70001627 jam 39 ,mem_le_ch_mapped 
+022e 70890f36 hjam 0x36 ,0x90f 
+022f 70890b5f hjam 0x5f ,0x90b 
+0230 202053d4 branch le_enable + 2 
+
+p_le_disable:
+0231 70890f2e hjam 0x2e ,0x90f 
+0232 70890bff hjam 0xff ,0x90b 
+0233 202053d9 branch le_disable + 2 
+
+p_mouse_idle:
+0234 20600000 rtn 
+
+p_check_enter_hibernate:
+0235 68014ba0 fetch 2 ,mem_ipc_2c51_write_index 
+0236 60014b9e store 2 ,mem_ipc_2c51_read_index 
+0237 68014b9c fetch 2 ,mem_ipc_2bt_write_index 
+0238 60014b9a store 2 ,mem_ipc_2bt_read_index 
+0239 700b7e03 jam syc_task_hibernate ,mem_c51_flag 
+023a 20400162 call p_c51_wait 
+
+p_enter_hibernate_continue:
+023b 704c975a jam 0x5a ,mem_hibernate_flag 
+023c 20403db8 call lpm_write_gpio_wakeup 
+023d 68120138 hfetch 4 ,core_lpm_ctrl 
+023e 793ffe0f set0 15 ,pdata 
+023f 6012004c hstore 4 ,core_lpm_reg 
+0240 20403db0 call lpm_write_ctrl 
+0241 d85fffff arg param_hibernate_clks ,temp 
+0242 20203cda branch lpm_sleep 
+
+p_fifo_in:
+0243 ea2a8000 ifetcht util_fifo_len ,rega 
+0244 18417eff and temp ,0xff ,pdata 
+0245 243a0248 nbranch p_fifo_in_push ,blank 
+0246 184cfe00 rshift8 temp ,pdata 
+0247 e2228000 istore util_fifo_len ,rega 
+
+p_fifo_in_push:
+0248 1a20a204 increase util_fifo_len + util_fifo_offset ,rega 
+0249 ea208000 ifetch 1 ,rega 
+024a 247a0000 nrtn ,blank 
+024b 20207f9c branch fifo_in_push + 3 
+
+p_check_51cmd_once:
+024c 20407c20 call ui_ipc_get_lock 
+024d da2047e4 arg mem_ipc_fifo_c512bt ,rega 
+024e 20407f9f call fifo_out 
+024f 1fe20400 copy pdata ,temp 
+0250 20407c24 call ui_ipc_put_lock 
+0251 18427e00 copy temp ,pdata 
+0252 207a0000 rtn blank 
+0253 c010825c beq bt_cmd_start_24g ,p_check_51cmd_start24g 
+0254 c011025e beq bt_cmd_stop_24g ,p_check_51cmd_stop24g 
+0255 c011855c beq bt_cmd_pair_24g ,p_g24_start_pairing_sm1 
+0256 c006826c beq bt_cmd_start_adv ,p_check_51cmd_start_adv 
+0257 c016026c beq bt_cmd_start_adv_discovery ,p_check_51cmd_start_adv 
+0258 c0158277 beq bt_cmd_start_adv_rec ,p_handle_adv_1 
+0259 c0150291 beq bt_cmd_set_reconnect_init ,p_disconnect_connected_device 
+025a c0097c85 beq bt_cmd_le_update_conn ,bt_cmd_le_update_conn_1 
+025b 20207c5a branch check_51cmd_once + 9 
+
+p_check_51cmd_start24g:
+025c 704befff jam state_24g_pairing_success ,mem_24g_pairing_sm 
+025d 2020058f branch p_g24_start_24g_mode 
+
+p_check_51cmd_stop24g:
+025e 793f8023 set0 mark_24g ,mark 
+025f 704befff jam state_24g_pairing_success ,mem_24g_pairing_sm 
+0260 20200547 branch p_g24_stop_g24_mode 
+
+p_slave_ble_disconnect:
+0261 700b7d22 jam xt_ll_terminate_ind ,mem_fifo_temp 
+0262 20205620 branch le_xtype_fifo_in 
+
+p_check_51cmd_once_continue:
+0263 6800807c fetch 1 ,mem_lmo_opcode2 
+0264 203a0268 branch p_check_51cmd_once_continue0 ,blank 
+0265 204061d9 call lmo_fifo_process 
+0266 6800807c fetch 1 ,mem_lmo_opcode2 
+0267 243a7c8c nbranch check_51cmd_restore ,blank 
+
+p_check_51cmd_once_continue0:
+0268 68008b7d fetch 1 ,mem_fifo_temp 
+0269 c584fc87 bmark0 mark_context ,check_51cmd_check_idle 
+026a c0088261 beq bt_cmd_le_disconnect ,p_slave_ble_disconnect 
+026b 20207c7b branch check_51cmd_once_continue0 
+
+p_check_51cmd_start_adv:
+026c 20403eff call app_clear_reconnect_flag 
+026d 20407cd5 call check_51cmd_bb_reconn_cancel 
+026e 70413100 jam 0 ,mem_lpm_mode 
+026f 180a7e00 random pdata 
+0270 6000c4f9 store 1 ,mem_le_lap 
+
+p_handle_adv_0:
+0271 7043dc05 jam 5 ,mem_le_adv_data + 2 
+0272 58181203 setarg 0x181203 
+0273 6001c3e2 store 3 ,mem_le_adv_data + 8 
+0274 d8400007 arg 7 ,temp 
+0275 2040027d call p_le_adv_data_update 
+0276 20207cae branch check_51cmd_adv 
+
+p_handle_adv_1:
+0277 7043dc04 jam 4 ,mem_le_adv_data + 2 
+0278 580000ff setarg 0x0000ff 
+0279 6001c3e2 store 3 ,mem_le_adv_data + 8 
+027a d8400000 arg 0 ,temp 
+027b 2040027d call p_le_adv_data_update 
+027c 20207cae branch check_51cmd_adv 
+
+p_le_adv_data_update:
+027d 6800c3f9 fetch 1 ,mem_le_scan_data_len 
+027e 9840fe00 iadd temp ,pdata 
+027f 1fe0fe0b add pdata ,11 ,pdata 
+0280 1fe67c1f sub pdata ,0x1f ,null 
+0281 2421028d nbranch p_le_adv_data_overflow ,positive 
+0282 6000c3d9 store 1 ,mem_le_adv_data_len 
+0283 d8a043e5 arg mem_le_adv_data + 11 ,contw 
+0284 18427e00 copy temp ,pdata 
+0285 245a028a ncall p_handle_adv_swift_pair ,blank 
+0286 6800c3f9 fetch 1 ,mem_le_scan_data_len 
+0287 1fe27200 copy pdata ,loopcnt 
+0288 d8c043fa arg mem_le_scan_data ,contr 
+0289 20207e45 branch memcpy 
+
+p_handle_adv_swift_pair:
+028a 1fe27200 copy pdata ,loopcnt 
+028b d8c04d6b arg mem_le_adv_swift_pair ,contr 
+028c 20207e45 branch memcpy 
+
+p_le_adv_data_overflow:
+028d 6800c3f9 fetch 1 ,mem_le_scan_data_len 
+028e 1fe0fe0b add pdata ,11 ,pdata 
+028f 6000c3d9 store 1 ,mem_le_adv_data_len 
+0290 20600000 rtn 
+
+p_disconnect_connected_device:
+0291 680147f4 fetch 2 ,mem_ui_state_map 
+0292 c284bf90 bbit1 ui_state_ble_connected ,app_ble_disconnect 
+0293 c283fcd5 bbit1 ui_state_bt_reconnect ,check_51cmd_bb_reconn_cancel 
+0294 c5118547 bmark1 mark_24g ,p_g24_stop_g24_mode 
+0295 7043d800 jam off ,mem_le_adv_enable 
+0296 20403f7e call app_bt_stop_discovery 
+0297 700b7d37 jam bt_evt_reconnect_standy ,mem_fifo_temp 
+0298 20207c27 branch ui_ipc_send_event 
+
+p_lpm_sleep:
+0299 20403b36 call xtal_fast_wake 
+029a 20203cdc branch lpm_sleep + 2 
+
+p_hid_rx_process_data_hid_kb:
+029b e8c08000 ifetch 1 ,contr 
+029c 6000ccb7 store 1 ,mem_caps_num_lock 
+029d 20600000 rtn 
+
+p_scale_process_le_discon:
+029e 704d7e00 jam 0 ,mem_le_pause_enc_flag 
+029f 202004c2 branch scale_process_le_discon 
+
+p_le_transmit_receive_sifs:
+02a0 204054bd call le_transmit 
+02a1 68088017 fetcht 1 ,mem_last_freq 
+02a2 20403a82 call set_freq_rx 
+02a3 20403a87 call rf_rx_enable 
+02a4 78287c00 enable swfine 
+02a5 d960157c arg 5500 ,timeup 
+02a6 2020547f branch le_receive_rxon 
+
+p_le_init_conn:
+02a7 70443e01 jam 0x01 ,mem_le_txheader 
+02a8 70443f00 jam 0 ,mem_le_txlen 
+02a9 2020534e branch le_init_conn + 2 
+
+p_le_transmit:
+02aa 204053dd call le_prep 
+02ab 204002ad call p_letx_setfreq 
+02ac 202054c1 branch le_transmit + 4 
+
+p_letx_setfreq:
+02ad 20368184 branch p_txon ,match 
+02ae 204053ee call le_setfreq 
+02af 20203a91 branch set_freq_tx 
+
+p_le_send_adv_ind:
+02b0 6800cc60 fetch 1 ,mem_le_rx_window 
+02b1 600246f9 store 4 ,mem_le_transmit_window 
+02b2 6800c4db fetch 1 ,mem_le_adv_type 
+02b3 c00082b5 beq adv_direct_ind ,p_le_send_adv_direct_ind 
+02b4 202054e0 branch le_send_adv_ind + 2 
+
+p_le_send_adv_direct_ind:
+02b5 7044db00 jam 0 ,mem_le_adv_type 
+02b6 202054ef branch le_send_adv_direct_ind 
+
+p_le_update_param:
+02b7 680083c0 fetch 1 ,mem_le_state 
+02b8 c4028000 rtnbit0 lestate_update_param 
+02b9 680103da fetch 2 ,mem_le_event_count 
+02ba 680903e0 fetcht 2 ,mem_le_instant 
+02bb 98467e00 isub temp ,pdata 
+02bc 24610000 nrtn positive 
+02bd 2020557e branch le_update_param + 8 
+
+p_le_prepare_tx:
+02be 680083d7 fetch 1 ,mem_le_arq 
+02bf c3828000 rtnbit1 wak 
+02c0 68008341 fetch 1 ,mem_le_rxbuf + 1 
+02c1 203a5626 branch le_prepare_tx + 4 ,blank 
+02c2 20205890 branch le_send_empty 
+
+p_le_check_wak:
+02c3 680883d7 fetcht 1 ,mem_le_arq 
+02c4 284c0005 isolate0 wak ,temp 
+02c5 20608000 rtn true 
+02c6 68008340 fetch 1 ,mem_le_rxbuf 
+02c7 1fe3fe00 lshift pdata ,pdata 
+02c8 9842fe00 ixor temp ,pdata 
+02c9 c4018000 rtnbit0 sn 
+02ca 793f8405 set0 wak ,temp 
+02cb 79400403 setflip sn ,temp 
+02cc 600883d7 storet 1 ,mem_le_arq 
+02cd 28400603 compare 3 ,temp ,3 
+02ce 24608000 nrtn true 
+02cf 6800c440 fetch 1 ,mem_le_txpayload 
+02d0 c00282d4 beq ll_start_enc_req ,p_le_set_enc 
+02d1 6800cd7e fetch 1 ,mem_le_pause_enc_flag 
+02d2 c00082d8 beq 1 ,p_le_clear_enc 
+02d3 20600000 rtn 
+
+p_le_set_enc:
+02d4 680083c0 fetch 1 ,mem_le_state 
+02d5 79207e04 set1 lestate_encryption ,pdata 
+02d6 600083c0 store 1 ,mem_le_state 
+02d7 20600000 rtn 
+
+p_le_clear_enc:
+02d8 704d7e00 jam 0 ,mem_le_pause_enc_flag 
+02d9 dfe00000 arg 0 ,pdata 
+02da 6002446f store 4 ,mem_le_last_mic 
+02db 6000c48b store 1 ,mem_ltk_exists 
+02dc 6002c465 store 5 ,mem_le_pcnt_tx 
+02dd 79207e27 set1 39 ,pdata 
+02de 6002c46a store 5 ,mem_le_pcnt_rx 
+02df 680083c0 fetch 1 ,mem_le_state 
+02e0 793ffe04 set0 lestate_encryption ,pdata 
+02e1 600083c0 store 1 ,mem_le_state 
+02e2 20600000 rtn 
+
+p_le_prepare_tx_cmd:
+02e3 6800c440 fetch 1 ,mem_le_txpayload 
+02e4 c00382fd beq ll_unknown_rsp ,p_le_send_unknown_rsp 
+02e5 c0078301 beq ll_connection_param_req ,p_le_send_conn_param_req 
+02e6 c00302f0 beq ll_start_enc_rsp ,p_le_send_start_enc_rsp 
+02e7 c00102ed beq ll_terminate_ind ,p_le_send_terminate_ind 
+02e8 c00982eb beq ll_ping_rsp ,p_le_send_ping_rsp 
+02e9 c00582eb beq ll_pause_enc_rsp ,p_le_send_pause_enc_rsp 
+02ea 2020563a branch le_prepare_tx_cmd + 10 
+
+p_le_send_pause_enc_rsp:
+
+p_le_send_ping_rsp:
+02eb 18000401 force 1 ,temp 
+02ec 20205892 branch le_send_packet 
+
+p_le_send_terminate_ind:
+02ed 5800000a setarg 10 
+02ee 600103ef store 2 ,mem_le_superto 
+02ef 20205693 branch le_send_terminate_ind 
+
+p_le_send_start_enc_rsp:
+02f0 700b7d12 jam bt_cmd_le_update_conn ,mem_fifo_temp 
+02f1 20407c33 call ui_ipc_send_cmd 
+02f2 18000401 force 1 ,temp 
+02f3 2034d892 branch le_send_packet ,master 
+02f4 700b7d34 jam bt_evt_le_protocol_connected ,mem_fifo_temp 
+02f5 20407c27 call ui_ipc_send_event 
+02f6 6800cc69 fetch 1 ,mem_le_pairing_state 
+02f7 c00102f9 beq flag_le_pairing_after_auth ,p_le_send_start_enc_rsp0 
+02f8 202002fb branch p_le_send_start_enc_rsp_end 
+
+p_le_send_start_enc_rsp0:
+02f9 700b7d46 jam xt_smp_encryption_information ,mem_fifo_temp 
+02fa 20405620 call le_xtype_fifo_in 
+
+p_le_send_start_enc_rsp_end:
+02fb 18000401 force 1 ,temp 
+02fc 20205892 branch le_send_packet 
+
+p_le_send_unknown_rsp:
+02fd 6800cc68 fetch 1 ,mem_le_ll_unknown_type 
+02fe e0a08000 istore 1 ,contw 
+02ff 18000402 force 2 ,temp 
+0300 20205892 branch le_send_packet 
+
+p_le_send_conn_param_req:
+0301 18a08bff increase -1 ,contw 
+0302 68044c6c fetch 8 ,mem_le_connection_updata_param 
+0303 e0a40000 istore 8 ,contw 
+0304 e8c40000 ifetch 8 ,contr 
+0305 e0a40000 istore 8 ,contw 
+0306 18000202 force 2 ,type 
+0307 2020588a branch le_send_autolen 
+
+p_le_prepare_smp:
+0308 6800c444 fetch 1 ,mem_le_l2cap 
+0309 c004d719 beq smp_identity_address_information ,le_send_smp_identity_address_information + 2 
+030a c001030d beq smp_pairing_response ,p_le_send_smp_pairing_response 
+030b c003d70d beq smp_master_identification ,le_send_smp_master_identification + 2 
+030c 20205656 branch le_prepare_smp0 
+
+p_le_send_smp_pairing_response:
+030d 59000302 setarg param_smp_paring_response 
+030e 6001c4b5 store 3 ,mem_le_pres 
+030f 58000001 setarg 0x01 
+0310 e0a08000 istore 1 ,contw 
+0311 58010010 setarg param_smp_key_dist0 
+0312 e0a18000 istore 3 ,contw 
+0313 202056f1 branch le_send_smp_pairing_response + 4 
+
+p_lerx_nopayload:
+0314 09800018 parse 3 ,0 ,24 
+0315 78287c00 enable swfine 
+0316 db600664 arg param_sifs ,27 
+0317 1fef7e00 rshift32 pdata ,pdata 
+0318 1ff17e00 rshift16 pdata ,pdata 
+0319 e0a18000 istore 3 ,contw 
+031a 2023375c branch end_of_packet ,6 
+031b 7836fc00 enable match 
+031c 68008017 fetch 1 ,mem_last_freq 
+031d 1fe0a200 add pdata ,0 ,rega 
+031e 202054af branch lerx_nopayload + 12 
+
+p_le_parse_att:
+031f e8c18000 ifetch 3 ,contr 
+0320 600183f9 store 3 ,mem_le_att_opcode 
+0321 c0290325 beq attop_write_command ,p_le_parse_att_write_command 
+0322 c001033c beq attop_exchange_mtu_request ,p_le_parse_att_exchange_mtu_request 
+0323 c009032b beq attop_write_request ,p_le_parse_att_write_request 
+0324 20205907 branch le_parse_att_p 
+
+p_le_parse_att_write_command:
+0325 704d3801 jam 1 ,mem_reconnect_continue 
+0326 680103fa fetch 2 ,mem_le_att_handle 
+0327 c0108329 beq handle_uuid_chrctr_report_id1_output ,p_handle_num 
+0328 202059ed branch le_parse_att_write_command 
+
+p_handle_num:
+0329 d8c00349 arg mem_le_rxbuf + 9 ,contr 
+032a 2020029b branch p_hid_rx_process_data_hid_kb 
+
+p_le_parse_att_write_request:
+032b 680103fa fetch 2 ,mem_le_att_handle 
+032c 1fe67c21 sub pdata ,handle_uuid_chrctr_report_id1_output ,null 
+032d 20428329 call p_handle_num ,zero 
+032e 680103fa fetch 2 ,mem_le_att_handle 
+032f 1fe67c2d sub pdata ,handle_uuid_end ,null 
+0330 2042833a call p_set_lpm_mode ,zero 
+0331 680103fa fetch 2 ,mem_le_att_handle 
+0332 68094cbc fetcht 2 ,mem_att_report3 
+0333 18408401 increase 1 ,temp 
+0334 98467c00 isub temp ,null 
+0335 20228337 branch p_key_data_send ,zero 
+0336 202059ca branch le_parse_att_write_request 
+
+p_key_data_send:
+0337 700b7d34 jam bt_evt_le_protocol_connected ,mem_fifo_temp 
+0338 20407c27 call ui_ipc_send_event 
+0339 202059ca branch le_parse_att_write_request 
+
+p_set_lpm_mode:
+033a 70413101 jam 1 ,mem_lpm_mode 
+033b 20600000 rtn 
+
+p_le_parse_att_exchange_mtu_request:
+033c 700b7d03 jam attop_exchange_mtu_response ,mem_fifo_temp 
+033d 20205620 branch le_xtype_fifo_in 
+
+p_le_prepare_att:
+033e 6800c444 fetch 1 ,mem_le_l2cap 
+033f c00d8476 beq attop_handle_value_notification ,p_le_send_att_handle_value_notification 
+0340 c00e8476 beq attop_handle_value_indication ,p_le_send_att_handle_value_indication 
+0341 c008840a beq attop_read_by_group_type_response ,p_le_send_att_read_by_group_type_response 
+0342 c00483bc beq attop_read_by_type_response ,p_le_send_att_read_by_type_response 
+0343 c00283aa beq attop_find_information_response ,p_le_send_att_find_information_response 
+0344 c003835e beq attop_find_by_type_value_response ,p_le_send_att_find_by_type_value_response 
+0345 c009d85c beq attop_write_response ,le_send_att_write_response_go 
+0346 c001834f beq attop_exchange_mtu_response ,p_le_send_att_exchange_mtu_rsp 
+0347 c0058352 beq attop_read_response ,p_le_send_att_read_response 
+0348 c006834a beq attop_read_blob_response ,p_le_send_att_read_blob_response 
+0349 20205666 branch le_prepare_att0 
+
+p_le_send_att_read_blob_response:
+034a 680103fa fetch 2 ,mem_le_att_handle 
+034b c003834d beq handle_uuid_chrctr_device_name ,p_le_send_att_read_blob_response_error 
+034c 202057d6 branch le_send_att_read_blob_response 
+
+p_le_send_att_read_blob_response_error:
+034d 7003fc07 jam att_err_invalid_offset ,mem_le_err_code 
+034e 20205729 branch le_send_att_error_response 
+
+p_le_send_att_exchange_mtu_rsp:
+
+p_le_send_att_exchange_mtu_req:
+034f 68014c6a fetch 2 ,mem_le_local_mtu 
+0350 e0a10000 istore 2 ,contw 
+0351 2020588a branch le_send_autolen 
+
+p_le_send_att_read_response:
+0352 680103fa fetch 2 ,mem_le_att_handle 
+0353 c0070355 beq handle_uuid_chrctr_manufacturer_name ,p_le_send_att_read_response_error 
+0354 202057c6 branch le_send_att_read_response 
+
+p_le_send_att_read_response_error:
+0355 6800cc69 fetch 1 ,mem_le_pairing_state 
+0356 c08057c6 bne flag_le_pairing_null ,le_send_att_read_response 
+0357 6800cc7c fetch 1 ,mem_ltk_states 
+0358 c001d7c6 beq ltk_not_lost ,le_send_att_read_response 
+0359 18a20400 copy contw ,temp 
+035a 704c6901 jam flag_le_pairing_start ,mem_le_pairing_state 
+035b 18420a00 copy temp ,contw 
+035c 7003fc05 jam att_err_insufficient_authentication ,mem_le_err_code 
+035d 20205729 branch le_send_att_error_response 
+
+p_le_send_att_find_by_type_value_response:
+035e 2040577b call le_start_end_handle_check_1 
+035f 20740000 rtn user 
+0360 680944c0 fetcht 2 ,mem_le_search_att_type 
+0361 58001812 setarg uuid_service_hids 
+0362 98467c00 isub temp ,null 
+0363 20228377 branch p_le_send_att_find_value_by_type_hid ,zero 
+0364 5800180f setarg uuid_service_battery 
+0365 98467c00 isub temp ,null 
+0366 20228379 branch p_le_send_att_find_value_by_type_battery ,zero 
+0367 5800180a setarg uuid_service_device_info 
+0368 98467c00 isub temp ,null 
+0369 2022837d branch p_le_send_att_find_value_by_type_device_info ,zero 
+036a 58001801 setarg uuid_service_generic_att 
+036b 98467c00 isub temp ,null 
+036c 2022837b branch p_le_send_att_find_value_by_type_gatt ,zero 
+036d 20205754 branch le_send_att_find_by_type_value_response + 2 
+
+p_le_send_find_value_by_type:
+036e 6800cc7f fetch 1 ,mem_shutter_find_type_value_flag 
+036f d8400000 arg 0 ,temp 
+0370 f9200400 qset1 temp 
+0371 98417e00 iand temp ,pdata 
+0372 c0805728 bne 0 ,le_send_att_error_response_notfound 
+0373 6800cc7f fetch 1 ,mem_shutter_find_type_value_flag 
+0374 f9207e00 qset1 pdata 
+0375 6000cc7f store 1 ,mem_shutter_find_type_value_flag 
+0376 2020037f branch p_le_send_att_find_value_by_type_command 
+
+p_le_send_att_find_value_by_type_hid:
+0377 d8e00000 arg le_find_type_value_hid_bit ,queue 
+0378 2020036e branch p_le_send_find_value_by_type 
+
+p_le_send_att_find_value_by_type_battery:
+0379 d8e00001 arg le_find_type_value_battery_bit ,queue 
+037a 2020036e branch p_le_send_find_value_by_type 
+
+p_le_send_att_find_value_by_type_gatt:
+037b d8e00003 arg le_find_type_value_gatt_bit ,queue 
+037c 2020036e branch p_le_send_find_value_by_type 
+
+p_le_send_att_find_value_by_type_device_info:
+037d d8e00002 arg le_find_type_value_device_info_bit ,queue 
+037e 2020036e branch p_le_send_find_value_by_type 
+
+p_le_send_att_find_value_by_type_command:
+037f 680144c0 fetch 2 ,mem_le_search_att_type 
+0380 1fe22200 copy pdata ,rega 
+0381 680944c4 fetcht 2 ,mem_le_uuid 
+0382 18422400 copy temp ,regb 
+0383 20400386 call p_find_type_value_start_handle 
+0384 20228391 branch p_le_save_find_value_handle ,zero 
+0385 20205728 branch le_send_att_error_response_notfound 
+
+p_find_type_value_start_handle:
+0386 d8c04504 arg mem_le_att_list ,contr 
+
+p_find_type_value_start_handle_loop:
+0387 e8c10000 ifetch 2 ,contr 
+0388 207a0000 rtn blank 
+0389 e8c18000 ifetch 3 ,contr 
+038a e8c10000 ifetch 2 ,contr 
+038b 9a267c00 isub rega ,null 
+038c 20628000 rtn zero 
+038d 18c08dfd increase -3 ,contr 
+038e e8c08000 ifetch 1 ,contr 
+038f 98c08c00 iadd contr ,contr 
+0390 20200387 branch p_find_type_value_start_handle_loop 
+
+p_le_save_find_value_handle:
+0391 18c08df9 increase -7 ,contr 
+0392 e8c10000 ifetch 2 ,contr 
+0393 60014c61 store 2 ,mem_le_find_type_value_start_handle 
+0394 2040039f call p_find_type_value_end_handle 
+0395 203a5728 branch le_send_att_error_response_notfound ,blank 
+0396 18c08dfc increase -4 ,contr 
+0397 e8c10000 ifetch 2 ,contr 
+0398 1fe0ffff increase -1 ,pdata 
+0399 60014c63 store 2 ,mem_le_find_type_value_end_handle 
+039a 70444407 jam attop_find_by_type_value_response ,mem_le_l2cap 
+039b 68024c61 fetch 4 ,mem_le_find_type_value_start_handle 
+039c 60024445 store 4 ,mem_le_l2cap_response 
+039d 18000409 force 9 ,temp 
+039e 20205892 branch le_send_packet 
+
+p_find_type_value_end_handle:
+039f e8c10000 ifetch 2 ,contr 
+03a0 e8c08000 ifetch 1 ,contr 
+03a1 98c08c00 iadd contr ,contr 
+
+p_find_type_value_end_handle_loop:
+03a2 e8c10000 ifetch 2 ,contr 
+03a3 207a0000 rtn blank 
+03a4 e8c10000 ifetch 2 ,contr 
+03a5 9a467c00 isub regb ,null 
+03a6 20628000 rtn zero 
+03a7 e8c08000 ifetch 1 ,contr 
+03a8 98c08c00 iadd contr ,contr 
+03a9 202003a2 branch p_find_type_value_end_handle_loop 
+
+p_le_send_att_find_information_response:
+03aa d9600003 arg 3 ,timeup 
+03ab 18007e01 force 1 ,pdata 
+03ac 6000c445 store 1 ,mem_le_l2cap_response 
+03ad 20405a74 call le_init_attlist_search 
+
+p_le_send_att_find_information_res_loop:
+03ae 20405a7d call le_att_handle_inrange 
+03af 203a5746 branch le_send_att_find_information_res_end ,blank 
+03b0 242103ba nbranch p_le_send_att_find_information_res_next ,positive 
+03b1 78547c00 disable user 
+03b2 e0a10000 istore 2 ,contw 
+03b3 e8c10000 ifetch 2 ,contr 
+03b4 e0a10000 istore 2 ,contw 
+03b5 196097ff increase -1 ,timeup 
+03b6 2022d746 branch le_send_att_find_information_res_end ,zero 
+
+p_le_send_att_find_information_res_cont:
+03b7 e8c08000 ifetch 1 ,contr 
+03b8 98c08c00 iadd contr ,contr 
+03b9 202003ae branch p_le_send_att_find_information_res_loop 
+
+p_le_send_att_find_information_res_next:
+03ba 18c08c02 increase 2 ,contr 
+03bb 202003b7 branch p_le_send_att_find_information_res_cont 
+
+p_le_send_att_read_by_type_response:
+03bc 680944c0 fetcht 2 ,mem_le_search_att_type 
+03bd 58002a00 setarg uuid_chrctr_device_name 
+03be 98467c00 isub temp ,null 
+03bf 202283fc branch p_le_send_att_read_by_type_res_device_name ,zero 
+03c0 58002a50 setarg uuid_pnp_id 
+03c1 98467c00 isub temp ,null 
+03c2 20228407 branch p_le_send_att_read_by_type_res_pnp_id ,zero 
+03c3 58002803 setarg uuid_gatt_characteristic 
+03c4 98467c00 isub temp ,null 
+03c5 2422d728 nbranch le_send_att_error_response_notfound ,zero 
+03c6 680144bc fetch 2 ,mem_le_search_handle_start 
+03c7 600102a0 store 2 ,mem_temp 
+03c8 78347c00 enable user 
+
+p_le_send_att_read_by_type_response_loop:
+03c9 2040044e call p_le_att_handle_inrange 
+03ca 242103d8 nbranch p_le_send_att_read_by_type_response_end ,positive 
+03cb 680902a0 fetcht 2 ,mem_temp 
+03cc 20400456 call p_le_att_get_handle_info 
+03cd c00083d8 beq 1 ,p_le_send_att_read_by_type_response_end 
+03ce 20400452 call p_le_att_same_type 
+03cf 242283d6 nbranch p_le_send_att_read_by_type_response_next_handle ,zero 
+03d0 78547c00 disable user 
+03d1 204003da call p_le_send_att_read_by_type_write_properties 
+03d2 2040043c call p_le_att_next_handle 
+03d3 20400456 call p_le_att_get_handle_info 
+03d4 204003e2 call p_le_send_att_read_by_type_write_uuid 
+03d5 202003d8 branch p_le_send_att_read_by_type_response_end 
+
+p_le_send_att_read_by_type_response_next_handle:
+03d6 2040043c call p_le_att_next_handle 
+03d7 202003c9 branch p_le_send_att_read_by_type_response_loop 
+
+p_le_send_att_read_by_type_response_end:
+03d8 20345728 branch le_send_att_error_response_notfound ,user 
+03d9 20200474 branch p_le_send_auto_len_by_mem 
+
+p_le_send_att_read_by_type_write_properties:
+03da 680102a0 fetch 2 ,mem_temp 
+03db 60014446 store 2 ,mem_le_l2cap_response + 1 
+03dc 6800cc67 fetch 1 ,mem_le_search_len 
+03dd 1fe27200 copy pdata ,loopcnt 
+03de 2040046b call p_get_contr 
+03df d8a04448 arg mem_le_l2cap_response + 3 ,contw 
+03e0 20407e45 call memcpy 
+03e1 2020046e branch p_store_contw 
+
+p_le_send_att_read_by_type_write_uuid:
+03e2 68094c65 fetcht 2 ,mem_le_cur_att_type 
+03e3 184cfe00 rshift8 temp ,pdata 
+03e4 c08283f4 bne 0x05 ,p_le_send_att_read_by_type_write_short_uuid 
+03e5 20400468 call p_get_contw 
+03e6 680102a0 fetch 2 ,mem_temp 
+03e7 e0a10000 istore 2 ,contw 
+03e8 2040046e call p_store_contw 
+03e9 58004504 setarg mem_le_att_list 
+03ea 98408c00 iadd temp ,contr 
+03eb e8c08000 ifetch 1 ,contr 
+03ec 18c20400 copy contr ,temp 
+03ed 1fe27200 copy pdata ,loopcnt 
+03ee 1fe0fe05 increase 5 ,pdata 
+03ef 6000c445 store 1 ,mem_le_l2cap_response 
+03f0 20400468 call p_get_contw 
+03f1 18420c00 copy temp ,contr 
+03f2 20407e45 call memcpy 
+03f3 2020046e branch p_store_contw 
+
+p_le_send_att_read_by_type_write_short_uuid:
+03f4 20400468 call p_get_contw 
+03f5 680102a0 fetch 2 ,mem_temp 
+03f6 e0a10000 istore 2 ,contw 
+03f7 68014c65 fetch 2 ,mem_le_cur_att_type 
+03f8 e0a10000 istore 2 ,contw 
+03f9 2040046e call p_store_contw 
+03fa 70444507 jam 7 ,mem_le_l2cap_response 
+03fb 20600000 rtn 
+
+p_le_send_att_read_by_type_res_device_name:
+03fc 20405b08 call le_get_device_name 
+
+p_le_send_att_read_by_type_res_packet:
+03fd e8c08000 ifetch 1 ,contr 
+03fe 1fe27200 copy pdata ,loopcnt 
+03ff 1fe0fe02 increase 2 ,pdata 
+0400 6000c445 store 1 ,mem_le_l2cap_response 
+0401 18c08dfb increase -5 ,contr 
+0402 e8c10000 ifetch 2 ,contr 
+0403 e0a10000 istore 2 ,contw 
+0404 18c08c03 increase 3 ,contr 
+0405 20407e45 call memcpy 
+0406 2020588a branch le_send_autolen 
+
+p_le_send_att_read_by_type_res_pnp_id:
+0407 d8402a50 arg uuid_pnp_id ,temp 
+0408 20405b0c call le_att_get_uuid_ptr 
+0409 202003fd branch p_le_send_att_read_by_type_res_packet 
+
+p_le_send_att_read_by_group_type_response:
+040a d9600002 arg 2 ,timeup 
+040b 680144bc fetch 2 ,mem_le_search_handle_start 
+040c 600102a0 store 2 ,mem_temp 
+040d 700d5c00 jam 0 ,mem_le_search_res 
+040e 78347c00 enable user 
+
+p_le_send_att_read_by_group_type_response_loop:
+040f 2040044e call p_le_att_handle_inrange 
+0410 24210432 nbranch p_le_send_att_read_by_group_type_end0 ,positive 
+0411 680902a0 fetcht 2 ,mem_temp 
+0412 20400456 call p_le_att_get_handle_info 
+0413 c0008435 beq 1 ,p_le_send_att_read_by_group_type_end1 
+0414 20400452 call p_le_att_same_type 
+0415 2422842e nbranch p_le_send_att_read_by_group_type_next_handle ,zero 
+0416 68008d5c fetch 1 ,mem_le_search_res 
+0417 c0008435 beq 1 ,p_le_send_att_read_by_group_type_end1 
+0418 2434041f nbranch p_le_send_att_read_by_group_type_store_write_record ,user 
+0419 78547c00 disable user 
+041a 6800cc67 fetch 1 ,mem_le_search_len 
+041b 1fe0fe04 increase 4 ,pdata 
+041c 6000c445 store 1 ,mem_le_l2cap_response 
+041d 2040046e call p_store_contw 
+041e 20200429 branch p_le_send_att_read_by_group_type_store_record 
+
+p_le_send_att_read_by_group_type_store_write_record:
+041f 6800cc67 fetch 1 ,mem_le_search_len 
+0420 1fe67c10 sub pdata ,0x10 ,null 
+0421 20228435 branch p_le_send_att_read_by_group_type_end1 ,zero 
+0422 6800c445 fetch 1 ,mem_le_l2cap_response 
+0423 1fe67c10 sub pdata ,0x10 ,null 
+0424 20228435 branch p_le_send_att_read_by_group_type_end1 ,zero 
+0425 680102a0 fetch 2 ,mem_temp 
+0426 1fe0ffff increase -1 ,pdata 
+0427 60010d5a store 2 ,mem_le_cur_handle_end 
+0428 20400445 call p_le_write_att_record 
+
+p_le_send_att_read_by_group_type_store_record:
+0429 680102a0 fetch 2 ,mem_temp 
+042a 60010d58 store 2 ,mem_le_cur_handle_start 
+042b 20400440 call p_le_store_att_record 
+042c 196097ff increase -1 ,timeup 
+042d 20228430 branch p_le_send_att_read_by_group_type_last_find ,zero 
+
+p_le_send_att_read_by_group_type_next_handle:
+042e 2040043c call p_le_att_next_handle 
+042f 2020040f branch p_le_send_att_read_by_group_type_response_loop 
+
+p_le_send_att_read_by_group_type_last_find:
+0430 700d5c01 jam 1 ,mem_le_search_res 
+0431 2020042e branch p_le_send_att_read_by_group_type_next_handle 
+
+p_le_send_att_read_by_group_type_end0:
+0432 680102a0 fetch 2 ,mem_temp 
+0433 60010d5a store 2 ,mem_le_cur_handle_end 
+0434 20200439 branch p_le_send_att_read_by_group_type_end_common 
+
+p_le_send_att_read_by_group_type_end1:
+0435 680102a0 fetch 2 ,mem_temp 
+0436 1fe0ffff increase -1 ,pdata 
+0437 60010d5a store 2 ,mem_le_cur_handle_end 
+0438 20200439 branch p_le_send_att_read_by_group_type_end_common 
+
+p_le_send_att_read_by_group_type_end_common:
+0439 20345728 branch le_send_att_error_response_notfound ,user 
+043a 20400445 call p_le_write_att_record 
+043b 20200474 branch p_le_send_auto_len_by_mem 
+
+p_le_att_next_handle:
+043c 680902a0 fetcht 2 ,mem_temp 
+043d 18408401 increase 1 ,temp 
+043e 600902a0 storet 2 ,mem_temp 
+043f 20600000 rtn 
+
+p_le_store_att_record:
+0440 6800cc67 fetch 1 ,mem_le_search_len 
+0441 60008103 store 1 ,mem_tmp_buffer 
+0442 1fe27200 copy pdata ,loopcnt 
+0443 2040046b call p_get_contr 
+0444 20207e45 branch memcpy 
+
+p_le_write_att_record:
+0445 20400468 call p_get_contw 
+0446 68010d58 fetch 2 ,mem_le_cur_handle_start 
+0447 e0a10000 istore 2 ,contw 
+0448 68010d5a fetch 2 ,mem_le_cur_handle_end 
+0449 e0a10000 istore 2 ,contw 
+044a 68008103 fetch 1 ,mem_tmp_buffer 
+044b 1fe27200 copy pdata ,loopcnt 
+044c 20407e45 call memcpy 
+044d 2020046e branch p_store_contw 
+
+p_le_att_handle_inrange:
+044e 680902a0 fetcht 2 ,mem_temp 
+044f 680144be fetch 2 ,mem_le_search_handle_end 
+0450 98467c00 isub temp ,null 
+0451 20600000 rtn 
+
+p_le_att_same_type:
+0452 680144c0 fetch 2 ,mem_le_search_att_type 
+0453 68094c65 fetcht 2 ,mem_le_cur_att_type 
+0454 98467c00 isub temp ,null 
+0455 20600000 rtn 
+
+p_le_att_get_handle_info:
+0456 d8c04504 arg mem_le_att_list ,contr 
+0457 18422200 copy temp ,rega 
+
+p_le_att_get_handle_loop:
+0458 e8c10000 ifetch 2 ,contr 
+0459 203a0461 branch p_le_att_unfind_handle ,blank 
+045a e8c90000 ifetcht 2 ,contr 
+045b 60094c65 storet 2 ,mem_le_cur_att_type 
+045c 9a267c00 isub rega ,null 
+045d 20228463 branch p_le_att_finded_handle ,zero 
+045e e8c08000 ifetch 1 ,contr 
+045f 98c08c00 iadd contr ,contr 
+0460 20200458 branch p_le_att_get_handle_loop 
+
+p_le_att_unfind_handle:
+0461 58000001 setarg 1 
+0462 20600000 rtn 
+
+p_le_att_finded_handle:
+0463 e8c08000 ifetch 1 ,contr 
+0464 6000cc67 store 1 ,mem_le_search_len 
+0465 20400471 call p_store_contr 
+0466 58000000 setarg 0 
+0467 20600000 rtn 
+
+p_get_contw:
+0468 680102b9 fetch 2 ,mem_contw 
+0469 1fe20a00 copy pdata ,contw 
+046a 20600000 rtn 
+
+p_get_contr:
+046b 680102b7 fetch 2 ,mem_contr 
+046c 1fe20c00 copy pdata ,contr 
+046d 20600000 rtn 
+
+p_store_contw:
+046e 18a27e00 copy contw ,pdata 
+046f 600102b9 store 2 ,mem_contw 
+0470 20600000 rtn 
+
+p_store_contr:
+0471 18c27e00 copy contr ,pdata 
+0472 600102b7 store 2 ,mem_contr 
+0473 20600000 rtn 
+
+p_le_send_auto_len_by_mem:
+0474 20400468 call p_get_contw 
+0475 2020588a branch le_send_autolen 
+
+p_le_send_att_handle_value_indication:
+
+p_le_send_att_handle_value_notification:
+0476 6800cbab fetch 1 ,mem_queue_read 
+0477 1fe08401 add pdata ,1 ,temp 
+0478 18410403 and temp ,0x03 ,temp 
+0479 6008cbab storet 1 ,mem_queue_read 
+047a 1feffe07 mul32 pdata ,7 ,pdata 
+047b d8c04bad arg mem_uart_packet ,contr 
+047c 98c08c00 iadd contr ,contr 
+047d 6800cc82 fetch 1 ,mem_le51_tx_length 
+047e 1fe0fffb increase -5 ,pdata 
+047f 1fe27200 copy pdata ,loopcnt 
+0480 d8a04445 arg mem_le_l2cap + 1 ,contw 
+0481 20407e45 call memcpy 
+0482 6808cc82 fetcht 1 ,mem_le51_tx_length 
+0483 20205892 branch le_send_packet 
+
+p_le_parse:
+0484 2040561c call le_xtype_fifo_is_full 
+0485 202058b0 branch le_parse + 4 
+
+p_le_parse_ll:
+0486 1a627e00 copy regc ,pdata 
+0487 c0018496 beq ll_enc_req ,p_le_parse_enc_req 
+0488 c005049a beq ll_pause_enc_req ,p_le_parse_pause_enc_rsq 
+0489 c0000491 beq ll_connection_update_req ,p_le_parse_connection_update_req 
+048a c0090498 beq ll_ping_req ,p_le_parse_ping_req 
+048b c001049d beq ll_terminate_ind ,p_le_parse_terminate_ind 
+048c 1fe67c0d sub pdata ,0x0d ,null 
+048d 202158c0 branch le_parse + 20 ,positive 
+048e 6000cc68 store 1 ,mem_le_ll_unknown_type 
+048f 700b7d27 jam xt_ll_unknown_rsp ,mem_fifo_temp 
+0490 20205620 branch le_xtype_fifo_in 
+
+p_le_parse_connection_update_req:
+0491 20405924 call le_parse_connection_update_req 
+0492 68014437 fetch 2 ,mem_le_new_param + 3 
+0493 1fef8404 mul32 pdata ,4 ,temp 
+0494 60094d4f storet 2 ,mem_customize_timer_setup 
+0495 20600000 rtn 
+
+p_le_parse_enc_req:
+0496 704c7c00 jam default_states ,mem_ltk_states 
+0497 20205938 branch le_parse_enc_req 
+
+p_le_parse_ping_req:
+0498 700b7d33 jam xt_ll_ping_rsp ,mem_fifo_temp 
+0499 20205620 branch le_xtype_fifo_in 
+
+p_le_parse_pause_enc_rsq:
+049a 704d7e01 jam 1 ,mem_le_pause_enc_flag 
+049b 700b7d2b jam xt_ll_pause_enc_rsp ,mem_fifo_temp 
+049c 20205620 branch le_xtype_fifo_in 
+
+p_le_parse_terminate_ind:
+049d 58000014 setarg 20 
+049e 600103ef store 2 ,mem_le_superto 
+049f 20600000 rtn 
+
+p_le_send_non_l2cap:
+04a0 6800c43e fetch 1 ,mem_le_txheader 
+04a1 28200601 compare 1 ,type ,3 
+04a2 202084a4 branch p_le_send_non_l2cap1 ,true 
+04a3 202058a7 branch le_send_non_l2cap + 14 
+
+p_le_send_non_l2cap1:
+04a4 6800c43f fetch 1 ,mem_le_txlen 
+04a5 203a04a7 branch p_le_send_empty_clear_md ,blank 
+04a6 202058a7 branch le_send_non_l2cap + 14 
+
+p_le_send_empty_clear_md:
+04a7 6800c43e fetch 1 ,mem_le_txheader 
+04a8 793ffe04 set0 md ,pdata 
+04a9 6000c43e store 1 ,mem_le_txheader 
+04aa 20600000 rtn 
+
+p_le_parse_smp:
+04ab e8c08000 ifetch 1 ,contr 
+04ac c00084b2 beq smp_pairing_request ,p_le_parse_smp_pairing_request 
+04ad c00204b8 beq smp_pairing_random ,p_le_parse_smp_pairing_random 
+04ae c00484b0 beq smp_identity_address_information ,p_le_parse_smp_identity_address_information 
+04af 202058f8 branch le_parse_smp + 4 
+
+p_le_parse_smp_identity_address_information:
+04b0 704c6903 jam flag_le_pairing_end ,mem_le_pairing_state 
+04b1 20205974 branch le_parse_smp_identity_address_information 
+
+p_le_parse_smp_pairing_request:
+04b2 704d3d01 jam 1 ,mem_le_send_security_request_flag 
+04b3 6000c4ae store 1 ,mem_le_preq 
+04b4 e8c30000 ifetch 6 ,contr 
+04b5 e0a30000 istore 6 ,contw 
+04b6 700b7d42 jam xt_smp_pairing_response ,mem_fifo_temp 
+04b7 20205620 branch le_xtype_fifo_in 
+
+p_le_parse_smp_pairing_random:
+04b8 204074a8 call authenticate_rconfirm 
+04b9 202284bb branch p_le_parse_smp_pairing_random_success ,zero 
+04ba 20205968 branch le_parse_smp_pairing_random + 2 
+
+p_le_parse_smp_pairing_random_success:
+04bb 704c6902 jam flag_le_pairing_after_auth ,mem_le_pairing_state 
+04bc 2020596a branch le_parse_smp_pairing_random_success 
+
+scale_process_le_conn:
+04bd 704c7d00 jam pair_unknown ,mem_pair_state 
+04be 20403f86 call app_ble_stop_adv 
+04bf 20403f7e call app_bt_stop_discovery 
+04c0 20403fa4 call app_lpm_mult_enable 
+04c1 20203ecc branch app_le_event_bb_connected 
+
+scale_process_le_discon:
+04c2 70421300 jam 0 ,mem_lpm_mult 
+04c3 70448b00 jam 0 ,mem_ltk_exists 
+04c4 704c7c00 jam default_states ,mem_ltk_states 
+04c5 704c6900 jam flag_le_pairing_null ,mem_le_pairing_state 
+04c6 704c7f00 jam 0 ,mem_shutter_find_type_value_flag 
+04c7 704c7d00 jam pair_unknown ,mem_pair_state 
+04c8 20203ed0 branch app_le_event_bb_disconn 
+
+p_le_queue_init:
+04c9 58000000 setarg 0 
+04ca 60024ba9 store 4 ,mem_queue_write 
+04cb 20600000 rtn 
+
+p_g24_dispatch:
+04cc c6918000 rtnmark0 mark_24g 
+04cd 68024d40 fetch 4 ,mem_24g_enter_hibernate 
+04ce 60024d72 store 4 ,mem_24g_enter_hibernate_setup 
+04cf 204004f2 call p_g24_txdata_prep 
+04d0 243404e5 nbranch p_g24_long_sleep ,user 
+04d1 704c150a jam 10 ,mem_24g_enter_lpm_timer 
+04d2 20400513 call p_g24_transmit_packet 
+04d3 6800cbef fetch 1 ,mem_24g_pairing_sm 
+04d4 c1ff8000 rtnne state_24g_pairing_success 
+04d5 704c3d02 jam tx_power_5db ,mem_tx_power 
+
+p_g24_short_sleep:
+04d6 6800cd45 fetch 1 ,mem_mouse_retry_flag 
+04d7 247a0000 nrtn blank 
+04d8 20400155 call p_check_ipc_for_lpm 
+04d9 24740000 nrtn user 
+04da 68008b7f fetch 1 ,mem_c51_lpm_lock 
+04db 247a0000 nrtn blank 
+04dc 20403cab call lpo_calibration 
+04dd 6801c210 fetch 3 ,mem_clks_per_lpo 
+04de 207a0000 rtn blank 
+04df 6800c131 fetch 1 ,mem_lpm_mode 
+04e0 207a0000 rtn blank 
+
+p_g24_short_sleep_1:
+04e1 6801cd7a fetch 3 ,mem_24g_short_sleep_counter 
+
+p_g24_short_sleep_2:
+04e2 20407e8a call clk2lpo 
+04e3 600a41fc storet 4 ,mem_sleep_counter 
+04e4 20203cda branch lpm_sleep 
+
+p_g24_long_sleep:
+04e5 20400155 call p_check_ipc_for_lpm 
+04e6 24740000 nrtn user 
+04e7 68008b7f fetch 1 ,mem_c51_lpm_lock 
+04e8 247a0000 nrtn blank 
+04e9 20403cab call lpo_calibration 
+04ea 6801c210 fetch 3 ,mem_clks_per_lpo 
+04eb 207a0000 rtn blank 
+04ec 6800c131 fetch 1 ,mem_lpm_mode 
+04ed 207a0000 rtn blank 
+04ee 6800cc15 fetch 1 ,mem_24g_enter_lpm_timer 
+04ef 243a04e1 nbranch p_g24_short_sleep_1 ,blank 
+04f0 68024d72 fetch 4 ,mem_24g_enter_hibernate_setup 
+04f1 202004e2 branch p_g24_short_sleep_2 
+
+p_g24_txdata_prep:
+04f2 6800cbef fetch 1 ,mem_24g_pairing_sm 
+04f3 c0ff8565 bne state_24g_pairing_success ,p_g24_pairing_sm 
+04f4 204004f9 call p_g24_package_data 
+04f5 20540510 call p_g24_get_package_data ,user 
+04f6 205405d4 call p_g24_transmit_prep ,user 
+
+p_g24_txdata_enable_tx:
+04f7 704be601 jam ensure_on_24g ,mem_24g_ensure 
+04f8 20600000 rtn 
+
+p_g24_package_data:
+04f9 78547c00 disable user 
+04fa 704be202 jam 2 ,mem_24g_data_type 
+04fb 6800cd57 fetch 1 ,mem_24g_txbuf_new 
+04fc c0020503 beq 0x04 ,p_g24_dataready 
+04fd c0028506 beq 0x05 ,p_g24_dataready_mk 
+04fe c003850c beq 0x07 ,p_g24_dataready_ms 
+04ff c0030509 beq 0x06 ,p_g24_dataready_sys 
+0500 6800cd45 fetch 1 ,mem_mouse_retry_flag 
+0501 245a34df ncall enable_user ,blank 
+0502 20600000 rtn 
+
+p_g24_dataready:
+0503 704d5700 jam 0x00 ,mem_24g_txbuf_new 
+0504 704be10a jam 10 ,mem_24g_datalen 
+0505 2020050e branch p_g24_package_data_rtn 
+
+p_g24_dataready_mk:
+0506 704d5703 jam 0x03 ,mem_24g_txbuf_new 
+0507 704be104 jam 4 ,mem_24g_datalen 
+0508 2020050e branch p_g24_package_data_rtn 
+
+p_g24_dataready_sys:
+0509 704d5702 jam 0x02 ,mem_24g_txbuf_new 
+050a 704be103 jam 3 ,mem_24g_datalen 
+050b 2020050e branch p_g24_package_data_rtn 
+
+p_g24_dataready_ms:
+050c 704be201 jam 1 ,mem_24g_data_type 
+050d 704be108 jam 8 ,mem_24g_datalen 
+
+p_g24_package_data_rtn:
+050e 704be700 jam 0 ,mem_24g_get_ack_fail 
+050f 202034df branch enable_user 
+
+p_g24_get_package_data:
+0510 6804cd57 fetch 9 ,mem_24g_txbuf_new 
+0511 60048cd5 store 9 ,mem_24g_txbuf 
+0512 20600000 rtn 
+
+p_g24_transmit_packet:
+0513 704be800 jam 0 ,mem_24g_retry 
+
+p_g24_transmit_loop:
+0514 d9600d00 arg param_rx_setup ,timeup 
+0515 34730200 until clkn_rt ,meet 
+0516 2040053a call p_g24_transmit_receive_ack 
+0517 24378523 nbranch p_g24_retransmit ,user3 
+0518 2040054a call p_g24_ackpayload_parse 
+0519 6800cbe0 fetch 1 ,mem_24g_pid 
+051a 1fe0fe01 increase 1 ,pdata 
+051b 6000cbe0 store 1 ,mem_24g_pid 
+051c 704d4500 jam 0 ,mem_mouse_retry_flag 
+051d 6800cbef fetch 1 ,mem_24g_pairing_sm 
+051e c0ff8539 bne state_24g_pairing_success ,p_g24_paring_mode_start 
+
+p_g24_transmit_abandon:
+051f 20400535 call p_g24_clear_txbuf 
+0520 704be700 jam 0 ,mem_24g_get_ack_fail 
+0521 704be600 jam ensure_off_24g ,mem_24g_ensure 
+0522 20600000 rtn 
+
+p_g24_retransmit:
+0523 704d4501 jam 1 ,mem_mouse_retry_flag 
+0524 6800cbe7 fetch 1 ,mem_24g_get_ack_fail 
+0525 1fe0fe01 increase 1 ,pdata 
+0526 6000cbe7 store 1 ,mem_24g_get_ack_fail 
+0527 6800cbef fetch 1 ,mem_24g_pairing_sm 
+0528 c0ff8545 bne state_24g_pairing_success ,p_g24_tx_paring_retry 
+0529 6800cbe7 fetch 1 ,mem_24g_get_ack_fail 
+052a c07f8547 beq 0xff ,p_g24_stop_g24_mode 
+052b 6800cbe7 fetch 1 ,mem_24g_get_ack_fail 
+052c d8400010 arg 16 ,temp 
+052d 98467c00 isub temp ,null 
+052e 202105f3 branch p_g24_ch ,positive 
+052f 6800cbe8 fetch 1 ,mem_24g_retry 
+0530 1fe0fe01 increase 1 ,pdata 
+0531 6000cbe8 store 1 ,mem_24g_retry 
+0532 2000000a nop 10 
+0533 c0838514 bne retry_24g ,p_g24_transmit_loop 
+0534 202005f3 branch p_g24_ch 
+
+p_g24_clear_txbuf:
+0535 58000000 setarg 0 
+0536 60048cd5 store 9 ,mem_24g_txbuf 
+0537 6004cd57 store 9 ,mem_24g_txbuf_new 
+0538 20600000 rtn 
+
+p_g24_paring_mode_start:
+0539 2020057f branch p_g24_paring_mode 
+
+p_g24_transmit_receive_ack:
+053a 7857fc00 disable user3 
+053b 2040064b call p_g24_transmit 
+053c 18002a00 force 0 ,radio_ctrl 
+053d 68024c00 fetch 4 ,mem_24g_addr 
+053e 98001200 iforce access 
+053f 68088017 fetcht 1 ,mem_last_freq 
+0540 20403a82 call set_freq_rx 
+0541 20403a87 call rf_rx_enable 
+0542 2040060b call p_g24_receive_rxon 
+0543 20578645 call p_g24_end_of_packet ,user3 
+0544 20600000 rtn 
+
+p_g24_tx_paring_retry:
+0545 704d4500 jam 0 ,mem_mouse_retry_flag 
+0546 20600000 rtn 
+
+p_g24_stop_g24_mode:
+0547 704d4500 jam 0 ,mem_mouse_retry_flag 
+0548 700b7d32 jam bt_evt_24g_attempt_fail ,mem_fifo_temp 
+0549 20207c27 branch ui_ipc_send_event 
+
+p_g24_ackpayload_parse:
+054a 204005b4 call p_g24_read_len_pid_crc 
+054b 68008cb3 fetch 1 ,mem_24g_rxbuf 
+054c c1810000 rtnne 0x02 
+054d 6800cbdf fetch 1 ,mem_24g_rxdata_length 
+054e 207a0000 rtn blank 
+054f 98007200 iforce loopcnt 
+0550 d8c00cb5 arg mem_24g_rxbuf + 2 ,contr 
+0551 d8a00d17 arg mem_24g_rxpayload ,contw 
+0552 20407e45 call memcpy 
+0553 68008cb4 fetch 1 ,mem_24g_rxbuf + 1 
+0554 2fe1f008 compare 0x08 ,pdata ,0xf8 
+0555 24608000 nrtn true 
+0556 68008cb5 fetch 1 ,mem_24g_rxbuf + 2 
+0557 c07f855a beq 0xff ,p_pc_sleep_mode 
+0558 6000ccb7 store 1 ,mem_caps_num_lock 
+0559 20600000 rtn 
+
+p_pc_sleep_mode:
+055a 704d7d01 jam 1 ,mem_pc_sleep_flag 
+055b 20600000 rtn 
+
+p_g24_start_pairing_sm1:
+055c 79200023 set1 mark_24g ,mark 
+055d 20400561 call p_g24_pair_init 
+055e 2040051f call p_g24_transmit_abandon 
+055f 704bef01 jam state_24g_pairing_1 ,mem_24g_pairing_sm 
+0560 20600000 rtn 
+
+p_g24_pair_init:
+0561 704be000 jam 0 ,mem_24g_pid 
+0562 704be94e jam g24_pair_ch ,mem_24g_ch 
+0563 68024beb fetch 4 ,mem_24g_paring_addr 
+0564 202005c6 branch p_g24_update_addr_and_synccrc8 
+
+p_g24_pairing_sm:
+0565 20400561 call p_g24_pair_init 
+0566 6800cbe6 fetch 1 ,mem_24g_ensure 
+0567 c000b4df beq ensure_on_24g ,enable_user 
+0568 6800cbef fetch 1 ,mem_24g_pairing_sm 
+0569 c000856d beq state_24g_pairing_1 ,p_g24_pairing_sm_1 
+056a c0010570 beq state_24g_pairing_2 ,p_g24_pairing_sm_2 
+056b c0018573 beq state_24g_pairing_3 ,p_g24_pairing_sm_3 
+056c 20203bf1 branch assert 
+
+p_g24_pairing_sm_1:
+056d 704bef11 jam state_24g_pairing_1_waiting_ack ,mem_24g_pairing_sm 
+056e 700d37aa jam 0xaa ,mem_24g_common_temp 
+056f 20200575 branch p_g24_pairing_sm_common 
+
+p_g24_pairing_sm_2:
+0570 704bef12 jam state_24g_pairing_2_waiting_ack ,mem_24g_pairing_sm 
+0571 700d3755 jam 0x55 ,mem_24g_common_temp 
+0572 20200575 branch p_g24_pairing_sm_common 
+
+p_g24_pairing_sm_3:
+0573 704bef13 jam state_24g_pairing_3_waiting_ack ,mem_24g_pairing_sm 
+0574 700d3722 jam 0x22 ,mem_24g_common_temp 
+
+p_g24_pairing_sm_common:
+0575 700d3802 jam 0x02 ,mem_24g_common_temp + 1 
+0576 68024c06 fetch 4 ,mem_24g_device_addr 
+0577 60020d39 store 4 ,mem_24g_common_temp + 2 
+0578 700d3d00 jam 0 ,mem_24g_common_temp + 6 
+0579 da200d37 arg mem_24g_common_temp ,rega 
+057a d8400007 arg 7 ,temp 
+057b 204005af call p_g24_put_data_in_buff 
+057c 204005d4 call p_g24_transmit_prep 
+057d 204004f7 call p_g24_txdata_enable_tx 
+057e 202034df branch enable_user 
+
+p_g24_paring_mode:
+057f 6800cbef fetch 1 ,mem_24g_pairing_sm 
+0580 c17f8000 rtneq state_24g_pairing_success 
+0581 c0088585 beq state_24g_pairing_1_waiting_ack ,p_g24_pairing_sm_1_waiting_ack 
+0582 c0090587 beq state_24g_pairing_2_waiting_ack ,p_g24_pairing_sm_2_waiting_ack 
+0583 c0098589 beq state_24g_pairing_3_waiting_ack ,p_g24_pairing_sm_3_waiting_ack 
+0584 20600000 rtn 
+
+p_g24_pairing_sm_1_waiting_ack:
+0585 704bef02 jam state_24g_pairing_2 ,mem_24g_pairing_sm 
+0586 2020051f branch p_g24_transmit_abandon 
+
+p_g24_pairing_sm_2_waiting_ack:
+0587 704bef03 jam state_24g_pairing_3 ,mem_24g_pairing_sm 
+0588 2020051f branch p_g24_transmit_abandon 
+
+p_g24_pairing_sm_3_waiting_ack:
+0589 704befff jam state_24g_pairing_success ,mem_24g_pairing_sm 
+058a 700b7d31 jam bt_evt_24g_pairing_complete ,mem_fifo_temp 
+058b 20407c27 call ui_ipc_send_event 
+058c 68020d19 fetch 4 ,mem_24g_rxpayload + 2 
+058d 204005c6 call p_g24_update_addr_and_synccrc8 
+058e 2020051f branch p_g24_transmit_abandon 
+
+p_g24_start_24g_mode:
+058f 79200023 set1 mark_24g ,mark 
+0590 204005c7 call p_g24_syncword_crc8 
+0591 204005f3 call p_g24_ch 
+0592 6800cbef fetch 1 ,mem_24g_pairing_sm 
+0593 c1ff8000 rtnne state_24g_pairing_success 
+0594 204005a1 call p_g24_tx_attemp_data_prep 
+0595 58000000 setarg 0 
+0596 60014c04 store 2 ,mem_24g_check_dongle_times 
+
+p_g24_tx_attemp_dongle_loop:
+0597 20403cab call lpo_calibration 
+0598 200007d0 nop 2000 
+0599 6800cc04 fetch 1 ,mem_24g_check_dongle_times 
+059a c07f8547 beq 0xff ,p_g24_stop_g24_mode 
+059b 2040053a call p_g24_transmit_receive_ack 
+059c 243785aa nbranch p_g24_attemp_txdata_retry ,user3 
+
+p_g24_tx_attemp_dongle_succ:
+059d 20400535 call p_g24_clear_txbuf 
+059e 79200023 set1 mark_24g ,mark 
+059f 700b7d3c jam bt_evt_24g_attempt_success ,mem_fifo_temp 
+05a0 20207c27 branch ui_ipc_send_event 
+
+p_g24_tx_attemp_data_prep:
+05a1 700d37ff jam 0xff ,mem_24g_common_temp 
+05a2 6800cbe2 fetch 1 ,mem_24g_data_type 
+05a3 60008d38 store 1 ,mem_24g_common_temp + 1 
+05a4 68024c06 fetch 4 ,mem_24g_device_addr 
+05a5 60020d39 store 4 ,mem_24g_common_temp + 2 
+05a6 d8400006 arg 6 ,temp 
+05a7 da200d37 arg mem_24g_common_temp ,rega 
+05a8 204005af call p_g24_put_data_in_buff 
+05a9 202005d4 branch p_g24_transmit_prep 
+
+p_g24_attemp_txdata_retry:
+05aa 68014c04 fetch 2 ,mem_24g_check_dongle_times 
+05ab 1fe0fe01 increase 1 ,pdata 
+05ac 60014c04 store 2 ,mem_24g_check_dongle_times 
+05ad 204005f3 call p_g24_ch 
+05ae 20200597 branch p_g24_tx_attemp_dongle_loop 
+
+p_g24_put_data_in_buff:
+05af 6008cbe1 storet 1 ,mem_24g_datalen 
+05b0 18427200 copy temp ,loopcnt 
+05b1 d8a00cd5 arg mem_24g_txbuf ,contw 
+05b2 1a220c00 copy rega ,contr 
+05b3 20207e45 branch memcpy 
+
+p_g24_read_len_pid_crc:
+05b4 68008cb4 fetch 1 ,mem_24g_rxbuf + 1 
+05b5 1fe97e00 rshift3 pdata ,pdata 
+05b6 6000cbdf store 1 ,mem_24g_rxdata_length 
+05b7 1fe0fe01 increase 1 ,pdata 
+05b8 d8c00cb4 arg mem_24g_rxbuf + 1 ,contr 
+05b9 98c08c00 iadd contr ,contr 
+05ba e8c18000 ifetch 3 ,contr 
+05bb 6001cc0b store 3 ,mem_24g_sta_crc 
+05bc 20600000 rtn 
+
+p_rssi_signal:
+05bd 6808cc3c fetcht 1 ,mem_rssi_signal_index 
+05be 58004c2b setarg mem_rssi_signal_buf 
+05bf 98408a00 iadd temp ,contw 
+05c0 1a227e00 copy rega ,pdata 
+05c1 e0a08000 istore 1 ,contw 
+05c2 18408401 increase 1 ,temp 
+05c3 18410407 and_into rssi_buf_len_signal ,temp 
+05c4 6008cc3c storet 1 ,mem_rssi_signal_index 
+05c5 20600000 rtn 
+
+p_g24_update_addr_and_synccrc8:
+05c6 60024c00 store 4 ,mem_24g_addr 
+
+p_g24_syncword_crc8:
+05c7 da200000 arg 0 ,rega 
+05c8 df200004 arg 4 ,loopcnt 
+05c9 d8c04c00 arg mem_24g_addr ,contr 
+
+p_g24_syncword_crc8_loop:
+05ca e8c08000 ifetch 1 ,contr 
+05cb 9a20a200 iadd rega ,rega 
+05cc c20005ca loop p_g24_syncword_crc8_loop 
+05cd 1a227e00 copy rega ,pdata 
+05ce 60014c16 store 2 ,mem_24g_syncword 
+05cf 6800cc16 fetch 1 ,mem_24g_syncword 
+05d0 6808cc17 fetcht 1 ,mem_24g_syncword + 1 
+05d1 9840fe00 iadd temp ,pdata 
+05d2 6000cc18 store 1 ,mem_24g_syncword_crc8 
+05d3 20600000 rtn 
+
+p_g24_transmit_prep:
+05d4 6800cbe1 fetch 1 ,mem_24g_datalen 
+05d5 1fe0fe02 increase 2 ,pdata 
+05d6 6000cbe3 store 1 ,mem_24g_txlen 
+05d7 6800cbe2 fetch 1 ,mem_24g_data_type 
+05d8 60008cf5 store 1 ,mem_24g_txpayload 
+05d9 6800cbe1 fetch 1 ,mem_24g_datalen 
+05da 1fe9fe00 lshift3 pdata ,pdata 
+05db 6808cbe0 fetcht 1 ,mem_24g_pid 
+05dc 18410403 and temp ,0x03 ,temp 
+05dd 18438400 lshift temp ,temp 
+05de 9841fe00 ior temp ,pdata 
+05df 6808cc0a fetcht 1 ,mem_24g_no_ack 
+05e0 9840fe00 iadd temp ,pdata 
+05e1 e0a08000 istore 1 ,contw 
+05e2 6800cbef fetch 1 ,mem_24g_pairing_sm 
+05e3 c0ff85e6 bne state_24g_pairing_success ,p_g24_transmit_prep_pair 
+05e4 6800cbe2 fetch 1 ,mem_24g_data_type 
+05e5 e0a08000 istore 1 ,contw 
+
+p_g24_transmit_prep_pair:
+05e6 6800cbe1 fetch 1 ,mem_24g_datalen 
+05e7 98007200 iforce loopcnt 
+05e8 6800cbe2 fetch 1 ,mem_24g_data_type 
+05e9 c00085f1 beq 1 ,p_g24_transmit_prep_mouse 
+05ea d8c00cd5 arg mem_24g_txbuf ,contr 
+05eb 20407e45 call memcpy 
+05ec 68008cd5 fetch 1 ,mem_24g_txbuf 
+05ed c00185ef beq 0x03 ,p_g24_multi_key_setup 
+05ee 20600000 rtn 
+
+p_g24_multi_key_setup:
+05ef 700cd502 jam 0x02 ,mem_24g_txbuf 
+05f0 20600000 rtn 
+
+p_g24_transmit_prep_mouse:
+05f1 d8c00cd6 arg mem_24g_txbuf + 1 ,contr 
+05f2 20207e45 branch memcpy 
+
+p_g24_ch:
+05f3 6808cbea fetcht 1 ,mem_24g_current_ch_number 
+05f4 204005f9 call p_g24_ch_calc 
+05f5 18408401 increase 1 ,temp 
+05f6 18410403 and_into 3 ,temp 
+05f7 6008cbea storet 1 ,mem_24g_current_ch_number 
+05f8 20600000 rtn 
+
+p_g24_ch_calc:
+05f9 6800cc00 fetch 1 ,mem_24g_addr 
+05fa 1fe17e03 and_into 0x03 ,pdata 
+05fb 1fefa204 mul32 pdata ,4 ,rega 
+05fc 58004bf0 setarg mem_24g_ch_map1 
+05fd 9a20fe00 iadd rega ,pdata 
+05fe 98408c00 iadd temp ,contr 
+05ff e8c08000 ifetch 1 ,contr 
+0600 6000cbe9 store 1 ,mem_24g_ch 
+0601 20600000 rtn 
+
+p_g24_prep:
+0602 7844fc00 disable enable_crc 
+0603 7843fc00 disable enable_white 
+0604 58555555 setarg 0x555555 
+0605 98001e00 iforce crc24_init 
+0606 6800cbe9 fetch 1 ,mem_24g_ch 
+0607 1fed8400 reverse pdata ,temp 
+0608 79200401 set1 1 ,temp 
+0609 18431c00 rshift temp ,white_init 
+060a 20600000 rtn 
+
+p_g24_receive_rxon:
+060b 20400602 call p_g24_prep 
+060c 7826fc00 enable decode_fec0 
+060d 7830fc00 enable is_rx 
+060e 78507c00 disable is_tx 
+060f 78287c00 enable swfine 
+0610 68014be4 fetch 2 ,mem_24g_rx_window 
+0611 98003600 iforce stop_watch 
+0612 37c18400 correlate null ,timeout 
+0613 242c0645 nbranch p_g24_sync_timeout ,sync 
+0614 7846fc00 disable decode_fec0 
+0615 7825fc00 enable decode_fec1 
+0616 7823fc00 enable enable_white 
+0617 7824fc00 enable enable_crc 
+0618 09800008 parse demod ,bucket ,8 
+0619 19897e00 rshift3 pwindow ,pdata 
+061a 6000cc19 store 1 ,mem_24g_get_syncword_crc8 
+061b 6808cc18 fetcht 1 ,mem_24g_syncword_crc8 
+061c 98467c00 isub temp ,null 
+061d 24228645 nbranch p_g24_end_of_packet ,zero 
+061e 09800008 parse demod ,bucket ,8 
+061f 19897e00 rshift3 pwindow ,pdata 
+0620 60008cb3 store 1 ,mem_24g_rxbuf 
+0621 68008cb3 fetch 1 ,mem_24g_rxbuf 
+0622 6808cbe2 fetcht 1 ,mem_24g_data_type 
+0623 a8400e00 icompare bits_data ,temp 
+0624 24208645 nbranch p_g24_end_of_packet ,true 
+
+p_g24_receive_skip:
+0625 09800008 parse demod ,bucket ,8 
+0626 19897e00 rshift3 pwindow ,pdata 
+0627 e0a08000 istore 1 ,contw 
+0628 1fe97e00 rshift3 pdata ,pdata 
+0629 1fe1721f and pdata ,0x1f ,loopcnt 
+062a 2022862f branch p_g24rx_nopayload ,zero 
+
+p_g24rx_loop:
+062b 09800008 parse demod ,bucket ,8 
+062c 19897e00 rshift3 pwindow ,pdata 
+062d e0a08000 istore 1 ,contw 
+062e c200062b loop p_g24rx_loop 
+
+p_g24rx_nopayload:
+062f 18a22200 copy contw ,rega 
+0630 09800008 parse demod ,bucket ,8 
+0631 19897e00 rshift3 pwindow ,pdata 
+0632 6000cc2a store 1 ,mem_rssi_hex_received 
+0633 1a220a00 copy rega ,contw 
+0634 09800018 parse demod ,bucket ,24 
+0635 78287c00 enable swfine 
+0636 db600664 arg param_sifs ,stop_watch 
+0637 1fef7e00 rshift32 pdata ,pdata 
+0638 1ff17e00 rshift16 pdata ,pdata 
+0639 e0a18000 istore 3 ,contw 
+063a 7845fc00 disable decode_fec1 
+063b 20230645 branch p_g24_end_of_packet ,crc_failed 
+063c 7837fc00 enable user3 
+063d 68008017 fetch 1 ,mem_last_freq 
+063e 1fe0a200 add pdata ,0 ,rega 
+063f 20403ab6 call rf_write_freq 
+0640 7846fc00 disable decode_fec0 
+0641 20403a7a call set_sync_on 
+0642 6800cc2a fetch 1 ,mem_rssi_hex_received 
+0643 1fe22200 copy pdata ,rega 
+0644 202005bd branch p_rssi_signal 
+
+p_g24_sync_timeout:
+
+p_g24_end_of_packet:
+0645 784dfc00 disable encode_fec1 
+0646 7845fc00 disable decode_fec1 
+0647 2020375c branch end_of_packet 
+
+p_g24_set_freq_tx:
+0648 20403a7a call set_sync_on 
+0649 6808cbe9 fetcht 1 ,mem_24g_ch 
+064a 20203a91 branch set_freq_tx 
+
+p_g24_transmit:
+064b 204053d2 call le_enable 
+064c 68024c00 fetch 4 ,mem_24g_addr 
+064d 98001200 iforce access 
+064e 20400602 call p_g24_prep 
+064f 20400648 call p_g24_set_freq_tx 
+0650 79202a00 set1 txgfsk ,radio_ctrl 
+0651 782efc00 enable encode_fec0 
+0652 78307c00 enable is_tx 
+0653 7850fc00 disable is_rx 
+0654 19317e00 rshift16 access ,pdata 
+0655 1fecfe00 rshift8 pdata ,pdata 
+0656 1ff1fe00 rshift4 pdata ,pdata 
+0657 08008628 inject mod ,40 
+0658 784efc00 disable encode_fec0 
+0659 782dfc00 enable encode_fec1 
+065a 7823fc00 enable enable_white 
+065b 7824fc00 enable enable_crc 
+065c 6800cc18 fetch 1 ,mem_24g_syncword_crc8 
+065d 08008608 inject mod ,8 
+065e 6800cbe3 fetch 1 ,mem_24g_txlen 
+065f 98007200 iforce loopcnt 
+0660 d8c00cf5 arg mem_24g_txpayload ,contr 
+
+p_g24tr_loop:
+0661 e8c08000 ifetch 1 ,contr 
+0662 08008608 inject mod ,8 
+0663 c2000661 loop p_g24tr_loop 
+0664 78247c00 enable enable_parity 
+0665 08008618 inject mod ,24 
+0666 78447c00 disable enable_parity 
+0667 37d38200 until null ,tx_clear 
+0668 20000064 nop 100 
+0669 784efc00 disable encode_fec0 
+066a 784dfc00 disable encode_fec1 
+066b 20203a7a branch set_sync_on 
+              org 0x3000
+
+start:
+3000 20403c74 call lpmstate 
+
+soft_reset:
+3001 793f8025 set0 mark_ext_patch ,mark 
+3002 44804000 bpatch patch00_0 ,mem_patch00 
+3003 20800000 clear_stack 
+3004 20403a9e call initialize_radio 
+3005 20406805 call iicd_init_12m 
+3006 20403bfa call init_param 
+3007 20404d98 call l2cap_init 
+3008 793f8025 set0 mark_ext_patch ,mark 
+3009 4480c000 bpatch patch00_1 ,mem_patch00 
+300a 20406b53 call rfcomm_init 
+300b 20405b62 call init_lmp 
+300c 20407b9d call ui_init 
+300d 20403e4f call app_init 
+300e 793f8025 set0 mark_ext_patch ,mark 
+300f 44814000 bpatch patch00_2 ,mem_patch00 
+3010 2055be5f call app_lpm_init ,wake 
+3011 20407719 call sp_initialize 
+3012 2055bcf1 call lpm_recover_clk ,wake 
+
+main_loop:
+3013 793f8025 set0 mark_ext_patch ,mark 
+3014 4481c000 bpatch patch00_3 ,mem_patch00 
+3015 20407813 call sp_calc_sequence 
+3016 20405373 call le_dispatch 
+3017 20404449 call hci_dispatch 
+3018 793f8025 set0 mark_ext_patch ,mark 
+3019 44824000 bpatch patch00_4 ,mem_patch00 
+301a 2040303e call idle_dispatch 
+301b 20403e6a call app_process_idle 
+301c 204030a1 call inquiry_dispatch 
+301d 793f8025 set0 mark_ext_patch ,mark 
+301e 4482c000 bpatch patch00_5 ,mem_patch00 
+301f 20403392 call inquiry_scan_dispatch 
+3020 20403407 call page_scan_dispatch 
+3021 20403024 call connection_dispatch 
+3022 20403d1c call lpm_dispatch 
+3023 20203013 branch main_loop 
+
+connection_dispatch:
+3024 20403029 call connection_incontext 
+3025 c6848000 rtnmark0 mark_context 
+3026 793f8009 set0 mark_context ,mark 
+3027 204032bd call context_save 
+3028 202053d7 branch le_disable 
+
+connection_incontext:
+3029 793f8025 set0 mark_ext_patch ,mark 
+302a 44834000 bpatch patch00_6 ,mem_patch00 
+302b 204032fe call context_search_insniff 
+302c 2422b033 nbranch connection_nosniff ,zero 
+302d 204032a3 call context_load 
+302e 1a208c01 add rega ,coffset_mode ,contr 
+302f e8c08000 ifetch 1 ,contr 
+3030 c2805377 bbit1 mode_le ,le_conn_dispatch 
+3031 c280b1a7 bbit1 mode_master ,master_dispatch 
+3032 20203473 branch slave_dispatch 
+
+connection_nosniff:
+3033 793f8025 set0 mark_ext_patch ,mark 
+3034 4483c000 bpatch patch00_7 ,mem_patch00 
+3035 204032c6 call context_get_next 
+3036 1f227c00 copy loopcnt ,null 
+3037 20628000 rtn zero 
+3038 204032a3 call context_load 
+3039 68008030 fetch 1 ,mem_state 
+303a c281b103 bbit1 state_inpage ,master_page 
+303b 68008031 fetch 1 ,mem_mode 
+303c c280b1a7 bbit1 mode_master ,master_dispatch 
+303d 20203473 branch slave_dispatch 
+
+idle_dispatch:
+303e 6800c272 fetch 1 ,mem_hci_cmd 
+303f 207a0000 rtn blank 
+3040 c000b04e beq hci_cmd_inquiry ,idle_inquiry 
+3041 c0013053 beq hci_cmd_inquiry_cancel ,idle_inquiry_cancel 
+3042 c001b056 beq hci_cmd_remote_name_req ,idle_remote_name_req 
+3043 c002b05b beq hci_cmd_create_conn ,idle_create_conn 
+3044 c00db04b beq hci_cmd_le_create_conn ,idle_le_create_conn 
+3045 204032f6 call context_search_conn_handle 
+3046 20628000 rtn zero 
+3047 204032f9 call context_search_plap 
+3048 20628000 rtn zero 
+
+idle_exit:
+3049 70427200 jam 0 ,mem_hci_cmd 
+304a 20600000 rtn 
+
+idle_le_create_conn:
+304b 70041c1b jam hci_cmd_le_create_conn ,mem_cmd_le_create_conn 
+304c 70427200 jam 0 ,mem_hci_cmd 
+304d 20600000 rtn 
+
+idle_inquiry:
+304e 7920001c set1 mark_inquiry_on ,mark 
+304f 793f801e set0 mark_inquiry_trainb ,mark 
+3050 70008eff jam param_ninquiry ,mem_ninqy_index 
+3051 70008c1f jam 31 ,mem_nfreq_index_inq 
+3052 20203049 branch idle_exit 
+
+idle_inquiry_cancel:
+3053 793f801c set0 mark_inquiry_on ,mark 
+3054 18003600 force 0 ,stop_watch 
+3055 20203049 branch idle_exit 
+
+idle_remote_name_req:
+3056 204032f9 call context_search_plap 
+3057 20628000 rtn zero 
+3058 18000401 force lmp_name_req ,temp 
+3059 70017805 jam 5 ,mem_nameres_cnt 
+305a 20203068 branch idle_start_page 
+
+idle_create_conn:
+305b 793f8025 set0 mark_ext_patch ,mark 
+305c 44844001 bpatch patch01_0 ,mem_patch01 
+305d 6800c132 fetch 1 ,mem_device_option 
+305e c000b064 beq dvc_op_hci ,idle_create_conn_hci 
+
+idle_create_conn_device:
+305f 68034274 fetch 6 ,mem_hci_plap 
+3060 203a3049 branch idle_exit ,blank 
+3061 7047f301 jam reconnect_hid ,memui_reconnect_mode 
+3062 70005503 jam conn_sm_wait_features_res ,mem_conn_sm 
+3063 20203067 branch idle_create_conn_cont 
+
+idle_create_conn_hci:
+3064 68034274 fetch 6 ,mem_hci_plap 
+3065 203a3049 branch idle_exit ,blank 
+3066 60030040 store 6 ,mem_plap 
+
+idle_create_conn_cont:
+3067 18000425 force lmp_version_req ,temp 
+
+idle_start_page:
+3068 793f8025 set0 mark_ext_patch ,mark 
+3069 4484c001 bpatch patch01_1 ,mem_patch01 
+306a 680080f3 fetch 1 ,mem_page_mode 
+306b 203a306f branch idle_page_mode_r0 ,blank 
+306c 1fe9fe00 lshift3 pdata ,pdata 
+306d 1ff27e00 lshift4 pdata ,pdata 
+306e 1fe0ffff increase -1 ,pdata 
+
+idle_page_mode_r0:
+306f 6000c146 store 1 ,mem_npage 
+3070 600080f2 store 1 ,mem_npage_index 
+3071 70008d1f jam 31 ,mem_nfreq_index_page 
+3072 793f800c set0 mark_page_trainb ,mark 
+3073 204032d6 call context_new 
+3074 2422b090 nbranch idle_page_fail ,zero 
+3075 20403bd1 call get_free_amaddr 
+3076 60008077 store 1 ,mem_amaddr 
+3077 6008807c storet 1 ,mem_lmo_opcode2 
+3078 68034274 fetch 6 ,mem_hci_plap 
+3079 60030040 store 6 ,mem_plap 
+307a 793f8025 set0 mark_ext_patch ,mark 
+307b 44854001 bpatch patch01_2 ,mem_patch01 
+307c 18007e00 force 0 ,pdata 
+307d 2841fe01 compare lmp_name_req ,temp ,0xff 
+307e 7d20fe05 nsetflag true ,state_init_seq ,pdata 
+307f 79207e03 set1 state_inpage ,pdata 
+3080 60008030 store 1 ,mem_state 
+3081 700b7d03 jam bt_evt_reconn_started ,mem_fifo_temp 
+3082 20407c27 call ui_ipc_send_event 
+3083 18007e00 force 0 ,pdata 
+3084 7920fe04 setflag true ,smap_name_req ,pdata 
+3085 6000804c store 1 ,mem_state_map 
+3086 58000000 setarg 0 
+3087 79207e01 set1 mode_master ,pdata 
+3088 60008031 store 1 ,mem_mode 
+3089 7834fc00 enable master 
+308a 204032bd call context_save 
+308b 7854fc00 disable master 
+308c 18000e04 force page_length_timer ,queue 
+308d 68014159 fetch 2 ,mem_page_to 
+308e 20407e4c call timer_init 
+308f 20203049 branch idle_exit 
+
+idle_page_fail:
+3090 793f8025 set0 mark_ext_patch ,mark 
+3091 4485c001 bpatch patch01_3 ,mem_patch01 
+3092 68034274 fetch 6 ,mem_hci_plap 
+3093 60030040 store 6 ,mem_plap 
+3094 2841fe01 compare lmp_name_req ,temp ,0xff 
+3095 2020b099 branch idle_name_fail ,true 
+3096 18000407 force hci_error_memory_full ,temp 
+3097 20404826 call hci_send_connection_error 
+3098 20203049 branch idle_exit 
+
+idle_name_fail:
+3099 d8a00103 arg mem_tmp_buffer ,contw 
+309a df200008 arg 8 ,loopcnt 
+309b 20407e3b call memset0 
+309c 18000e07 force hci_error_memory_full ,queue 
+309d 20404898 call hci_send_name 
+309e 700b7d04 jam bt_evt_reconn_failed ,mem_fifo_temp 
+309f 20407c27 call ui_ipc_send_event 
+30a0 20203049 branch idle_exit 
+
+inquiry_dispatch:
+30a1 c68e0000 rtnmark0 mark_inquiry_on 
+30a2 18000e02 force inquiry_length_timer ,queue 
+30a3 20407e53 call timer_check 
+30a4 7d3a001c nsetflag blank ,mark_inquiry_on ,mark 
+30a5 243a30a7 nbranch inquiry_start ,blank 
+30a6 20600000 rtn 
+
+inquiry_start:
+30a7 793f8025 set0 mark_ext_patch ,mark 
+30a8 44864001 bpatch patch01_4 ,mem_patch01 
+30a9 6809415b fetcht 2 ,mem_inq_window 
+30aa 18000e04 force 4 ,queue 
+30ab 2040383d call sniff_check_window 
+30ac 20740000 rtn user 
+30ad 20403a12 call afh_clear 
+30ae 18004800 force 0 ,freq_mode 
+
+inquiry_restart:
+30af 20618000 rtn timeout 
+30b0 793f800b set0 mark_fhs_already_good ,mark 
+30b1 793f8000 set0 mark_fhs_eir ,mark 
+
+inquiry_rx_restart:
+30b2 1c40c201 add clkn_bt ,1 ,bt_clk 
+30b3 280ffe1e isolate1 mark_inquiry_trainb ,mark 
+30b4 7920c802 setflag true ,2 ,freq_mode 
+30b5 2c200400 compare 0x00 ,bt_clk ,0x02 
+30b6 2420b0d3 nbranch inquiry_receive ,true 
+
+inquiry_transmit:
+30b7 793f8025 set0 mark_ext_patch ,mark 
+30b8 4486c001 bpatch patch01_5 ,mem_patch01 
+30b9 68008012 fetch 1 ,mem_inquiry_transmit 
+30ba 1fe0fe01 increase 1 ,pdata 
+30bb 60008012 store 1 ,mem_inquiry_transmit 
+30bc 20403a49 call fetch_giac 
+30bd 20403a42 call tx_radio_freq 
+30be 20403a66 call fetch_diac 
+30bf 20403bae call start_transmitter 
+30c0 20403bb4 call start_tx_native 
+30c1 20403bc5 call send_access_word 
+30c2 2040375c call end_of_packet 
+30c3 204030c5 call inquiry_check_train 
+30c4 202030af branch inquiry_restart 
+
+inquiry_check_train:
+30c5 793f8025 set0 mark_ext_patch ,mark 
+30c6 44874001 bpatch patch01_6 ,mem_patch01 
+30c7 6800808c fetch 1 ,mem_nfreq_index_inq 
+30c8 1fe0ffff increase -1 ,pdata 
+30c9 6000808c store 1 ,mem_nfreq_index_inq 
+30ca 20610000 rtn positive 
+30cb 70008c1f jam 31 ,mem_nfreq_index_inq 
+30cc 6800808e fetch 1 ,mem_ninqy_index 
+30cd 1fe0ffff increase -1 ,pdata 
+30ce 6000808e store 1 ,mem_ninqy_index 
+30cf 20610000 rtn positive 
+30d0 7940001e setflip mark_inquiry_trainb ,mark 
+30d1 70008eff jam param_ninquiry ,mem_ninqy_index 
+30d2 20600000 rtn 
+
+inquiry_receive:
+30d3 793f8025 set0 mark_ext_patch ,mark 
+30d4 4487c001 bpatch patch01_7 ,mem_patch01 
+30d5 20403a49 call fetch_giac 
+30d6 20403a3b call rx_radio_freq 
+30d7 20403a66 call fetch_diac 
+30d8 20403bba call start_rx_native 
+30d9 20403b3a call start_receiver 
+30da 20403b63 call wait_access_clkn_rt 
+30db 202c30de branch inquiry_sync ,sync 
+30dc 204030c5 call inquiry_check_train 
+30dd 202030b2 branch inquiry_rx_restart 
+
+inquiry_sync:
+30de 793f8025 set0 mark_ext_patch ,mark 
+30df 44884002 bpatch patch02_0 ,mem_patch02 
+30e0 20403af3 call save_rssi 
+30e1 20403bcd call scan_mode_whiten 
+30e2 204035e1 call receive_packet_whitened 
+30e3 793f8001 set0 mark_rxbuf_inuse ,mark 
+30e4 c6858000 rtnmark0 mark_fhs_already_good 
+
+inquiry_receive_rtn:
+30e5 793f8025 set0 mark_ext_patch ,mark 
+30e6 4488c002 bpatch patch02_1 ,mem_patch02 
+30e7 6800c2a4 fetch 1 ,mem_at_using_flag 
+30e8 c2804221 bbit1 at_flag_inq ,at_inquiry_reply 
+30e9 2040477b call hci_inquiry_reply 
+
+inquiry_receive_eir_rtn:
+30ea 68008013 fetch 1 ,mem_inquiry_rcv 
+30eb 1fe0fe01 increase 1 ,pdata 
+30ec 60008013 store 1 ,mem_inquiry_rcv 
+30ed 20600000 rtn 
+
+inquiry_receive_eir:
+30ee 793f800b set0 mark_fhs_already_good ,mark 
+30ef 204030fe call rf_setup_time_slave_slot_eir 
+30f0 20403a49 call fetch_giac 
+30f1 20403a3b call rx_radio_freq 
+30f2 204034e1 call init_rx_packet_flags 
+30f3 20403bba call start_rx_native 
+30f4 20403b3a call start_receiver 
+30f5 20403b63 call wait_access_clkn_rt 
+30f6 202c30f8 branch inquiry_receive_eir_packet ,sync 
+30f7 20600000 rtn 
+
+inquiry_receive_eir_packet:
+30f8 20403bcd call scan_mode_whiten 
+30f9 204035e1 call receive_packet_whitened 
+30fa 793f8001 set0 mark_rxbuf_inuse ,mark 
+30fb 202330e5 branch inquiry_receive_rtn ,crc_failed 
+30fc 2040479b call hci_inquiry_reply_eir 
+30fd 202030ea branch inquiry_receive_eir_rtn 
+
+rf_setup_time_slave_slot_eir:
+30fe d9600600 arg param_rf_setup ,timeup 
+
+rf_setup_time_eir:
+30ff 34730200 until clkn_rt ,meet 
+3100 1c417e03 and clkn_bt ,3 ,pdata 
+3101 c080b0ff bne 1 ,rf_setup_time_eir 
+3102 20600000 rtn 
+
+master_page:
+3103 793f8025 set0 mark_ext_patch ,mark 
+3104 44894002 bpatch patch02_2 ,mem_patch02 
+3105 7834fc00 enable master 
+3106 78387c00 enable clknt 
+3107 68014155 fetch 2 ,mem_page_interval 
+3108 203a310c branch master_page_no_interval ,blank 
+3109 18000e0d force page_interval_timer ,queue 
+310a 20407e53 call timer_check 
+310b 247a0000 nrtn blank 
+
+master_page_no_interval:
+310c 793f8025 set0 mark_ext_patch ,mark 
+310d 4489c002 bpatch patch02_3 ,mem_patch02 
+310e 68094157 fetcht 2 ,mem_page_window 
+310f 18000e28 force 40 ,queue 
+3110 2040383d call sniff_check_window 
+3111 2034314e branch page_exit ,user 
+3112 18000e04 force page_length_timer ,queue 
+3113 20407e53 call timer_check 
+3114 243a3127 nbranch page_start ,blank 
+3115 6800804c fetch 1 ,mem_state_map 
+3116 c282311a bbit1 smap_name_req ,master_npage_timeout 
+3117 18000404 force hci_error_page_timeout ,temp 
+3118 20404826 call hci_send_connection_error 
+3119 2020311f branch master_page_timeout 
+
+master_npage_timeout:
+311a d8a00103 arg mem_tmp_buffer ,contw 
+311b df200008 arg 8 ,loopcnt 
+311c 20407e3b call memset0 
+311d 18000e04 force hci_error_page_timeout ,queue 
+311e 20404898 call hci_send_name 
+
+master_page_timeout:
+311f 793f8025 set0 mark_ext_patch ,mark 
+3120 448a4002 bpatch patch02_4 ,mem_patch02 
+3121 70003000 jam 0 ,mem_state 
+3122 20405b63 call init_lmp_work 
+3123 7047f300 jam 0 ,memui_reconnect_mode 
+3124 700b7d13 jam bt_evt_reconn_page_timeout ,mem_fifo_temp 
+3125 20407c27 call ui_ipc_send_event 
+3126 2020314e branch page_exit 
+
+page_start:
+3127 793f8025 set0 mark_ext_patch ,mark 
+3128 448ac002 bpatch patch02_5 ,mem_patch02 
+3129 18001600 force 0 ,timeup 
+312a 34730200 until clkn_rt ,meet 
+312b 680080f4 fetch 1 ,mem_page_clk 
+312c 1fe0ffff increase -1 ,pdata 
+312d 9c42fe00 ixor clkn_bt ,pdata 
+312e 2fe00600 compare 0 ,pdata ,3 
+312f 2420b127 nbranch page_start ,true 
+3130 18827e00 deposit am_addr 
+3131 6000818b store 1 ,mem_fhs_am_addr 
+3132 18004c00 force 0 ,n_tx_slot 
+3133 18004800 force 0 ,freq_mode 
+
+page_restart:
+3134 793f8025 set0 mark_ext_patch ,mark 
+3135 448b4002 bpatch patch02_6 ,mem_patch02 
+3136 2021b14e branch page_exit ,timeout 
+3137 20403a4d call fetch_page_bt_adr 
+3138 d9600600 arg param_rf_setup ,timeup 
+3139 34730200 until clkn_rt ,meet 
+
+page_rx_restart:
+313a 793f8025 set0 mark_ext_patch ,mark 
+313b 448bc002 bpatch patch02_7 ,mem_patch02 
+313c 680200f4 fetch 4 ,mem_page_clk 
+313d 98004200 iforce bt_clk 
+313e 1fe0fe01 increase 1 ,pdata 
+313f 600200f4 store 4 ,mem_page_clk 
+3140 280ffe0c isolate1 mark_page_trainb ,mark 
+3141 7920c802 setflag true ,2 ,freq_mode 
+3142 2c200400 compare 0x00 ,bt_clk ,0x02 
+3143 2420b164 nbranch page_receive ,true 
+3144 6800800c fetch 1 ,mem_page_transmit 
+3145 1fe0fe01 increase 1 ,pdata 
+3146 6000800c store 1 ,mem_page_transmit 
+3147 20403a42 call tx_radio_freq 
+3148 20403bae call start_transmitter 
+3149 20403bb4 call start_tx_native 
+314a 20403bc5 call send_access_word 
+314b 2040375c call end_of_packet 
+314c 20403155 call page_check_train 
+314d 20203134 branch page_restart 
+
+master_dispatch_exit:
+
+page_exit:
+314e 793f8025 set0 mark_ext_patch ,mark 
+314f 448c4003 bpatch patch03_0 ,mem_patch03 
+3150 7854fc00 disable master 
+3151 68014155 fetch 2 ,mem_page_interval 
+3152 207a0000 rtn blank 
+3153 18000e0d force page_interval_timer ,queue 
+3154 20207e4c branch timer_init 
+
+page_check_train:
+3155 793f8025 set0 mark_ext_patch ,mark 
+3156 448cc003 bpatch patch03_1 ,mem_patch03 
+3157 6800808d fetch 1 ,mem_nfreq_index_page 
+3158 1fe0ffff increase -1 ,pdata 
+3159 6000808d store 1 ,mem_nfreq_index_page 
+315a 20610000 rtn positive 
+315b 70008d1f jam 31 ,mem_nfreq_index_page 
+315c 680080f2 fetch 1 ,mem_npage_index 
+315d 1fe0ffff increase -1 ,pdata 
+315e 600080f2 store 1 ,mem_npage_index 
+315f 20610000 rtn positive 
+3160 7940000c setflip mark_page_trainb ,mark 
+3161 6800c146 fetch 1 ,mem_npage 
+3162 600080f2 store 1 ,mem_npage_index 
+3163 20600000 rtn 
+
+page_receive:
+3164 793f8025 set0 mark_ext_patch ,mark 
+3165 448d4003 bpatch patch03_2 ,mem_patch03 
+3166 20403a3b call rx_radio_freq 
+3167 20403bba call start_rx_native 
+3168 20403b3a call start_receiver 
+3169 20403b63 call wait_access_clkn_rt 
+316a 202c316d branch page_sync ,sync 
+316b 20403155 call page_check_train 
+316c 2020313a branch page_rx_restart 
+
+page_sync:
+316d 2040375c call end_of_packet 
+316e 6800800d fetch 1 ,mem_page_rcv 
+316f 1fe0fe01 increase 1 ,pdata 
+3170 6000800d store 1 ,mem_page_rcv 
+3171 18003600 force 0 ,stop_watch 
+3172 680200f4 fetch 4 ,mem_page_clk 
+
+page_send_fhs:
+3173 793f8025 set0 mark_ext_patch ,mark 
+3174 448dc003 bpatch patch03_3 ,mem_patch03 
+3175 20403bac call rf_setup_time_master_slot 
+3176 20403a4d call fetch_page_bt_adr 
+3177 1cc0cc01 increase 1 ,n_tx_slot 
+
+page_send_fhs_continue:
+3178 1c2143fd and_into 0x1fd ,bt_clk 
+3179 1c8149fc and_into 0x1fc ,freq_mode 
+317a 20403a42 call tx_radio_freq 
+317b 20403bae call start_transmitter 
+317c 20403bb4 call start_tx_native 
+317d 20403bc5 call send_access_word 
+317e 1c427e00 deposit clkn_bt 
+317f 6002016b store 4 ,mem_clkn_bt 
+3180 18000800 force 0 ,am_addr 
+3181 18000202 force type_fhs ,type 
+3182 20403bcd call scan_mode_whiten 
+3183 204038c1 call transmit_packet_whitened 
+
+page_wait_fhs_reply:
+3184 793f8025 set0 mark_ext_patch ,mark 
+3185 448e4003 bpatch patch03_4 ,mem_patch03 
+3186 20403baa call rf_setup_time_slave_slot 
+3187 1c21c202 or_into 0x02 ,bt_clk 
+3188 1c8149fc and_into 0x1fc ,freq_mode 
+3189 20403a3b call rx_radio_freq 
+318a 20403bba call start_rx_native 
+318b 20403b3a call start_receiver 
+318c 20403b63 call wait_access_clkn_rt 
+318d 204c375c call end_of_packet ,sync 
+318e 202c3194 branch page_wait_fhs_reply_ok ,sync 
+318f 68008010 fetch 1 ,mem_fhs_wait_counter 
+3190 203a3134 branch page_restart ,blank 
+3191 1fe0ffff increase -1 ,pdata 
+3192 60008010 store 1 ,mem_fhs_wait_counter 
+3193 20203173 branch page_send_fhs 
+
+page_wait_fhs_reply_ok:
+3194 793f8025 set0 mark_ext_patch ,mark 
+3195 448ec003 bpatch patch03_5 ,mem_patch03 
+3196 6800800e fetch 1 ,mem_page_rcv_fhs 
+3197 1fe0fe01 increase 1 ,pdata 
+3198 6000800e store 1 ,mem_page_rcv_fhs 
+3199 204034ed call prepare_newconn 
+
+master_newconn_loop:
+319a 2040338b call master_newconn_once 
+319b 202c319f branch newconn_poll_responded ,sync 
+319c 2040350e call new_conn_timeout 
+319d 243a319a nbranch master_newconn_loop ,blank 
+319e 20203134 branch page_restart 
+
+newconn_poll_responded:
+319f 793f8025 set0 mark_ext_patch ,mark 
+31a0 448f4003 bpatch patch03_6 ,mem_patch03 
+31a1 68008030 fetch 1 ,mem_state 
+31a2 793ffe03 set0 state_inpage ,pdata 
+31a3 60008030 store 1 ,mem_state 
+31a4 204034f9 call newconn_init 
+31a5 7854fc00 disable master 
+31a6 20600000 rtn 
+
+master_dispatch:
+31a7 793f8025 set0 mark_ext_patch ,mark 
+31a8 448fc003 bpatch patch03_7 ,mem_patch03 
+31a9 7834fc00 enable master 
+31aa 78387c00 enable clknt 
+31ab 2040324e call role_switch_master 
+31ac 20740000 rtn user 
+31ad 20403e25 call check_bt_disabled 
+31ae 20403bac call rf_setup_time_master_slot 
+31af 1c40c201 add clkn_bt ,1 ,bt_clk 
+31b0 20403a54 call fetch_self_bt_adr 
+31b1 18004803 force 0x03 ,freq_mode 
+31b2 2040327c call load_esco 
+31b3 20406a54 call get_sco_data 
+31b4 20406e10 call scheduler_tx_l2cap_pkt 
+31b5 20403547 call prepare_tx 
+31b6 20403a42 call tx_radio_freq 
+31b7 20403bae call start_transmitter 
+31b8 20403bb4 call start_tx_native 
+31b9 20403bc5 call send_access_word 
+31ba 204038bf call transmit_packet 
+
+master_loop:
+31bb 793f8025 set0 mark_ext_patch ,mark 
+31bc 44904004 bpatch patch04_0 ,mem_patch04 
+31bd 20405b78 call parse_lmp 
+31be 20404995 call process_cmd 
+31bf 204048a9 call hci_send_num_complete_packets 
+31c0 2040337c call master_conn_recv_packet 
+31c1 2436b1c7 nbranch master_notmatch ,match 
+31c2 20403bec call supervision_flush 
+31c3 20403870 call parse_l2cap 
+31c4 6800800f fetch 1 ,mem_master_rcvcnt 
+31c5 1fe0fe01 increase 1 ,pdata 
+31c6 6000800f store 1 ,mem_master_rcvcnt 
+
+master_notmatch:
+31c7 793f8025 set0 mark_ext_patch ,mark 
+31c8 4490c004 bpatch patch04_1 ,mem_patch04 
+31c9 20406dec call scheduler_process 
+31ca 204031d5 call check_master_disconnect 
+31cb 24748000 nrtn master 
+31cc 20403812 call check_attempt 
+31cd 243a31d2 nbranch master_attempt ,blank 
+
+master_exit:
+31ce 20406a5c call process_sco_data 
+31cf 20403290 call restore_esco 
+31d0 7854fc00 disable master 
+31d1 20600000 rtn 
+
+master_attempt:
+31d2 20403547 call prepare_tx 
+31d3 20403371 call master_conn_send_packet 
+31d4 202031bb branch master_loop 
+
+check_master_disconnect:
+31d5 2036b1d8 branch check_master_match ,match 
+31d6 20403be2 call supervision_update 
+31d7 202131e6 branch master_disconnect ,positive 
+
+check_master_match:
+31d8 20403204 call check_disconnect_timeout 
+31d9 243431e6 nbranch master_disconnect ,user 
+31da 6800804c fetch 1 ,mem_state_map 
+31db c4020000 rtnbit0 smap_name_req 
+31dc c3818000 rtnbit1 smap_name_res 
+31dd 6800804b fetch 1 ,mem_op 
+31de c3818000 rtnbit1 op_disconn 
+31df 2040320d call conn_timer_expired 
+31e0 247a0000 nrtn blank 
+31e1 68008178 fetch 1 ,mem_nameres_cnt 
+31e2 1fe0ffff increase -1 ,pdata 
+31e3 60008178 store 1 ,mem_nameres_cnt 
+31e4 247a0000 nrtn blank 
+31e5 20205ed5 branch lmp_disconnect 
+
+master_disconnect:
+31e6 793f8025 set0 mark_ext_patch ,mark 
+31e7 44914004 bpatch patch04_2 ,mem_patch04 
+31e8 20403516 call quit_connection 
+31e9 7854fc00 disable master 
+31ea 6800804c fetch 1 ,mem_state_map 
+31eb c28231f2 bbit1 smap_name_req ,master_name_disconnect 
+31ec 68008030 fetch 1 ,mem_state 
+31ed c30231f0 bbit0 state_conn_comp ,master_disconnect_quiet 
+31ee 68088046 fetcht 1 ,mem_conn_handle 
+31ef 202048c4 branch hci_send_disconn_complete 
+
+master_disconnect_quiet:
+31f0 18000408 force hci_error_connection_timeout ,temp 
+31f1 20204826 branch hci_send_connection_error 
+
+master_name_disconnect:
+31f2 18000e00 force hci_success ,queue 
+31f3 6800804c fetch 1 ,mem_state_map 
+31f4 c281c898 bbit1 smap_name_res ,hci_send_name 
+
+master_name_error:
+31f5 18000e04 force hci_error_page_timeout ,queue 
+31f6 d8a00103 arg mem_tmp_buffer ,contw 
+31f7 df200008 arg 8 ,loopcnt 
+31f8 20407e3b call memset0 
+31f9 20204898 branch hci_send_name 
+
+disconnect_stop_sco:
+31fa 793f8025 set0 mark_ext_patch ,mark 
+31fb 4491c004 bpatch patch04_3 ,mem_patch04 
+31fc 68008030 fetch 1 ,mem_state 
+31fd c4010000 rtnbit0 state_insco 
+31fe 68088046 fetcht 1 ,mem_conn_handle 
+31ff 680080ac fetch 1 ,mem_sco_asso_handle 
+3200 98467c00 isub temp ,null 
+3201 24628000 nrtn zero 
+3202 20403869 call stop_esco 
+3203 20203293 branch restore_esco_check_no_mark 
+
+check_disconnect_timeout:
+3204 793f8025 set0 mark_ext_patch ,mark 
+3205 44924004 bpatch patch04_4 ,mem_patch04 
+3206 78347c00 enable user 
+3207 6800804b fetch 1 ,mem_op 
+3208 c4018000 rtnbit0 op_disconn 
+3209 2040320d call conn_timer_expired 
+320a 247a0000 nrtn blank 
+
+disable_usr:
+320b 78547c00 disable user 
+320c 20600000 rtn 
+
+conn_timer_expired:
+320d 68008072 fetch 1 ,mem_conn_timer 
+320e 1fe0ffff increase -1 ,pdata 
+320f 60008072 store 1 ,mem_conn_timer 
+3210 20600000 rtn 
+
+linkkey_ready:
+3211 793f8025 set0 mark_ext_patch ,mark 
+3212 4492c004 bpatch patch04_5 ,mem_patch04 
+3213 68008030 fetch 1 ,mem_state 
+3214 c283b21f bbit1 state_linkkey ,linkkey_set 
+3215 6800c132 fetch 1 ,mem_device_option 
+3216 c000b21d beq dvc_op_hci ,linkkey_send_hci 
+3217 680087e1 fetch 1 ,mem_pairing_auth 
+3218 203a321f branch linkkey_set ,blank 
+3219 7007e100 jam defalt_pairing_auth ,mem_pairing_auth 
+321a 700b7d18 jam bt_evt_linkkey_generate ,mem_fifo_temp 
+321b 20407c27 call ui_ipc_send_event 
+321c 2020321f branch linkkey_set 
+
+linkkey_send_hci:
+321d 20406216 call check_localsm 
+321e 2440c852 ncall hci_send_linkkey_notification ,true 
+
+linkkey_set:
+321f 793f8025 set0 mark_ext_patch ,mark 
+3220 44934004 bpatch patch04_6 ,mem_patch04 
+3221 204032f0 call context_traverse_linkkey 
+3222 68008030 fetch 1 ,mem_state 
+3223 79207e07 set1 state_linkkey ,pdata 
+3224 60008030 store 1 ,mem_state 
+3225 70425e01 jam 1 ,mem_link_key_exists 
+3226 68008055 fetch 1 ,mem_conn_sm 
+3227 c08b3228 bne conn_sm_pairing ,linkkey_set_continue 
+
+linkkey_set_continue:
+3228 20600000 rtn 
+
+generate_linkkey_continue:
+3229 7007e101 jam pairing_auth ,mem_pairing_auth 
+
+clear_linkstate:
+322a 68008030 fetch 1 ,mem_state 
+322b 793ffe07 set0 state_linkkey ,pdata 
+322c 60008030 store 1 ,mem_state 
+322d 20600000 rtn 
+
+role_switch_check:
+322e 793f8025 set0 mark_ext_patch ,mark 
+322f 4493c004 bpatch patch04_7 ,mem_patch04 
+3230 78547c00 disable user 
+3231 68008030 fetch 1 ,mem_state 
+3232 c4008000 rtnbit0 state_insniff 
+3233 68010032 fetch 2 ,mem_tsniff 
+3234 247a0000 nrtn blank 
+3235 68020034 fetch 4 ,mem_sniff_anchor 
+3236 20383239 branch role_switch_clkn ,clknt 
+3237 9d067e00 isub clke_bt ,pdata 
+3238 2020323a branch role_switch_clke 
+
+role_switch_clkn:
+3239 9c467e00 isub clkn_bt ,pdata 
+
+role_switch_clke:
+323a 1fe67c04 sub pdata ,4 ,null 
+323b 24610000 nrtn positive 
+323c 68008030 fetch 1 ,mem_state 
+323d 793ffe01 set0 state_insniff ,pdata 
+323e 60008030 store 1 ,mem_state 
+323f 78347c00 enable user 
+3240 20600000 rtn 
+
+role_switch_prepare:
+3241 1fe20400 copy pdata ,temp 
+3242 793f8025 set0 mark_ext_patch ,mark 
+3243 44944005 bpatch patch05_0 ,mem_patch05 
+3244 60020034 store 4 ,mem_sniff_anchor 
+
+role_switch_prepare0:
+3245 70474801 jam switch_flag_accept ,mem_switch_flag 
+3246 68008030 fetch 1 ,mem_state 
+3247 79207e01 set1 state_insniff ,pdata 
+3248 60008030 store 1 ,mem_state 
+3249 18007e00 force 0 ,pdata 
+324a 60010032 store 2 ,mem_tsniff 
+324b 70008a0a jam 10 ,mem_current_sniff_attempt 
+324c 70007301 jam 1 ,mem_sniff_attempt 
+324d 20600000 rtn 
+
+role_switch_master:
+324e 793f8025 set0 mark_ext_patch ,mark 
+324f 4494c005 bpatch patch05_1 ,mem_patch05 
+3250 2040322e call role_switch_check 
+3251 24740000 nrtn user 
+3252 78547c00 disable user 
+3253 70001120 jam param_newconnto ,mem_newconnto_counter 
+3254 793f800b set0 mark_fhs_already_good ,mark 
+
+roles_waitfhs_loop:
+3255 20403bac call rf_setup_time_master_slot 
+3256 2040337f call master_recv_packet 
+3257 c505b263 bmark1 mark_fhs_already_good ,roles_replyto_fhs 
+3258 2040350e call new_conn_timeout 
+3259 243a3255 nbranch roles_waitfhs_loop ,blank 
+
+role_switch_fail_master:
+325a 793f8025 set0 mark_ext_patch ,mark 
+325b 44954005 bpatch patch05_2 ,mem_patch05 
+325c 78547c00 disable user 
+325d 1c427e00 deposit clkn_bt 
+325e 6002416a store 4 ,mem_next_btclk 
+325f 78387c00 enable clknt 
+3260 7834fc00 enable master 
+3261 700b7d2a jam bt_evt_switch_fail_master ,mem_fifo_temp 
+3262 20207c27 branch ui_ipc_send_event 
+
+roles_replyto_fhs:
+3263 793f8025 set0 mark_ext_patch ,mark 
+3264 4495c005 bpatch patch05_3 ,mem_patch05 
+3265 20403baa call rf_setup_time_slave_slot 
+3266 20403374 call master_send_packet 
+3267 78587c00 disable clknt 
+3268 7854fc00 disable master 
+3269 20403982 call apply_switch_clke 
+326a 204034ed call prepare_newconn 
+
+roles_newconns_loop:
+326b 793f8025 set0 mark_ext_patch ,mark 
+326c 44964005 bpatch patch05_4 ,mem_patch05 
+326d 20403539 call slave_newconn_once 
+326e 2036b272 branch roles_newconns_responded ,match 
+326f 2040350e call new_conn_timeout 
+3270 243a326b nbranch roles_newconns_loop ,blank 
+3271 2020325a branch role_switch_fail_master 
+
+roles_newconns_responded:
+3272 18000401 force 1 ,temp 
+3273 2040487f call hci_send_role_change 
+3274 68008031 fetch 1 ,mem_mode 
+3275 793ffe01 set0 mode_master ,pdata 
+3276 60008031 store 1 ,mem_mode 
+3277 20403bec call supervision_flush 
+3278 204039ac call calc_clke_offset 
+3279 78347c00 enable user 
+327a 700b7d2b jam bt_evt_switch_success_master ,mem_fifo_temp 
+327b 20207c27 branch ui_ipc_send_event 
+
+load_esco:
+327c 793f8025 set0 mark_ext_patch ,mark 
+327d 4496c005 bpatch patch05_5 ,mem_patch05 
+327e c6838000 rtnmark0 mark_esco 
+327f 68008030 fetch 1 ,mem_state 
+3280 c4010000 rtnbit0 state_insco 
+
+load_esco_do:
+3281 20403c23 call init_esco_ibuff 
+3282 680080b3 fetch 1 ,mem_esco_arq 
+3283 68088047 fetcht 1 ,mem_arq 
+3284 600880b4 storet 1 ,mem_esco_saved_arq 
+3285 60008047 store 1 ,mem_arq 
+3286 18827e00 deposit am_addr 
+3287 600080b2 store 1 ,mem_saved_amaddr 
+3288 6800c1f9 fetch 1 ,mem_esco_addr 
+3289 98000800 iforce am_addr 
+328a 793f8008 set0 mark_esco_rxok ,mark 
+328b 6800c165 fetch 1 ,mem_last_type 
+328c 6000c167 store 1 ,mem_last_type_saved 
+328d 6800c166 fetch 1 ,mem_last_type_esco 
+328e 6000c165 store 1 ,mem_last_type 
+328f 20600000 rtn 
+
+restore_esco:
+3290 793f8025 set0 mark_ext_patch ,mark 
+3291 44974005 bpatch patch05_6 ,mem_patch05 
+3292 c6838000 rtnmark0 mark_esco 
+
+restore_esco_check_no_mark:
+3293 20403847 call check_esco_amaddr 
+3294 24608000 nrtn true 
+
+restore_esco_do:
+3295 20403799 call clear_got_tx 
+3296 680080b4 fetch 1 ,mem_esco_saved_arq 
+3297 68088047 fetcht 1 ,mem_arq 
+3298 60008047 store 1 ,mem_arq 
+3299 600880b3 storet 1 ,mem_esco_arq 
+329a 680080b2 fetch 1 ,mem_saved_amaddr 
+329b 98000800 iforce am_addr 
+329c 6800c165 fetch 1 ,mem_last_type 
+329d 6000c166 store 1 ,mem_last_type_esco 
+329e 6800c167 fetch 1 ,mem_last_type_saved 
+329f 6000c165 store 1 ,mem_last_type 
+32a0 5800ffff setarg 0xffff 
+32a1 60014168 store 2 ,mem_retransmission_cnt 
+32a2 20600000 rtn 
+
+context_load:
+32a3 793f8025 set0 mark_ext_patch ,mark 
+32a4 4497c005 bpatch patch05_7 ,mem_patch05 
+32a5 79200009 set1 mark_context ,mark 
+32a6 1a227e00 deposit rega 
+32a7 6001001e store 2 ,mem_context_ptr 
+32a8 18007250 force context_size ,loopcnt 
+32a9 d8a003c0 arg mem_le_state ,contw 
+32aa 1a208c01 add rega ,coffset_mode ,contr 
+32ab e8c08000 ifetch 1 ,contr 
+32ac 1a220c00 copy rega ,contr 
+32ad c2807e45 bbit1 mode_le ,memcpy 
+32ae d8a00030 arg mem_state ,contw 
+32af 20407e45 call memcpy 
+32b0 78577c00 disable attempt 
+32b1 68008077 fetch 1 ,mem_amaddr 
+32b2 98000800 iforce am_addr 
+32b3 70008a01 jam 1 ,mem_current_sniff_attempt 
+32b4 2034b2b6 branch context_load_master ,master 
+32b5 70008a01 jam 1 ,mem_current_sniff_attempt 
+
+context_load_master:
+32b6 68008030 fetch 1 ,mem_state 
+32b7 c4008000 rtnbit0 state_insniff 
+32b8 68008073 fetch 1 ,mem_sniff_attempt 
+32b9 6000808a store 1 ,mem_current_sniff_attempt 
+32ba 68008074 fetch 1 ,mem_sniff_timeout 
+32bb 6000808b store 1 ,mem_current_sniff_timeout 
+32bc 20600000 rtn 
+
+context_save:
+32bd 793f8025 set0 mark_ext_patch ,mark 
+32be 44984006 bpatch patch06_0 ,mem_patch06 
+32bf 6801001e fetch 2 ,mem_context_ptr 
+32c0 98000a00 iforce contw 
+32c1 18007250 force context_size ,loopcnt 
+32c2 d8c003c0 arg mem_le_state ,contr 
+32c3 203b7e45 branch memcpy ,le 
+32c4 d8c00030 arg mem_state ,contr 
+32c5 20207e45 branch memcpy 
+
+context_get_next:
+32c6 68088015 fetcht 1 ,mem_current_context 
+32c7 df200003 arg context_num ,loopcnt 
+
+context_get_next_loop:
+32c8 18408401 increase 1 ,temp 
+32c9 2841fe03 compare context_num ,temp ,0xff 
+32ca 2420b2cc nbranch context_get_next_cont ,true 
+32cb d8400000 arg 0 ,temp 
+
+context_get_next_cont:
+32cc 60088015 storet 1 ,mem_current_context 
+32cd 184ffe50 mul32 temp ,context_size ,pdata 
+32ce da204040 arg mem_context ,rega 
+32cf 9a20a200 iadd rega ,rega 
+32d0 ea208000 ifetch 1 ,rega 
+32d1 c280b2d4 bbit1 state_insniff ,context_get_next_sniff 
+32d2 c3800000 rtnbit1 state_inconn 
+32d3 c3818000 rtnbit1 state_inpage 
+
+context_get_next_sniff:
+32d4 c20032c8 loop context_get_next_loop 
+32d5 20600000 rtn 
+
+context_new:
+32d6 793f8025 set0 mark_ext_patch ,mark 
+32d7 4498c006 bpatch patch06_1 ,mem_patch06 
+32d8 da60330b arg context_search_empty ,regc 
+32d9 20403301 call context_search 
+32da 24628000 nrtn zero 
+32db 1a227e00 deposit rega 
+32dc 6001001e store 2 ,mem_context_ptr 
+32dd 18007c00 force 0 ,null 
+32de 20600000 rtn 
+
+context_check_all_wack:
+32df 20403847 call check_esco_amaddr 
+32e0 2020b2e7 branch context_check_esco_wack ,true 
+32e1 6801001e fetch 2 ,mem_context_ptr 
+32e2 1fe08a17 add pdata ,coffset_arq ,contw 
+32e3 68008047 fetch 1 ,mem_arq 
+32e4 e0a08000 istore 1 ,contw 
+32e5 da603334 arg context_check_a_wack ,regc 
+32e6 20203301 branch context_search 
+
+context_check_esco_wack:
+32e7 68008047 fetch 1 ,mem_arq 
+32e8 2feffe03 isolate1 wack ,pdata 
+32e9 2020b2ec branch context_esco_wack ,true 
+32ea 18007c01 force 1 ,null 
+32eb 20600000 rtn 
+
+context_esco_wack:
+32ec 18007c00 force 0 ,null 
+32ed 20600000 rtn 
+
+context_check_idle:
+32ee da603331 arg context_check_inconn ,regc 
+32ef 20203301 branch context_search 
+
+context_traverse_linkkey:
+32f0 6809001e fetcht 2 ,mem_context_ptr 
+32f1 da603366 arg context_traverse_clearkey ,regc 
+32f2 20203301 branch context_search 
+
+context_traverse_max_slot:
+32f3 6809001e fetcht 2 ,mem_context_ptr 
+32f4 da603359 arg context_traverse_mslot ,regc 
+32f5 20203301 branch context_search 
+
+context_search_conn_handle:
+32f6 6808c273 fetcht 1 ,mem_hci_conn_handle 
+
+context_search_conn_handle2:
+32f7 da603316 arg context_search_handle ,regc 
+32f8 20203301 branch context_search 
+
+context_search_plap:
+32f9 793f8025 set0 mark_ext_patch ,mark 
+32fa 44994006 bpatch patch06_2 ,mem_patch06 
+32fb 680b4274 fetcht 6 ,mem_hci_plap 
+
+context_search_plap2:
+32fc da60330f arg context_search_lap ,regc 
+32fd 20203301 branch context_search 
+
+context_search_insniff:
+32fe da60331c arg context_search_sniff ,regc 
+32ff 20203301 branch context_search 
+
+context_search_sniff_window:
+3300 da603350 arg context_search_window ,regc 
+
+context_search:
+3301 793f8025 set0 mark_ext_patch ,mark 
+3302 4499c006 bpatch patch06_3 ,mem_patch06 
+3303 da204040 arg mem_context ,rega 
+3304 18007203 force context_num ,loopcnt 
+
+context_search_loop:
+3305 ea208000 ifetch 1 ,rega 
+3306 1a627a00 copy regc ,pc 
+
+context_search_next:
+3307 1a20a250 increase context_size ,rega 
+3308 c2003305 loop context_search_loop 
+3309 18007c01 force 1 ,null 
+330a 20600000 rtn 
+
+context_search_empty:
+330b c2803307 bbit1 state_inconn ,context_search_next 
+330c c281b307 bbit1 state_inpage ,context_search_next 
+330d 18007c00 force 0 ,null 
+330e 20600000 rtn 
+
+context_search_lap:
+330f c281b311 bbit1 state_inpage ,context_search_lap_cont 
+3310 c3003307 bbit0 state_inconn ,context_search_next 
+
+context_search_lap_cont:
+3311 1a208c10 add rega ,coffset_plap ,contr 
+3312 e8c30000 ifetch 6 ,contr 
+3313 98467c00 isub temp ,null 
+3314 20628000 rtn zero 
+3315 20203307 branch context_search_next 
+
+context_search_handle:
+3316 c3003307 bbit0 state_inconn ,context_search_next 
+3317 1a208c16 add rega ,coffset_conn_handle ,contr 
+3318 e8c08000 ifetch 1 ,contr 
+3319 98467c00 isub temp ,null 
+331a 20628000 rtn zero 
+331b 20203307 branch context_search_next 
+
+context_search_sniff:
+331c c300b307 bbit0 state_insniff ,context_search_next 
+
+context_search_sniff_loop:
+331d 2040333d call context_get_anchor 
+331e c28db322 bbit1 27 ,context_search_sniff_cont 
+331f 284c001b isolate0 27 ,temp 
+3320 2020b322 branch context_search_sniff_cont ,true 
+3321 79207e1c set1 28 ,pdata 
+
+context_search_sniff_cont:
+3322 98467e00 isub temp ,pdata 
+3323 1fe0fe01 increase 1 ,pdata 
+3324 2021332b branch context_search_sniff_miss ,positive 
+3325 1fe0fe05 increase 5 ,pdata 
+3326 24213307 nbranch context_search_next ,positive 
+
+context_search_meet:
+3327 18424200 copy temp ,bt_clk 
+3328 20403349 call context_next_anchor 
+3329 18007c00 force 0 ,null 
+332a 20600000 rtn 
+
+context_search_sniff_miss:
+332b 98002400 iforce regb 
+332c 1a208c02 add rega ,coffset_tsniff ,contr 
+332d e8c10000 ifetch 2 ,contr 
+332e 203a3327 branch context_search_meet ,blank 
+332f 20403349 call context_next_anchor 
+3330 2020331d branch context_search_sniff_loop 
+
+context_check_inconn:
+3331 c3003307 bbit0 state_inconn ,context_search_next 
+3332 18007c00 force 0 ,null 
+3333 20600000 rtn 
+
+context_check_a_wack:
+3334 c3003307 bbit0 state_inconn ,context_search_next 
+3335 1a208c01 add rega ,coffset_mode ,contr 
+3336 e8c08000 ifetch 1 ,contr 
+3337 c2803307 bbit1 mode_le ,context_search_next 
+3338 1a208c17 add rega ,coffset_arq ,contr 
+3339 e8c08000 ifetch 1 ,contr 
+333a c301b307 bbit0 wack ,context_search_next 
+333b 18007c00 force 0 ,null 
+333c 20600000 rtn 
+
+context_get_anchor:
+333d 1a208c01 add rega ,coffset_mode ,contr 
+333e e8c88000 ifetcht 1 ,contr 
+333f 1c427e00 deposit clkn_bt 
+3340 284ffe01 isolate1 mode_master ,temp 
+3341 1a208c04 add rega ,coffset_sniff_anchor ,contr 
+3342 e8ca0000 ifetcht 4 ,contr 
+3343 20608000 rtn true 
+3344 1a208c08 add rega ,coffset_clk_offset ,contr 
+3345 e8c30000 ifetch 6 ,contr 
+3346 204039c0 call calc_clke2 
+3347 1d027e00 deposit clke_bt 
+3348 20600000 rtn 
+
+context_next_anchor:
+3349 1a208c02 add rega ,coffset_tsniff ,contr 
+334a 1a208a04 add rega ,coffset_sniff_anchor ,contw 
+334b e8c10000 ifetch 2 ,contr 
+334c 98409600 iadd temp ,timeup 
+334d 19627e00 deposit timeup 
+334e e0a20000 istore 4 ,contw 
+334f 20205434 branch le_context_nexthop 
+
+context_search_window:
+3350 c300b307 bbit0 state_insniff ,context_search_next 
+3351 2040333d call context_get_anchor 
+3352 9b60fe00 iadd stop_watch ,pdata 
+3353 9b60fe00 iadd stop_watch ,pdata 
+3354 98e0fe00 iadd queue ,pdata 
+3355 98467c00 isub temp ,null 
+3356 24213307 nbranch context_search_next ,positive 
+3357 18007c00 force 0 ,null 
+3358 20600000 rtn 
+
+context_traverse_mslot:
+3359 c3003307 bbit0 state_inconn ,context_search_next 
+335a 18427e00 deposit temp 
+335b 9a267c00 isub rega ,null 
+335c 203f3307 branch context_search_next ,null 
+335d 1a208c01 add rega ,coffset_mode ,contr 
+335e e8c08000 ifetch 1 ,contr 
+335f c2803307 bbit1 mode_le ,context_search_next 
+3360 1a208a18 add rega ,coffset_lmp_to_send ,contw 
+3361 e8a08000 ifetch 1 ,contw 
+3362 243a3307 nbranch context_search_next ,blank 
+3363 18007e2d force lmp_max_slot ,pdata 
+3364 e0a08000 istore 1 ,contw 
+3365 20203307 branch context_search_next 
+
+context_traverse_clearkey:
+3366 c3003307 bbit0 state_inconn ,context_search_next 
+3367 18427e00 deposit temp 
+3368 9a267c00 isub rega ,null 
+3369 203f3307 branch context_search_next ,null 
+336a 1a208c01 add rega ,coffset_mode ,contr 
+336b e8c08000 ifetch 1 ,contr 
+336c c2803307 bbit1 mode_le ,context_search_next 
+336d ea208000 ifetch 1 ,rega 
+336e 793ffe07 set0 state_linkkey ,pdata 
+336f e2208000 istore 1 ,rega 
+3370 20203307 branch context_search_next 
+
+master_conn_send_packet:
+3371 793f8025 set0 mark_ext_patch ,mark 
+3372 449a4006 bpatch patch06_4 ,mem_patch06 
+3373 20403bac call rf_setup_time_master_slot 
+
+master_send_packet:
+3374 1c40c201 add clkn_bt ,1 ,bt_clk 
+3375 20403a54 call fetch_self_bt_adr 
+3376 18004803 force 0x03 ,freq_mode 
+3377 20403a42 call tx_radio_freq 
+3378 20403bae call start_transmitter 
+3379 20403bb4 call start_tx_native 
+337a 20403bc5 call send_access_word 
+337b 202038bf branch transmit_packet 
+
+master_conn_recv_packet:
+337c 793f8025 set0 mark_ext_patch ,mark 
+337d 449ac006 bpatch patch06_5 ,mem_patch06 
+337e 20403baa call rf_setup_time_slave_slot 
+
+master_recv_packet:
+337f 1c40c201 add clkn_bt ,1 ,bt_clk 
+3380 20403a54 call fetch_self_bt_adr 
+3381 18004803 force 0x03 ,freq_mode 
+3382 20403a3b call rx_radio_freq 
+3383 204034e1 call init_rx_packet_flags 
+3384 20403b41 call prep_crypt 
+3385 20403bba call start_rx_native 
+3386 20403b3a call start_receiver 
+
+master_rx_conn_finish_packet:
+3387 20403b63 call wait_access_clkn_rt 
+3388 246c0000 nrtn sync 
+3389 20403af3 call save_rssi 
+338a 202035df branch receive_packet 
+
+master_newconn_once:
+338b 793f8025 set0 mark_ext_patch ,mark 
+338c 449b4006 bpatch patch06_6 ,mem_patch06 
+338d 6800818b fetch 1 ,mem_fhs_am_addr 
+338e 98000800 iforce am_addr 
+338f 18000201 force type_poll ,type 
+3390 20403371 call master_conn_send_packet 
+3391 2020337c branch master_conn_recv_packet 
+
+inquiry_scan_dispatch:
+3392 6800c133 fetch 1 ,mem_scan_mode 
+3393 c4000000 rtnbit0 inq_scan_mode 
+3394 18000e05 force iscan_interval_timer ,queue 
+3395 20407e53 call timer_check 
+3396 247a0000 nrtn blank 
+3397 6809414d fetcht 2 ,mem_iscan_window 
+3398 18000e04 force 4 ,queue 
+3399 2040383d call sniff_check_window 
+339a 20740000 rtn user 
+339b 204033a2 call inquiry_scan_start 
+339c 18000e05 force iscan_interval_timer ,queue 
+339d 6801414f fetch 2 ,mem_iscan_interval 
+339e 242c7e4c nbranch timer_init ,sync 
+339f 180a7e00 random pdata 
+33a0 9ea17e00 iand mask3ff ,pdata 
+33a1 20207e4c branch timer_init 
+
+inquiry_scan_start:
+33a2 793f8025 set0 mark_ext_patch ,mark 
+33a3 449bc006 bpatch patch06_7 ,mem_patch06 
+33a4 70018b00 jam 0 ,mem_fhs_am_addr 
+33a5 78587c00 disable clknt 
+33a6 78577c00 disable attempt 
+33a7 20403a12 call afh_clear 
+33a8 1c4143fc and clkn_bt ,0x1fc ,bt_clk 
+33a9 18004801 force 0x01 ,freq_mode 
+33aa 20403a49 call fetch_giac 
+33ab 20403a3b call rx_radio_freq 
+33ac 7940001d setflip mark_inquiry_state ,mark 
+33ad 68008006 fetch 1 ,mem_inquiryscan_waitcnt 
+33ae 1fe0fe01 increase 1 ,pdata 
+33af 60008006 store 1 ,mem_inquiryscan_waitcnt 
+33b0 20403a66 call fetch_diac 
+33b1 20403b3a call start_receiver 
+33b2 20403b6b call wait_access_forever 
+33b3 246c0000 nrtn sync 
+33b4 793f8025 set0 mark_ext_patch ,mark 
+33b5 449c4007 bpatch patch07_0 ,mem_patch07 
+33b6 18003600 force 0 ,stop_watch 
+33b7 20403a6d call shutdown_radio 
+33b8 68008007 fetch 1 ,mem_inquiryscan_rcvcnt 
+33b9 1fe0fe01 increase 1 ,pdata 
+33ba 60008007 store 1 ,mem_inquiryscan_rcvcnt 
+33bb 20403a49 call fetch_giac 
+33bc 20403baa call rf_setup_time_slave_slot 
+33bd 1c21c202 or_into 0x002 ,bt_clk 
+33be 18004801 force 0x01 ,freq_mode 
+33bf 20403a42 call tx_radio_freq 
+33c0 20403a66 call fetch_diac 
+33c1 20403bae call start_transmitter 
+33c2 20403bbf call start_tx_external 
+33c3 1c427e00 deposit clkn_bt 
+33c4 6002016b store 4 ,mem_clkn_bt 
+33c5 20403bc5 call send_access_word 
+33c6 18000202 force type_fhs ,type 
+33c7 18000800 force 0 ,am_addr 
+33c8 20403bcd call scan_mode_whiten 
+33c9 204038c1 call transmit_packet_whitened 
+33ca 204033ce call send_eir 
+33cb 1c2143fd and_into 0x1fd ,bt_clk 
+33cc 1cc0cc01 increase 1 ,n_tx_slot 
+33cd 20600000 rtn 
+
+send_eir:
+33ce 793f8025 set0 mark_ext_patch ,mark 
+33cf 449cc007 bpatch patch07_1 ,mem_patch07 
+33d0 6800c172 fetch 1 ,mem_eir_enable 
+33d1 207a0000 rtn blank 
+33d2 d8a001bc arg mem_eir ,contw 
+33d3 6800c702 fetch 1 ,mem_local_name_length 
+33d4 1fe27200 copy pdata ,loopcnt 
+33d5 1fe0fe01 increase 1 ,pdata 
+33d6 e0a08000 istore 1 ,contw 
+33d7 18a20400 copy contw ,temp 
+33d8 1fe0fe01 increase 1 ,pdata 
+33d9 60010091 store 2 ,mem_tx_len 
+33da 18420a00 copy temp ,contw 
+33db 58000009 setarg 0x09 
+33dc e0a08000 istore 1 ,contw 
+33dd d8c04703 arg mem_local_name ,contr 
+33de 20407e45 call memcpy 
+33df da604771 arg mem_all_uuid_128bits ,regc 
+33e0 df200004 arg 4 ,loopcnt 
+33e1 204033f1 call get_all_uuid 
+33e2 da60475b arg mem_all_uuid_16bits ,regc 
+33e3 df200001 arg 1 ,loopcnt 
+33e4 204033f1 call get_all_uuid 
+33e5 1800020a force type_dm3 ,type 
+33e6 70009002 jam 2 ,mem_tx_lch 
+33e7 580001bc setarg mem_eir 
+33e8 60010179 store 2 ,mem_txptr 
+33e9 20403baa call rf_setup_time_slave_slot 
+33ea 20403a42 call tx_radio_freq 
+33eb 20403bae call start_transmitter 
+33ec 20403bbf call start_tx_external 
+33ed 20403bc5 call send_access_word 
+33ee 20403bcd call scan_mode_whiten 
+33ef 204038c1 call transmit_packet_whitened 
+33f0 20600000 rtn 
+
+get_all_uuid:
+33f1 18a20400 copy contw ,temp 
+33f2 1a620c00 copy regc ,contr 
+33f3 e8c08000 ifetch 1 ,contr 
+33f4 207a0000 rtn blank 
+
+lshift_loop:
+33f5 1fe3fe00 lshift pdata ,pdata 
+33f6 c20033f5 loop lshift_loop 
+33f7 1fe22200 copy pdata ,rega 
+33f8 1fe0fe02 increase 2 ,pdata 
+33f9 1fe20e00 copy pdata ,queue 
+33fa 68010091 fetch 2 ,mem_tx_len 
+33fb 98e0fe00 iadd queue ,pdata 
+33fc 60010091 store 2 ,mem_tx_len 
+33fd 18420a00 copy temp ,contw 
+33fe 1a227e00 copy rega ,pdata 
+33ff 1fe0fe01 increase 1 ,pdata 
+3400 e0a08000 istore 1 ,contw 
+3401 1a620c00 copy regc ,contr 
+3402 e8c08000 ifetch 1 ,contr 
+3403 e8c08000 ifetch 1 ,contr 
+3404 e0a08000 istore 1 ,contw 
+3405 1a227200 copy rega ,loopcnt 
+3406 20207e45 branch memcpy 
+
+page_scan_dispatch:
+3407 6800c133 fetch 1 ,mem_scan_mode 
+3408 c4008000 rtnbit0 page_scan_mode 
+3409 18000e06 force pscan_interval_timer ,queue 
+340a 20407e53 call timer_check 
+340b 247a0000 nrtn blank 
+340c 68094151 fetcht 2 ,mem_pscan_window 
+340d 18000e28 force 40 ,queue 
+340e 2040383d call sniff_check_window 
+340f 20740000 rtn user 
+3410 18000800 force 0 ,am_addr 
+3411 70001008 jam param_pagerespto ,mem_fhs_wait_counter 
+3412 793f800b set0 mark_fhs_already_good ,mark 
+3413 20403417 call page_scan_start 
+3414 18000e06 force pscan_interval_timer ,queue 
+3415 68014153 fetch 2 ,mem_pscan_interval 
+3416 20207e4c branch timer_init 
+
+page_scan_start:
+3417 793f8025 set0 mark_ext_patch ,mark 
+3418 449d4007 bpatch patch07_2 ,mem_patch07 
+3419 78587c00 disable clknt 
+341a 20403a12 call afh_clear 
+341b 68008008 fetch 1 ,mem_pagescan_waitcnt 
+341c 1fe0fe01 increase 1 ,pdata 
+341d 60008008 store 1 ,mem_pagescan_waitcnt 
+341e 18004c00 force 0 ,n_tx_slot 
+341f 20403a54 call fetch_self_bt_adr 
+3420 1c40c201 add clkn_bt ,1 ,bt_clk 
+3421 18004802 force 0x02 ,freq_mode 
+3422 793f8025 set0 mark_ext_patch ,mark 
+3423 449dc007 bpatch patch07_3 ,mem_patch07 
+3424 20403a3b call rx_radio_freq 
+3425 20403b3a call start_receiver 
+3426 20403b6b call wait_access_forever 
+3427 246c0000 nrtn sync 
+3428 20403a6d call shutdown_radio 
+3429 68008009 fetch 1 ,mem_pagescan_rcvcnt 
+342a 1fe0fe01 increase 1 ,pdata 
+342b 60008009 store 1 ,mem_pagescan_rcvcnt 
+342c 18003600 force 0 ,stop_watch 
+342d 20403baa call rf_setup_time_slave_slot 
+342e 1c21c202 or_into 0x002 ,bt_clk 
+342f 18004801 force 0x01 ,freq_mode 
+3430 20403a42 call tx_radio_freq 
+3431 20403bae call start_transmitter 
+3432 20403bbf call start_tx_external 
+3433 20403bc5 call send_access_word 
+3434 2040375c call end_of_packet 
+3435 18000800 force 0 ,am_addr 
+3436 d9600600 arg param_rf_setup ,timeup 
+3437 35330200 until clke_rt ,meet 
+3438 1d01d003 or_into 0x03 ,clke_bt 
+3439 1c2143fd and_into 0x1fd ,bt_clk 
+
+page_scan_wait_fhs_restart:
+343a 793f8025 set0 mark_ext_patch ,mark 
+343b 449e4007 bpatch patch07_4 ,mem_patch07 
+343c 1cc0cc01 increase 1 ,n_tx_slot 
+343d 20403a3b call rx_radio_freq 
+343e 20403b3a call start_receiver 
+343f 20403b5d call wait_access_mhalfbnd 
+3440 242c3444 nbranch page_scan_wait_fhs_again ,sync 
+3441 20403bcd call scan_mode_whiten 
+3442 204035e1 call receive_packet_whitened 
+3443 c505b44c bmark1 mark_fhs_already_good ,page_scan_reply_to_fhs 
+
+page_scan_wait_fhs_again:
+3444 793f8025 set0 mark_ext_patch ,mark 
+3445 449ec007 bpatch patch07_5 ,mem_patch07 
+3446 68008010 fetch 1 ,mem_fhs_wait_counter 
+3447 207a0000 rtn blank 
+3448 1fe0ffff increase -1 ,pdata 
+3449 60008010 store 1 ,mem_fhs_wait_counter 
+344a 20403bac call rf_setup_time_master_slot 
+344b 2020343a branch page_scan_wait_fhs_restart 
+
+page_scan_reply_to_fhs:
+344c 793f8025 set0 mark_ext_patch ,mark 
+344d 449f4007 bpatch patch07_6 ,mem_patch07 
+344e 793fd001 set0 1 ,clke_bt 
+344f 79205000 set1 0 ,clke_bt 
+3450 6800800a fetch 1 ,mem_pagescan_rcvfhscnt 
+3451 1fe0fe01 increase 1 ,pdata 
+3452 6000800a store 1 ,mem_pagescan_rcvfhscnt 
+3453 20403baa call rf_setup_time_slave_slot 
+3454 1c21c202 or_into 0x02 ,bt_clk 
+3455 20403a42 call tx_radio_freq 
+3456 20403bae call start_transmitter 
+3457 20403bbf call start_tx_external 
+3458 20403bc5 call send_access_word 
+3459 2040375c call end_of_packet 
+
+slave_apply_clke_bt:
+345a 2d000603 compare 0x03 ,clke_bt ,0x03 
+345b 2020b45e branch slave_apply_clke_bt_now ,true 
+345c 37cb8200 until null ,mhalfbnd 
+345d 2020345a branch slave_apply_clke_bt 
+
+slave_apply_clke_bt_now:
+345e 6802016f fetch 4 ,mem_clke_bt 
+345f 1fe1fe03 or_into 0x03 ,pdata 
+3460 1fe25000 icopy clke_bt 
+
+start_slave_connection:
+3461 793f8025 set0 mark_ext_patch ,mark 
+3462 449fc007 bpatch patch07_7 ,mem_patch07 
+3463 68030182 fetch 6 ,extm_lap 
+3464 60030040 store 6 ,mem_plap 
+3465 204034ed call prepare_newconn 
+
+slave_newconn_loop:
+3466 20403539 call slave_newconn_once 
+3467 2036b46b branch sconn_successful ,match 
+3468 2040350e call new_conn_timeout 
+3469 243a3466 nbranch slave_newconn_loop ,blank 
+346a 20600000 rtn 
+
+sconn_successful:
+346b 793f8025 set0 mark_ext_patch ,mark 
+346c 44a04008 bpatch patch08_0 ,mem_patch08 
+346d 204034f9 call newconn_init 
+346e 204032d6 call context_new 
+346f 24628000 nrtn zero 
+3470 70003100 jam 0 ,mem_mode 
+3471 204039ac call calc_clke_offset 
+3472 202032bd branch context_save 
+
+slave_dispatch:
+3473 793f8025 set0 mark_ext_patch ,mark 
+3474 44a0c008 bpatch patch08_1 ,mem_patch08 
+3475 204039bc call calc_clke 
+3476 204034a5 call role_switch_slave 
+3477 20740000 rtn user 
+3478 2040327c call load_esco 
+3479 20406a54 call get_sco_data 
+
+slave_loop:
+347a 793f8025 set0 mark_ext_patch ,mark 
+347b 44a14008 bpatch patch08_2 ,mem_patch08 
+347c 20403e25 call check_bt_disabled 
+347d 20406dec call scheduler_process 
+347e 204035d6 call slave_conn_recv_packet 
+347f 20407f39 call slave_savelist 
+3480 2436b48d nbranch slave_notmatch ,match 
+3481 20403bec call supervision_flush 
+3482 20403870 call parse_l2cap 
+3483 20406e10 call scheduler_tx_l2cap_pkt 
+3484 20403547 call prepare_tx 
+3485 204038b1 call slave_conn_send_packet 
+3486 20405b78 call parse_lmp 
+3487 20404995 call process_cmd 
+3488 204048a9 call hci_send_num_complete_packets 
+3489 6800800b fetch 1 ,mem_slave_rcvcnt 
+348a 1fe0fe01 increase 1 ,pdata 
+348b 6000800b store 1 ,mem_slave_rcvcnt 
+348c 204039ac call calc_clke_offset 
+
+slave_notmatch:
+348d 793f8025 set0 mark_ext_patch ,mark 
+348e 44a1c008 bpatch patch08_3 ,mem_patch08 
+348f 20403d61 call lpm_set_mult 
+3490 20403be2 call supervision_update 
+3491 20213498 branch slave_disconnect ,positive 
+3492 20403204 call check_disconnect_timeout 
+3493 24343498 nbranch slave_disconnect ,user 
+3494 20403812 call check_attempt 
+3495 243a347a nbranch slave_loop ,blank 
+3496 20406a5c call process_sco_data 
+3497 20203290 branch restore_esco 
+
+slave_disconnect:
+3498 793f8025 set0 mark_ext_patch ,mark 
+3499 44a24008 bpatch patch08_4 ,mem_patch08 
+349a 70015300 jam 0 ,mem_tester_emulate 
+349b 70018900 jam 0 ,mem_debug_config 
+349c 20403516 call quit_connection 
+349d 793f8011 set0 mark_testmode ,mark 
+349e 20407f8a call test_enable_white 
+349f 68008030 fetch 1 ,mem_state 
+34a0 c30234a3 bbit0 state_conn_comp ,slave_connection_fail 
+34a1 68088046 fetcht 1 ,mem_conn_handle 
+34a2 202048c4 branch hci_send_disconn_complete 
+
+slave_connection_fail:
+34a3 18000406 force hci_error_key_missing ,temp 
+34a4 20204826 branch hci_send_connection_error 
+
+role_switch_slave:
+34a5 793f8025 set0 mark_ext_patch ,mark 
+34a6 44a2c008 bpatch patch08_5 ,mem_patch08 
+34a7 2040322e call role_switch_check 
+34a8 24740000 nrtn user 
+34a9 18820400 copy am_addr ,temp 
+34aa 20403bd1 call get_free_amaddr 
+34ab 6000818b store 1 ,mem_fhs_am_addr 
+34ac 18420800 copy temp ,am_addr 
+34ad 70001120 jam param_newconnto ,mem_newconnto_counter 
+
+roles_sendfhs_loop:
+34ae 793f8025 set0 mark_ext_patch ,mark 
+34af 44a34008 bpatch patch08_6 ,mem_patch08 
+34b0 20403bac call rf_setup_time_master_slot 
+34b1 18000202 force type_fhs ,type 
+34b2 204038a8 call slave_send_access 
+34b3 1c427e00 deposit clkn_bt 
+34b4 6002016b store 4 ,mem_clkn_bt 
+34b5 204038bf call transmit_packet 
+34b6 20403baa call rf_setup_time_slave_slot 
+34b7 7837fc00 enable user3 
+34b8 204035b7 call slave_receive_access 
+34b9 202c34c1 branch roles_got_fhs_reply ,sync 
+34ba 20403a6d call shutdown_radio 
+34bb 2040350e call new_conn_timeout 
+34bc 243a34ae nbranch roles_sendfhs_loop ,blank 
+34bd c6820000 rtnmark0 mark_accept_switch 
+34be 70007c34 jam lmp_slot_offset ,mem_lmo_opcode2 
+34bf 79200003 set1 mark_switch_initiated ,mark 
+34c0 20600000 rtn 
+
+roles_got_fhs_reply:
+34c1 78387c00 enable clknt 
+34c2 204034ed call prepare_newconn 
+34c3 20403a12 call afh_clear 
+
+roles_newconn_loop:
+34c4 793f8025 set0 mark_ext_patch ,mark 
+34c5 44a3c008 bpatch patch08_7 ,mem_patch08 
+34c6 2040338b call master_newconn_once 
+34c7 202c34ce branch roles_newconn_responded ,sync 
+34c8 2040350e call new_conn_timeout 
+34c9 243a34c4 nbranch roles_newconn_loop ,blank 
+34ca 78587c00 disable clknt 
+34cb 1d027e00 deposit clke_bt 
+34cc 6002416a store 4 ,mem_next_btclk 
+34cd 20600000 rtn 
+
+roles_newconn_responded:
+34ce 18000400 force 0 ,temp 
+34cf 2040487f call hci_send_role_change 
+34d0 7834fc00 enable master 
+34d1 c58234d6 bmark0 mark_accept_switch ,roles_newconn_nolmp 
+34d2 793f8004 set0 mark_accept_switch ,mark 
+34d3 70007c03 jam lmp_accepted ,mem_lmo_opcode2 
+34d4 70007d33 jam lmp_host_connection_req ,mem_lmi_opcode2 
+34d5 20406212 call tid_set_reply 
+
+roles_newconn_nolmp:
+34d6 18827e00 deposit am_addr 
+34d7 60008077 store 1 ,mem_amaddr 
+34d8 18007e00 force 0 ,pdata 
+34d9 60030038 store 6 ,mem_clk_offset 
+34da 68008031 fetch 1 ,mem_mode 
+34db 79207e01 set1 mode_master ,pdata 
+34dc 60008031 store 1 ,mem_mode 
+34dd 20403bec call supervision_flush 
+34de 7854fc00 disable master 
+
+enable_user:
+34df 78347c00 enable user 
+34e0 20600000 rtn 
+
+init_rx_packet_flags:
+34e1 793f8025 set0 mark_ext_patch ,mark 
+34e2 44a44009 bpatch patch09_0 ,mem_patch09 
+34e3 7856fc00 disable match 
+34e4 793f8005 set0 mark_loopback ,mark 
+34e5 793f800a set0 mark_am_addr_broadcast ,mark 
+34e6 793f8010 set0 mark_longpacket ,mark 
+34e7 793f800f set0 mark_old_packet ,mark 
+34e8 68008047 fetch 1 ,mem_arq 
+34e9 793ffe05 set0 arqnx ,pdata 
+34ea 79207e04 set1 flowx ,pdata 
+34eb 60008047 store 1 ,mem_arq 
+34ec 20600000 rtn 
+
+prepare_newconn:
+34ed 793f8025 set0 mark_ext_patch ,mark 
+34ee 44a4c009 bpatch patch09_1 ,mem_patch09 
+34ef 70001120 jam param_newconnto ,mem_newconnto_counter 
+34f0 70004750 jam param_newconn_arq ,mem_arq 
+34f1 6801415f fetch 2 ,mem_rx_window_init 
+34f2 6001003e store 2 ,mem_rx_window 
+34f3 1c427e00 deposit clkn_bt 
+34f4 6002416a store 4 ,mem_next_btclk 
+34f5 20780000 rtn clknt 
+34f6 1d027e00 deposit clke_bt 
+34f7 6002416a store 4 ,mem_next_btclk 
+34f8 20600000 rtn 
+
+newconn_init:
+34f9 793f8025 set0 mark_ext_patch ,mark 
+34fa 44a54009 bpatch patch09_2 ,mem_patch09 
+34fb 20405b6f call init_lmp_reinit 
+34fc 20403512 call new_conn_handle 
+34fd 60008046 store 1 ,mem_conn_handle 
+34fe 58001c80 setarg param_supervision_to 
+34ff 60010051 store 2 ,mem_supervision_to 
+3500 68008030 fetch 1 ,mem_state 
+3501 79207e00 set1 state_inconn ,pdata 
+3502 60008030 store 1 ,mem_state 
+3503 70004b00 jam 0 ,mem_op 
+3504 70004c00 jam 0 ,mem_state_map 
+3505 7000a200 jam 0 ,mem_lpm_current_mult 
+3506 20203bec branch supervision_flush 
+
+clear_linkkey:
+3507 793f8025 set0 mark_ext_patch ,mark 
+3508 44a5c009 bpatch patch09_3 ,mem_patch09 
+3509 18007e00 force 0 ,pdata 
+350a 60044262 store 8 ,mem_link_key 
+350b e0a40000 istore 8 ,contw 
+350c 2040322a call clear_linkstate 
+350d 202032f0 branch context_traverse_linkkey 
+
+new_conn_timeout:
+350e 68008011 fetch 1 ,mem_newconnto_counter 
+350f 1fe0ffff increase -1 ,pdata 
+3510 60008011 store 1 ,mem_newconnto_counter 
+3511 20600000 rtn 
+
+new_conn_handle:
+3512 6800c170 fetch 1 ,mem_handle_num 
+3513 1fe0fe01 increase 1 ,pdata 
+3514 6000c170 store 1 ,mem_handle_num 
+3515 20600000 rtn 
+
+quit_connection:
+3516 793f8025 set0 mark_ext_patch ,mark 
+3517 44a64009 bpatch patch09_4 ,mem_patch09 
+3518 204031fa call disconnect_stop_sco 
+3519 6800c272 fetch 1 ,mem_hci_cmd 
+351a c001b51d beq hci_cmd_remote_name_req ,quit_connection_name 
+351b 68008048 fetch 1 ,mem_lmp_to_send 
+351c c080b521 bne lmp_name_req ,quit_connection_cont 
+
+quit_connection_name:
+351d 204049be call cmd_check_plap 
+351e 2422b521 nbranch quit_connection_cont ,zero 
+351f 204031f5 call master_name_error 
+3520 70427200 jam 0 ,mem_hci_cmd 
+
+quit_connection_cont:
+3521 793f8025 set0 mark_ext_patch ,mark 
+3522 44a6c009 bpatch patch09_5 ,mem_patch09 
+3523 20403f18 call app_disconn_reason_collect_bt 
+3524 20404995 call process_cmd 
+3525 20403806 call sniff_exit 
+3526 700b7d02 jam bt_evt_bb_disconnected ,mem_fifo_temp 
+3527 20407c27 call ui_ipc_send_event 
+3528 20405b63 call init_lmp_work 
+3529 20404d99 call l2cap_init_work 
+352a 20407719 call sp_initialize 
+352b 68008030 fetch 1 ,mem_state 
+352c 793ffe00 set0 state_inconn 
+352d 60008030 store 1 ,mem_state 
+352e 7047f300 jam 0 ,memui_reconnect_mode 
+352f 6800804c fetch 1 ,mem_state_map 
+3530 2fe18000 compare 0x0 ,pdata ,0xc0 
+3531 2020b533 branch quit_connection_not_clear_mark ,true 
+3532 793f8001 set0 mark_rxbuf_inuse ,mark 
+
+quit_connection_not_clear_mark:
+3533 68008047 fetch 1 ,mem_arq 
+3534 c301b535 bbit0 wack ,quit_connection_not_clear_tx 
+
+quit_connection_not_clear_tx:
+3535 6800804b fetch 1 ,mem_op 
+3536 c4030000 rtnbit0 op_txl2cap 
+3537 793f8002 set0 mark_tx_l2cap ,mark 
+3538 20600000 rtn 
+
+slave_newconn_once:
+3539 793f8025 set0 mark_ext_patch ,mark 
+353a 44a74009 bpatch patch09_6 ,mem_patch09 
+353b 6800817e fetch 1 ,extm_newconn_am_addr 
+353c 207a0000 rtn blank 
+353d 1fe20800 icopy am_addr 
+353e 204035d6 call slave_conn_recv_packet 
+353f 24768000 nrtn match 
+3540 18000200 force type_null ,type 
+3541 204038b1 call slave_conn_send_packet 
+3542 18827e00 deposit am_addr 
+3543 60008077 store 1 ,mem_amaddr 
+3544 18007e00 force 0 ,pdata 
+3545 6000817e store 1 ,extm_newconn_am_addr 
+3546 20600000 rtn 
+
+prepare_tx:
+3547 793f8025 set0 mark_ext_patch ,mark 
+3548 44a7c009 bpatch patch09_7 ,mem_patch09 
+3549 68008030 fetch 1 ,mem_state 
+354a c3013555 bbit0 state_insco ,prepare_tx_not_sco 
+354b 18000207 force type_hv3 ,type 
+354c c583b554 bmark0 mark_esco ,prepare_tx_not_esco 
+354d 20403847 call check_esco_amaddr 
+354e 2420b555 nbranch prepare_tx_not_sco ,true 
+354f 20373555 branch prepare_tx_not_sco ,attempt 
+3550 20403583 call set_wait_ack 
+3551 58000002 setarg 2 
+3552 60014168 store 2 ,mem_retransmission_cnt 
+3553 20600000 rtn 
+
+prepare_tx_not_esco:
+3554 24770000 nrtn attempt 
+
+prepare_tx_not_sco:
+3555 793f8025 set0 mark_ext_patch ,mark 
+3556 44a8400a bpatch patch0a_0 ,mem_patch0a 
+3557 204032df call context_check_all_wack 
+3558 2422b568 nbranch prepare_tx_no_retransmit ,zero 
+3559 68008047 fetch 1 ,mem_arq 
+355a c301b571 bbit0 wack ,prepare_tx_pollnull 
+
+prepare_tx_retransmit:
+355b c502b575 bmark1 mark_loopback ,prepare_tx_loopback 
+355c 68008189 fetch 1 ,mem_debug_config 
+355d c283357c bbit1 debug_tx_pattern ,prepare_tx_txpat 
+355e 68014168 fetch 2 ,mem_retransmission_cnt 
+355f 1fe0ffff increase -1 ,pdata 
+3560 60014168 store 2 ,mem_retransmission_cnt 
+3561 203a3565 branch prepare_tx_nomore_retransmit ,blank 
+3562 6800c165 fetch 1 ,mem_last_type 
+3563 98000200 iforce type 
+3564 20600000 rtn 
+
+prepare_tx_nomore_retransmit:
+3565 793f8025 set0 mark_ext_patch ,mark 
+3566 44a8c00a bpatch patch0a_1 ,mem_patch0a 
+3567 20403799 call clear_got_tx 
+
+prepare_tx_no_retransmit:
+3568 20403847 call check_esco_amaddr 
+3569 2020b571 branch prepare_tx_pollnull ,true 
+356a 20405ed9 call send_lmp 
+356b 20343580 branch prepare_tx_sendlmp ,user 
+356c 6800804b fetch 1 ,mem_op 
+356d c2833582 bbit1 op_txl2cap ,prepare_tx_sendl2cap 
+356e c502b575 bmark1 mark_loopback ,prepare_tx_loopback 
+356f 68008189 fetch 1 ,mem_debug_config 
+3570 c283357c bbit1 debug_tx_pattern ,prepare_tx_txpat 
+
+prepare_tx_pollnull:
+3571 18000201 force type_poll ,type 
+3572 20748000 rtn master 
+3573 18000200 force type_null ,type 
+3574 20600000 rtn 
+
+prepare_tx_loopback:
+3575 793f8025 set0 mark_ext_patch ,mark 
+3576 44a9400a bpatch patch0a_2 ,mem_patch0a 
+3577 68008019 fetch 1 ,mem_rx_type 
+3578 98000200 iforce type 
+3579 c1808000 rtnne 1 
+357a 18000200 force type_null ,type 
+357b 20600000 rtn 
+
+prepare_tx_txpat:
+357c 6800815a fetch 1 ,test_mode_packet_type 
+357d 1fe1020f and pdata ,0xf ,type 
+357e 79200005 set1 mark_loopback ,mark 
+357f 20600000 rtn 
+
+prepare_tx_sendlmp:
+3580 18000213 force type_lmp ,type 
+3581 20203583 branch set_wait_ack 
+
+prepare_tx_sendl2cap:
+3582 2040358d call tx_l2cap_type 
+
+set_wait_ack:
+3583 793f8025 set0 mark_ext_patch ,mark 
+3584 44a9c00a bpatch patch0a_3 ,mem_patch0a 
+3585 68088047 fetcht 1 ,mem_arq 
+3586 79200403 set1 wack ,temp 
+3587 60088047 storet 1 ,mem_arq 
+3588 18227e00 deposit type 
+3589 6000c165 store 1 ,mem_last_type 
+358a 5800ffff setarg 0xffff 
+358b 60014168 store 2 ,mem_retransmission_cnt 
+358c 20600000 rtn 
+
+tx_l2cap_type:
+358d 793f8025 set0 mark_ext_patch ,mark 
+358e 44aa400a bpatch patch0a_4 ,mem_patch0a 
+358f 6800804c fetch 1 ,mem_state_map 
+3590 2feffe05 isolate1 smap_edr ,pdata 
+3591 68010091 fetch 2 ,mem_tx_len 
+3592 2020b5a1 branch tx_l2cap_type_edr ,true 
+3593 18000203 force type_dm1 ,type 
+3594 1fe67c11 sub pdata ,17 ,null 
+3595 20610000 rtn positive 
+3596 18000204 force type_dh1 ,type 
+3597 1fe67c1b sub pdata ,27 ,null 
+3598 20610000 rtn positive 
+3599 1800020a force type_dm3 ,type 
+359a 1fe67c79 sub pdata ,121 ,null 
+359b 20610000 rtn positive 
+359c 1800020e force type_dm5 ,type 
+359d 1fe67ce0 sub pdata ,224 ,null 
+359e 20610000 rtn positive 
+359f 1800020f force type_dh5 ,type 
+35a0 20600000 rtn 
+
+tx_l2cap_type_edr:
+35a1 18000203 force type_dm1 ,type 
+35a2 1fe67c11 sub pdata ,17 ,null 
+35a3 20610000 rtn positive 
+35a4 18000204 force type_dh1 ,type 
+35a5 1fe67c36 sub pdata ,54 ,null 
+35a6 20610000 rtn positive 
+35a7 1800020a force type_dm3 ,type 
+35a8 d840016f arg 367 ,temp 
+35a9 98467c00 isub temp ,null 
+35aa 24610000 nrtn positive 
+35ab 1800020e force type_dm5 ,type 
+35ac d84002a7 arg 679 ,temp 
+35ad 98467c00 isub temp ,null 
+35ae 24610000 nrtn positive 
+35af 1800020f force type_dh5 ,type 
+35b0 20600000 rtn 
+
+slave_receive_master_slot:
+35b1 68008030 fetch 1 ,mem_state 
+35b2 c300b5b6 bbit0 state_insniff ,slave_receive_notsniff 
+35b3 68010032 fetch 2 ,mem_tsniff 
+35b4 203a35b6 branch slave_receive_notsniff ,blank 
+35b5 243735b8 nbranch slave_receive_sniff ,attempt 
+
+slave_receive_notsniff:
+35b6 20403bac call rf_setup_time_master_slot 
+
+slave_receive_access:
+35b7 1d00c201 add clke_bt ,1 ,bt_clk 
+
+slave_receive_sniff:
+35b8 78287c00 enable swfine 
+35b9 6801003e fetch 2 ,mem_rx_window 
+35ba 1fe37e00 rshift pdata ,pdata 
+35bb d8400500 arg param_pll_setup ,temp 
+35bc 9840fe00 iadd temp ,pdata 
+35bd 20403b7d call ahead_window 
+35be 20403a5d call fetch_extm_bt_adr 
+35bf 18004803 force 0x03 ,freq_mode 
+35c0 20403a3b call rx_radio_freq 
+35c1 204034e1 call init_rx_packet_flags 
+35c2 20403b41 call prep_crypt 
+35c3 793f8025 set0 mark_ext_patch ,mark 
+35c4 44aac00a bpatch patch0a_5 ,mem_patch0a 
+35c5 6801003e fetch 2 ,mem_rx_window 
+35c6 1fe37e00 rshift pdata ,pdata 
+35c7 20403b7d call ahead_window 
+35c8 20403b3a call start_receiver 
+35c9 7826fc00 enable decode_fec0 
+35ca 6801003e fetch 2 ,mem_rx_window 
+35cb d84003bb arg param_clke_cal ,temp 
+35cc 9840b600 iadd temp ,stop_watch 
+35cd 37c18400 correlate null ,timeout 
+35ce 1b420400 copy clke ,temp 
+35cf 600b009c storet 6 ,mem_sync_clke 
+35d0 7846fc00 disable decode_fec0 
+35d1 246c0000 nrtn sync 
+35d2 dd2003bb arg param_clke_cal ,clke_rt 
+35d3 1c225000 copy bt_clk ,clke_bt 
+35d4 2035bcb6 branch lpm_adjust_clk ,wake 
+35d5 20600000 rtn 
+
+slave_conn_recv_packet:
+35d6 793f8025 set0 mark_ext_patch ,mark 
+35d7 44ab400a bpatch patch0a_6 ,mem_patch0a 
+35d8 204035b1 call slave_receive_master_slot 
+35d9 242c3a6d nbranch shutdown_radio ,sync 
+35da 20403af3 call save_rssi 
+35db c588b5df bmark0 mark_testmode ,receive_packet 
+35dc 680100f8 fetch 2 ,mem_tst_pktcnt_sync 
+35dd 1fe0fe01 increase 1 ,pdata 
+35de 600100f8 store 2 ,mem_tst_pktcnt_sync 
+
+receive_packet:
+35df 1c230400 rshift bt_clk ,temp 
+35e0 18419c40 or temp ,0x40 ,white_init 
+
+receive_packet_whitened:
+35e1 793f8025 set0 mark_ext_patch ,mark 
+35e2 44abc00a bpatch patch0a_7 ,mem_patch0a 
+35e3 7823fc00 enable enable_white 
+35e4 78257c00 enable enable_hec 
+35e5 7825fc00 enable decode_fec1 
+35e6 09800003 parse demod ,bucket ,3 
+35e7 198cfe00 rshift8 pwindow ,pdata 
+35e8 6000815f store 1 ,mem_temp_am_addr 
+35e9 09800004 parse demod ,bucket ,4 
+35ea 08008007 inject bucket ,7 
+35eb 19827e00 copy pwindow ,pdata 
+35ec 60008019 store 1 ,mem_rx_type 
+35ed 09800003 parse demod ,bucket ,3 
+35ee 198cfe00 rshift8 pwindow ,pdata 
+35ef 60008160 store 1 ,mem_temp_arq 
+35f0 68008019 fetch 1 ,mem_rx_type 
+35f1 1fe67c03 sub pdata ,3 ,null 
+35f2 202135f7 branch receive_packet_noedr ,positive 
+35f3 c003b5f7 beq 7 ,receive_packet_noedr 
+35f4 6800804c fetch 1 ,mem_state_map 
+35f5 2feffe05 isolate1 smap_edr ,pdata 
+35f6 7920aa01 setflag true ,psk ,radio_ctrl 
+
+receive_packet_noedr:
+35f7 793f8025 set0 mark_ext_patch ,mark 
+35f8 44ac400b bpatch patch0b_0 ,mem_patch0b 
+35f9 09800008 parse demod ,bucket ,8 
+35fa 7845fc00 disable decode_fec1 
+35fb 78457c00 disable enable_hec 
+35fc 2023373e branch error_header ,crc_failed 
+35fd c588b601 bmark0 mark_testmode ,receive_packet_amchk 
+35fe 680100fa fetch 2 ,mem_tst_pktcnt_hec 
+35ff 1fe0fe01 increase 1 ,pdata 
+3600 600100fa store 2 ,mem_tst_pktcnt_hec 
+
+receive_packet_amchk:
+3601 793f8025 set0 mark_ext_patch ,mark 
+3602 44acc00b bpatch patch0b_1 ,mem_patch0b 
+3603 6800815f fetch 1 ,mem_temp_am_addr 
+3604 2fe00e00 compare 0 ,pdata ,0x07 
+3605 7920800a setflag true ,mark_am_addr_broadcast ,mark 
+3606 2020b613 branch am_addr_ok ,true 
+3607 a8800e00 icompare 0x07 ,am_addr 
+3608 2020b612 branch am_addr_match ,true 
+3609 c583b75c bmark0 mark_esco ,end_of_packet 
+360a 680880b2 fetcht 1 ,mem_saved_amaddr 
+360b a8400e00 icompare 0x7 ,temp 
+360c 2420b75c nbranch end_of_packet ,true 
+360d 20403290 call restore_esco 
+360e 68008047 fetch 1 ,mem_arq 
+360f 793ffe05 set0 arqnx ,pdata 
+3610 79207e04 set1 flowx ,pdata 
+3611 60008047 store 1 ,mem_arq 
+
+am_addr_match:
+3612 7836fc00 enable match 
+
+am_addr_ok:
+3613 793f8025 set0 mark_ext_patch ,mark 
+3614 44ad400b bpatch patch0b_2 ,mem_patch0b 
+3615 68008019 fetch 1 ,mem_rx_type 
+3616 1fe20200 icopy type 
+3617 c5053623 bmark1 mark_am_addr_broadcast ,arqn_bypass 
+3618 68088160 fetcht 1 ,mem_temp_arq 
+3619 68008047 fetch 1 ,mem_arq 
+361a 793ffe00 set0 flow ,pdata 
+361b 284ffe00 isolate1 flow ,temp 
+361c 7920fe00 setflag true ,flow ,pdata 
+361d 284ffe01 isolate1 arqn ,temp 
+361e 7920fe01 setflag true ,arqn ,pdata 
+361f 60008047 store 1 ,mem_arq 
+3620 284c0001 isolate0 arqn ,temp 
+3621 2020b623 branch arqn_bypass ,true 
+3622 20403799 call clear_got_tx 
+
+arqn_bypass:
+3623 793f8025 set0 mark_ext_patch ,mark 
+3624 44adc00b bpatch patch0b_3 ,mem_patch0b 
+3625 d8400000 arg 0 ,temp 
+3626 20403b74 call reserve_slot 
+3627 18217e0f and type ,0xf ,pdata 
+3628 c000b656 beq type_poll ,process_poll 
+3629 c000375c beq type_null ,end_of_packet 
+362a c0013769 beq type_fhs ,process_fhs 
+362b 68088160 fetcht 1 ,mem_temp_arq 
+362c 68008047 fetch 1 ,mem_arq 
+362d a8400800 icompare 0x04 ,temp 
+362e 2420b632 nbranch rx_type_dispatch ,true 
+362f c5853631 bmark0 mark_am_addr_broadcast ,failed_seqn 
+3630 c303b632 bbit0 bcast1 ,rx_type_dispatch 
+
+failed_seqn:
+3631 7920000f set1 mark_old_packet ,mark 
+
+rx_type_dispatch:
+3632 793f8025 set0 mark_ext_patch ,mark 
+3633 44ae400b bpatch patch0b_4 ,mem_patch0b 
+3634 18227e00 deposit type 
+3635 c001b658 beq type_dm1 ,process_dm1 
+3636 c002365c beq type_dh1 ,process_dh1 
+3637 c003b642 beq type_hv3 ,process_hev 
+3638 c004365b beq type_3dh1 ,process_3dh1 
+3639 d8400004 arg 4 ,temp 
+363a 20403b74 call reserve_slot 
+363b c0053657 beq type_dm3 ,process_dm3 
+363c c005b65a beq type_dh3 ,process_dh3 
+363d d8400008 arg 8 ,temp 
+363e 20403b74 call reserve_slot 
+363f c0073657 beq type_dm5 ,process_dm5 
+3640 c007b65a beq type_dh5 ,process_dh5 
+3641 20600000 rtn 
+
+process_hev:
+3642 793f8025 set0 mark_ext_patch ,mark 
+3643 44aec00b bpatch patch0b_5 ,mem_patch0b 
+3644 7826fc00 enable decode_fec0 
+3645 7824fc00 enable enable_crc 
+3646 78277c00 enable encrypt 
+3647 d8a000d3 arg mem_sco_ibuf ,contw 
+3648 1800721e force 30 ,loopcnt 
+
+process_hev_loop:
+3649 09800008 parse demod ,bucket ,8 
+364a 19897e00 rshift3 pwindow ,pdata 
+364b e0a08000 istore 1 ,contw 
+364c c2003649 loop process_hev_loop 
+364d c583b75c bmark0 mark_esco ,end_of_packet 
+364e 09800010 parse demod ,bucket ,16 
+364f 7d230008 nsetflag crc_failed ,mark_esco_rxok ,mark 
+3650 20433653 call test_esco ,crc_failed 
+3651 2023374b branch error_payload ,crc_failed 
+3652 2020372c branch ack_payload 
+
+test_esco:
+3653 1b427e00 deposit clke 
+3654 60030020 store 6 ,mem_display 
+3655 20600000 rtn 
+
+process_poll:
+3656 2020375c branch end_of_packet 
+
+process_dm3:
+
+process_dm5:
+3657 79200010 set1 mark_longpacket ,mark 
+
+process_dm1:
+3658 78267c00 enable decode_fec2 
+3659 2020365d branch process_dmh 
+
+process_dh3:
+
+process_dh5:
+365a 79200010 set1 mark_longpacket ,mark 
+
+process_3dh1:
+365b 79202a02 set1 psk3m ,radio_ctrl 
+
+process_dh1:
+365c 7826fc00 enable decode_fec0 
+
+process_dmh:
+365d 793f8025 set0 mark_ext_patch ,mark 
+365e 44af400b bpatch patch0b_6 ,mem_patch0b 
+365f c500b75c bmark1 mark_rxbuf_inuse ,end_of_packet 
+3660 2aac0001 isolate0 psk ,radio_ctrl 
+3661 2020b66a branch process_dmh_noedr ,true 
+3662 7843fc00 disable enable_white 
+3663 7826fc00 enable decode_fec0 
+3664 78467c00 disable decode_fec2 
+3665 1c409602 add clkn_bt ,2 ,timeup 
+3666 34530400 correlate clkn_bt ,meet 
+3667 242c374b nbranch error_payload ,sync 
+3668 79200010 set1 mark_longpacket ,mark 
+3669 7823fc00 enable enable_white 
+
+process_dmh_noedr:
+366a 793f8025 set0 mark_ext_patch ,mark 
+366b 44afc00b bpatch patch0b_7 ,mem_patch0b 
+366c 78277c00 enable encrypt 
+366d 7824fc00 enable enable_crc 
+366e 09800003 parse demod ,bucket ,3 
+366f 198cfe00 rshift8 pwindow ,pdata 
+3670 6000818a store 1 ,mem_lch_code 
+3671 09800005 parse demod ,bucket ,5 
+3672 c5083676 bmark1 mark_longpacket ,process_dmh_long 
+3673 19897200 rshift3 pwindow ,loopcnt 
+3674 1f297200 rshift3 loopcnt ,loopcnt 
+3675 20203679 branch process_dmh_common 
+
+process_dmh_long:
+3676 09800005 parse demod ,bucket ,5 
+3677 19837200 rshift pwindow ,loopcnt 
+3678 09800003 parse demod ,bucket ,3 
+
+process_dmh_common:
+3679 793f8025 set0 mark_ext_patch ,mark 
+367a 44b0400c bpatch patch0c_0 ,mem_patch0c 
+367b 1f227e00 deposit loopcnt 
+367c 60010169 store 2 ,mem_len 
+367d 203a36ee branch process_dmh_data_end ,blank 
+367e 9ea67c00 isub mask3ff ,null 
+367f 2021374b branch error_payload ,positive 
+3680 793f8025 set0 mark_ext_patch ,mark 
+3681 44b0c00c bpatch patch0c_1 ,mem_patch0c 
+3682 793f8000 set0 mark_fhs_eir ,mark 
+3683 6800818a fetch 1 ,mem_lch_code 
+3684 1fe17e03 and_into 0x03 ,pdata 
+3685 d8a004de arg mem_rxbuf ,contw 
+3686 c001b68f beq llid_lmp ,process_lmp 
+3687 c508b6ea bmark1 mark_testmode ,process_dmh_data 
+3688 6800c132 fetch 1 ,mem_device_option 
+3689 c000b694 beq dvc_op_hci ,process_dmh_acl 
+368a 6800818a fetch 1 ,mem_lch_code 
+368b 1fe17e03 and_into 0x03 ,pdata 
+368c c00136c3 beq llid_l2cap_start ,process_dmh_data_l2cap_start_pkt 
+368d c000b6d8 beq llid_l2cap_cont ,process_dmh_data_l2cap_continue_pkt 
+368e 2020374b branch error_payload 
+
+process_lmp:
+368f 68010169 fetch 2 ,mem_len 
+3690 1fe67c70 sub pdata ,0x70 ,null 
+3691 2421374b nbranch error_payload ,positive 
+3692 c507b72c bmark1 mark_old_packet ,ack_payload 
+3693 202036ea branch process_dmh_data 
+
+process_dmh_acl:
+3694 793f8025 set0 mark_ext_patch ,mark 
+3695 44b1400c bpatch patch0c_2 ,mem_patch0c 
+3696 c507b72c bmark1 mark_old_packet ,ack_payload 
+3697 68010169 fetch 2 ,mem_len 
+3698 203a374b branch error_payload ,blank 
+3699 20404494 call hci_check_bcsp_protocol 
+369a 2420b6a1 nbranch process_dmh_acl_check_h4_buff ,true 
+
+process_dmh_acl_bcsp:
+369b 68090291 fetcht 2 ,mem_h5tx_free 
+369c 1fe0fe0a increase 10 ,pdata 
+369d 98467c00 isub temp ,null 
+369e 242136a7 nbranch process_dmh_acl_packet ,positive 
+369f 20404449 call hci_dispatch 
+36a0 2020369b branch process_dmh_acl_bcsp 
+
+process_dmh_acl_check_h4_buff:
+36a1 6811010e hfetch 2 ,core_uart_txitems 
+36a2 d840012c arg 300 ,temp 
+36a3 98467c00 isub temp ,null 
+36a4 2021374b branch error_payload ,positive 
+36a5 68014800 fetch 2 ,mem_acl_credits 
+36a6 203a374b branch error_payload ,blank 
+
+process_dmh_acl_packet:
+36a7 793f8025 set0 mark_ext_patch ,mark 
+36a8 44b1c00c bpatch patch0c_3 ,mem_patch0c 
+36a9 20404972 call hci_get_packet_ptr 
+36aa 68008046 fetch 1 ,mem_conn_handle 
+36ab 6808818a fetcht 1 ,mem_lch_code 
+36ac 18410403 and_into 3 ,temp 
+36ad 184d0400 lshift8 temp ,temp 
+36ae 18520400 lshift4 temp ,temp 
+36af 9841fe00 ior temp ,pdata 
+36b0 e1410000 istore 2 ,contwu 
+36b1 68090169 fetcht 2 ,mem_len 
+36b2 18427200 copy temp ,loopcnt 
+36b3 e1490000 istoret 2 ,contwu 
+
+process_dmh_acl_copy:
+36b4 793f8025 set0 mark_ext_patch ,mark 
+36b5 44b2400c bpatch patch0c_4 ,mem_patch0c 
+36b6 09800008 parse demod ,bucket ,8 
+36b7 19897e00 rshift3 pwindow ,pdata 
+36b8 e1408000 istore 1 ,contwu 
+36b9 c20036b4 loop process_dmh_acl_copy 
+36ba 1840f204 add temp ,4 ,loopcnt 
+36bb 20404494 call hci_check_bcsp_protocol 
+36bc 2420b6c1 nbranch process_dmh_acl_send_h4 ,true 
+36bd 79200013 set1 mark_h5tx_rp ,mark 
+36be 18000e06 force 6 ,queue 
+36bf 20404378 call bcsp_send_packet 
+36c0 202036ee branch process_dmh_data_end 
+
+process_dmh_acl_send_h4:
+36c1 20404424 call h4_send_packet_acl 
+36c2 202036ee branch process_dmh_data_end 
+
+process_dmh_data_l2cap_start_pkt:
+36c3 793f8025 set0 mark_ext_patch ,mark 
+36c4 44b2c00c bpatch patch0c_5 ,mem_patch0c 
+36c5 c507b72c bmark1 mark_old_packet ,ack_payload 
+36c6 68010169 fetch 2 ,mem_len 
+36c7 d84002e0 arg 0x2e0 ,temp 
+36c8 98467c00 isub temp ,null 
+36c9 2021374b branch error_payload ,positive 
+36ca 680082ca fetch 1 ,mem_l2cap_rxbuff_inuse 
+36cb c30036ce bbit0 l2cap_inuse_buff1 ,process_dmh_data_into_buff1 
+36cc c300b6d3 bbit0 l2cap_inuse_buff2 ,process_dmh_data_into_buff2 
+36cd 2020375c branch end_of_packet 
+
+process_dmh_data_into_buff1:
+36ce 7002c801 jam 1 ,mem_l2cap_rxbuff_new 
+36cf 680102c4 fetch 2 ,mem_l2cap_rxbuff1_len 
+36d0 c080375c bne 0 ,end_of_packet 
+36d1 d8a01000 arg mem_l2cap_rxbuff1 ,contw 
+36d2 202036ea branch process_dmh_data 
+
+process_dmh_data_into_buff2:
+36d3 7002c802 jam 2 ,mem_l2cap_rxbuff_new 
+36d4 680102c6 fetch 2 ,mem_l2cap_rxbuff2_len 
+36d5 c080375c bne 0 ,end_of_packet 
+36d6 d8a01400 arg mem_l2cap_rxbuff2 ,contw 
+36d7 202036ea branch process_dmh_data 
+
+process_dmh_data_l2cap_continue_pkt:
+36d8 793f8025 set0 mark_ext_patch ,mark 
+36d9 44b3400c bpatch patch0c_6 ,mem_patch0c 
+36da c507b72c bmark1 mark_old_packet ,ack_payload 
+36db 68010169 fetch 2 ,mem_len 
+36dc d84002e0 arg 0x2e0 ,temp 
+36dd 98467c00 isub temp ,null 
+36de 2021374b branch error_payload ,positive 
+36df 680082c8 fetch 1 ,mem_l2cap_rxbuff_new 
+36e0 c000b6e3 beq 1 ,process_dmh_data_l2cap_continue_pkt1 
+36e1 c00136e7 beq 2 ,process_dmh_data_l2cap_continue_pkt2 
+36e2 2020375c branch end_of_packet 
+
+process_dmh_data_l2cap_continue_pkt1:
+36e3 d8a01000 arg mem_l2cap_rxbuff1 ,contw 
+36e4 680102c4 fetch 2 ,mem_l2cap_rxbuff1_len 
+36e5 98a08a00 iadd contw ,contw 
+36e6 202036ea branch process_dmh_data 
+
+process_dmh_data_l2cap_continue_pkt2:
+36e7 d8a01400 arg mem_l2cap_rxbuff2 ,contw 
+36e8 680102c6 fetch 2 ,mem_l2cap_rxbuff2_len 
+36e9 98a08a00 iadd contw ,contw 
+
+process_dmh_data:
+36ea 09800008 parse demod ,bucket ,8 
+36eb 19897e00 rshift3 pwindow ,pdata 
+36ec e0a08000 istore 1 ,contw 
+36ed c20036ea loop process_dmh_data 
+
+process_dmh_data_end:
+36ee 793f8025 set0 mark_ext_patch ,mark 
+36ef 44b3c00c bpatch patch0c_7 ,mem_patch0c 
+36f0 09800010 parse demod ,bucket ,16 
+36f1 20233745 branch error_payload_crc ,crc_failed 
+36f2 20403e0f call lpm_hci_wake_dispatch 
+36f3 6800c3cc fetch 1 ,mem_l2cap_flow_ctrl_flag 
+36f4 c000b75c beq l2cap_flow_ctrl_enable ,end_of_packet 
+36f5 c508b718 bmark1 mark_testmode ,process_dmh_cont 
+36f6 c507b759 bmark1 mark_old_packet ,redundant_payload 
+36f7 6800818a fetch 1 ,mem_lch_code 
+36f8 2fe00603 compare 3 ,pdata ,3 
+36f9 2020b718 branch process_dmh_cont ,true 
+36fa 68010169 fetch 2 ,mem_len 
+36fb 203a3718 branch process_dmh_cont ,blank 
+36fc 6800c132 fetch 1 ,mem_device_option 
+36fd c000b718 beq dvc_op_hci ,process_dmh_cont 
+36fe 793f8025 set0 mark_ext_patch ,mark 
+36ff 44b4400d bpatch patch0d_0 ,mem_patch0d 
+3700 680082c8 fetch 1 ,mem_l2cap_rxbuff_new 
+3701 c000b704 beq 1 ,process_l2cap_pass_crc_buff1 
+3702 c001370e beq 2 ,process_l2cap_pass_crc_buff2 
+3703 20203bf1 branch assert 
+
+process_l2cap_pass_crc_buff1:
+3704 680102c4 fetch 2 ,mem_l2cap_rxbuff1_len 
+3705 68090169 fetcht 2 ,mem_len 
+3706 9840fe00 iadd temp ,pdata 
+3707 600102c4 store 2 ,mem_l2cap_rxbuff1_len 
+3708 c0003bf1 beq 0 ,assert 
+3709 68091000 fetcht 2 ,mem_l2cap_rxbuff1 
+370a 18408404 increase 4 ,temp 
+370b 98467c00 isub temp ,null 
+370c 2042b8a0 call l2cap_buff1_inuse ,zero 
+370d 20203718 branch process_dmh_cont 
+
+process_l2cap_pass_crc_buff2:
+370e 680102c6 fetch 2 ,mem_l2cap_rxbuff2_len 
+370f 68090169 fetcht 2 ,mem_len 
+3710 9840fe00 iadd temp ,pdata 
+3711 600102c6 store 2 ,mem_l2cap_rxbuff2_len 
+3712 c0003bf1 beq 0 ,assert 
+3713 68091400 fetcht 2 ,mem_l2cap_rxbuff2 
+3714 18408404 add temp ,4 ,temp 
+3715 98467c00 isub temp ,null 
+3716 2042b8a4 call l2cap_buff2_inuse ,zero 
+3717 20203718 branch process_dmh_cont 
+
+process_dmh_cont:
+3718 793f8025 set0 mark_ext_patch ,mark 
+3719 44b4c00d bpatch patch0d_1 ,mem_patch0d 
+371a 6808804c fetcht 1 ,mem_state_map 
+371b 6800818a fetch 1 ,mem_lch_code 
+371c 2fe00603 compare 3 ,pdata ,0x03 
+371d 79208406 setflag true ,smap_rxlmp ,temp 
+371e 7d208407 nsetflag true ,smap_rxl2cap ,temp 
+371f 6008804c storet 1 ,mem_state_map 
+3720 2420b722 nbranch process_dmh_cont_rxbuf_not_use ,true 
+3721 79200001 set1 mark_rxbuf_inuse ,mark 
+
+process_dmh_cont_rxbuf_not_use:
+3722 c588b72c bmark0 mark_testmode ,ack_payload 
+3723 284ffe06 isolate1 smap_rxlmp ,temp 
+3724 2020b72c branch ack_payload ,true 
+3725 680100fc fetch 2 ,mem_tst_pktcnt_crc 
+3726 1fe0fe01 increase 1 ,pdata 
+3727 600100fc store 2 ,mem_tst_pktcnt_crc 
+3728 79200005 set1 mark_loopback ,mark 
+3729 793f8407 set0 smap_rxl2cap ,temp 
+372a 793f8001 set0 mark_rxbuf_inuse ,mark 
+372b 6008804c storet 1 ,mem_state_map 
+
+ack_payload:
+372c 793f8025 set0 mark_ext_patch ,mark 
+372d 44b5400d bpatch patch0d_2 ,mem_patch0d 
+372e 68088160 fetcht 1 ,mem_temp_arq 
+372f 68008047 fetch 1 ,mem_arq 
+3730 79207e05 set1 arqnx ,pdata 
+3731 284ffe02 isolate1 seqn ,temp 
+3732 7920fe02 setflag true ,seqn ,pdata 
+3733 280ffe0a isolate1 mark_am_addr_broadcast ,mark 
+3734 7920fe07 setflag true ,bcast1 ,pdata 
+3735 60008047 store 1 ,mem_arq 
+3736 68010169 fetch 2 ,mem_len 
+3737 243a375c nbranch end_of_packet ,blank 
+3738 6800804c fetch 1 ,mem_state_map 
+3739 793ffe07 set0 smap_rxl2cap ,pdata 
+373a 6000804c store 1 ,mem_state_map 
+373b 6800818a fetch 1 ,mem_lch_code 
+373c 2fe00e01 compare 0x01 ,pdata ,0x07 
+373d 2020375c branch end_of_packet 
+
+error_header:
+373e 793f8025 set0 mark_ext_patch ,mark 
+373f 44b5c00d bpatch patch0d_3 ,mem_patch0d 
+3740 7856fc00 disable match 
+3741 6801001a fetch 2 ,mem_rx_hec_err 
+3742 1fe0fe01 increase 1 ,pdata 
+3743 6001001a store 2 ,mem_rx_hec_err 
+3744 2020375c branch end_of_packet 
+
+error_payload_crc:
+3745 6801001c fetch 2 ,mem_rx_crc_err 
+3746 1fe0fe01 increase 1 ,pdata 
+3747 6001001c store 2 ,mem_rx_crc_err 
+3748 2040374c call discard_pkt 
+3749 c588b74b bmark0 mark_testmode ,error_payload 
+374a 79200005 set1 mark_loopback ,mark 
+
+error_payload:
+374b 2020375c branch end_of_packet 
+
+discard_pkt:
+374c 793f8025 set0 mark_ext_patch ,mark 
+374d 44b6400d bpatch patch0d_4 ,mem_patch0d 
+374e 6800818a fetch 1 ,mem_lch_code 
+374f 2fe00603 compare 3 ,pdata ,0x03 
+3750 2420b755 nbranch discard_pkt_l2cap ,true 
+
+discard_pkt_lmp:
+3751 6808804c fetcht 1 ,mem_state_map 
+3752 793f8406 set0 smap_rxlmp ,temp 
+3753 6008804c storet 1 ,mem_state_map 
+3754 20600000 rtn 
+
+discard_pkt_l2cap:
+3755 6808804c fetcht 1 ,mem_state_map 
+3756 793f8407 set0 smap_rxl2cap ,temp 
+3757 6008804c storet 1 ,mem_state_map 
+3758 2020443b branch h4_send_acl_trigger_clear 
+
+redundant_payload:
+3759 68008047 fetch 1 ,mem_arq 
+375a 79207e05 set1 arqnx ,pdata 
+375b 60008047 store 1 ,mem_arq 
+
+end_of_packet:
+375c 793f8025 set0 mark_ext_patch ,mark 
+375d 44b6c00d bpatch patch0d_5 ,mem_patch0d 
+375e 784efc00 disable encode_fec0 
+375f 784e7c00 disable encode_fec2 
+3760 7846fc00 disable decode_fec0 
+3761 78467c00 disable decode_fec2 
+3762 7844fc00 disable enable_crc 
+3763 78477c00 disable encrypt 
+3764 7843fc00 disable enable_white 
+3765 2030ba6d branch shutdown_radio ,is_rx 
+3766 37d38200 until null ,tx_clear 
+3767 20000064 nop 100 
+3768 20203a6d branch shutdown_radio 
+
+process_fhs:
+3769 793f8025 set0 mark_ext_patch ,mark 
+376a 44b7400d bpatch patch0d_6 ,mem_patch0d 
+376b 7824fc00 enable enable_crc 
+376c 78267c00 enable decode_fec2 
+376d 09800048 parse demod ,bucket ,72 
+376e 2feffe3a isolate1 58 ,pdata 
+376f 79208000 setflag true ,mark_fhs_eir ,mark 
+3770 1c020400 copy bt_adr ,temp 
+3771 57e04000 ialigned bt_adr 
+3772 57e03c00 ialigned fhs0 
+3773 782afc00 pulse recalc 
+3774 380bffff setsect 2 ,0xfffff 
+3775 380cffff setsect 3 ,0x0ffff 
+3776 20000020 nop 32 
+3777 29a80000 iverify fhs_parity 
+3778 1d827e00 deposit lap 
+3779 60018182 store 3 ,extm_lap 
+377a 1da27e00 deposit uap 
+377b 60008185 store 1 ,extm_uap 
+377c 18424000 copy temp ,bt_adr 
+377d 2020b77f branch fhs_parity_ok ,true 
+377e 2020374b branch error_payload 
+
+fhs_parity_ok:
+377f 793f8025 set0 mark_ext_patch ,mark 
+3780 44b7c00d bpatch patch0d_7 ,mem_patch0d 
+3781 09800048 parse demod ,bucket ,72 
+3782 57e03e00 ialigned fhs1 
+3783 57e00800 ialigned am_addr 
+3784 57e05c00 ialigned nap 
+3785 57e02400 ialigned regb 
+3786 18007e00 force 0 ,pdata 
+3787 09800010 parse demod ,bucket ,16 
+3788 2023374b branch error_payload ,crc_failed 
+3789 5ffffffc setarg 0x0ffffffc 
+378a 9a417e00 iand regb ,pdata 
+378b 6002016f store 4 ,mem_clke_bt 
+378c 1ba27e00 deposit fhs_class 
+378d 6001817f store 3 ,extm_class 
+378e 1b827e00 deposit fhs_misc 
+378f 6000817d store 1 ,extm_fhs_misc 
+3790 18827e00 deposit am_addr 
+3791 6000817e store 1 ,extm_newconn_am_addr 
+3792 1dc27e00 deposit nap 
+3793 60010186 store 2 ,extm_nap 
+3794 1c227e00 deposit bt_clk 
+3795 08008220 inject rxf ,32 
+3796 28201e02 compare type_fhs ,type ,0x0f 
+3797 7920800b setflag true ,mark_fhs_already_good ,mark 
+3798 2020375c branch end_of_packet 
+
+clear_got_tx:
+3799 793f8025 set0 mark_ext_patch ,mark 
+379a 44b8400e bpatch patch0e_0 ,mem_patch0e 
+379b 68008047 fetch 1 ,mem_arq 
+379c c4018000 rtnbit0 wack 
+379d 793ffe03 set0 wack ,pdata 
+379e 79407e06 setflip seqnx ,pdata 
+379f 60008047 store 1 ,mem_arq 
+37a0 6800c165 fetch 1 ,mem_last_type 
+37a1 c009b7b1 beq type_lmp ,clear_got_txlmp 
+37a2 c1038000 rtneq type_hv3 
+37a3 6800804b fetch 1 ,mem_op 
+37a4 c4030000 rtnbit0 op_txl2cap ,pdata 
+37a5 793ffe06 set0 op_txl2cap ,pdata 
+37a6 79207e07 set1 op_pkt_comp ,pdata 
+37a7 6000804b store 1 ,mem_op 
+37a8 793f8002 set0 mark_tx_l2cap ,mark 
+37a9 6800c132 fetch 1 ,mem_device_option 
+37aa c1008000 rtneq dvc_op_hci 
+37ab 680142af fetch 2 ,mem_l2cap_tx_multi_offset 
+37ac 247a0000 nrtn blank 
+37ad 6800804b fetch 1 ,mem_op 
+37ae 793ffe07 set0 op_pkt_comp ,pdata 
+37af 6000804b store 1 ,mem_op 
+37b0 20205267 branch l2cap_malloc_free 
+
+clear_got_txlmp:
+37b1 793f8025 set0 mark_ext_patch ,mark 
+37b2 44b8c00e bpatch patch0e_1 ,mem_patch0e 
+37b3 68008433 fetch 1 ,mem_lmo_header_opcode 
+37b4 1fe37e00 rshift pdata ,pdata 
+37b5 c008b7d0 beq lmp_start_encryption_req ,start_encryption 
+37b6 c00937da beq lmp_stop_encryption_req ,stop_encryption 
+37b7 c00c3806 beq lmp_unsniff_req ,sniff_exit 
+37b8 c03fb7bf beq lmp_escape ,clear_lmp_escape 
+37b9 c016385e beq lmp_remove_sco_link_req ,stop_sco 
+37ba c1818000 rtnne lmp_accepted 
+37bb 68008434 fetch 1 ,mem_lmo_payload 
+37bc c015b7c8 beq lmp_sco_link_req ,sco_link_req_by_slave 
+37bd c008b7c3 beq lmp_start_encryption_req ,clear_send_setup_complete 
+37be 20600000 rtn 
+
+clear_lmp_escape:
+37bf 68008434 fetch 1 ,mem_lmo_payload 
+37c0 79207e07 set1 7 ,pdata 
+37c1 c046b85e beq lmp_ext_remove_esco_req ,stop_sco 
+37c2 20600000 rtn 
+
+clear_send_setup_complete:
+37c3 20748000 rtn master 
+37c4 68008030 fetch 1 ,mem_state 
+37c5 c3820000 rtnbit1 state_conn_comp 
+37c6 70007c31 jam lmp_setup_complete ,mem_lmo_opcode2 
+37c7 20600000 rtn 
+
+sco_link_req_by_slave:
+37c8 20748000 rtn master 
+37c9 68008031 fetch 1 ,mem_mode 
+37ca 2feffe04 isolate1 send_sco_when_slave ,pdata 
+37cb 2020b7cd branch clean_mem_mode ,true 
+37cc 20600000 rtn 
+
+clean_mem_mode:
+37cd 793ffe04 set0 send_sco_when_slave ,pdata 
+37ce 60008031 store 1 ,mem_mode 
+37cf 20600000 rtn 
+
+start_encryption:
+37d0 793f8025 set0 mark_ext_patch ,mark 
+37d1 44b9400e bpatch patch0e_2 ,mem_patch0e 
+37d2 6800804c fetch 1 ,mem_state_map 
+37d3 79207e02 set1 smap_encryption ,pdata 
+37d4 6000804c store 1 ,mem_state_map 
+37d5 70801101 hjam 1 ,core_encrypt 
+37d6 68008030 fetch 1 ,mem_state 
+37d7 2feffe04 isolate1 state_conn_comp ,pdata 
+37d8 2020c845 branch hci_send_encryption_change ,true 
+37d9 20600000 rtn 
+
+stop_encryption:
+37da 793f8025 set0 mark_ext_patch ,mark 
+37db 44b9c00e bpatch patch0e_3 ,mem_patch0e 
+37dc 6800804c fetch 1 ,mem_state_map 
+37dd 793ffe02 set0 smap_encryption ,pdata 
+37de 6000804c store 1 ,mem_state_map 
+37df 70801100 hjam 0 ,core_encrypt 
+37e0 20600000 rtn 
+
+sniff_init:
+37e1 793f8025 set0 mark_ext_patch ,mark 
+37e2 44ba400e bpatch patch0e_4 ,mem_patch0e 
+37e3 1c427e00 copy clkn_bt ,pdata 
+37e4 600242a5 store 4 ,mem_lpm_delay_after_sniff 
+37e5 1c40a203 add clkn_bt ,3 ,rega 
+37e6 2034b7e8 branch sniff_init_master ,master 
+37e7 1d00a203 add clke_bt ,3 ,rega 
+
+sniff_init_master:
+37e8 68090032 fetcht 2 ,mem_tsniff 
+37e9 1a227e00 deposit rega 
+37ea 793ffe1b set0 27 ,pdata 
+37eb 9846fc00 idiv temp 
+37ec 68010075 fetch 2 ,mem_dsniff 
+37ed 20407efd call wait_div_end 
+37ee 18072600 remainder regc 
+37ef 9a667e00 isub regc ,pdata 
+37f0 202137f2 branch sniff_init_nowrap ,positive 
+37f1 9840fe00 iadd temp ,pdata 
+
+sniff_init_nowrap:
+37f2 9a20fe00 iadd rega ,pdata 
+37f3 60020034 store 4 ,mem_sniff_anchor 
+37f4 70474800 jam switch_flag_init ,mem_switch_flag 
+37f5 68008030 fetch 1 ,mem_state 
+37f6 79207e01 set1 state_insniff ,pdata 
+37f7 60008030 store 1 ,mem_state 
+37f8 68008073 fetch 1 ,mem_sniff_attempt 
+37f9 6000808a store 1 ,mem_current_sniff_attempt 
+37fa 70416e80 jam 0x80 ,mem_seqi 
+37fb 58000000 setarg 0 
+37fc 6001c20a store 3 ,mem_sniff_rcv 
+37fd 6001c20d store 3 ,mem_sniff_lost 
+37fe 6000c1fa store 1 ,mem_sniff_unint_lost 
+37ff 700b7d0b jam bt_evt_enter_sniff ,mem_fifo_temp 
+3800 20407c27 call ui_ipc_send_event 
+3801 68014161 fetch 2 ,mem_rx_window_sniff 
+3802 6001003e store 2 ,mem_rx_window 
+3803 24748000 nrtn master 
+3804 18808fff add am_addr ,-1 ,queue 
+3805 20600000 rtn 
+
+sniff_exit:
+3806 793f8025 set0 mark_ext_patch ,mark 
+3807 44bac00e bpatch patch0e_5 ,mem_patch0e 
+3808 68008030 fetch 1 ,mem_state 
+3809 c4008000 rtnbit0 state_insniff 
+380a 793ffe01 set0 state_insniff ,pdata 
+380b 60008030 store 1 ,mem_state 
+380c 70416e7f jam 0x7f ,mem_seqi 
+380d 6801415f fetch 2 ,mem_rx_window_init 
+380e 6001003e store 2 ,mem_rx_window 
+380f 7855fc00 disable wake 
+3810 700b7d0c jam bt_evt_exit_sniff ,mem_fifo_temp 
+3811 20207c27 branch ui_ipc_send_event 
+
+check_attempt:
+3812 793f8025 set0 mark_ext_patch ,mark 
+3813 44bb400e bpatch patch0e_6 ,mem_patch0e 
+3814 78377c00 enable attempt 
+3815 68008030 fetch 1 ,mem_state 
+3816 c280b820 bbit1 state_insniff ,check_attempt_sniff 
+3817 c6088000 rtnmark1 mark_testmode 
+3818 68008047 fetch 1 ,mem_arq 
+3819 c3818000 rtnbit1 wack 
+381a 68008048 fetch 1 ,mem_lmp_to_send 
+381b 247a0000 nrtn blank 
+381c 6800804b fetch 1 ,mem_op 
+381d c3830000 rtnbit1 op_txl2cap 
+
+check_attempt_nomore:
+381e 18007e00 force 0 ,pdata 
+381f 20600000 rtn 
+
+check_attempt_sniff:
+3820 c3013830 bbit0 state_insco ,check_attempt_not_sco 
+3821 6800808a fetch 1 ,mem_current_sniff_attempt 
+3822 c0013826 beq 2 ,check_attempt_sniff_restore_sco 
+3823 68008047 fetch 1 ,mem_arq 
+3824 c281b839 bbit1 wack ,check_attempt_notimeout 
+3825 c5843839 bmark0 mark_esco_rxok ,check_attempt_notimeout 
+
+check_attempt_sniff_restore_sco:
+3826 20403290 call restore_esco 
+3827 2434b839 nbranch check_attempt_notimeout ,master 
+3828 68008048 fetch 1 ,mem_lmp_to_send 
+3829 243a3839 nbranch check_attempt_notimeout ,blank 
+
+check_attempt_sco_master:
+382a 680080f1 fetch 1 ,mem_sco_poll 
+382b 1fe0ffff increase -1 ,pdata 
+382c 600080f1 store 1 ,mem_sco_poll 
+382d 243a381e nbranch check_attempt_nomore ,blank 
+382e 7000f110 jam param_sco_poll ,mem_sco_poll 
+382f 20203839 branch check_attempt_notimeout 
+
+check_attempt_not_sco:
+3830 6800808a fetch 1 ,mem_current_sniff_attempt 
+3831 c080b839 bne 1 ,check_attempt_notimeout 
+3832 6800808b fetch 1 ,mem_current_sniff_timeout 
+3833 203a3839 branch check_attempt_notimeout ,blank 
+3834 1fe0ffff increase -1 ,pdata 
+3835 6000808b store 1 ,mem_current_sniff_timeout 
+3836 68008047 fetch 1 ,mem_arq 
+3837 c3818000 rtnbit1 wack 
+3838 24768000 nrtn match 
+
+check_attempt_notimeout:
+3839 6800808a fetch 1 ,mem_current_sniff_attempt 
+383a 1fe0ffff increase -1 ,pdata 
+383b 6000808a store 1 ,mem_current_sniff_attempt 
+383c 20600000 rtn 
+
+sniff_check_window:
+383d 793f8025 set0 mark_ext_patch ,mark 
+383e 44bbc00e bpatch patch0e_7 ,mem_patch0e 
+383f 78487c00 disable swfine 
+3840 18423600 copy temp ,stop_watch 
+3841 20403300 call context_search_sniff_window 
+3842 78547c00 disable user 
+3843 24628000 nrtn zero 
+3844 18003600 force 0 ,stop_watch 
+3845 78347c00 enable user 
+3846 20600000 rtn 
+
+check_esco_amaddr:
+3847 6800c1f9 fetch 1 ,mem_esco_addr 
+3848 a881fe00 icompare 0xff ,am_addr 
+3849 20600000 rtn 
+
+play_sco:
+384a 793f8025 set0 mark_ext_patch ,mark 
+384b 44bc400f bpatch patch0f_0 ,mem_patch0f 
+384c 70417101 jam 1 ,mem_max_slot 
+384d 20406a40 call enable_pcm 
+384e 18007e0c force 12 ,pdata 
+384f 60010032 store 2 ,mem_tsniff 
+3850 680080af fetch 1 ,mem_esco_desco 
+3851 1fe3fe00 lshift pdata ,pdata 
+3852 60010075 store 2 ,mem_dsniff 
+3853 68008030 fetch 1 ,mem_state 
+3854 79207e02 set1 state_insco ,pdata 
+3855 60008030 store 1 ,mem_state 
+3856 70007303 jam 3 ,mem_sniff_attempt 
+3857 70008a03 jam 3 ,mem_current_sniff_attempt 
+3858 204037e1 call sniff_init 
+3859 18000400 force 0 ,temp 
+385a 20404914 call hci_send_sco_complete 
+385b 7000b350 jam 0x50 ,mem_esco_arq 
+385c 7000f110 jam param_sco_poll ,mem_sco_poll 
+385d 20600000 rtn 
+
+stop_sco:
+385e 793f8025 set0 mark_ext_patch ,mark 
+385f 44bcc00f bpatch patch0f_1 ,mem_patch0f 
+3860 20403806 call sniff_exit 
+3861 70417105 jam 5 ,mem_max_slot 
+3862 20406a4a call disable_pcm 
+3863 68008030 fetch 1 ,mem_state 
+3864 793ffe02 set0 state_insco ,pdata 
+3865 60008030 store 1 ,mem_state 
+
+stop_sco_hci:
+3866 d8400e00 arg 0xe00 ,temp 
+3867 7002c013 jam hci_error_remote_user_ended_connection ,mem_hci_disconn_reason 
+3868 202048c4 branch hci_send_disconn_complete 
+
+stop_esco:
+3869 793f8025 set0 mark_ext_patch ,mark 
+386a 44bd400f bpatch patch0f_2 ,mem_patch0f 
+386b 7000b100 jam default_neogotiation_state ,mem_neogotiation_state 
+386c 2040385e call stop_sco 
+386d 20403290 call restore_esco 
+386e 793f8007 set0 mark_esco ,mark 
+386f 20600000 rtn 
+
+parse_l2cap:
+3870 793f8025 set0 mark_ext_patch ,mark 
+3871 44bdc00f bpatch patch0f_3 ,mem_patch0f 
+3872 6800c132 fetch 1 ,mem_device_option 
+3873 c000b898 beq dvc_op_hci ,parse_l2cap_hci 
+3874 793f8001 set0 mark_rxbuf_inuse ,mark 
+
+parse_l2cap_cont:
+3875 7002d100 jam l2cap_rx_clear ,mem_l2cap_rx_done 
+3876 680082ca fetch 1 ,mem_l2cap_rxbuff_inuse 
+3877 207a0000 rtn blank 
+3878 2feffe00 isolate1 l2cap_inuse_buff1 ,pdata 
+3879 d8c01000 arg mem_l2cap_rxbuff1 ,contr 
+387a 2040cda8 call process_rx_l2cap_pkt ,true 
+387b 793f8025 set0 mark_ext_patch ,mark 
+387c 44be400f bpatch patch0f_4 ,mem_patch0f 
+387d 680082d1 fetch 1 ,mem_l2cap_rx_done 
+387e c000b88c beq l2cap_rx_done ,parse_l2cap_release_buff1 
+387f 7002d100 jam l2cap_rx_clear ,mem_l2cap_rx_done 
+3880 680082ca fetch 1 ,mem_l2cap_rxbuff_inuse 
+3881 c4008000 rtnbit0 l2cap_inuse_buff2 
+3882 d8c01400 arg mem_l2cap_rxbuff2 ,contr 
+3883 20404da8 call process_rx_l2cap_pkt 
+3884 680082d1 fetch 1 ,mem_l2cap_rx_done 
+3885 c000b892 beq l2cap_rx_done ,parse_l2cap_release_buff2 
+3886 20600000 rtn 
+
+parse_l2cap_exit:
+3887 6800804c fetch 1 ,mem_state_map 
+3888 793ffe07 set0 smap_rxl2cap ,pdata 
+3889 6000804c store 1 ,mem_state_map 
+388a 793f8001 set0 mark_rxbuf_inuse ,mark 
+388b 2020443b branch h4_send_acl_trigger_clear 
+
+parse_l2cap_release_buff1:
+388c 680082ca fetch 1 ,mem_l2cap_rxbuff_inuse 
+388d 793ffe00 set0 l2cap_inuse_buff1 ,pdata 
+388e 600082ca store 1 ,mem_l2cap_rxbuff_inuse 
+388f 58000000 setarg 0 
+3890 600102c4 store 2 ,mem_l2cap_rxbuff1_len 
+3891 20600000 rtn 
+
+parse_l2cap_release_buff2:
+3892 680082ca fetch 1 ,mem_l2cap_rxbuff_inuse 
+3893 793ffe01 set0 l2cap_inuse_buff2 ,pdata 
+3894 600082ca store 1 ,mem_l2cap_rxbuff_inuse 
+3895 58000000 setarg 0 
+3896 600102c6 store 2 ,mem_l2cap_rxbuff2_len 
+3897 20600000 rtn 
+
+parse_l2cap_hci:
+3898 6800804c fetch 1 ,mem_state_map 
+3899 c4038000 rtnbit0 smap_rxl2cap ,pdata 
+389a 20404435 call h4_send_acl_trigger 
+389b 68014800 fetch 2 ,mem_acl_credits 
+389c 203a3bf1 branch assert ,blank 
+389d 1fe0ffff increase -1 ,pdata 
+389e 60014800 store 2 ,mem_acl_credits 
+389f 20203887 branch parse_l2cap_exit 
+
+l2cap_buff1_inuse:
+38a0 680082ca fetch 1 ,mem_l2cap_rxbuff_inuse 
+38a1 79207e00 set1 l2cap_inuse_buff1 ,pdata 
+38a2 600082ca store 1 ,mem_l2cap_rxbuff_inuse 
+38a3 20600000 rtn 
+
+l2cap_buff2_inuse:
+38a4 680082ca fetch 1 ,mem_l2cap_rxbuff_inuse 
+38a5 79207e01 set1 l2cap_inuse_buff2 ,pdata 
+38a6 600082ca store 1 ,mem_l2cap_rxbuff_inuse 
+38a7 20600000 rtn 
+
+slave_send_access:
+38a8 793f8025 set0 mark_ext_patch ,mark 
+38a9 44bec00f bpatch patch0f_5 ,mem_patch0f 
+38aa 1d00c201 add clke_bt ,1 ,bt_clk 
+38ab 20403a5d call fetch_extm_bt_adr 
+38ac 18004803 force 0x03 ,freq_mode 
+38ad 20403a42 call tx_radio_freq 
+38ae 20403bae call start_transmitter 
+38af 20403bbf call start_tx_external 
+38b0 20203bc5 branch send_access_word 
+
+slave_conn_send_packet:
+38b1 793f8025 set0 mark_ext_patch ,mark 
+38b2 44bf400f bpatch patch0f_6 ,mem_patch0f 
+38b3 20403baa call rf_setup_time_slave_slot 
+38b4 1d027e00 deposit clke_bt 
+38b5 680a416a fetcht 4 ,mem_next_btclk 
+38b6 98467e00 isub temp ,pdata 
+38b7 c1808000 rtnne 1 
+38b8 28203e00 compare type_null ,type ,0x1f 
+38b9 2420b8bc nbranch slave_conn_send_access ,true 
+38ba 68008019 fetch 1 ,mem_rx_type 
+38bb 207a0000 rtn blank 
+
+slave_conn_send_access:
+38bc 204038a8 call slave_send_access 
+38bd 28203e10 compare type_id ,type ,0x1f 
+38be 2020b75c branch end_of_packet ,true 
+
+transmit_packet:
+38bf 1c230400 rshift bt_clk ,temp 
+38c0 18419c40 or temp ,0x40 ,white_init 
+
+transmit_packet_whitened:
+38c1 793f8025 set0 mark_ext_patch ,mark 
+38c2 44bfc00f bpatch patch0f_7 ,mem_patch0f 
+38c3 7823fc00 enable enable_white 
+38c4 78257c00 enable enable_hec 
+38c5 782dfc00 enable encode_fec1 
+38c6 793f8010 set0 mark_longpacket ,mark 
+38c7 18827e00 deposit am_addr 
+38c8 08008603 inject mod ,3 
+38c9 18227e00 deposit type 
+38ca 08008604 inject mod ,4 
+38cb 68008047 fetch 1 ,mem_arq 
+38cc 08008004 inject bucket ,4 
+38cd 08008603 inject mod ,3 
+38ce 78247c00 enable enable_parity 
+38cf 08008608 inject mod ,8 
+38d0 784dfc00 disable encode_fec1 
+38d1 78447c00 disable enable_parity 
+38d2 78457c00 disable enable_hec 
+38d3 793faa02 set0 psk3m ,radio_ctrl 
+38d4 d8400000 arg 0 ,temp 
+38d5 20403b74 call reserve_slot 
+38d6 793f8025 set0 mark_ext_patch ,mark 
+38d7 44c04010 bpatch patch10_0 ,mem_patch10 
+38d8 18217e1f and type ,0x1f ,pdata 
+38d9 c009b913 beq type_lmp ,transmit_lmp 
+38da c000375c beq type_null ,end_of_packet 
+38db c000b75c beq type_poll ,end_of_packet 
+38dc c00138f5 beq type_fhs ,transmit_fhs 
+38dd c001b925 beq type_dm1 ,transmit_dm1 
+38de c002392b beq type_dh1 ,transmit_dh1 
+38df c003b8e9 beq type_hv3 ,transmit_hev 
+38e0 c004392a beq type_3dh1 ,transmit_3dh1 
+38e1 d8400004 arg 4 ,temp 
+38e2 20403b74 call reserve_slot 
+38e3 c0053927 beq type_dm3 ,transmit_dm3 
+38e4 c005b92d beq type_dh3 ,transmit_dh3 
+38e5 d8400008 arg 8 ,temp 
+38e6 20403b74 call reserve_slot 
+38e7 c007b92d beq type_dh5 ,transmit_dh5 
+38e8 20203927 branch transmit_dm5 
+
+transmit_hev:
+38e9 793f8025 set0 mark_ext_patch ,mark 
+38ea 44c0c010 bpatch patch10_1 ,mem_patch10 
+38eb 782efc00 enable encode_fec0 
+38ec 7824fc00 enable enable_crc 
+38ed 78277c00 enable encrypt 
+38ee 1800721e force 30 ,loopcnt 
+38ef d8c000b5 arg mem_sco_obuf ,contr 
+
+transmit_ev_loop:
+38f0 e8c08000 ifetch 1 ,contr 
+38f1 08008608 inject mod ,8 
+38f2 c20038f0 loop transmit_ev_loop 
+38f3 c503b960 bmark1 mark_esco ,transmit_end 
+38f4 2020375c branch end_of_packet 
+
+transmit_fhs:
+38f5 793f8025 set0 mark_ext_patch ,mark 
+38f6 44c14010 bpatch patch10_2 ,mem_patch10 
+38f7 6800818b fetch 1 ,mem_fhs_am_addr 
+38f8 1fe20800 icopy am_addr 
+38f9 6800808f fetch 1 ,mem_fhs_misc 
+38fa 1fe23800 icopy fhs_misc 
+38fb 6801c14a fetch 3 ,mem_class 
+38fc 1fe23a00 icopy fhs_class 
+38fd 68014144 fetch 2 ,mem_nap 
+38fe 1fe25c00 icopy nap 
+38ff 7824fc00 enable enable_crc 
+3900 782e7c00 enable encode_fec2 
+3901 1c022200 copy bt_adr ,rega 
+3902 20403a54 call fetch_self_bt_adr 
+3903 782afc00 pulse recalc 
+3904 20000020 nop 32 
+3905 1c221600 copy bt_clk ,timeup 
+3906 6802016b fetch 4 ,mem_clkn_bt 
+3907 1fe24200 icopy bt_clk 
+3908 53c07e00 preload fhs0 
+3909 79207e3a set1 58 ,pdata 
+390a 08008648 inject mod ,72 
+390b 53e07e00 preload fhs1 
+390c 08008648 inject mod ,72 
+390d 19624200 copy timeup ,bt_clk 
+390e 1a224000 copy rega ,bt_adr 
+390f 78247c00 enable enable_parity 
+3910 08008610 inject mod ,16 
+3911 78447c00 disable enable_parity 
+3912 2020375c branch end_of_packet 
+
+transmit_lmp:
+3913 793f8025 set0 mark_ext_patch ,mark 
+3914 44c1c010 bpatch patch10_3 ,mem_patch10 
+3915 78277c00 enable encrypt 
+3916 7824fc00 enable enable_crc 
+3917 782e7c00 enable encode_fec2 
+3918 68008432 fetch 1 ,mem_lmo_header_length 
+3919 1fe105f8 and pdata ,0x1f8 ,temp 
+391a d8c00432 arg mem_lmo_header_length ,contr 
+391b 18408408 increase 8 ,temp 
+
+transmit_lmp_loop:
+391c 1840a7b8 add temp ,-72 ,regc 
+391d 24213922 nbranch transmit_lmp_finish ,positive 
+391e e8c48000 ifetch 9 ,contr 
+391f 08008648 inject mod ,72 
+3920 1a620400 copy regc ,temp 
+3921 2020391c branch transmit_lmp_loop 
+
+transmit_lmp_finish:
+3922 e8c48000 ifetch 9 ,contr 
+3923 08418600 iinject mod ,temp 
+3924 20203960 branch transmit_end 
+
+transmit_dm1:
+3925 782e7c00 enable encode_fec2 
+3926 20203930 branch transmit_dmh 
+
+transmit_dm3:
+
+transmit_dm5:
+3927 782e7c00 enable encode_fec2 
+3928 79200010 set1 mark_longpacket ,mark 
+3929 20203930 branch transmit_dmh 
+
+transmit_3dh1:
+392a 79202a02 set1 psk3m ,radio_ctrl 
+
+transmit_dh1:
+392b 782efc00 enable encode_fec0 
+392c 20203930 branch transmit_dmh 
+
+transmit_dh3:
+
+transmit_dh5:
+392d 79202a02 set1 psk3m ,radio_ctrl 
+392e 782efc00 enable encode_fec0 
+392f 79200010 set1 mark_longpacket ,mark 
+
+transmit_dmh:
+3930 793f8025 set0 mark_ext_patch ,mark 
+3931 44c24010 bpatch patch10_4 ,mem_patch10 
+3932 6800804c fetch 1 ,mem_state_map 
+3933 c302b946 bbit0 smap_edr ,transmit_noedr 
+3934 18267c03 sub type ,3 ,null 
+3935 20213946 branch transmit_noedr ,positive 
+3936 78477c00 disable encrypt 
+3937 784e7c00 disable encode_fec2 
+3938 782efc00 enable encode_fec0 
+3939 7843fc00 disable enable_white 
+393a 79202a01 set1 psk ,radio_ctrl 
+393b 2aaffe02 isolate1 psk3m ,radio_ctrl 
+393c 2020b940 branch transmit_edr3m ,true 
+393d 580abeee setarg 0xabeee 
+393e 08008614 inject mod ,20 
+393f 20203944 branch transmit_edr_sync_end 
+
+transmit_edr3m:
+3940 585faeba setarg 0x5faeba 
+3941 08008618 inject mod ,24 
+3942 58000012 setarg 0x12 
+3943 08008606 inject mod ,6 
+
+transmit_edr_sync_end:
+3944 7823fc00 enable enable_white 
+3945 79200010 set1 mark_longpacket ,mark 
+
+transmit_noedr:
+3946 78277c00 enable encrypt 
+3947 7824fc00 enable enable_crc 
+3948 c502b969 bmark1 mark_loopback ,transmit_loopback 
+3949 68008090 fetch 1 ,mem_tx_lch 
+394a 08008603 inject mod ,3 
+394b 68010091 fetch 2 ,mem_tx_len 
+394c 98007200 iforce loopcnt 
+394d c5083950 bmark1 mark_longpacket ,transmit_long 
+394e 08008605 inject mod ,5 
+394f 20203951 branch transmit_stuff 
+
+transmit_long:
+3950 0800860d inject mod ,13 
+
+transmit_stuff:
+3951 6800c132 fetch 1 ,mem_device_option 
+3952 c000b95b beq dvc_op_hci ,transmit_stuff_hci 
+3953 1f227e00 deposit loopcnt 
+3954 203a3960 branch transmit_end ,blank 
+3955 68010179 fetch 2 ,mem_txptr 
+3956 98000c00 iforce contr 
+
+transmit_stuff_loop:
+3957 e8c08000 ifetch 1 ,contr 
+3958 08008608 inject mod ,8 
+3959 c2003957 loop transmit_stuff_loop 
+395a 20203960 branch transmit_end 
+
+transmit_stuff_hci:
+395b 68010179 fetch 2 ,mem_txptr 
+395c 98000600 iforce contru 
+
+transmit_stuff_hci_loop:
+395d e8608000 ifetch 1 ,contru 
+395e 08008608 inject mod ,8 
+395f c200395d loop transmit_stuff_hci_loop 
+
+transmit_end:
+3960 78247c00 enable enable_parity 
+3961 08008610 inject mod ,16 
+3962 78447c00 disable enable_parity 
+3963 20403583 call set_wait_ack 
+3964 6800804c fetch 1 ,mem_state_map 
+3965 c302b75c bbit0 smap_edr ,end_of_packet 
+3966 18007e00 force 0 ,pdata 
+3967 08008606 inject mod ,6 
+3968 2020375c branch end_of_packet 
+
+transmit_loopback:
+3969 793f8025 set0 mark_ext_patch ,mark 
+396a 44c2c010 bpatch patch10_5 ,mem_patch10 
+396b c5083972 bmark1 mark_longpacket ,transmit_loopback_long 
+
+transmit_loopback_short:
+396c 6800818a fetch 1 ,mem_lch_code 
+396d 08008603 inject mod ,3 
+396e 68008169 fetch 1 ,mem_len 
+396f 98002600 iforce regc 
+3970 08008605 inject mod ,5 
+3971 20203977 branch transmit_loopback_cont 
+
+transmit_loopback_long:
+3972 6800818a fetch 1 ,mem_lch_code 
+3973 08008603 inject mod ,3 
+3974 68010169 fetch 2 ,mem_len 
+3975 98002600 iforce regc 
+3976 0800860d inject mod ,13 
+
+transmit_loopback_cont:
+3977 d8c004de arg mem_rxbuf ,contr 
+
+transmit_loopback_loop:
+3978 1a627c00 copy regc ,null 
+3979 2022b97e branch transmit_loopback_end ,zero 
+397a e8c08000 ifetch 1 ,contr 
+397b 08008608 inject mod ,8 
+397c 1a60a7ff increase -1 ,regc 
+397d 20203978 branch transmit_loopback_loop 
+
+transmit_loopback_end:
+397e 680100fe fetch 2 ,mem_tst_pktcnt_dmh 
+397f 1fe0fe01 increase 1 ,pdata 
+3980 600100fe store 2 ,mem_tst_pktcnt_dmh 
+3981 20203960 branch transmit_end 
+
+apply_switch_clke:
+3982 6802016f fetch 4 ,mem_clke_bt 
+3983 1fe0a207 add pdata ,7 ,rega 
+3984 6801017b fetch 2 ,mem_slot_offset 
+3985 243a3988 nbranch apply_switch_nozero ,blank 
+3986 1a20a3fd increase -3 ,rega 
+3987 20203990 branch apply_switch_wait_loop 
+
+apply_switch_nozero:
+3988 1feffe0c mul32 pdata ,12 ,pdata 
+3989 68190040 hfetcht 2 ,core_halfslot 
+398a 18408401 increase 1 ,temp 
+
+apply_switch_loop:
+398b 98467e00 isub temp ,pdata 
+398c 2421398f nbranch apply_switch_bt ,positive 
+398d 1a20a3ff increase -1 ,rega 
+398e 2020398b branch apply_switch_loop 
+
+apply_switch_bt:
+398f 1fe67e00 sub pdata ,0 ,pdata 
+
+apply_switch_wait_loop:
+3990 37d18200 until null ,oneslot 
+3991 2c400600 compare 0 ,clkn_bt ,3 
+3992 2420b990 nbranch apply_switch_wait_loop ,true 
+3993 98005200 iforce clke_rt 
+3994 1a225000 copy rega ,clke_bt 
+3995 98005200 iforce clke_rt 
+3996 20600000 rtn 
+
+calc_slot_offset:
+3997 793f8025 set0 mark_ext_patch ,mark 
+3998 44c34010 bpatch patch10_6 ,mem_patch10 
+3999 37d10200 until null ,halfslot 
+399a 1b427e00 deposit clke 
+399b 98000c00 iforce contr 
+399c 1ff17e00 rshift16 ,pdata ,pdata 
+399d 9c467200 isub clkn_bt ,loopcnt 
+399e 1f217203 and_into 3 ,loopcnt 
+399f 2422b9a2 nbranch calc_bt_portion ,zero 
+39a0 18007e00 force 0 ,pdata 
+39a1 202039a6 branch calc_skip_bt 
+
+calc_bt_portion:
+39a2 d8400ea6 arg 3750 ,temp 
+39a3 18007e00 force 0 ,pdata 
+
+calc_slot_offset_loop:
+39a4 9840fe00 iadd temp ,pdata 
+39a5 c20039a4 loop calc_slot_offset_loop 
+
+calc_skip_bt:
+39a6 98c0fe00 iadd contr ,pdata 
+39a7 1fe6fc0c div pdata ,12 
+39a8 20407efd call wait_div_end 
+39a9 1807fe00 quotient pdata 
+39aa 6001017b store 2 ,mem_slot_offset 
+39ab 20600000 rtn 
+
+calc_clke_offset:
+39ac 793f8025 set0 mark_ext_patch ,mark 
+39ad 44c3c010 bpatch patch10_7 ,mem_patch10 
+39ae 1b427e00 deposit clke 
+39af 1b220400 copy clkn ,temp 
+39b0 98467c00 isub temp ,null 
+39b1 7d217e2c nsetflag positive ,44 ,pdata 
+39b2 98460400 isub temp ,temp 
+39b3 58000ea6 setarg 3750 
+39b4 284c000f isolate0 15 ,temp 
+39b5 2020b9b8 branch calc_clke_pos ,true 
+39b6 5fff0ea6 setarg -61786 
+39b7 98408400 iadd temp ,temp 
+
+calc_clke_pos:
+39b8 600b03c8 storet 6 ,mem_le_clk_offset 
+39b9 207b0000 rtn le 
+39ba 600b0038 storet 6 ,mem_clk_offset 
+39bb 20600000 rtn 
+
+calc_clke:
+39bc 78587c00 disable clknt 
+39bd 680303c8 fetch 6 ,mem_le_clk_offset 
+39be 203b39c0 branch calc_clke2 ,le 
+39bf 68030038 fetch 6 ,mem_clk_offset 
+
+calc_clke2:
+39c0 9b20e000 iadd clkn ,alarm 
+39c1 1e00e00a increase 10 ,alarm 
+39c2 58000ea6 setarg 3750 
+39c3 9e067e00 isub alarm ,pdata 
+39c4 2fec000f isolate0 15 ,pdata 
+39c5 2020b9ca branch calc_clke_pos_adj ,true 
+39c6 5800f15a setarg 0xf15a 
+39c7 9e00e000 iadd alarm ,alarm 
+
+calc_clke_pos2:
+39c8 1e023400 copy alarm ,clke 
+39c9 20600000 rtn 
+
+calc_clke_pos_adj:
+39ca 18007c00 force 0 ,null 
+39cb 202039c8 branch calc_clke_pos2 
+
+calc_radio_freq:
+39cc 793f8025 set0 mark_ext_patch ,mark 
+39cd 44c44011 bpatch patch11_0 ,mem_patch11 
+39ce 20403a7a call set_sync_on 
+39cf 1c227e00 copy bt_clk ,pdata 
+39d0 1fe17f80 and_into 0x180 ,pdata 
+39d1 2c800e03 compare 3 ,freq_mode ,0x07 
+39d2 2420b9d6 nbranch freq_not_connection ,true 
+39d3 1fe97e00 rshift3 pdata ,pdata 
+39d4 9ae0fe00 iadd freq_index ,pdata 
+39d5 202039d7 branch do_hop_mod_now 
+
+freq_not_connection:
+39d6 1ae27e00 copy freq_index ,pdata 
+
+do_hop_mod_now:
+39d7 1fe6fc4f div pdata ,79 
+39d8 782afc00 pulse recalc 
+39d9 20407efd call wait_div_end 
+39da 18072200 remainder rega 
+39db 1a2085d8 add rega ,-40 ,temp 
+39dc 202139df branch odd_half ,positive 
+39dd 1a238400 lshift rega ,temp 
+39de 202039e1 branch freq_result 
+
+odd_half:
+39df 18438400 lshift temp ,temp 
+39e0 18408401 increase 1 ,temp 
+
+freq_result:
+39e1 793f8025 set0 mark_ext_patch ,mark 
+39e2 44c4c011 bpatch patch11_1 ,mem_patch11 
+39e3 68008031 fetch 1 ,mem_mode 
+39e4 c301b9f3 bbit0 afh_change ,afh_process_con 
+
+afh_process_0:
+39e5 68024173 fetch 4 ,mem_afh_instant 
+39e6 9c267c00 isub bt_clk ,null 
+39e7 202139f3 branch afh_process_con ,positive 
+39e8 20403a12 call afh_clear 
+39e9 6800c17a fetch 1 ,mem_afh_new_mod 
+39ea 207a0000 rtn blank 
+39eb 68008031 fetch 1 ,mem_mode 
+39ec 79207e02 set1 afh_enable ,pdata 
+39ed 60008031 store 1 ,mem_mode 
+39ee 6802c188 fetch 5 ,mem_afh_map_new 
+39ef 6002c17b store 5 ,mem_afh_map_lo 
+39f0 e8c28000 ifetch 5 ,contr 
+39f1 6002c180 store 5 ,mem_afh_map_hi 
+39f2 20403a17 call afh_process_freq_map 
+
+afh_process_con:
+39f3 68008031 fetch 1 ,mem_mode 
+39f4 c4010000 rtnbit0 afh_enable 
+39f5 2c2ffe01 isolate1 1 ,bt_clk 
+39f6 2020ba0f branch afh_same_channel ,true 
+39f7 18492200 rshift3 temp ,rega 
+39f8 18410e07 and temp ,7 ,queue 
+39f9 5800417b setarg mem_afh_map_lo 
+39fa 9a20a200 iadd rega ,rega 
+39fb ea208000 ifetch 1 ,rega 
+39fc afec0000 qisolate0 pdata 
+39fd 2020ba00 branch afh_process_1 ,true 
+39fe 18427e00 deposit temp 
+39ff 20203a0c branch afh_process_end 
+
+afh_process_1:
+3a00 6800c185 fetch 1 ,mem_afh_used 
+3a01 98002400 iforce regb 
+3a02 1c227e00 deposit bt_clk 
+3a03 1fe17f80 and_into 0x180 ,pdata 
+3a04 1fe97e00 rshift3 pdata ,pdata 
+3a05 9ae0fe00 iadd freq_index ,pdata 
+3a06 9a46fc00 idiv regb 
+3a07 58004193 setarg mem_afh_map 
+3a08 20407efd call wait_div_end 
+3a09 18072200 remainder rega 
+3a0a 9a208c00 iadd rega ,contr 
+3a0b e8c08000 ifetch 1 ,contr 
+
+afh_process_end:
+3a0c 6000c186 store 1 ,mem_afh_index 
+3a0d 98000400 iforce temp 
+3a0e 20600000 rtn 
+
+afh_same_channel:
+3a0f 6800c186 fetch 1 ,mem_afh_index 
+3a10 98000400 iforce temp 
+3a11 20600000 rtn 
+
+afh_clear:
+3a12 68008031 fetch 1 ,mem_mode 
+3a13 793ffe02 set0 afh_enable ,pdata 
+3a14 793ffe03 set0 afh_change ,pdata 
+3a15 60008031 store 1 ,mem_mode 
+3a16 20600000 rtn 
+
+afh_process_freq_map:
+3a17 793f8025 set0 mark_ext_patch ,mark 
+3a18 44c54011 bpatch patch11_2 ,mem_patch11 
+3a19 d8a04193 arg mem_afh_map ,contw 
+3a1a 1800720a force 10 ,loopcnt 
+3a1b 20407e3b call memset0 
+3a1c d8a04193 arg mem_afh_map ,contw 
+3a1d 18002600 force 0 ,regc 
+3a1e 18000e02 force 2 ,queue 
+
+process_freq_3:
+3a1f 6802c17b fetch 5 ,mem_afh_map_lo 
+3a20 98000400 iforce temp 
+3a21 28e1fe02 compare 2 ,queue ,0xff 
+3a22 2020ba24 branch process_freq_1 ,true 
+3a23 18430400 rshift temp ,temp 
+
+process_freq_1:
+3a24 284c0000 isolate0 0 ,temp 
+3a25 2020ba28 branch process_freq_0 ,true 
+3a26 1a627e00 deposit regc 
+3a27 e0a08000 istore 1 ,contw 
+
+process_freq_0:
+3a28 184b0400 rshift2 temp ,temp 
+3a29 1a60a602 increase 2 ,regc 
+3a2a 2a61fc28 compare 40 ,regc ,0xfe 
+3a2b 2420ba31 nbranch process_freq_2 ,true 
+3a2c 6802c180 fetch 5 ,mem_afh_map_hi 
+3a2d 98000400 iforce temp 
+3a2e 28e1fe02 compare 2 ,queue ,0xff 
+3a2f 2020ba31 branch process_freq_2 ,true 
+3a30 18430400 rshift temp ,temp 
+
+process_freq_2:
+3a31 1a667c4e sub regc ,78 ,null 
+3a32 20213a24 branch process_freq_1 ,positive 
+3a33 18002601 force 1 ,regc 
+3a34 18e08fff increase -1 ,queue 
+3a35 2422ba1f nbranch process_freq_3 ,zero 
+3a36 da204193 arg mem_afh_map ,rega 
+3a37 18a27e00 deposit contw 
+3a38 9a267e00 isub rega ,pdata 
+3a39 6000c185 store 1 ,mem_afh_used 
+3a3a 20600000 rtn 
+
+rx_radio_freq:
+3a3b 793f8025 set0 mark_ext_patch ,mark 
+3a3c 44c5c011 bpatch patch11_3 ,mem_patch11 
+3a3d 204039cc call calc_radio_freq 
+3a3e 68008189 fetch 1 ,mem_debug_config 
+3a3f c302ba41 bbit0 debug_rx_fixed_freq ,rx_radio_freq_now 
+3a40 68088448 fetcht 1 ,mem_rx_fixed_freq 
+
+rx_radio_freq_now:
+3a41 20203a82 branch set_freq_rx 
+
+tx_radio_freq:
+3a42 793f8025 set0 mark_ext_patch ,mark 
+3a43 44c64011 bpatch patch11_4 ,mem_patch11 
+3a44 204039cc call calc_radio_freq 
+3a45 68008189 fetch 1 ,mem_debug_config 
+3a46 c3023a48 bbit0 debug_tx_fixed_freq ,tx_radio_freq_now 
+3a47 68088447 fetcht 1 ,mem_tx_fixed_freq 
+
+tx_radio_freq_now:
+3a48 20203a91 branch set_freq_tx 
+
+fetch_giac:
+3a49 18005a00 force 0 ,uap 
+3a4a 6801c147 fetch 3 ,mem_glap 
+3a4b 98005800 iforce lap 
+3a4c 20600000 rtn 
+
+fetch_page_bt_adr:
+3a4d 793f8025 set0 mark_ext_patch ,mark 
+3a4e 44c6c011 bpatch patch11_5 ,mem_patch11 
+3a4f 6800c277 fetch 1 ,mem_hci_puap 
+3a50 1fe25a00 icopy uap 
+3a51 6801c274 fetch 3 ,mem_hci_plap 
+3a52 1fe25800 icopy lap 
+3a53 20600000 rtn 
+
+fetch_self_bt_adr:
+3a54 793f8025 set0 mark_ext_patch ,mark 
+3a55 44c74011 bpatch patch11_6 ,mem_patch11 
+3a56 68014144 fetch 2 ,mem_nap 
+3a57 1fe25c00 icopy nap 
+3a58 6800c143 fetch 1 ,mem_uap 
+3a59 1fe25a00 icopy uap 
+3a5a 6801c140 fetch 3 ,mem_lap 
+3a5b 1fe25800 icopy lap 
+3a5c 20600000 rtn 
+
+fetch_extm_bt_adr:
+3a5d 793f8025 set0 mark_ext_patch ,mark 
+3a5e 44c7c011 bpatch patch11_7 ,mem_patch11 
+3a5f 68010044 fetch 2 ,mem_pnap 
+3a60 1fe25c00 icopy nap 
+3a61 68008043 fetch 1 ,mem_puap 
+3a62 1fe25a00 icopy uap 
+3a63 68018040 fetch 3 ,mem_plap 
+3a64 1fe25800 icopy lap 
+3a65 20600000 rtn 
+
+fetch_diac:
+3a66 c5103a69 bmark1 mark_all_diac ,fetch_diac_do 
+3a67 c68e8000 rtnmark0 mark_inquiry_state 
+3a68 c68f8000 rtnmark0 mark_periodical_diac 
+
+fetch_diac_do:
+3a69 1d815900 and_into -256 ,lap 
+3a6a 782afc00 pulse recalc 
+3a6b 20000020 nop 32 
+3a6c 20600000 rtn 
+
+shutdown_radio:
+3a6d 793f8025 set0 mark_ext_patch ,mark 
+3a6e 44c84012 bpatch patch12_0 ,mem_patch12 
+3a6f 18002a00 force 0 ,radio_ctrl 
+3a70 7850fc00 disable is_rx 
+3a71 78507c00 disable is_tx 
+3a72 782f7c00 pulse packet_end 
+3a73 70890200 hjam 0x0 ,rfen_mdm 
+3a74 70890100 hjam 0x0 ,rfen_tx 
+3a75 70890000 hjam 0x0 ,rfen_rx 
+3a76 70890300 hjam 0 ,rfen_sn 
+3a77 70890470 hjam 0x70 ,rfen_msc 
+3a78 70890600 hjam 0x0 ,rfen_adc 
+3a79 20600000 rtn 
+
+set_sync_on:
+3a7a 793f8025 set0 mark_ext_patch ,mark 
+3a7b 44c8c012 bpatch patch12_1 ,mem_patch12 
+3a7c 70890200 hjam 0x0 ,rfen_mdm 
+3a7d 70890100 hjam 0x0 ,rfen_tx 
+3a7e 70890018 hjam 0x18 ,rfen_rx 
+3a7f 708903a7 hjam 0xa7 ,rfen_sn 
+3a80 7089047f hjam 0x7f ,rfen_msc 
+3a81 20600000 rtn 
+
+set_freq_rx:
+3a82 793f8025 set0 mark_ext_patch ,mark 
+3a83 44c94012 bpatch patch12_2 ,mem_patch12 
+3a84 60088017 storet 1 ,mem_last_freq 
+3a85 1840a204 add temp ,rx_freq_offset ,rega 
+3a86 20203ab6 branch rf_write_freq 
+
+rf_rx_enable:
+3a87 793f8025 set0 mark_ext_patch ,mark 
+3a88 44c9c012 bpatch patch12_3 ,mem_patch12 
+3a89 708901cf hjam 0xcf ,rfen_tx 
+3a8a 2000000a nop 10 
+3a8b 708900ff hjam 0xff ,rfen_rx 
+3a8c 708903af hjam 0xaf ,rfen_sn 
+3a8d 708904ff hjam 0xff ,rfen_msc 
+3a8e 2000000a nop 10 
+3a8f 708902a0 hjam 0xa0 ,rfen_mdm 
+3a90 20600000 rtn 
+
+set_freq_tx:
+3a91 793f8025 set0 mark_ext_patch ,mark 
+3a92 44ca4012 bpatch patch12_4 ,mem_patch12 
+3a93 60088017 storet 1 ,mem_last_freq 
+3a94 1840a202 add temp ,tx_freq_offset ,rega 
+3a95 20403ab6 call rf_write_freq 
+3a96 58000500 setarg param_pll_setup 
+3a97 20403bf3 call sleep 
+
+txon:
+3a98 70890601 hjam 0x1 ,rfen_adc 
+3a99 7089003c hjam 0x3c ,rfen_rx 
+3a9a 708901e0 hjam 0xe0 ,rfen_tx 
+3a9b 708903b7 hjam 0xb7 ,rfen_sn 
+3a9c 7089027f hjam 0x7f ,rfen_mdm 
+3a9d 20600000 rtn 
+
+initialize_radio:
+3a9e 70804206 hjam clksel_rc ,core_clksel 
+3a9f 20403c29 call init_rf_regs 
+3aa0 20403c3a call init_agc_table 
+
+initialize_radio_wait:
+3aa1 68014163 fetch 2 ,mem_rf_init_ptr 
+3aa2 c3073aa1 bbit0 14 ,initialize_radio_wait 
+3aa3 98000c00 iforce contr 
+3aa4 d8408900 arg 0x8900 ,temp 
+
+initialize_radio_loop:
+3aa5 e8c08000 ifetch 1 ,contr 
+3aa6 c07fbaab beq 0xff ,initialize_radio_cont 
+3aa7 98418a00 ior temp ,contw 
+3aa8 e8c08000 ifetch 1 ,contr 
+3aa9 e0a08000 istore 1 ,contw 
+3aaa 20203aa5 branch initialize_radio_loop 
+
+initialize_radio_cont:
+3aab 793f8025 set0 mark_ext_patch ,mark 
+3aac 44cac012 bpatch patch12_5 ,mem_patch12 
+3aad 20403d91 call lpm_cal_xtal_startup 
+3aae 20403b0a call switchto_dpllclk 
+3aaf 580007d0 setarg param_dpll_start_delay 
+3ab0 9c40fe00 iadd clkn_bt ,pdata 
+3ab1 60020173 store 4 ,mem_dpll_clkn 
+3ab2 79202a03 set1 reset ,radio_ctrl 
+3ab3 18002a00 force 0 ,radio_ctrl 
+3ab4 2455bace ncall do_rccal ,wake 
+3ab5 20203ae2 branch set_rccal 
+
+rf_write_freq:
+3ab6 793f8025 set0 mark_ext_patch ,mark 
+3ab7 44cb4012 bpatch patch12_6 ,mem_patch12 
+3ab8 58000960 setarg 2400 
+3ab9 9a208400 iadd rega ,temp 
+3aba 6800c15d fetch 1 ,mem_fcomp_mul 
+3abb 70895f04 hjam 0x04 ,rf_pll_rstn 
+3abc 984ffe00 imul32 temp ,pdata 
+3abd 6808c15e fetcht 1 ,mem_fcomp_div 
+3abe 9846fc00 idiv temp 
+3abf 20407efd call wait_div_end 
+3ac0 1807a200 quotient rega 
+3ac1 18077e00 remainder pdata 
+3ac2 1ff07e00 lshift16 pdata ,pdata 
+3ac3 1ff27e00 lshift4 pdata ,pdata 
+3ac4 9846fc00 idiv temp 
+3ac5 20407efd call wait_div_end 
+3ac6 1807fe00 quotient pdata 
+3ac7 1fed7e00 lshift8 pdata ,pdata 
+3ac8 1fe3fe00 lshift pdata ,pdata 
+3ac9 9a21fe00 ior rega ,pdata 
+3aca 60120960 hstore 4 ,rf_pll_intg 
+3acb 70895f44 hjam 0x44 ,rf_pll_rstn 
+3acc 70895fc4 hjam 0xc4 ,rf_pll_rstn 
+3acd 20600000 rtn 
+
+do_rccal:
+3ace 793f8025 set0 mark_ext_patch ,mark 
+3acf 44cbc012 bpatch patch12_7 ,mem_patch12 
+3ad0 70890602 hjam 0x02 ,rfen_adc 
+3ad1 5803d090 setarg 250000 
+3ad2 20403bf3 call sleep 
+3ad3 7089007f hjam 0x7f ,rfen_rx 
+3ad4 20000082 nop 130 
+3ad5 70895230 hjam 0x30 ,rf_rccal_ctrl 
+3ad6 708901d0 hjam 0xd0 ,rfen_tx 
+3ad7 70895270 hjam 0x70 ,rf_rccal_ctrl 
+3ad8 708952f0 hjam 0xf0 ,rf_rccal_ctrl 
+3ad9 18007232 force 50 ,loopcnt 
+
+do_rccal_loop:
+3ada 68108980 hfetch 1 ,rf_rccal_result 
+3adb c282badd bbit1 5 ,do_rccal_end 
+3adc c2003ada loop do_rccal_loop 
+
+do_rccal_end:
+3add 6000c16f store 1 ,mem_rf_rccal 
+3ade 70890100 hjam 0 ,rfen_tx 
+3adf 70890000 hjam 0 ,rfen_rx 
+3ae0 70890600 hjam 0x00 ,rfen_adc 
+3ae1 20600000 rtn 
+
+set_rccal:
+3ae2 793f8025 set0 mark_ext_patch ,mark 
+3ae3 44cc4013 bpatch patch13_0 ,mem_patch13 
+3ae4 6800c16f fetch 1 ,mem_rf_rccal 
+3ae5 79207e05 set1 5 ,pdata 
+3ae6 60108952 hstore 1 ,rf_rccal_ctrl 
+3ae7 68188950 hfetcht 1 ,rf_bpf_ctrim 
+3ae8 18410407 and_into 7 ,temp 
+3ae9 1fe9fe00 lshift3 pdata ,pdata 
+3aea 9841fe00 ior temp ,pdata 
+3aeb 60108950 hstore 1 ,rf_bpf_ctrim 
+3aec 68108951 hfetch 1 ,rf_bpf_ib 
+3aed 793ffe00 set0 bpf_rccal ,pdata 
+3aee 60108951 hstore 1 ,rf_bpf_ib 
+3aef 68108952 hfetch 1 ,rf_adc_rccal 
+3af0 793ffe05 set0 adc_rccal ,pdata 
+3af1 60108952 hstore 1 ,rf_adc_rccal 
+3af2 20600000 rtn 
+
+save_rssi:
+3af3 793f8025 set0 mark_ext_patch ,mark 
+3af4 44ccc013 bpatch patch13_1 ,mem_patch13 
+3af5 68110981 hfetch 2 ,rf_afc_d2a 
+3af6 1ff1fe00 rshift4 pdata ,pdata 
+3af7 1fe97e00 rshift3 pdata ,pdata 
+3af8 1fe67e00 sub pdata ,0 ,pdata 
+3af9 1fe17eff and_into 0xff ,pdata 
+3afa 1fe6fc0a div pdata ,10 
+3afb 20407efd call wait_div_end 
+3afc 1807fe00 quotient pdata 
+3afd 1ff27e00 lshift4 pdata ,pdata 
+3afe 18070400 remainder temp 
+3aff 9841fe00 ior temp ,pdata 
+3b00 60008018 store 1 ,mem_rssi 
+3b01 20600000 rtn 
+
+switchto_rcclk:
+3b02 7080420a hjam 0xa ,core_clksel 
+3b03 70890500 hjam 0 ,rfen_ck 
+3b04 68118138 hfetch 3 ,core_lpm_ctrl 
+3b05 6011804c hstore 3 ,core_lpm_reg 
+3b06 70804cfc hjam 0xfc ,core_lpm_reg 
+3b07 20403db0 call lpm_write_ctrl 
+3b08 200003e8 nop 1000 
+3b09 20600000 rtn 
+
+switchto_dpllclk:
+3b0a 70804206 hjam clksel_rc ,core_clksel 
+3b0b 6810896b hfetch 1 ,rf_clkpll_frac + 2 
+3b0c 793ffe04 set0 4 ,pdata 
+3b0d 793ffe05 set0 5 ,pdata 
+3b0e 6010896b hstore 1 ,rf_clkpll_frac + 2 
+3b0f 70890500 hjam 0x00 ,rfen_ck 
+3b10 70890400 hjam 0x00 ,rfen_msc 
+3b11 70890470 hjam 0x70 ,rfen_msc 
+3b12 708905ff hjam 0xff ,rfen_ck 
+3b13 6810896b hfetch 1 ,rf_clkpll_frac + 2 
+3b14 79207e04 set1 4 ,pdata 
+3b15 79207e05 set1 5 ,pdata 
+3b16 6010896b hstore 1 ,rf_clkpll_frac + 2 
+3b17 20403b38 call init_lpm_ctrl 
+3b18 68108968 hfetch 1 ,rf_clkpll_int 
+3b19 79207e07 set1 7 ,pdata 
+3b1a 60108968 hstore 1 ,rf_clkpll_int 
+3b1b 793ffe07 set0 7 ,pdata 
+3b1c 60108968 hstore 1 ,rf_clkpll_int 
+3b1d 79207e07 set1 7 ,pdata 
+3b1e 60108968 hstore 1 ,rf_clkpll_int 
+3b1f 70804205 hjam clksel_dpll ,core_clksel 
+3b20 20600000 rtn 
+
+check_dpll:
+3b21 200003e8 nop 1000 
+3b22 70804204 hjam clksel_xtal ,core_clksel 
+3b23 2000000a nop 10 
+3b24 7080b400 hjam 0x00 ,core_bist_ctrl 
+3b25 70800680 hjam ccnt_start ,core_misc_ctrl 
+
+check_dpll_loop:
+3b26 6810812d hfetch 1 ,core_perf_status 
+3b27 c300bb26 bbit0 1 ,check_dpll_loop 
+3b28 68198149 hfetcht 3 ,core_clk_counter 
+3b29 70804205 hjam clksel_dpll ,core_clksel 
+3b2a 2000000a nop 10 
+3b2b 70800680 hjam ccnt_start ,core_misc_ctrl 
+
+check_dpll_loop2:
+3b2c 6810812d hfetch 1 ,core_perf_status 
+3b2d c300bb2c bbit0 1 ,check_dpll_loop2 
+3b2e 68118149 hfetch 3 ,core_clk_counter 
+3b2f 98467e00 isub temp ,pdata 
+3b30 20213b32 branch check_dpll_pos ,positive 
+3b31 1fe67e00 sub pdata ,0 ,pdata 
+
+check_dpll_pos:
+3b32 6001018c store 2 ,mem_dpll_error 
+3b33 1fe67c46 sub pdata ,70 ,null 
+
+check_dpll_assert:
+3b34 24213b34 nbranch check_dpll_assert ,positive 
+3b35 20600000 rtn 
+
+xtal_fast_wake:
+3b36 58000f0f setarg 0xf0f 
+3b37 20203da7 branch lpm_write_config 
+
+init_lpm_ctrl:
+3b38 5800080f setarg 0x80f 
+3b39 20203da7 branch lpm_write_config 
+
+start_receiver:
+3b3a 793f8025 set0 mark_ext_patch ,mark 
+3b3b 44cd4013 bpatch patch13_2 ,mem_patch13 
+3b3c 20403a87 call rf_rx_enable 
+3b3d 78507c00 disable is_tx 
+3b3e 7830fc00 enable is_rx 
+3b3f 782b7c00 pulse init_encrypt 
+3b40 20600000 rtn 
+
+prep_crypt:
+3b41 793f8025 set0 mark_ext_patch ,mark 
+3b42 44cdc013 bpatch patch13_3 ,mem_patch13 
+3b43 6800804c fetch 1 ,mem_state_map 
+3b44 2feffe02 isolate1 smap_encryption ,pdata 
+3b45 7920fe00 setflag true ,0 ,pdata 
+3b46 60108011 hstore 1 ,core_encrypt 
+3b47 d8c00062 arg mem_kc ,contr 
+3b48 e8c48000 ifetch 9 ,contr 
+3b49 98006400 iforce kc_ls 
+3b4a e8c38000 ifetch 7 ,contr 
+3b4b 98006600 iforce kc_ms 
+3b4c 68008054 fetch 1 ,mem_key_size 
+3b4d 1fe0e9ff add pdata ,-1 ,g1l 
+3b4e 782d7c00 pulse kc_p_activate 
+3b4f 20600000 rtn 
+
+wait_access_clke_rt:
+3b50 793f8025 set0 mark_ext_patch ,mark 
+3b51 44ce4013 bpatch patch13_4 ,mem_patch13 
+3b52 7826fc00 enable decode_fec0 
+3b53 d9600600 arg param_conn_access ,timeup 
+3b54 35330400 correlate clke_rt ,meet 
+
+wait_access_end:
+3b55 1b427e00 deposit clke 
+3b56 6003009c store 6 ,mem_sync_clke 
+3b57 7846fc00 disable decode_fec0 
+3b58 242c3a6d nbranch shutdown_radio ,sync 
+3b59 dd2003bb arg param_clke_cal ,clke_rt 
+3b5a 1d00d001 increase 1 ,clke_bt 
+3b5b 1d0151fc and_into 0x1fc ,clke_bt 
+3b5c 20600000 rtn 
+
+wait_access_mhalfbnd:
+3b5d 7826fc00 enable decode_fec0 
+
+wait_access_mhalfbnd_correlate:
+3b5e 37cb8400 correlate null ,mhalfbnd 
+3b5f 202c3b55 branch wait_access_end ,sync 
+3b60 2d000402 compare 0x02 ,clke_bt ,0x02 
+3b61 2420bb5e nbranch wait_access_mhalfbnd_correlate ,true 
+3b62 20203b55 branch wait_access_end 
+
+wait_access_clkn_rt:
+3b63 793f8025 set0 mark_ext_patch ,mark 
+3b64 44cec013 bpatch patch13_5 ,mem_patch13 
+3b65 d9600600 arg param_conn_access ,timeup 
+3b66 7826fc00 enable decode_fec0 
+3b67 34730400 correlate clkn_rt ,meet 
+3b68 7846fc00 disable decode_fec0 
+3b69 242c3a6d nbranch shutdown_radio ,sync 
+3b6a 20600000 rtn 
+
+wait_access_forever:
+3b6b 793f8025 set0 mark_ext_patch ,mark 
+3b6c 44cf4013 bpatch patch13_6 ,mem_patch13 
+3b6d 7826fc00 enable decode_fec0 
+3b6e 37c18400 correlate null ,timeout 
+3b6f 7846fc00 disable decode_fec0 
+3b70 242c3a6d nbranch shutdown_radio ,sync 
+3b71 dd2003bb arg param_clke_cal ,clke_rt 
+3b72 1d0151fc and_into 0x1fc ,clke_bt 
+3b73 20600000 rtn 
+
+reserve_slot:
+3b74 793f8025 set0 mark_ext_patch ,mark 
+3b75 44cfc013 bpatch patch13_7 ,mem_patch13 
+3b76 98002200 iforce rega 
+3b77 1c227e00 deposit bt_clk 
+3b78 98409600 iadd temp ,timeup 
+3b79 19627e00 copy timeup ,pdata 
+3b7a 6002416a store 4 ,mem_next_btclk 
+3b7b 1a227e00 deposit rega 
+3b7c 20600000 rtn 
+
+ahead_window:
+3b7d 1fe20400 copy pdata ,temp 
+3b7e 793f8025 set0 mark_ext_patch ,mark 
+3b7f 44d04014 bpatch patch14_0 ,mem_patch14 
+3b80 18427e00 copy temp ,pdata 
+3b81 20407e91 call clk2bt 
+3b82 1c307e00 lshift16 bt_clk ,pdata 
+3b83 79207e2c set1 44 ,pdata 
+3b84 20407e7a call clk_diff 
+3b85 793ffe2c set0 44 ,pdata 
+3b86 20403bda call get_clk 
+3b87 20407e7a call clk_diff 
+3b88 20740000 rtn user 
+3b89 20407e84 call clk2rt 
+3b8a 98003600 iforce stop_watch 
+3b8b 37c18200 until null ,timeout 
+3b8c 20600000 rtn 
+
+setup_clk:
+3b8d 793f8025 set0 mark_ext_patch ,mark 
+3b8e 44d0c014 bpatch patch14_1 ,mem_patch14 
+3b8f 20383b93 branch setup_clkn ,clknt 
+3b90 35330200 until clke_rt ,meet 
+
+skip_setup_clke:
+3b91 1d020400 copy clke_bt ,temp 
+3b92 20203b96 branch setup_clknbt 
+
+setup_clkn:
+3b93 20373b95 branch skip_setup_clkn ,attempt 
+3b94 34730200 until clkn_rt ,meet 
+
+skip_setup_clkn:
+3b95 1c420400 copy clkn_bt ,temp 
+
+setup_clknbt:
+3b96 20343ba3 branch setup_clk11 ,user 
+3b97 28400601 compare 1 ,temp ,3 
+3b98 2420bb8d nbranch setup_clk ,true 
+
+setup_complete:
+3b99 793f8025 set0 mark_ext_patch ,mark 
+3b9a 44d14014 bpatch patch14_2 ,mem_patch14 
+3b9b 68008030 fetch 1 ,mem_state 
+3b9c c4000000 rtnbit0 state_inconn 
+3b9d 6802416a fetch 4 ,mem_next_btclk 
+3b9e 98467e00 isub temp ,pdata 
+3b9f 24610000 nrtn positive 
+3ba0 1fe67cff sub pdata ,0xff ,null 
+3ba1 20213b8d branch setup_clk ,positive 
+3ba2 20600000 rtn 
+
+setup_clk11:
+3ba3 28400603 compare 3 ,temp ,3 
+3ba4 2420bb8d nbranch setup_clk ,true 
+3ba5 20203b99 branch setup_complete 
+
+rf_setup_time:
+3ba6 793f8025 set0 mark_ext_patch ,mark 
+3ba7 44d1c014 bpatch patch14_3 ,mem_patch14 
+3ba8 d9600600 arg param_rf_setup ,timeup 
+3ba9 20203b8d branch setup_clk 
+
+rf_setup_time_slave_slot:
+3baa 78547c00 disable user 
+3bab 20203ba6 branch rf_setup_time 
+
+rf_setup_time_master_slot:
+3bac 78347c00 enable user 
+3bad 20203ba6 branch rf_setup_time 
+
+start_transmitter:
+3bae 793f8025 set0 mark_ext_patch ,mark 
+3baf 44d24014 bpatch patch14_4 ,mem_patch14 
+3bb0 20403b41 call prep_crypt 
+3bb1 7850fc00 disable is_rx 
+3bb2 78307c00 enable is_tx 
+3bb3 20600000 rtn 
+
+start_tx_native:
+3bb4 793f8025 set0 mark_ext_patch ,mark 
+3bb5 44d2c014 bpatch patch14_5 ,mem_patch14 
+3bb6 d9600e43 arg param_tx_setup ,timeup 
+3bb7 34730200 until clkn_rt ,meet 
+3bb8 782b7c00 pulse init_encrypt 
+3bb9 20600000 rtn 
+
+start_rx_native:
+3bba 793f8025 set0 mark_ext_patch ,mark 
+3bbb 44d34014 bpatch patch14_6 ,mem_patch14 
+3bbc d9600d00 arg param_rx_setup ,timeup 
+3bbd 34730200 until clkn_rt ,meet 
+3bbe 20600000 rtn 
+
+start_tx_external:
+3bbf 793f8025 set0 mark_ext_patch ,mark 
+3bc0 44d3c014 bpatch patch14_7 ,mem_patch14 
+3bc1 d9600e43 arg param_tx_setup ,timeup 
+3bc2 35330200 until clke_rt ,meet 
+3bc3 782b7c00 pulse init_encrypt 
+3bc4 20600000 rtn 
+
+send_access_word:
+3bc5 793f8025 set0 mark_ext_patch ,mark 
+3bc6 44d44015 bpatch patch15_0 ,mem_patch15 
+3bc7 51207e00 preload access 
+3bc8 782efc00 enable encode_fec0 
+3bc9 79202a00 set1 txgfsk ,radio_ctrl 
+3bca 08008648 inject mod ,72 
+3bcb 784efc00 disable encode_fec0 
+3bcc 20600000 rtn 
+
+scan_mode_whiten:
+3bcd 1ca20400 copy xin ,temp 
+3bce 18418460 or_into 0x60 ,temp 
+3bcf 18421c00 copy temp ,white_init 
+3bd0 20600000 rtn 
+
+get_free_amaddr:
+3bd1 793f8025 set0 mark_ext_patch ,mark 
+3bd2 44d4c015 bpatch patch15_1 ,mem_patch15 
+3bd3 6800c130 fetch 1 ,mem_current_amaddr 
+3bd4 1fe0fe01 increase 1 ,pdata 
+3bd5 c083bbd7 bne param_esco_addr ,get_free_amaddr_cont 
+3bd6 18007e01 force 1 ,pdata 
+
+get_free_amaddr_cont:
+3bd7 6000c130 store 1 ,mem_current_amaddr 
+3bd8 98000800 iforce am_addr 
+3bd9 20600000 rtn 
+
+get_clk:
+3bda 1b220400 copy clkn ,temp 
+3bdb 20748000 rtn master 
+3bdc 1b420400 copy clke ,temp 
+3bdd 20600000 rtn 
+
+get_clkbt:
+3bde 1c427e00 deposit clkn_bt 
+3bdf 20748000 rtn master 
+3be0 1d027e00 deposit clke_bt 
+3be1 20600000 rtn 
+
+supervision_update:
+3be2 793f8025 set0 mark_ext_patch ,mark 
+3be3 44d54015 bpatch patch15_2 ,mem_patch15 
+3be4 680a004d fetcht 4 ,mem_supervision_timer 
+3be5 20403bde call get_clkbt 
+3be6 98461600 isub temp ,timeup 
+3be7 19627e00 deposit timeup 
+3be8 68090051 fetcht 2 ,mem_supervision_to 
+3be9 18438400 lshift temp ,temp 
+3bea 98467e00 isub temp ,pdata 
+3beb 20600000 rtn 
+
+supervision_flush:
+3bec 793f8025 set0 mark_ext_patch ,mark 
+3bed 44d5c015 bpatch patch15_3 ,mem_patch15 
+3bee 20403bde call get_clkbt 
+3bef 6002004d store 4 ,mem_supervision_timer 
+3bf0 20600000 rtn 
+
+assert:
+3bf1 20203bf1 branch assert 
+
+loop:
+3bf2 20203bf2 branch loop 
+
+sleep:
+3bf3 207a0000 rtn blank 
+3bf4 1fe37e00 rshift pdata ,pdata 
+3bf5 1fe0fffd increase -3 ,pdata 
+
+sleep_loop:
+3bf6 1fe0ffff increase -1 ,pdata 
+3bf7 2422bbf6 nbranch sleep_loop ,zero 
+3bf8 18007e00 force 0 ,pdata 
+3bf9 20600000 rtn 
+
+init_param:
+3bfa df200010 arg 0x10 ,loopcnt 
+3bfb d8a00000 arg 0 ,contw 
+3bfc 20407e3b call memset0 
+3bfd d8a003c0 arg mem_le_state ,contw 
+3bfe df20000a arg 10 ,loopcnt 
+3bff 20407e3b call memset0 
+3c00 7007de00 jam 0 ,mem_sp_calc 
+3c01 700b7d00 jam 0 ,mem_fifo_temp 
+3c02 70040d00 jam 0 ,mem_le_testtype 
+3c03 70018900 jam 0 ,mem_debug_config 
+3c04 70044d00 jam 0 ,mem_lmp_conn_state 
+3c05 793f8025 set0 mark_ext_patch ,mark 
+3c06 44d64015 bpatch patch15_4 ,mem_patch15 
+3c07 70017700 jam 0 ,mem_connection_options 
+3c08 70015300 jam 0 ,mem_tester_emulate 
+3c09 70015e00 jam 0 ,mem_tester_cnt 
+3c0a 589e8b33 setarg param_glap 
+3c0b 6001c147 store 3 ,mem_glap 
+3c0c 58000153 setarg param_acl_pktlen 
+3c0d 60010083 store 2 ,mem_acl_pktlen 
+3c0e 7000851e jam param_sco_pktlen ,mem_sco_pktlen 
+3c0f 70008601 jam param_acl_pktcnt ,mem_acl_pktcnt 
+3c10 70008807 jam param_sco_pktcnt ,mem_sco_pktcnt 
+3c11 5812e904 setarg param_hci_version 
+3c12 60018080 store 3 ,mem_hci_version 
+3c13 58000a04 setarg param_lmp_version 
+3c14 6001c6fd store 3 ,mem_lmp_version 
+3c15 580012e9 setarg param_lmp_subversion 
+3c16 60014700 store 2 ,mem_lmp_subversion 
+3c17 70008f60 jam 0x60 ,mem_fhs_misc 
+3c18 70417105 jam param_max_slot ,mem_max_slot 
+3c19 70001402 jam 0x02 ,mem_fw_ver 
+3c1a 204075cd call init_memp 
+3c1b 793f8025 set0 mark_ext_patch ,mark 
+3c1c 44d6c015 bpatch patch15_5 ,mem_patch15 
+3c1d 20758000 rtn wake 
+3c1e 58000000 setarg 0 
+3c1f 60010091 store 2 ,mem_tx_len 
+3c20 1c437e00 rshift clkn_bt ,pdata 
+3c21 60024134 store 4 ,mem_last_clkn 
+3c22 20600000 rtn 
+
+init_esco_ibuff:
+3c23 580000aa setarg 0xaa ,pdata 
+3c24 d8a000d3 arg mem_sco_ibuf ,contw 
+3c25 1800721e force 30 ,loopcnt 
+
+init_esco_ibuff_loop:
+3c26 e0a08000 istore 1 ,contw 
+3c27 c2003c26 loop init_esco_ibuff_loop 
+3c28 20600000 rtn 
+
+init_rf_regs:
+3c29 70890702 hjam 0x02 ,0x907 
+3c2a 7089081f hjam 0x1f ,0x908 
+3c2b 7089091f hjam 0x1f ,0x909 
+3c2c 70890ae0 hjam 0xe0 ,0x90a 
+3c2d 70890b4e hjam 0x4e ,0x90b 
+3c2e 70891245 hjam 0x45 ,rf_agc_ctrl 
+3c2f 70895300 hjam 0x00 ,0x953 
+3c30 70894cfb hjam 0xfb ,0x94c 
+3c31 70894def hjam 0xef ,0x94d 
+3c32 70894e0c hjam 0x0c ,0x94e 
+3c33 70896f88 hjam 0x88 ,0x96f 
+3c34 70897330 hjam 0x30 ,0x973 
+3c35 70895300 hjam 0x00 ,0x953 
+3c36 708956c9 hjam 0xc9 ,0x956 
+3c37 7089586c hjam 0x6c ,0x958 
+3c38 70895950 hjam 0x50 ,0x959 
+3c39 20600000 rtn 
+
+init_agc_table:
+3c3a 708930a9 hjam 0xa9 ,0x930 
+3c3b 70892fb1 hjam 0xb1 ,0x92f 
+3c3c 70892eb9 hjam 0xb9 ,0x92e 
+3c3d 70892dad hjam 0xAD ,0x92d 
+3c3e 70892cb1 hjam 0xB1 ,0x92c 
+3c3f 70892bb5 hjam 0xB5 ,0x92b 
+3c40 70892aba hjam 0xBA ,0x92a 
+3c41 708929be hjam 0xBE ,0x929 
+3c42 708928c2 hjam 0xC2 ,0x928 
+3c43 708927c6 hjam 0xC6 ,0x927 
+3c44 708926ca hjam 0xCA ,0x926 
+3c45 708925ce hjam 0xCE ,0x925 
+3c46 708924d2 hjam 0xD2 ,0x924 
+3c47 708923d6 hjam 0xD6 ,0x923 
+3c48 708922da hjam 0xDA ,0x922 
+3c49 708921de hjam 0xDE ,0x921 
+3c4a 708920e2 hjam 0xE2 ,0x920 
+3c4b 70891fe6 hjam 0xE6 ,0x91f 
+3c4c 70891eea hjam 0xEA ,0x91e 
+3c4d 70891dee hjam 0xEE ,0x91d 
+3c4e 70891cf2 hjam 0xF2 ,0x91c 
+3c4f 70891bf6 hjam 0xF6 ,0x91b 
+3c50 70891afb hjam 0xFB ,0x91a 
+3c51 708947f5 hjam 0xf5 ,0x947 
+3c52 708946e5 hjam 0xe5 ,0x946 
+3c53 708945d5 hjam 0xd5 ,0x945 
+3c54 708944d8 hjam 0xD8 ,0x944 
+3c55 708943c9 hjam 0xC9 ,0x943 
+3c56 708942c8 hjam 0xC8 ,0x942 
+3c57 70894189 hjam 0x89 ,0x941 
+3c58 70894088 hjam 0x88 ,0x940 
+3c59 70893f87 hjam 0x87 ,0x93f 
+3c5a 70893e48 hjam 0x48 ,0x93e 
+3c5b 70893d09 hjam 0x09 ,0x93d 
+3c5c 70893c08 hjam 0x08 ,0x93c 
+3c5d 70893bc9 hjam 0xC9 ,0x93b 
+3c5e 70893ac8 hjam 0xC8 ,0x93a 
+3c5f 708939c7 hjam 0xC7 ,0x939 
+3c60 708938c6 hjam 0xC6 ,0x938 
+3c61 708937c5 hjam 0xC5 ,0x937 
+3c62 708936c4 hjam 0xC4 ,0x936 
+3c63 708935c3 hjam 0xC3 ,0x935 
+3c64 708934c2 hjam 0xC2 ,0x934 
+3c65 708933c1 hjam 0xC1 ,0x933 
+3c66 708932c0 hjam 0xC0 ,0x932 
+3c67 70893180 hjam 0x80 ,0x931 
+3c68 20600000 rtn 
+
+init_250k:
+3c69 783b7c00 enable le 
+3c6a 588e89be setarg 0x8e89be 
+3c6b 1fed7e00 lshift8 pdata ,pdata 
+3c6c 1fe1fed6 or_into 0xd6 ,pdata 
+3c6d 98001200 iforce access 
+3c6e 70891407 hjam 7 ,0x914 
+3c6f 70890aa0 hjam 0xa0 ,0x90a 
+3c70 70890d8f hjam 0x8f ,0x90d 
+3c71 7089110f hjam 0x0f ,0x911 
+3c72 70891287 hjam 0x87 ,0x912 
+3c73 20600000 rtn 
+
+lpmstate:
+3c74 5800ee21 setarg 0xee21 
+3c75 60110050 hstore 2 ,core_clkoff 
+3c76 6810813e hfetch 1 ,core_lpm_ldocnt 
+3c77 c301e725 bbit0 gpio_latch ,loadcode 
+3c78 7835fc00 enable wake 
+3c79 c303bc7f bbit0 cold_wake ,lpmwake 
+3c7a 7855fc00 disable wake 
+3c7b 1ce27e00 deposit auxcnt 
+3c7c 243a3c7f nbranch lpmwake ,blank 
+3c7d d85fffff arg param_hibernate_clks ,temp 
+3c7e 20203cec branch lpm_enter_sleep 
+
+lpmwake:
+3c7f 6811813c hfetch 3 ,core_lpm_xtalcnt 
+3c80 6011804c hstore 3 ,core_lpm_reg 
+3c81 e8c08000 ifetch 1 ,contr 
+3c82 1fe1feef or_into isogate_mask ,pdata 
+3c83 e0a08000 istore 1 ,contw 
+3c84 20403db2 call lpm_write_ctrl2 
+3c85 6810804f hfetch 1 ,core_lpm_isogate 
+3c86 79207e04 set1 enable_retmem ,pdata 
+3c87 6010804f hstore 1 ,core_lpm_isogate 
+3c88 20403db2 call lpm_write_ctrl2 
+3c89 2055bc90 call lpm_load_context ,wake 
+3c8a 6810804e hfetch 1 ,core_lpm_reg + 2 
+3c8b 793ffe03 set0 gpio_latch ,pdata 
+3c8c 6010804e hstore 1 ,core_lpm_reg + 2 
+3c8d 20403db2 call lpm_write_ctrl2 
+3c8e 20758000 rtn wake 
+3c8f 20206725 branch loadcode 
+
+lpm_load_context:
+3c90 6800c239 fetch 1 ,mem_saved_spidctrl 
+3c91 60108086 hstore 1 ,core_spid_ctrl 
+3c92 6801c22e fetch 3 ,mem_saved_gsel 
+3c93 60118080 hstore 3 ,core_gpio_sel 
+3c94 68024222 fetch 4 ,mem_saved_gpio + 4 
+3c95 60120074 hstore 4 ,core_gpio_out0 
+3c96 6802421e fetch 4 ,mem_saved_gpio 
+3c97 60120070 hstore 4 ,core_gpio_oe0 
+3c98 68044226 fetch 8 ,mem_saved_gpio + 8 
+3c99 60140078 hstore 8 ,core_gpio_pu0 
+3c9a 68044231 fetch 8 ,mem_saved_mark 
+3c9b 98000000 iforce mark 
+3c9c 68140140 hfetch 8 ,core_gpio_wakeup_low 
+3c9d 600400a3 store 8 ,mem_gpio_wakeup_low 
+3c9e 20406781 call load_ucode 
+3c9f 20600000 rtn 
+
+lpm_save_context:
+3ca0 18027e00 deposit mark 
+3ca1 60044231 store 8 ,mem_saved_mark 
+3ca2 68140070 hfetch 8 ,core_gpio_oe0 
+3ca3 6004421e store 8 ,mem_saved_gpio 
+3ca4 e8c40000 ifetch 8 ,contr 
+3ca5 e0a40000 istore 8 ,contw 
+3ca6 68118080 hfetch 3 ,core_gpio_sel 
+3ca7 6001c22e store 3 ,mem_saved_gsel 
+3ca8 68108086 hfetch 1 ,core_spid_ctrl 
+3ca9 6000c239 store 1 ,mem_saved_spidctrl 
+3caa 20203db8 branch lpm_write_gpio_wakeup 
+
+lpo_calibration:
+3cab 681080b4 hfetch 1 ,core_bist_ctrl 
+3cac 243a3cb1 nbranch lpo_cal_inited ,blank 
+3cad 6801c210 fetch 3 ,mem_clks_per_lpo 
+3cae 247a0000 nrtn blank 
+3caf 7080b4c0 hjam 0xc0 ,core_bist_ctrl 
+3cb0 70800680 hjam ccnt_start ,core_misc_ctrl 
+
+lpo_cal_inited:
+3cb1 6810812d hfetch 1 ,core_perf_status 
+3cb2 c4008000 rtnbit0 1 
+3cb3 68118149 hfetch 3 ,core_clk_counter 
+3cb4 6001c210 store 3 ,mem_clks_per_lpo 
+3cb5 20600000 rtn 
+
+lpm_adjust_clk:
+3cb6 793f8025 set0 mark_ext_patch ,mark 
+3cb7 44d74015 bpatch patch15_6 ,mem_patch15 
+3cb8 1b427e00 deposit clke 
+3cb9 20407e78 call clk_diff_rt 
+3cba 680a4200 fetcht 4 ,mem_sleep_counter_all 
+3cbb 18467cff sub temp ,0xff ,null 
+3cbc 20610000 rtn positive 
+3cbd 1fed7e00 lshift8 pdata ,pdata 
+3cbe 1ff27e00 lshift4 pdata ,pdata 
+3cbf 9846fc00 idiv temp 
+3cc0 20407efd call wait_div_end 
+3cc1 1807fe00 quotient pdata 
+3cc2 d84000c8 arg param_lpm_adjmax ,temp 
+3cc3 20407f2e call ceiling 
+3cc4 6000809b store 1 ,mem_lpm_adjust 
+3cc5 24343cc7 nbranch lpm_adjust_positive ,user 
+3cc6 1fe67e00 sub pdata ,0 ,pdata 
+
+lpm_adjust_positive:
+3cc7 6809c210 fetcht 3 ,mem_clks_per_lpo 
+3cc8 9840fe00 iadd temp ,pdata 
+3cc9 6001c210 store 3 ,mem_clks_per_lpo 
+
+lpm_clear_counter:
+3cca 58000000 setarg 0 
+3ccb 60024200 store 4 ,mem_sleep_counter_all 
+3ccc 20600000 rtn 
+
+lpm_hibernate:
+3ccd 793f8025 set0 mark_ext_patch ,mark 
+3cce 44d7c015 bpatch patch15_7 ,mem_patch15 
+3ccf 20403db8 call lpm_write_gpio_wakeup 
+3cd0 68120138 hfetch 4 ,core_lpm_ctrl 
+3cd1 793ffe0f set0 15 ,pdata 
+3cd2 6012004c hstore 4 ,core_lpm_reg 
+3cd3 20403db0 call lpm_write_ctrl 
+
+lpm_hibernate_normal:
+3cd4 d85fffff arg param_hibernate_clks ,temp 
+3cd5 6800c1f8 fetch 1 ,mem_lpm_hibernate_switch 
+3cd6 6000c21d store 1 ,mem_lpm_xtalcnt + 4 
+3cd7 6800c21b fetch 1 ,mem_lpm_xtalcnt + 2 
+3cd8 79207e07 set1 cold_wake ,pdata 
+3cd9 6000c21b store 1 ,mem_lpm_xtalcnt + 2 
+
+lpm_sleep:
+3cda 793f8025 set0 mark_ext_patch ,mark 
+3cdb 44d84016 bpatch patch16_0 ,mem_patch16 
+3cdc 68024200 fetch 4 ,mem_sleep_counter_all 
+3cdd 9840fe00 iadd temp ,pdata 
+3cde 60024200 store 4 ,mem_sleep_counter_all 
+3cdf 20403ca0 call lpm_save_context 
+3ce0 6802c219 fetch 5 ,mem_lpm_xtalcnt 
+3ce1 6012004c hstore 4 ,core_lpm_reg 
+3ce2 1fef2200 rshift32 pdata ,rega 
+3ce3 37d98200 until null ,lpo_edge 
+3ce4 1b227e00 deposit clkn 
+3ce5 60034204 store 6 ,mem_sleep_clkn 
+3ce6 70800502 hjam lpmreg_sel_ctrl2 ,core_lpm_wr 
+3ce7 37d98200 until null ,lpo_edge 
+3ce8 37d98200 until null ,lpo_edge 
+3ce9 1a227e00 deposit rega 
+3cea 6010804f hstore 1 ,core_lpm_isogate 
+3ceb 70800502 hjam lpmreg_sel_ctrl2 ,core_lpm_wr 
+
+lpm_enter_sleep:
+3cec 37d98200 until null ,lpo_edge 
+3ced 37d98200 until null ,lpo_edge 
+3cee 601a004c hstoret 4 ,core_lpm_reg 
+3cef 70800510 hjam lpmreg_sel_counter ,core_lpm_wr 
+3cf0 37df8200 until null ,never 
+
+lpm_recover_clk:
+3cf1 793f8025 set0 mark_ext_patch ,mark 
+3cf2 44d8c016 bpatch patch16_1 ,mem_patch16 
+3cf3 58000000 setarg 0 
+3cf4 1ce27c00 copy auxcnt ,null 
+3cf5 2022bcfd branch lpm_recover_timeout ,zero 
+3cf6 6810813c hfetch 1 ,core_lpm_xtalcnt 
+3cf7 6818813d hfetcht 1 ,core_lpm_buckcnt 
+3cf8 98467c00 isub temp ,null 
+3cf9 20213cfb branch lpm_recover_xtal ,positive 
+3cfa 18427e00 deposit temp 
+
+lpm_recover_xtal:
+3cfb 9ce67e00 isub auxcnt ,pdata 
+3cfc 1fe0fe01 increase 1 ,pdata 
+
+lpm_recover_timeout:
+3cfd 1fe0fe08 increase 8 ,pdata 
+3cfe 37d98200 until null ,lpo_edge 
+3cff 9e20fe00 iadd lpo_time ,pdata 
+3d00 680a41fc fetcht 4 ,mem_sleep_counter 
+3d01 9840fe00 iadd temp ,pdata 
+3d02 6809c210 fetcht 3 ,mem_clks_per_lpo 
+3d03 984ffe00 imul32 temp ,pdata 
+3d04 1fecfe00 rshift8 pdata ,pdata 
+3d05 1ff1fe00 rshift4 pdata ,pdata 
+3d06 1fe0fe6e increase param_lpm_fix ,pdata 
+3d07 d8400ea6 arg 3750 ,temp 
+3d08 9846fc00 idiv temp 
+3d09 20407efd call wait_div_end 
+3d0a 1807fe00 quotient pdata 
+3d0b 1ff07e00 lshift16 pdata ,pdata 
+3d0c 18070400 remainder temp 
+3d0d 9841fe00 ior temp ,pdata 
+3d0e 680b4204 fetcht 6 ,mem_sleep_clkn 
+3d0f 20407e6d call clk_add 
+3d10 18423200 copy temp ,clkn 
+3d11 68034048 fetch 6 ,mem_context + coffset_clk_offset 
+3d12 204039c0 call calc_clke2 
+3d13 1b427e00 deposit clke 
+3d14 60030161 store 6 ,mem_pdatatemp 
+3d15 1ce27e00 deposit auxcnt 
+3d16 e0a08000 istore 1 ,contw 
+3d17 6810811d hfetch 1 ,core_gpio_in1 
+3d18 1fe1fef0 or_into 0xf0 ,pdata 
+3d19 e0a08000 istore 1 ,contw 
+3d1a 20407f52 call savelist_2 
+3d1b 20600000 rtn 
+
+lpm_dispatch:
+3d1c 793f8025 set0 mark_ext_patch ,mark 
+3d1d 44d94016 bpatch patch16_2 ,mem_patch16 
+3d1e 20403cab call lpo_calibration 
+3d1f 6801c210 fetch 3 ,mem_clks_per_lpo 
+3d20 207a0000 rtn blank 
+3d21 6800c131 fetch 1 ,mem_lpm_mode 
+3d22 207a0000 rtn blank 
+3d23 20403dca call lpm_check_wake_lock 
+3d24 247a0000 nrtn blank 
+
+lpm_dispatch0:
+3d25 6800c040 fetch 1 ,mem_context 
+3d26 2fe00e03 compare 3 ,pdata ,0x7 
+3d27 2420bd4d nbranch lpm_dispatch_unconn ,true 
+3d28 68014042 fetch 2 ,mem_context + coffset_tsniff 
+3d29 207a0000 rtn blank 
+3d2a 20758000 rtn wake 
+3d2b 793f8025 set0 mark_ext_patch ,mark 
+3d2c 44d9c016 bpatch patch16_3 ,mem_patch16 
+
+lpm_dispatch1:
+3d2d 680880a2 fetcht 1 ,mem_lpm_current_mult 
+3d2e 68014042 fetch 2 ,mem_context + coffset_tsniff 
+3d2f 984ffe00 imul32 temp ,pdata 
+3d30 18518400 rshift4 temp ,temp 
+3d31 184b0400 rshift2 temp ,temp 
+3d32 98467e00 isub temp ,pdata 
+3d33 680a4044 fetcht 4 ,mem_context + coffset_sniff_anchor 
+3d34 9840fe00 iadd temp ,pdata 
+3d35 6808c1f7 fetcht 1 ,mem_lpm_overhead 
+3d36 98467e00 isub temp ,pdata 
+3d37 1ff06000 lshift16 pdata ,alarm 
+3d38 793f8025 set0 mark_ext_patch ,mark 
+3d39 44da4016 bpatch patch16_4 ,mem_patch16 
+3d3a 6801404e fetch 2 ,mem_context + coffset_rx_window 
+3d3b 1fe37e00 rshift pdata ,pdata 
+3d3c 20407e91 call clk2bt 
+3d3d 1e027e00 deposit alarm 
+3d3e 20407e7a call clk_diff 
+3d3f 1b420400 copy clke ,temp 
+3d40 20407e78 call clk_diff_rt 
+3d41 20740000 rtn user 
+
+lpm_dispatch_sleep:
+3d42 20407e8a call clk2lpo 
+
+lpm_dispatch_lpo:
+3d43 793f8025 set0 mark_ext_patch ,mark 
+3d44 44dac016 bpatch patch16_5 ,mem_patch16 
+3d45 6800c219 fetch 1 ,mem_lpm_xtalcnt 
+3d46 98467c00 isub temp ,null 
+3d47 20213cca branch lpm_clear_counter ,positive 
+3d48 600a41fc storet 4 ,mem_sleep_counter 
+3d49 20403ea9 call app_will_enter_lpm 
+3d4a 2040530c call l2cap_lpm_save_txbuf 
+3d4b 680a41fc fetcht 4 ,mem_sleep_counter 
+3d4c 20203cda branch lpm_sleep 
+
+lpm_dispatch_unconn:
+3d4d 793f8025 set0 mark_ext_patch ,mark 
+3d4e 44db4016 bpatch patch16_6 ,mem_patch16 
+3d4f 6800c040 fetch 1 ,mem_context 
+3d50 c3800000 rtnbit1 state_inconn 
+3d51 c3818000 rtnbit1 state_inpage 
+3d52 6800c7dc fetch 1 ,mem_ssp_enable 
+3d53 203a3d56 branch lpm_unconn_nossp ,blank 
+3d54 6800c793 fetch 1 ,mem_sp_local_key_invalid 
+3d55 207a0000 rtn blank 
+
+lpm_unconn_nossp:
+3d56 6800c3d8 fetch 1 ,mem_le_adv_enable 
+3d57 243a3d5a nbranch lpm_unconn_cont ,blank 
+3d58 6800c133 fetch 1 ,mem_scan_mode 
+3d59 207a0000 rtn blank 
+
+lpm_unconn_cont:
+3d5a 680141f5 fetch 2 ,mem_lpm_interval 
+3d5b 207a0000 rtn blank 
+
+lpm_sleep_btclk:
+3d5c 6808c1f7 fetcht 1 ,mem_lpm_overhead 
+3d5d 98467e00 isub temp ,pdata 
+3d5e d8401d4c arg 7500 ,temp 
+3d5f 984ffe00 imul32 temp ,pdata 
+3d60 20203d42 branch lpm_dispatch_sleep 
+
+lpm_set_mult:
+3d61 793f8025 set0 mark_ext_patch ,mark 
+3d62 44dbc016 bpatch patch16_7 ,mem_patch16 
+3d63 7855fc00 disable wake 
+3d64 68008030 fetch 1 ,mem_state 
+3d65 c4008000 rtnbit0 state_insniff 
+3d66 2436bd7b nbranch lpm_not_match ,match 
+3d67 20403d76 call lpm_match 
+3d68 68014161 fetch 2 ,mem_rx_window_sniff 
+3d69 6001003e store 2 ,mem_rx_window 
+3d6a 68008047 fetch 1 ,mem_arq 
+3d6b c281bd8a bbit1 wack ,lpm_mult_short 
+3d6c c586bd8a bmark0 mark_lpm_mult_enable ,lpm_mult_short 
+3d6d 2040527e call l2cap_malloc_is_fifo_empty 
+3d6e 243a3d8a nbranch lpm_mult_short ,blank 
+
+lpm_mult_wait_timeout:
+3d6f 7000a200 jam 0 ,mem_lpm_current_mult 
+3d70 c586bd8a bmark0 mark_lpm_mult_enable ,lpm_mult_short 
+3d71 6800c215 fetch 1 ,mem_lpm_mult_cnt 
+3d72 203a3d8e branch lpm_mult_long ,blank 
+3d73 1fe0ffff increase -1 ,pdata 
+3d74 6000c215 store 1 ,mem_lpm_mult_cnt 
+3d75 20600000 rtn 
+
+lpm_match:
+3d76 7041fa00 jam 0 ,mem_sniff_unint_lost 
+3d77 6801c20a fetch 3 ,mem_sniff_rcv 
+3d78 1fe0fe01 increase 1 ,pdata 
+3d79 6001c20a store 3 ,mem_sniff_rcv 
+3d7a 20600000 rtn 
+
+lpm_not_match:
+3d7b 793f8025 set0 mark_ext_patch ,mark 
+3d7c 44dc4017 bpatch patch17_0 ,mem_patch17 
+3d7d 68094161 fetcht 2 ,mem_rx_window_sniff 
+3d7e 18430400 rshift temp ,temp 
+3d7f 6801003e fetch 2 ,mem_rx_window 
+3d80 9840fe00 iadd temp ,pdata 
+3d81 6001003e store 2 ,mem_rx_window 
+
+lpm_lost:
+3d82 7000a200 jam 0 ,mem_lpm_current_mult 
+3d83 6801c20d fetch 3 ,mem_sniff_lost 
+3d84 1fe0fe01 increase 1 ,pdata 
+3d85 6001c20d store 3 ,mem_sniff_lost 
+3d86 6800c1fa fetch 1 ,mem_sniff_unint_lost 
+3d87 1fe0fe01 increase 1 ,pdata 
+3d88 6000c1fa store 1 ,mem_sniff_unint_lost 
+3d89 20600000 rtn 
+
+lpm_mult_short:
+3d8a 7000a200 jam 0 ,mem_lpm_current_mult 
+3d8b 6800c214 fetch 1 ,mem_lpm_mult_timeout 
+3d8c 6000c215 store 1 ,mem_lpm_mult_cnt 
+3d8d 20600000 rtn 
+
+lpm_mult_long:
+3d8e 6808c213 fetcht 1 ,mem_lpm_mult 
+3d8f 600880a2 storet 1 ,mem_lpm_current_mult 
+3d90 20600000 rtn 
+
+lpm_cal_xtal_startup:
+3d91 793f8025 set0 mark_ext_patch ,mark 
+3d92 44dcc017 bpatch patch17_1 ,mem_patch17 
+3d93 6800c219 fetch 1 ,mem_lpm_xtalcnt 
+3d94 247a0000 nrtn blank 
+3d95 70804206 hjam clksel_rc ,core_clksel 
+3d96 58000f0c setarg 0xf0c 
+3d97 20403da7 call lpm_write_config 
+3d98 58030d40 setarg 200000 
+3d99 20403bf3 call sleep 
+3d9a 37d98200 until null ,lpo_edge 
+3d9b 1e226000 copy lpo_time ,alarm 
+3d9c 20403b36 call xtal_fast_wake 
+3d9d 70804204 hjam clksel_xtal ,core_clksel 
+3d9e 2000000a nop 10 
+3d9f 37d98200 until null ,lpo_edge 
+3da0 1e227e00 deposit lpo_time 
+3da1 9e067e00 isub alarm ,pdata 
+3da2 1fe0fe30 increase 0x30 ,pdata 
+3da3 d84000ff arg 0xff ,temp 
+3da4 20407f2e call ceiling 
+3da5 6000c219 store 1 ,mem_lpm_xtalcnt 
+3da6 20600000 rtn 
+
+lpm_write_config:
+3da7 d8a00fff arg 0xfff ,contw 
+3da8 98a10a00 iand contw ,contw 
+3da9 6800c216 fetch 1 ,mem_lpm_config 
+3daa 1fe17ef0 and_into 0xf0 ,pdata 
+3dab 1fed7e00 lshift8 pdata ,pdata 
+3dac 98a1fe00 ior contw ,pdata 
+3dad 6011004c hstore 2 ,core_lpm_reg 
+3dae e8c10000 ifetch 2 ,contr 
+3daf e0a10000 istore 2 ,contw 
+
+lpm_write_ctrl:
+3db0 58000001 setarg lpmreg_sel_ctrl 
+3db1 20203db3 branch lpm_write 
+
+lpm_write_ctrl2:
+3db2 58000002 setarg lpmreg_sel_ctrl2 
+
+lpm_write:
+3db3 37d98200 until null ,lpo_edge 
+3db4 60108005 hstore 1 ,core_lpm_wr 
+3db5 37d98200 until null ,lpo_edge 
+3db6 37d98200 until null ,lpo_edge 
+3db7 20600000 rtn 
+
+lpm_write_gpio_wakeup:
+3db8 793f8025 set0 mark_ext_patch ,mark 
+3db9 44dd4017 bpatch patch17_2 ,mem_patch17 
+3dba 680200a3 fetch 4 ,mem_gpio_wakeup_low 
+3dbb 6012004c hstore 4 ,core_lpm_reg 
+3dbc 58000004 setarg lpmreg_sel_gpiolow 
+3dbd 20403db3 call lpm_write 
+3dbe 680200a7 fetch 4 ,mem_gpio_wakeup_high 
+3dbf 6012004c hstore 4 ,core_lpm_reg 
+3dc0 58000008 setarg lpmreg_sel_gpiohigh 
+3dc1 20203db3 branch lpm_write 
+
+lpm_get_wake_lock:
+3dc2 680141f3 fetch 2 ,mem_lpm_wake_lock 
+3dc3 f9207e00 qset1 pdata 
+3dc4 600141f3 store 2 ,mem_lpm_wake_lock 
+3dc5 20600000 rtn 
+
+lpm_put_wake_lock:
+3dc6 680141f3 fetch 2 ,mem_lpm_wake_lock 
+3dc7 f93ffe00 qset0 pdata 
+3dc8 600141f3 store 2 ,mem_lpm_wake_lock 
+3dc9 20600000 rtn 
+
+lpm_check_wake_lock:
+3dca 793f8025 set0 mark_ext_patch ,mark 
+3dcb 44ddc017 bpatch patch17_3 ,mem_patch17 
+3dcc 20403ea7 call app_check_wake_lock 
+3dcd 680141f3 fetch 2 ,mem_lpm_wake_lock 
+3dce 1fe22200 copy pdata ,rega 
+3dcf 6800804c fetch 1 ,mem_state_map 
+3dd0 2feffe06 isolate1 smap_rxlmp ,pdata 
+3dd1 7920a20b setflag true ,wake_lock_lmp_rx ,rega 
+3dd2 68008078 fetch 1 ,mem_lmo_opcode1 
+3dd3 6808807c fetcht 1 ,mem_lmo_opcode2 
+3dd4 9840fe00 iadd temp ,pdata 
+3dd5 68088048 fetcht 1 ,mem_lmp_to_send 
+3dd6 9840fe00 iadd temp ,pdata 
+3dd7 7d3a220a nsetflag blank ,wake_lock_lmp_tx ,rega 
+3dd8 793f8025 set0 mark_ext_patch ,mark 
+3dd9 44de4017 bpatch patch17_4 ,mem_patch17 
+3dda 680102c4 fetch 2 ,mem_l2cap_rxbuff1_len 
+3ddb 680902c6 fetcht 2 ,mem_l2cap_rxbuff2_len 
+3ddc 9840fe00 iadd temp ,pdata 
+3ddd 7d3a220d nsetflag blank ,wake_lock_l2cap_rx ,rega 
+3dde 6802c7df fetch 5 ,mem_ipc_fifo_bt2c51 
+3ddf 7d3a220f nsetflag blank ,wake_lock_ipc_bt2c51 ,rega 
+3de0 6802c7e4 fetch 5 ,mem_ipc_fifo_c512bt 
+3de1 7d3a220e nsetflag blank ,wake_lock_ipc_c512bt ,rega 
+3de2 6800c272 fetch 1 ,mem_hci_cmd 
+3de3 7d3a2208 nsetflag blank ,wake_lock_cmd ,rega 
+3de4 6800c132 fetch 1 ,mem_device_option 
+3de5 2fe1fe0a compare dvc_op_module ,pdata ,0xff 
+3de6 2040bdf5 call lpm_uart_wake_lock ,true 
+3de7 793f8025 set0 mark_ext_patch ,mark 
+3de8 44dec017 bpatch patch17_5 ,mem_patch17 
+3de9 6800c132 fetch 1 ,mem_device_option 
+3dea c080bdfa bne dvc_op_hci ,lpm_check_wake_lock_nothci 
+3deb 20403df5 call lpm_uart_wake_lock 
+3dec 6800c25e fetch 1 ,mem_link_key_exists 
+3ded 793a2203 setflag blank ,wake_link_key_exists ,rega 
+3dee 680242a5 fetch 4 ,mem_lpm_delay_after_sniff 
+3def d8401710 arg 0x1710 ,temp 
+3df0 98408400 iadd temp ,temp 
+3df1 1c427e00 copy clkn_bt ,pdata 
+3df2 98467c00 isub temp ,null 
+3df3 7d212204 nsetflag positive ,wake_lock_delay ,rega 
+3df4 20203dfc branch lpm_check_wake_lock_end 
+
+lpm_uart_wake_lock:
+3df5 68110112 hfetch 2 ,core_uart_rxitems 
+3df6 7d3a2206 nsetflag blank ,wake_lock_uart_rx ,rega 
+3df7 6811010e hfetch 2 ,core_uart_txitems 
+3df8 7d3a2205 nsetflag blank ,wake_lock_uart_tx ,rega 
+3df9 20600000 rtn 
+
+lpm_check_wake_lock_nothci:
+3dfa 5ffffff8 setarg -8 
+3dfb 9a212200 iand rega ,rega 
+
+lpm_check_wake_lock_end:
+3dfc 1a227e00 copy rega ,pdata 
+3dfd 600141f3 store 2 ,mem_lpm_wake_lock 
+3dfe 207a0000 rtn blank 
+3dff 20768000 rtn match 
+3e00 7835fc00 enable wake 
+3e01 20600000 rtn 
+
+lpm_shut_down:
+3e02 68120138 hfetch 4 ,core_lpm_ctrl 
+3e03 793ffe1b set0 27 ,pdata 
+3e04 6012004c hstore 4 ,core_lpm_reg 
+3e05 20403db0 call lpm_write_ctrl 
+3e06 20203bf1 branch assert 
+
+lpm_enable_exen_output:
+3e07 6812013c hfetch 4 ,core_lpm_xtalcnt 
+3e08 79207e14 set1 20 ,pdata 
+3e09 6012004c hstore 4 ,core_lpm_reg 
+3e0a 20203db2 branch lpm_write_ctrl2 
+
+lpm_disable_exen_output:
+3e0b 6812013c hfetch 4 ,core_lpm_xtalcnt 
+3e0c 793ffe14 set0 20 ,pdata 
+3e0d 6012004c hstore 4 ,core_lpm_reg 
+3e0e 20203db2 branch lpm_write_ctrl2 
+
+lpm_hci_wake_dispatch:
+3e0f 793f8025 set0 mark_ext_patch ,mark 
+3e10 44df4017 bpatch patch17_6 ,mem_patch17 
+3e11 6800c132 fetch 1 ,mem_device_option 
+3e12 c1808000 rtnne dvc_op_hci 
+3e13 20406a8b call gpio_check_uart_state 
+3e14 20608000 rtn true 
+3e15 68024807 fetch 4 ,mem_hci_wake_clk 
+3e16 243a3e1a nbranch lpm_hci_check_wake_time ,blank 
+3e17 1c427e00 copy clkn_bt ,pdata 
+3e18 60024807 store 4 ,mem_hci_wake_clk 
+3e19 20206a6b branch gpio_pd_uart_tx 
+
+lpm_hci_check_wake_time:
+3e1a 793f8025 set0 mark_ext_patch ,mark 
+3e1b 44dfc017 bpatch patch17_7 ,mem_patch17 
+3e1c 1c427e00 copy clkn_bt ,pdata 
+3e1d 680a4807 fetcht 4 ,mem_hci_wake_clk 
+3e1e 98467e00 isub temp ,pdata 
+3e1f d8400021 arg host_wake_time ,temp 
+3e20 98467c00 isub temp ,null 
+3e21 24610000 nrtn positive 
+3e22 58000000 setarg 0 
+3e23 60024807 store 4 ,mem_hci_wake_clk 
+3e24 20204599 branch hci_exit_lpm 
+
+check_bt_disabled:
+3e25 680141f1 fetch 2 ,mem_chip_functions 
+3e26 c2803bf1 bbit1 bt_disabled ,assert 
+3e27 20600000 rtn 
+
+check_ble_disabled:
+3e28 680141f1 fetch 2 ,mem_chip_functions 
+3e29 c280bbf1 bbit1 ble_disabled ,assert 
+3e2a 20600000 rtn 
+
+check_module_disabled:
+3e2b 680141f1 fetch 2 ,mem_chip_functions 
+3e2c c2813bf1 bbit1 module_disable ,assert 
+3e2d 20600000 rtn 
+
+test_init:
+3e2e 58003e37 setarg test_proc 
+3e2f 6001428e store 2 ,mem_cb_bt_process 
+3e30 58003e3d setarg test_sleep 
+3e31 60014292 store 2 ,mem_cb_bb_event_process 
+3e32 58003e37 setarg test_proc 
+3e33 60014290 store 2 ,mem_cb_idle_process 
+3e34 20758000 rtn wake 
+3e35 7047e901 jam ui_led_start ,mem_led_switch 
+3e36 20600000 rtn 
+
+test_proc:
+3e37 68008030 fetch 1 ,mem_state 
+3e38 c300de9f bbit0 state_insniff ,check_test_cond 
+3e39 7920000d set1 mark_lpm_mult_enable ,mark 
+3e3a 6803420a fetch 6 ,mem_sniff_rcv 
+3e3b 60034703 store 6 ,mem_local_name 
+3e3c 20207bde branch ui_led_blink_stop 
+
+test_sleep:
+3e3d 1a627e00 deposit regc 
+3e3e c1880000 rtnne bt_evt_button_long_pressed 
+
+test_sleep_loop:
+3e3f 20407bb1 call ui_button_polling 
+3e40 6800c7eb fetch 1 ,mem_ui_button_last_state 
+3e41 c000be3f beq 1 ,test_sleep_loop 
+3e42 20407be2 call ui_led_off 
+3e43 20203ccd branch lpm_hibernate 
+
+test_tx:
+3e44 18000402 force 2 ,temp 
+3e45 184085fe increase -2 ,temp 
+3e46 20403a7a call set_sync_on 
+3e47 20403a91 call set_freq_tx 
+3e48 7843fc00 disable enable_white 
+3e49 782efc00 enable encode_fec0 
+3e4a 79202a00 set1 txgfsk ,radio_ctrl 
+3e4b 20403bae call start_transmitter 
+
+test_tx_loop:
+3e4c 68008000 fetch 1 ,0 
+3e4d 08008608 inject mod ,8 
+3e4e 20203e4c branch test_tx_loop 
+
+app_init:
+3e4f 79200025 set1 mark_ext_patch ,mark 
+3e50 44e6c039 bpatch patch39_5 ,mem_patch39 
+3e51 6800c132 fetch 1 ,mem_device_option 
+3e52 203a3e4f branch app_init ,blank 
+3e53 c0035aa2 beq dvc_op_ukey ,le_ukey_init 
+3e54 c003cb33 beq dvc_op_ir ,le_ir_init 
+3e55 c0024293 beq dvc_op_dongle ,le_dongle_init 
+3e56 c001cc09 beq dvc_op_kb ,kb_init 
+3e57 c000c461 beq dvc_op_hci ,hci_init 
+3e58 c004f624 beq dvc_op_shutter ,shutter_init 
+3e59 c00562ef beq dvc_op_module ,module_init 
+3e5a c0064bf3 beq dvc_op_ble_kb ,le_kb_init 
+3e5b c006ea8e beq dvc_op_ble_prcp ,prcp_init 
+3e5c c07fbe2e beq dvc_op_test ,test_init 
+3e5d c2836486 bbit1 dvc_op_mouse ,mouse_init 
+3e5e 20600000 rtn 
+
+app_lpm_init:
+3e5f 79200025 set1 mark_ext_patch ,mark 
+3e60 44e74039 bpatch patch39_6 ,mem_patch39 
+3e61 70015300 jam 0 ,mem_tester_emulate 
+3e62 70018900 jam 0 ,mem_debug_config 
+3e63 70018a00 jam 0 ,mem_lch_code 
+3e64 58000000 setarg 0 
+3e65 600287da store 5 ,mem_sp_state_start 
+3e66 6800c132 fetch 1 ,mem_device_option 
+3e67 203a3e5f branch app_lpm_init ,blank 
+3e68 c005631f beq dvc_op_module ,module_lpm_init 
+3e69 20600000 rtn 
+
+app_process_idle:
+3e6a 20407ba1 call ui_dispatch 
+3e6b 20407c45 call check_51cmd 
+3e6c 20403e73 call app_process_bb_event 
+3e6d 68014290 fetch 2 ,mem_cb_idle_process 
+3e6e 20207f66 branch callback_func 
+
+app_process_bt:
+3e6f 6801428e fetch 2 ,mem_cb_bt_process 
+3e70 20207f66 branch callback_func 
+
+app_process_ble:
+3e71 6801428c fetch 2 ,mem_cb_le_process 
+3e72 20207f66 branch callback_func 
+
+app_process_bb_event:
+3e73 79200025 set1 mark_ext_patch ,mark 
+3e74 44e7c039 bpatch patch39_7 ,mem_patch39 
+3e75 da2047df arg mem_ipc_fifo_bt2c51 ,rega 
+3e76 20407f9f call fifo_out 
+3e77 207a0000 rtn blank 
+3e78 1fe22600 copy pdata ,regc 
+3e79 20403e7d call app_event_normal_process 
+3e7a 20203ea5 branch app_process_bb_event_priority 
+
+app_discard_event:
+3e7b da600000 arg 0 ,regc 
+3e7c 20600000 rtn 
+
+app_event_normal_process:
+3e7d c000be92 beq bt_evt_bb_connected ,app_evt_bt_conn 
+3e7e c0083ed9 beq bt_evt_button_long_pressed ,app_evt_button_long_pressed 
+3e7f c002beb6 beq bt_evt_setup_complete ,app_evt_setup_complete 
+3e80 c0093ebd beq bt_evt_hid_handshake ,app_evt_hid_handshake 
+3e81 c0033ed5 beq bt_evt_hid_connected ,app_bb_event_hid_connected 
+3e82 c0023efe beq bt_evt_reconn_failed ,app_bb_event_reconn_failed 
+3e83 c0013f03 beq bt_evt_bb_disconnected ,app_bb_event_bb_disconn 
+3e84 c009befe beq bt_evt_reconn_page_timeout ,app_bb_event_reconn_failed 
+3e85 c00a3ecc beq bt_evt_le_connected ,app_le_event_bb_connected 
+3e86 c00abed0 beq bt_evt_le_disconnected ,app_le_event_bb_disconn 
+3e87 c001beaf beq bt_evt_reconn_started ,app_event_reconn_start 
+3e88 c005bec1 beq bt_evt_enter_sniff ,app_event_enter_sniff 
+3e89 c0063ec8 beq bt_evt_exit_sniff ,app_event_exit_sniff 
+3e8a c00b3edd beq bt_evt_ml2cap_conn_refused ,app_event_ml2cap_conn_refused 
+3e8b c00c3eab beq bt_evt_linkkey_generate ,app_event_linkkey_generate 
+3e8c c0153e9b beq bt_evt_switch_fail_master ,app_event_switch_fail_master 
+3e8d c015be99 beq bt_evt_switch_success_master ,app_event_switch_success 
+3e8e 1fe1040f and pdata ,0x0f ,temp 
+3e8f 1fe17ef0 and_into bt_evt_timer_mask ,pdata 
+3e90 c0283ee1 beq bt_evt_timer_init ,app_evt_timer 
+3e91 20600000 rtn 
+
+app_evt_bt_conn:
+3e92 680147f4 fetch 2 ,mem_ui_state_map 
+3e93 79207e00 set1 ui_state_bt_connected ,pdata 
+3e94 600147f4 store 2 ,mem_ui_state_map 
+3e95 680142a2 fetch app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3e96 793ffe00 set0 app_disc_by_button ,pdata 
+3e97 600142a2 store app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3e98 20600000 rtn 
+
+app_event_switch_success:
+3e99 70025800 jam 0 ,mem_switch_fail_master_count 
+3e9a 20600000 rtn 
+
+app_event_switch_fail_master:
+3e9b 68008258 fetch 1 ,mem_switch_fail_master_count 
+3e9c 1fe0fe01 increase 1 ,pdata 
+3e9d 60008258 store 1 ,mem_switch_fail_master_count 
+3e9e 1fe67c01 sub pdata ,1 ,null 
+3e9f 20213f6c branch app_bt_role_switch ,positive 
+3ea0 70025800 jam 0 ,mem_switch_fail_master_count 
+3ea1 680142a2 fetch app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3ea2 79207e09 set1 app_disc_switch_fail ,pdata 
+3ea3 600142a2 store app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3ea4 20203f77 branch app_bt_disconnect 
+
+app_process_bb_event_priority:
+3ea5 68014292 fetch 2 ,mem_cb_bb_event_process 
+3ea6 20207f66 branch callback_func 
+
+app_check_wake_lock:
+3ea7 68014286 fetch 2 ,mem_cb_check_wakelock 
+3ea8 20207f66 branch callback_func 
+
+app_will_enter_lpm:
+3ea9 6801428a fetch 2 ,mem_cb_before_lpm 
+3eaa 20207f66 branch callback_func 
+
+app_event_linkkey_generate:
+3eab 680142a2 fetch app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3eac 79207e01 set1 app_disc_after_pairing ,pdata 
+3ead 600142a2 store app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3eae 20203fa2 branch app_bt_store_reconn_info 
+
+app_event_reconn_start:
+3eaf 680147f4 fetch 2 ,mem_ui_state_map 
+3eb0 79207e07 set1 ui_state_bt_reconnect ,pdata 
+3eb1 600147f4 store 2 ,mem_ui_state_map 
+3eb2 680142a2 fetch app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3eb3 79207e02 set1 app_disc_after_reconn ,pdata 
+3eb4 600142a2 store app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3eb5 20600000 rtn 
+
+app_evt_setup_complete:
+3eb6 680147f4 fetch 2 ,mem_ui_state_map 
+3eb7 79207e01 set1 ui_state_bt_setup_complete ,pdata 
+3eb8 600147f4 store 2 ,mem_ui_state_map 
+3eb9 680142a2 fetch app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3eba 79207e04 set1 app_disc_after_setup_done ,pdata 
+3ebb 600142a2 store app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3ebc 20600000 rtn 
+
+app_evt_hid_handshake:
+3ebd 680147f4 fetch 2 ,mem_ui_state_map 
+3ebe 79207e03 set1 ui_state_bt_hid_handshake ,pdata 
+3ebf 600147f4 store 2 ,mem_ui_state_map 
+3ec0 20600000 rtn 
+
+app_event_enter_sniff:
+3ec1 680147f4 fetch 2 ,mem_ui_state_map 
+3ec2 79207e05 set1 ui_state_bt_sniff ,pdata 
+3ec3 600147f4 store 2 ,mem_ui_state_map 
+3ec4 680142a2 fetch app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3ec5 79207e03 set1 app_disc_after_sniff ,pdata 
+3ec6 600142a2 store app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3ec7 20600000 rtn 
+
+app_event_exit_sniff:
+3ec8 680147f4 fetch 2 ,mem_ui_state_map 
+3ec9 793ffe05 set0 ui_state_bt_sniff ,pdata 
+3eca 600147f4 store 2 ,mem_ui_state_map 
+3ecb 20600000 rtn 
+
+app_le_event_bb_connected:
+3ecc 680147f4 fetch 2 ,mem_ui_state_map 
+3ecd 79207e09 set1 ui_state_ble_connected ,pdata 
+3ece 600147f4 store 2 ,mem_ui_state_map 
+3ecf 20600000 rtn 
+
+app_le_event_bb_disconn:
+3ed0 680147f4 fetch 2 ,mem_ui_state_map 
+3ed1 793ffe09 set0 ui_state_ble_connected ,pdata 
+3ed2 600147f4 store 2 ,mem_ui_state_map 
+3ed3 7046f800 jam 0 ,mem_le_switch_send_data 
+3ed4 20203fa6 branch app_lpm_mult_disable 
+
+app_bb_event_hid_connected:
+3ed5 680147f4 fetch 2 ,mem_ui_state_map 
+3ed6 79207e02 set1 ui_state_bt_hid_conn ,pdata 
+3ed7 600147f4 store 2 ,mem_ui_state_map 
+3ed8 20600000 rtn 
+
+app_evt_button_long_pressed:
+3ed9 680142a2 fetch app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3eda 79207e00 set1 app_disc_by_button ,pdata 
+3edb 600142a2 store app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3edc 20600000 rtn 
+
+app_event_ml2cap_conn_refused:
+3edd 680142a2 fetch app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3ede 79207e08 set1 app_disc_l2cap_refused ,pdata 
+3edf 600142a2 store app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3ee0 20203f77 branch app_bt_disconnect 
+
+app_evt_timer:
+3ee1 79200025 set1 mark_ext_patch ,mark 
+3ee2 44e8403a bpatch patch3a_0 ,mem_patch3a 
+3ee3 60088259 storet 1 ,mem_app_evt_timer_count 
+
+app_evt_100ms_loop:
+3ee4 68008259 fetch 1 ,mem_app_evt_timer_count 
+3ee5 207a0000 rtn blank 
+3ee6 1fe0ffff increase -1 ,pdata 
+3ee7 60008259 store 1 ,mem_app_evt_timer_count 
+3ee8 20407bb1 call ui_button_polling 
+3ee9 20403f60 call app_lpm_wake_auto_lock_timer 
+3eea 20403eed call app_unsniff_delay_timer 
+3eeb 20403ef5 call app_discovery_timer 
+3eec 20203ee4 branch app_evt_100ms_loop 
+
+app_unsniff_delay_timer:
+3eed 6800c29d fetch 1 ,mem_unsniff2sniff_timer_count 
+3eee 207a0000 rtn blank 
+3eef 1fe0ffff increase -1 ,pdata 
+3ef0 6000c29d store 1 ,mem_unsniff2sniff_timer_count 
+3ef1 247a0000 nrtn blank 
+3ef2 204032ee call context_check_idle 
+3ef3 2022bf9e branch app_bt_enter_sniff ,zero 
+3ef4 20600000 rtn 
+
+app_discovery_timer:
+3ef5 680147f0 fetch 2 ,mem_discovery_timeout_timer_count 
+3ef6 207a0000 rtn blank 
+3ef7 1fe0ffff increase -1 ,pdata 
+3ef8 600147f0 store 2 ,mem_discovery_timeout_timer_count 
+3ef9 247a0000 nrtn blank 
+3efa 20403f7e call app_bt_stop_discovery 
+3efb 20403f98 call app_led_off 
+3efc 68014294 fetch 2 ,mem_cb_discovry_timeout 
+3efd 20207f66 branch callback_func 
+
+app_bb_event_reconn_failed:
+3efe 20403f15 call app_disconn_reason_flag_clear 
+
+app_clear_reconnect_flag:
+3eff 680147f4 fetch 2 ,mem_ui_state_map 
+3f00 793ffe07 set0 ui_state_bt_reconnect ,pdata 
+3f01 600147f4 store 2 ,mem_ui_state_map 
+3f02 20600000 rtn 
+
+app_bb_event_bb_disconn:
+3f03 70429d00 jam 0 ,mem_unsniff2sniff_timer_count 
+3f04 680147f4 fetch 2 ,mem_ui_state_map 
+3f05 c283bf08 bbit1 ui_state_bt_reconnect ,app_bb_event_bb_reconn_disconn 
+3f06 2fec0001 isolate0 ui_state_bt_setup_complete ,pdata 
+3f07 2040be7b call app_discard_event ,true 
+
+app_bb_event_bb_reconn_disconn:
+3f08 680147f4 fetch 2 ,mem_ui_state_map 
+3f09 793ffe00 set0 ui_state_bt_connected ,pdata 
+3f0a 793ffe01 set0 ui_state_bt_setup_complete ,pdata 
+3f0b 793ffe02 set0 ui_state_bt_hid_conn ,pdata 
+3f0c 793ffe03 set0 ui_state_bt_hid_handshake ,pdata 
+3f0d 793ffe04 set0 ui_state_bt_spp_conn ,pdata 
+3f0e 600147f4 store 2 ,mem_ui_state_map 
+3f0f 20203fa6 branch app_lpm_mult_disable 
+
+app_bb_hibernate:
+3f10 20403f12 call app_disconn_reason_clear 
+3f11 20203f9a branch app_enter_hibernate 
+
+app_event_do_nothing:
+
+app_disconn_reason_clear:
+3f12 58000000 setarg 0 
+3f13 600142a0 store app_disc_rsn_size ,mem_app_disconn_reason 
+3f14 20600000 rtn 
+
+app_disconn_reason_flag_clear:
+3f15 58000000 setarg 0 
+3f16 600142a2 store app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3f17 20600000 rtn 
+
+app_disconn_reason_collect_bt:
+3f18 680142a2 fetch app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3f19 600142a0 store app_disc_rsn_size ,mem_app_disconn_reason 
+3f1a 58000000 setarg 0 
+3f1b 600142a2 store app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3f1c 20600000 rtn 
+
+app_disconn_reason_collect_ble:
+3f1d 680142a2 fetch app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3f1e 79207e07 set1 app_disc_ble ,pdata 
+3f1f 600142a0 store app_disc_rsn_size ,mem_app_disconn_reason 
+3f20 58000000 setarg 0 
+3f21 600142a2 store app_disc_rsn_size ,mem_app_disconn_reason_flag 
+3f22 20600000 rtn 
+
+app_check_reconn_target:
+3f23 2040691d call eeprom_load_reconn_info 
+3f24 68034274 fetch 6 ,mem_hci_plap 
+3f25 20600000 rtn 
+
+app_le_check_reconn_target:
+3f26 6800c48b fetch 1 ,mem_ltk_exists 
+3f27 203a3f2a branch app_le_check_reconn_target_none ,blank 
+3f28 20403f96 call app_led_on 
+3f29 20203f82 branch app_ble_start_direct_adv 
+
+app_le_check_reconn_target_none:
+3f2a 20403f94 call app_led_start_blink 
+3f2b 20203f88 branch app_ble_start_adv 
+
+app_check_plap:
+3f2c 79200025 set1 mark_ext_patch ,mark 
+3f2d 44e8c03a bpatch patch3a_1 ,mem_patch3a 
+3f2e da400244 arg mem_check_plap_temp ,regb 
+3f2f da603f31 arg app_check_one_plap ,regc 
+3f30 20203301 branch context_search 
+
+app_check_one_plap:
+3f31 d8400000 arg 0 ,temp 
+3f32 c3003f35 bbit0 state_inconn ,app_check_one_plap_next 
+3f33 1a208c10 add rega ,coffset_plap ,contr 
+3f34 e8cb0000 ifetcht 6 ,contr 
+
+app_check_one_plap_next:
+3f35 18427e00 copy temp ,pdata 
+3f36 245a3f3a ncall app_check_one_plap_device_exist ,blank 
+3f37 e24b0000 istoret 6 ,regb 
+3f38 1a40a406 increase 6 ,regb 
+3f39 20203307 branch context_search_next 
+
+app_check_one_plap_device_exist:
+3f3a 6800c29a fetch 1 ,mem_device_nums 
+3f3b 1fe0fe01 increase 1 ,pdata 
+3f3c 6000c29a store 1 ,mem_device_nums 
+3f3d 20600000 rtn 
+
+app_check_conn_device_nums_addr:
+3f3e 70429a00 jam 0 ,mem_device_nums 
+3f3f 20203f2c branch app_check_plap 
+
+app_check_sniff:
+3f40 6800c7f4 fetch 1 ,mem_ui_state_map 
+3f41 2feffe05 isolate1 ui_state_bt_sniff ,pdata 
+3f42 20600000 rtn 
+
+app_clearflag_store:
+3f43 58000000 setarg 0 
+3f44 20203f46 branch app_flag_store 
+
+app_initflag_store:
+3f45 5800aa55 setarg eeprom_init_flag 
+
+app_flag_store:
+3f46 600102a8 store 2 ,mem_timeup 
+3f47 79200025 set1 mark_ext_patch ,mark 
+3f48 44e9403a bpatch patch3a_2 ,mem_patch3a 
+3f49 d8400002 arg 2 ,temp 
+3f4a da2002a8 arg mem_timeup ,rega 
+3f4b da4000c3 arg eeprom_module_init_flag ,regb 
+3f4c 2020683e branch iicd_write_eep_data 
+
+app_initflag_check:
+3f4d 79200025 set1 mark_ext_patch ,mark 
+3f4e 44e9c03a bpatch patch3a_3 ,mem_patch3a 
+3f4f d8400002 arg 2 ,temp 
+3f50 da200161 arg mem_pdatatemp ,rega 
+3f51 da4000c3 arg eeprom_module_init_flag ,regb 
+3f52 2040681d call iicd_read_eep_data 
+3f53 68010161 fetch 2 ,mem_pdatatemp 
+3f54 d840aa55 arg eeprom_init_flag ,temp 
+3f55 98467c00 isub temp ,null 
+3f56 20600000 rtn 
+
+app_start_auto_sniff:
+3f57 6800c747 fetch 1 ,mem_unsniff2sniff_timer 
+3f58 6000c29d store 1 ,mem_unsniff2sniff_timer_count 
+3f59 20600000 rtn 
+
+app_get_lpm_wake_lock:
+3f5a d8e00009 arg wake_lock_app ,queue 
+3f5b 20203dc2 branch lpm_get_wake_lock 
+
+app_put_lpm_wake_lock:
+3f5c d8e00009 arg wake_lock_app ,queue 
+3f5d 20203dc6 branch lpm_put_wake_lock 
+
+app_lpm_wake_auto_lock:
+3f5e 70429e05 jam lpm_wake_up_delay_timer ,mem_wake_up_delay_timer 
+3f5f 20203f5a branch app_get_lpm_wake_lock 
+
+app_lpm_wake_auto_lock_timer:
+3f60 6800c29e fetch 1 ,mem_wake_up_delay_timer 
+3f61 207a0000 rtn blank 
+3f62 1fe0ffff increase -1 ,pdata 
+3f63 6000c29e store 1 ,mem_wake_up_delay_timer 
+3f64 247a0000 nrtn blank 
+3f65 20203f5c branch app_put_lpm_wake_lock 
+
+app_l2cap_flow_control_enable:
+3f66 7043cc01 jam l2cap_flow_ctrl_enable ,mem_l2cap_flow_ctrl_flag 
+3f67 20600000 rtn 
+
+app_l2cap_flow_control_disable:
+3f68 7043cc00 jam l2cap_flow_ctrl_disable ,mem_l2cap_flow_ctrl_flag 
+3f69 20600000 rtn 
+
+app_bt_set_pincode:
+3f6a 700b7d0a jam bt_cmd_set_pin_code ,mem_fifo_temp 
+3f6b 20207c33 branch ui_ipc_send_cmd 
+
+app_bt_role_switch:
+3f6c 700b7d1d jam bt_cmd_role_switch ,mem_fifo_temp 
+3f6d 20207c33 branch ui_ipc_send_cmd 
+
+app_bt_start_reconnect:
+3f6e 79200025 set1 mark_ext_patch ,mark 
+3f6f 44ea403a bpatch patch3a_4 ,mem_patch3a 
+3f70 6800c29f fetch 1 ,mem_app_connection_options 
+3f71 60008177 store 1 ,mem_connection_options 
+3f72 70025701 jam app_flag_reconnect ,mem_reconnect_flag 
+3f73 700b7d03 jam bt_cmd_reconnect ,mem_fifo_temp 
+3f74 20207c33 branch ui_ipc_send_cmd 
+
+app_bt_reconnect_cancel:
+3f75 700b7d1e jam bt_cmd_bb_reconn_cancel ,mem_fifo_temp 
+3f76 20207c33 branch ui_ipc_send_cmd 
+
+app_bt_disconnect:
+3f77 700b7d04 jam bt_cmd_disconnect ,mem_fifo_temp 
+3f78 20207c33 branch ui_ipc_send_cmd 
+
+app_bt_start_discovery_short:
+3f79 680147fe fetch 2 ,mem_discovery_timeout 
+3f7a 600147f0 store 2 ,mem_discovery_timeout_timer_count 
+
+app_bt_start_discovery_led_blink:
+3f7b 20403f94 call app_led_start_blink 
+
+app_bt_start_discovery:
+3f7c 700b7d01 jam bt_cmd_start_discovery ,mem_fifo_temp 
+3f7d 20207c33 branch ui_ipc_send_cmd 
+
+app_bt_stop_discovery:
+3f7e 58000000 setarg 0 
+3f7f 600147f0 store 2 ,mem_discovery_timeout_timer_count 
+3f80 700b7d02 jam bt_cmd_stop_discovery ,mem_fifo_temp 
+3f81 20207c33 branch ui_ipc_send_cmd 
+
+app_ble_start_direct_adv:
+3f82 700b7d0f jam bt_cmd_start_direct_adv ,mem_fifo_temp 
+3f83 20207c33 branch ui_ipc_send_cmd 
+
+app_ble_stop_direct_adv:
+3f84 700b7d10 jam bt_cmd_stop_direct_adv ,mem_fifo_temp 
+3f85 20207c33 branch ui_ipc_send_cmd 
+
+app_ble_stop_adv:
+3f86 700b7d0e jam bt_cmd_stop_adv ,mem_fifo_temp 
+3f87 20207c33 branch ui_ipc_send_cmd 
+
+app_ble_start_adv:
+3f88 700b7d0d jam bt_cmd_start_adv ,mem_fifo_temp 
+3f89 20207c33 branch ui_ipc_send_cmd 
+
+app_ble_start_scan:
+3f8a 700b7d17 jam bt_cmd_le_start_scan ,mem_fifo_temp 
+3f8b 20207c33 branch ui_ipc_send_cmd 
+
+app_ble_stop_scan:
+3f8c 700b7d18 jam bt_cmd_le_stop_scan ,mem_fifo_temp 
+3f8d 20207c33 branch ui_ipc_send_cmd 
+
+app_ble_start_conn:
+3f8e 700b7d16 jam bt_cmd_le_start_conn ,mem_fifo_temp 
+3f8f 20207c33 branch ui_ipc_send_cmd 
+
+app_ble_disconnect:
+3f90 700b7d11 jam bt_cmd_le_disconnect ,mem_fifo_temp 
+3f91 20207c33 branch ui_ipc_send_cmd 
+
+app_ble_start_write:
+3f92 700b7d1c jam bt_cmd_le_start_write ,mem_fifo_temp 
+3f93 20207c33 branch ui_ipc_send_cmd 
+
+app_led_start_blink:
+3f94 700b7d15 jam bt_cmd_led_blink ,mem_fifo_temp 
+3f95 20207c33 branch ui_ipc_send_cmd 
+
+app_led_on:
+3f96 700b7d14 jam bt_cmd_led_on ,mem_fifo_temp 
+3f97 20207c33 branch ui_ipc_send_cmd 
+
+app_led_stop_blink:
+
+app_led_off:
+3f98 700b7d13 jam bt_cmd_led_off ,mem_fifo_temp 
+3f99 20207c33 branch ui_ipc_send_cmd 
+
+app_enter_hibernate:
+3f9a 700b7d19 jam bt_cmd_enter_hibernate ,mem_fifo_temp 
+3f9b 20207c33 branch ui_ipc_send_cmd 
+
+app_bt_sniff_exit:
+3f9c 700b7d06 jam bt_cmd_exit_sniff ,mem_fifo_temp 
+3f9d 20207c33 branch ui_ipc_send_cmd 
+
+app_bt_enter_sniff:
+3f9e 700b7d05 jam bt_cmd_enter_sniff ,mem_fifo_temp 
+3f9f 20207c33 branch ui_ipc_send_cmd 
+
+app_ble_store_reconn_info:
+3fa0 700b7d1f jam bt_cmd_store_reconn_info_le ,mem_fifo_temp 
+3fa1 20207c33 branch ui_ipc_send_cmd 
+
+app_bt_store_reconn_info:
+3fa2 700b7d20 jam bt_cmd_store_reconn_info_bt ,mem_fifo_temp 
+3fa3 20207c33 branch ui_ipc_send_cmd 
+
+app_lpm_mult_enable:
+3fa4 7920000d set1 mark_lpm_mult_enable ,mark 
+3fa5 20600000 rtn 
+
+app_lpm_mult_disable:
+3fa6 793f800d set0 mark_lpm_mult_enable ,mark 
+3fa7 20600000 rtn 
+
+at_restore_param:
+3fa8 79200025 set1 mark_ext_patch ,mark 
+3fa9 44c84032 bpatch patch32_0 ,mem_patch32 
+3faa d8400020 arg 32 ,temp 
+3fab da204419 arg mem_le_name_len ,rega 
+3fac da4000a0 arg eeprom_module_ble_name_length ,regb 
+3fad 2040681d call iicd_read_eep_data 
+3fae d8400020 arg 32 ,temp 
+3faf da204702 arg mem_local_name_length ,rega 
+3fb0 da40007f arg eeprom_module_bt_name_length ,regb 
+3fb1 2040681d call iicd_read_eep_data 
+3fb2 d8400006 arg 6 ,temp 
+3fb3 da204140 arg mem_lap ,rega 
+3fb4 da400063 arg eeprom_module_bt_adss ,regb 
+3fb5 2040681d call iicd_read_eep_data 
+3fb6 d8400006 arg 6 ,temp 
+3fb7 da2044f9 arg mem_le_lap ,rega 
+3fb8 da400069 arg eeprom_module_le_adss ,regb 
+3fb9 2040681d call iicd_read_eep_data 
+3fba 20405adb call le_modified_name 
+3fbb d8400002 arg 2 ,temp 
+3fbc da2042ac arg mem_baud ,rega 
+3fbd da4000c0 arg eeprom_module_trans_baud ,regb 
+3fbe 2040681d call iicd_read_eep_data 
+3fbf 20406909 call uart_set_baud_by_mem 
+3fc0 20203fc1 branch at_restore_pin_code 
+
+at_restore_pin_code:
+3fc1 d840000e arg 14 ,temp 
+3fc2 da20054f arg mem_pin_length ,rega 
+3fc3 da40006f arg eeprom_module_pincode_length ,regb 
+3fc4 2020681d branch iicd_read_eep_data 
+
+init_module_environment:
+3fc5 79200025 set1 mark_ext_patch ,mark 
+3fc6 44c8c032 bpatch patch32_1 ,mem_patch32 
+3fc7 20403f4d call app_initflag_check 
+3fc8 2022bfa8 branch at_restore_param ,zero 
+
+init_module_eeprom:
+3fc9 20403fd2 call at_store_bt_name 
+3fca 20403fd7 call at_store_le_name 
+3fcb 20405adb call le_modified_name 
+3fcc 20403fdc call at_store_le_adss 
+3fcd 20403fe0 call at_store_bt_adss 
+3fce 204062e9 call pincode_reinit 
+3fcf 20403fe4 call at_store_bt_pincode 
+3fd0 20403fe9 call at_store_throughput_uart_baud115200 
+3fd1 20203f45 branch app_initflag_store 
+
+at_store_bt_name:
+3fd2 6808c702 fetcht 1 ,mem_local_name_length 
+3fd3 18408401 increase 1 ,temp 
+3fd4 da204702 arg mem_local_name_length ,rega 
+3fd5 da40007f arg eeprom_module_bt_name_length ,regb 
+3fd6 2020683e branch iicd_write_eep_data 
+
+at_store_le_name:
+3fd7 6808c419 fetcht 1 ,mem_le_name_len 
+3fd8 18408401 increase 1 ,temp 
+3fd9 da204419 arg mem_le_name_len ,rega 
+3fda da4000a0 arg eeprom_module_ble_name_length ,regb 
+3fdb 2020683e branch iicd_write_eep_data 
+
+at_store_le_adss:
+3fdc d8400006 arg 6 ,temp 
+3fdd da2044f9 arg mem_le_lap ,rega 
+3fde da400069 arg eeprom_module_le_adss ,regb 
+3fdf 2020683e branch iicd_write_eep_data 
+
+at_store_bt_adss:
+3fe0 d8400006 arg 6 ,temp 
+3fe1 da204140 arg mem_lap ,rega 
+3fe2 da400063 arg eeprom_module_bt_adss ,regb 
+3fe3 2020683e branch iicd_write_eep_data 
+
+at_store_bt_pincode:
+3fe4 6808854f fetcht 1 ,mem_pin_length 
+3fe5 18408401 increase 1 ,temp 
+3fe6 da20054f arg mem_pin_length ,rega 
+3fe7 da40006f arg eeprom_module_pincode_length ,regb 
+3fe8 2020683e branch iicd_write_eep_data 
+
+at_store_throughput_uart_baud115200:
+3fe9 580001a0 setarg at_baud_115200 
+3fea 600102a8 store 2 ,mem_timeup 
+
+at_store_throughput_uart_baud:
+3feb d8400002 arg 2 ,temp 
+3fec da2002a8 arg mem_timeup ,rega 
+3fed da4000c0 arg eeprom_module_trans_baud ,regb 
+3fee 2020683e branch iicd_write_eep_data 
+
+at_process:
+3fef 79200025 set1 mark_ext_patch ,mark 
+3ff0 44c94032 bpatch patch32_2 ,mem_patch32 
+3ff1 6801480e fetch 2 ,mem_current_packet_length 
+3ff2 d840012c arg 300 ,temp 
+3ff3 98467c00 isub temp ,null 
+3ff4 2021427f branch at_error_rev_end ,positive 
+3ff5 20403e2b call check_module_disabled 
+3ff6 20407f6b call get_uart_rrptr 
+3ff7 18622200 copy contru ,rega 
+3ff8 6801480e fetch 2 ,mem_current_packet_length 
+3ff9 1fe0fffe increase -2 ,pdata 
+3ffa 98608600 iadd contru ,contru 
+3ffb e8610000 ifetch 2 ,contru 
+3ffc d8400a0d arg at_cmd_end ,temp 
+3ffd 98467c00 isub temp ,null 
+3ffe 24628000 nrtn zero 
+3fff 1a220600 copy rega ,contru 
+4000 da404850 arg mem_prarm_atp ,regb 
+4001 df200003 arg 3 ,loopcnt 
+4002 20404237 call string_compare_uart_follow 
+4003 2420c27f nbranch at_error_rev_end ,true 
+4004 20204005 branch at_dispatch 
+
+at_dispatch:
+4005 79200025 set1 mark_ext_patch ,mark 
+4006 44c9c032 bpatch patch32_3 ,mem_patch32 
+4007 18622200 copy contru ,rega 
+4008 da404827 arg mem_prarm_name ,regb 
+4009 18007204 force 4 ,loopcnt 
+400a 20404237 call string_compare_uart_follow 
+400b 2020c06d branch at_rev_name ,true 
+400c da404824 arg mem_prarm_blename ,regb 
+400d 18007207 force 7 ,loopcnt 
+400e 20404237 call string_compare_uart_follow 
+400f 2020c074 branch at_rev_le_name ,true 
+4010 da40482e arg mem_prarm_adss ,regb 
+4011 18007204 force 4 ,loopcnt 
+4012 20404237 call string_compare_uart_follow 
+4013 2020c07b branch at_rev_adss ,true 
+4014 da40482b arg mem_prarm_bleadss ,regb 
+4015 18007207 force 7 ,loopcnt 
+4016 20404237 call string_compare_uart_follow 
+4017 2020c081 branch at_rev_leadss ,true 
+4018 da404832 arg mem_prarm_vers ,regb 
+4019 18007204 force 4 ,loopcnt 
+401a 20404237 call string_compare_uart_follow 
+401b 2020c087 branch at_rev_vers ,true 
+401c da404820 arg mem_prarm_uart ,regb 
+401d 18007204 force 4 ,loopcnt 
+401e 20404237 call string_compare_uart_follow 
+401f 2020c08c branch at_rev_uart ,true 
+4020 da40481c arg mem_prarm_pswd ,regb 
+4021 18007204 force 4 ,loopcnt 
+4022 20404237 call string_compare_uart_follow 
+4023 2020c08f branch at_rev_pswd ,true 
+4024 da404836 arg mem_prarm_class ,regb 
+4025 18007205 force 5 ,loopcnt 
+4026 20404237 call string_compare_uart_follow 
+4027 2020c095 branch at_rev_class ,true 
+4028 da404853 arg mem_prarm_list ,regb 
+4029 18007204 force 4 ,loopcnt 
+402a 20404237 call string_compare_uart_follow 
+402b 2020c09b branch at_rev_list ,true 
+402c da404857 arg mem_prarm_role ,regb 
+402d 18007204 force 4 ,loopcnt 
+402e 20404237 call string_compare_uart_follow 
+402f 2020c0a1 branch at_rev_role ,true 
+4030 da40485b arg mem_prarm_sniff ,regb 
+4031 18007205 force 5 ,loopcnt 
+4032 20404237 call string_compare_uart_follow 
+4033 2020c0a5 branch at_rev_sniff ,true 
+4034 da404860 arg mem_prarm_ldev ,regb 
+4035 18007204 force 4 ,loopcnt 
+4036 20404237 call string_compare_uart_follow 
+4037 2020c0ab branch at_rev_ldev ,true 
+4038 da404864 arg mem_prarm_rssi ,regb 
+4039 18007204 force 4 ,loopcnt 
+403a 20404237 call string_compare_uart_follow 
+403b 2020c0b0 branch at_rev_rssi ,true 
+403c da404868 arg mem_prarm_cdev ,regb 
+403d 18007204 force 4 ,loopcnt 
+403e 20404237 call string_compare_uart_follow 
+403f 2020c0b7 branch at_rev_cdev ,true 
+4040 da40486f arg mem_prarm_inqr ,regb 
+4041 18007204 force 4 ,loopcnt 
+4042 20404237 call string_compare_uart_follow 
+4043 2020c0d6 branch at_rev_inqr ,true 
+4044 da40486c arg mem_prarm_bleinqr ,regb 
+4045 18007207 force 7 ,loopcnt 
+4046 20404237 call string_compare_uart_follow 
+4047 2020c0dd branch at_rev_leinqr ,true 
+4048 da404873 arg mem_prarm_cmode ,regb 
+4049 18007205 force 5 ,loopcnt 
+404a 20404237 call string_compare_uart_follow 
+404b 2020c0f2 branch at_rev_cmode ,true 
+404c da404878 arg mem_prarm_mode ,regb 
+404d 18007204 force 4 ,loopcnt 
+404e 20404237 call string_compare_uart_follow 
+404f 2020c0f8 branch at_rev_mode ,true 
+4050 da40487c arg mem_prarm_dmstate ,regb 
+4051 18007207 force 7 ,loopcnt 
+4052 20404237 call string_compare_uart_follow 
+4053 2020c0fb branch at_rev_dmstate ,true 
+4054 da404841 arg mem_prarm_reconn ,regb 
+4055 18007206 force 6 ,loopcnt 
+4056 20404237 call string_compare_uart_follow 
+4057 2020c100 branch at_rev_reconn ,true 
+4058 da404883 arg mem_prarm_discov ,regb 
+4059 18007206 force 6 ,loopcnt 
+405a 20404237 call string_compare_uart_follow 
+405b 2020c12c branch at_rev_discov ,true 
+405c da404849 arg mem_prarm_dis ,regb 
+405d 18007203 force 3 ,loopcnt 
+405e 20404237 call string_compare_uart_follow 
+405f 2020c10e branch at_rev_dis ,true 
+4060 da40484c arg mem_prarm_stsn ,regb 
+4061 18007204 force 4 ,loopcnt 
+4062 20404237 call string_compare_uart_follow 
+4063 2020c117 branch at_rev_stsn ,true 
+4064 da40483b arg mem_prarm_clrflg ,regb 
+4065 18007206 force 6 ,loopcnt 
+4066 20404237 call string_compare_uart_follow 
+4067 2020c127 branch at_rev_clrflg ,true 
+4068 da404889 arg mem_prarm_ota ,regb 
+4069 18007203 force 3 ,loopcnt 
+406a 20404237 call string_compare_uart_follow 
+406b 2020c129 branch at_rev_ota ,true 
+406c 2020427f branch at_error_rev_end 
+
+at_rev_name:
+406d e8608000 ifetch 1 ,contru 
+406e c01fc071 beq at_ques ,at_rev_name_inquiry 
+406f c01ec131 beq at_equ ,at_rev_name_set 
+4070 2020427f branch at_error_rev_end 
+
+at_rev_name_inquiry:
+4071 20407f6e call get_uart_twptr 
+4072 20404194 call at_group_name_inquiry 
+4073 20204286 branch at_nomal_rev_end 
+
+at_rev_le_name:
+4074 e8608000 ifetch 1 ,contru 
+4075 c01fc078 beq at_ques ,at_rev_le_name_inquiry 
+4076 c01ec136 beq at_equ ,at_rev_le_name_set 
+4077 2020427f branch at_error_rev_end 
+
+at_rev_le_name_inquiry:
+4078 20407f6e call get_uart_twptr 
+4079 2040419b call at_group_le_name_inquiry 
+407a 20204286 branch at_nomal_rev_end 
+
+at_rev_adss:
+407b e8608000 ifetch 1 ,contru 
+407c c01fc07f beq at_ques ,at_rev_adss_inquiry 
+407d c01ec13c beq at_equ ,at_rev_adss_set 
+407e 2020427f branch at_error_rev_end 
+
+at_rev_adss_inquiry:
+407f 204041a2 call at_group_adss_inquiry 
+4080 20204286 branch at_nomal_rev_end 
+
+at_rev_leadss:
+4081 e8608000 ifetch 1 ,contru 
+4082 c01fc085 beq at_ques ,at_rev_leadss_inquiry 
+4083 c01ec140 beq at_equ ,at_rev_leadss_set 
+4084 2020427f branch at_error_rev_end 
+
+at_rev_leadss_inquiry:
+4085 204041a8 call at_group_leadss_inquiry 
+4086 20204286 branch at_nomal_rev_end 
+
+at_rev_vers:
+4087 e8608000 ifetch 1 ,contru 
+4088 c01fc08a beq at_ques ,at_rev_vers_inquiry 
+4089 2020427f branch at_error_rev_end 
+
+at_rev_vers_inquiry:
+408a 204041ae call at_group_version_inquiry 
+408b 20204286 branch at_nomal_rev_end 
+
+at_rev_uart:
+408c e8608000 ifetch 1 ,contru 
+408d c01ec149 beq at_equ ,at_rev_uart_set 
+408e 2020427f branch at_error_rev_end 
+
+at_rev_pswd:
+408f e8608000 ifetch 1 ,contru 
+4090 c01fc093 beq at_ques ,at_rev_pswd_inquiry 
+4091 c01ec144 beq at_equ ,at_rev_pswd_set 
+4092 2020427f branch at_error_rev_end 
+
+at_rev_pswd_inquiry:
+4093 20404204 call at_group_pswd_inquiry 
+4094 20204286 branch at_nomal_rev_end 
+
+at_rev_class:
+4095 e8608000 ifetch 1 ,contru 
+4096 c01fc099 beq at_ques ,at_rev_class_inquiry 
+4097 c01ec157 beq at_equ ,at_rev_class_set 
+4098 2020427f branch at_error_rev_end 
+
+at_rev_class_inquiry:
+4099 204041b4 call at_group_class_inquiry 
+409a 20204286 branch at_nomal_rev_end 
+
+at_rev_list:
+409b e8608000 ifetch 1 ,contru 
+409c c01fc09f beq at_ques ,at_rev_list_inquiry 
+409d c01ec172 beq at_equ ,at_rev_list_set 
+409e 2020427f branch at_error_rev_end 
+
+at_rev_list_inquiry:
+409f 204041ba call at_group_list_inquiry 
+40a0 20204286 branch at_nomal_rev_end 
+
+at_rev_role:
+40a1 e8608000 ifetch 1 ,contru 
+40a2 c01fc0e1 beq at_ques ,at_rev_role_inquiry 
+40a3 c01ec15a beq at_equ ,at_rev_role_set 
+40a4 2020427f branch at_error_rev_end 
+
+at_rev_sniff:
+40a5 e8608000 ifetch 1 ,contru 
+40a6 c01fc0a9 beq at_ques ,at_rev_sniff_inquiry 
+40a7 c01ec16b beq at_equ ,at_rev_sniff_set 
+40a8 2020427f branch at_error_rev_end 
+
+at_rev_sniff_inquiry:
+40a9 2040420b call at_group_sniff_inquiry 
+40aa 20204286 branch at_nomal_rev_end 
+
+at_rev_ldev:
+40ab e8608000 ifetch 1 ,contru 
+40ac c01fc0ae beq at_ques ,at_rev_ldev_inquiry 
+40ad 2020427f branch at_error_rev_end 
+
+at_rev_ldev_inquiry:
+40ae 204041c0 call at_group_ldev_inquiry 
+40af 20204286 branch at_nomal_rev_end 
+
+at_rev_rssi:
+40b0 e8608000 ifetch 1 ,contru 
+40b1 c01fc0b3 beq at_ques ,at_rev_rssi_inquiry 
+40b2 20204286 branch at_nomal_rev_end 
+
+at_rev_rssi_inquiry:
+40b3 204032ee call context_check_idle 
+40b4 2422c27f nbranch at_error_rev_end ,zero 
+40b5 204041cd call at_group_rssi_inquiry 
+40b6 20204286 branch at_nomal_rev_end 
+
+at_rev_cdev:
+40b7 e8608000 ifetch 1 ,contru 
+40b8 c01fc0ba beq at_ques ,at_rev_cdev_inquiry 
+40b9 2020427f branch at_error_rev_end 
+
+at_rev_cdev_inquiry:
+40ba 6800c040 fetch 1 ,mem_context 
+40bb c300427f bbit0 state_inconn ,at_error_rev_end 
+40bc 20407f6e call get_uart_twptr 
+40bd 6800c041 fetch 1 ,mem_context + coffset_mode 
+40be c28040c0 bbit1 mode_le ,le_cdev_inquiry 
+40bf 202040cb branch at_cdev_unle_inq 
+
+le_cdev_inquiry:
+40c0 da204868 arg mem_prarm_cdev ,rega 
+40c1 df200004 arg 4 ,loopcnt 
+40c2 20404232 call at_group_inquiryhead_common 
+40c3 20404247 call at_rev_uart_write_62 
+40c4 58000034 setarg 0x34 
+40c5 e1408000 istore 1 ,contwu 
+40c6 2040424e call at_rev_uart_write_44 
+40c7 da2003d0 arg mem_le_plap ,rega 
+40c8 20407e9d call adss_hex2string_to_uart 
+40c9 204068fa call uartd_send 
+40ca 20204286 branch at_nomal_rev_end 
+
+at_cdev_unle_inq:
+40cb da204868 arg mem_prarm_cdev ,rega 
+40cc df200004 arg 4 ,loopcnt 
+40cd 20404232 call at_group_inquiryhead_common 
+40ce 20404247 call at_rev_uart_write_62 
+40cf 58000033 setarg 0x33 
+40d0 e1408000 istore 1 ,contwu 
+40d1 2040424e call at_rev_uart_write_44 
+40d2 da200040 arg mem_plap ,rega 
+40d3 20407e9d call adss_hex2string_to_uart 
+40d4 204068fa call uartd_send 
+40d5 20204286 branch at_nomal_rev_end 
+
+at_rev_inqr:
+40d6 79200025 set1 mark_ext_patch ,mark 
+40d7 44ca4032 bpatch patch32_4 ,mem_patch32 
+40d8 20403f3e call app_check_conn_device_nums_addr 
+40d9 6800c29a fetch 1 ,mem_device_nums 
+40da c080427f bne 0 ,at_error_rev_end 
+40db 204041f0 call do_at_inquiry 
+40dc 20204286 branch at_nomal_rev_end 
+
+at_rev_leinqr:
+40dd 79200025 set1 mark_ext_patch ,mark 
+40de 44cac032 bpatch patch32_5 ,mem_patch32 
+40df 204041f6 call do_at_leinquiry 
+40e0 20204286 branch at_nomal_rev_end 
+
+at_rev_role_inquiry:
+40e1 da204857 arg mem_prarm_role ,rega 
+40e2 df200004 arg 4 ,loopcnt 
+40e3 20404232 call at_group_inquiryhead_common 
+40e4 204032ee call context_check_idle 
+40e5 2422c24a nbranch at_rev_uart_write_n ,zero 
+40e6 6800c041 fetch 1 ,mem_context + coffset_mode 
+40e7 c280c0eb bbit1 mode_master ,at_rev_uart_write_m 
+40e8 204040ef call at_rev_uart_write_s 
+40e9 204068fa call uartd_send 
+40ea 20204286 branch at_nomal_rev_end 
+
+at_rev_uart_write_m:
+40eb 5800004d setarg 0x4d 
+40ec e1408000 istore 1 ,contwu 
+40ed 204068fa call uartd_send 
+40ee 20204286 branch at_nomal_rev_end 
+
+at_rev_uart_write_s:
+40ef 58000053 setarg 0x53 
+40f0 e1408000 istore 1 ,contwu 
+40f1 20600000 rtn 
+
+at_rev_cmode:
+40f2 e8608000 ifetch 1 ,contru 
+40f3 c01fc0f6 beq at_ques ,at_rev_cmode_inquiry 
+40f4 c01ec17e beq at_equ ,at_rev_cmode_set 
+40f5 2020427f branch at_error_rev_end 
+
+at_rev_cmode_inquiry:
+40f6 204041d8 call at_group_cmode_inquiry 
+40f7 20204286 branch at_nomal_rev_end 
+
+at_rev_mode:
+40f8 e8608000 ifetch 1 ,contru 
+40f9 c01ec151 beq at_equ ,at_rev_mode_set 
+40fa 2020427f branch at_error_rev_end 
+
+at_rev_dmstate:
+40fb e8608000 ifetch 1 ,contru 
+40fc c01fc0fe beq at_ques ,at_rev_dmstate_inquiry 
+40fd 2020427f branch at_error_rev_end 
+
+at_rev_dmstate_inquiry:
+40fe 204041de call at_group_dmstate_inquiry 
+40ff 20204286 branch at_nomal_rev_end 
+
+at_rev_reconn:
+4100 6800c29f fetch 1 ,mem_app_connection_options 
+4101 60008177 store 1 ,mem_connection_options 
+4102 2040691d call eeprom_load_reconn_info 
+4103 20403f3e call app_check_conn_device_nums_addr 
+4104 6800c29a fetch 1 ,mem_device_nums 
+4105 c080427f bne 0 ,at_error_rev_end 
+4106 6800c2a9 fetch 1 ,mem_xrecord_mode 
+4107 c019c10c beq rec_3_mode ,at_rev_unle_reconn 
+4108 c01a410a beq rec_4_mode ,at_rev_lereconn 
+4109 2020427f branch at_error_rev_end 
+
+at_rev_lereconn:
+410a 20403f82 call app_ble_start_direct_adv 
+410b 20204286 branch at_nomal_rev_end 
+
+at_rev_unle_reconn:
+410c 20403f6e call app_bt_start_reconnect 
+410d 20204286 branch at_nomal_rev_end 
+
+at_rev_dis:
+410e 20403f3e call app_check_conn_device_nums_addr 
+410f 6800c29a fetch 1 ,mem_device_nums 
+4110 c080c27f bne 1 ,at_error_rev_end 
+4111 6800c041 fetch 1 ,mem_context + coffset_mode 
+4112 c2804115 bbit1 mode_le ,at_rev_ledis 
+4113 20403f77 call app_bt_disconnect 
+4114 20204286 branch at_nomal_rev_end 
+
+at_rev_ledis:
+4115 20403f90 call app_ble_disconnect 
+4116 20204286 branch at_nomal_rev_end 
+
+at_rev_stsn:
+4117 e8608000 ifetch 1 ,contru 
+4118 c01ec11a beq at_equ ,at_rev_stsn_set 
+4119 2020427f branch at_error_rev_end 
+
+at_rev_stsn_set:
+411a e8608000 ifetch 1 ,contru 
+411b c018c122 beq 0x31 ,at_exit_sniff 
+411c c018411e beq 0x30 ,at_enter_sniff 
+411d 2020427f branch at_error_rev_end 
+
+at_enter_sniff:
+411e 20403f40 call app_check_sniff 
+411f 2020c286 branch at_nomal_rev_end ,true 
+4120 20403f9e call app_bt_enter_sniff 
+4121 20204286 branch at_nomal_rev_end 
+
+at_exit_sniff:
+4122 20403f40 call app_check_sniff 
+4123 2420c286 nbranch at_nomal_rev_end ,true 
+4124 204063ab call module_exit_sniff 
+4125 20406414 call at_set_cmd_task_flag 
+4126 20204286 branch at_nomal_rev_end 
+
+at_rev_clrflg:
+4127 20403f43 call app_clearflag_store 
+4128 20204286 branch at_nomal_rev_end 
+
+at_rev_ota:
+4129 e8608000 ifetch 1 ,contru 
+412a c01ec187 beq at_equ ,at_rev_ota_process 
+412b 2020427f branch at_error_rev_end 
+
+at_rev_discov:
+412c 20403f3e call app_check_conn_device_nums_addr 
+412d 6800c29a fetch 1 ,mem_device_nums 
+412e c080427f bne 0 ,at_error_rev_end 
+412f 2040638a call module_disconn_start 
+4130 20204286 branch at_nomal_rev_end 
+
+at_rev_name_set:
+4131 da204703 arg mem_local_name ,rega 
+4132 2040422b call at_set_common 
+4133 6008c702 storet 1 ,mem_local_name_length 
+4134 20403fd2 call at_store_bt_name 
+4135 20204286 branch at_nomal_rev_end 
+
+at_rev_le_name_set:
+4136 da20441a arg mem_le_name ,rega 
+4137 2040422b call at_set_common 
+4138 6008c419 storet 1 ,mem_le_name_len 
+4139 20403fd7 call at_store_le_name 
+413a 20405adb call le_modified_name 
+413b 20204286 branch at_nomal_rev_end 
+
+at_rev_adss_set:
+413c d8a04140 arg mem_lap ,contw 
+413d 20407ebf call adss_string2hex_from_uart 
+413e 20403fe0 call at_store_bt_adss 
+413f 20204286 branch at_nomal_rev_end 
+
+at_rev_leadss_set:
+4140 d8a044f9 arg mem_le_lap ,contw 
+4141 20407ebf call adss_string2hex_from_uart 
+4142 20403fdc call at_store_le_adss 
+4143 20204286 branch at_nomal_rev_end 
+
+at_rev_pswd_set:
+4144 da200550 arg mem_pin ,rega 
+4145 2040422b call at_set_common 
+4146 6008854f storet 1 ,mem_pin_length 
+4147 20403fe4 call at_store_bt_pincode 
+4148 20204286 branch at_nomal_rev_end 
+
+at_rev_uart_set:
+4149 20407eb0 call string2dec_from_uart 
+414a 5adc6c00 setarg uart_clk 
+414b 9846fc00 idiv temp 
+414c 20407efd call wait_div_end 
+414d 1807fe00 quotient pdata 
+414e 600102a8 store 2 ,mem_timeup 
+414f 20403feb call at_store_throughput_uart_baud 
+4150 20204286 branch at_nomal_rev_end 
+
+at_rev_mode_set:
+4151 e8608000 ifetch 1 ,contru 
+4152 1fe67c33 sub pdata ,0x33 ,null 
+4153 2421427f nbranch at_error_rev_end ,positive 
+4154 1fe17e03 and pdata ,0x3 ,pdata 
+4155 6000c812 store 1 ,mem_module_state 
+4156 20204286 branch at_nomal_rev_end 
+
+at_rev_class_set:
+4157 e8618000 ifetch 3 ,contru 
+4158 6001c14a store 3 ,mem_class 
+4159 20204286 branch at_nomal_rev_end 
+
+at_rev_role_set:
+415a 204032ee call context_check_idle 
+415b 2422c27f nbranch at_error_rev_end ,zero 
+415c e8608000 ifetch 1 ,contru 
+415d c029c160 beq 0x53 ,at_role_slave 
+415e c026c163 beq 0x4D ,at_role_master 
+415f 2020427f branch at_error_rev_end 
+
+at_role_slave:
+4160 6800c041 fetch 1 ,mem_context + coffset_mode 
+4161 c280c166 bbit1 mode_master ,at_switch_role 
+4162 2020427f branch at_error_rev_end 
+
+at_role_master:
+4163 6800c041 fetch 1 ,mem_context + coffset_mode 
+4164 c300c166 bbit0 mode_master ,at_switch_role 
+4165 2020427f branch at_error_rev_end 
+
+at_switch_role:
+4166 6800c813 fetch 1 ,mem_module_task 
+4167 79207e04 set1 at_task_switch ,pdata 
+4168 6000c813 store 1 ,mem_module_task 
+4169 70427218 jam hci_cmd_role_switch ,mem_hci_cmd 
+416a 2020428c branch at_rev_end 
+
+at_rev_sniff_set:
+416b d8a04280 arg mem_sniff_param_interval ,contw 
+416c 20407ebd call mem2_string2hex_from_uart 
+416d d8a04282 arg mem_sniff_param_attempt ,contw 
+416e 20407ebd call mem2_string2hex_from_uart 
+416f d8a04284 arg mem_sniff_param_timeout ,contw 
+4170 20407ebd call mem2_string2hex_from_uart 
+4171 20204286 branch at_nomal_rev_end 
+
+at_rev_list_set:
+4172 e8608000 ifetch 1 ,contru 
+4173 c018c176 beq 0x31 ,at_rev_list_set_1 
+4174 c019417c beq 0x32 ,at_rev_list_set_2 
+4175 2020427f branch at_error_rev_end 
+
+at_rev_list_set_1:
+4176 e8608000 ifetch 1 ,contru 
+4177 d8a001b4 arg mem_temp_lap ,contw 
+4178 20407ebf call adss_string2hex_from_uart 
+4179 20406931 call eeprom_clear_bd_reconn_info 
+417a 24740000 nrtn user 
+417b 20204286 branch at_nomal_rev_end 
+
+at_rev_list_set_2:
+417c 2040693d call eeprom_clear_all_reconn_info 
+417d 20204286 branch at_nomal_rev_end 
+
+at_rev_cmode_set:
+417e e8608000 ifetch 1 ,contru 
+417f 6808c812 fetcht 1 ,mem_module_state 
+4180 7d3a0402 nsetflag blank ,at_state_cmode ,temp 
+4181 6008c812 storet 1 ,mem_module_state 
+4182 203a4286 branch at_nomal_rev_end ,blank 
+4183 e8608000 ifetch 1 ,contru 
+4184 d8a04814 arg mem_cmode_addr ,contw 
+4185 20407ebf call adss_string2hex_from_uart 
+4186 20204286 branch at_nomal_rev_end 
+
+at_rev_ota_process:
+4187 79200025 set1 mark_ext_patch ,mark 
+4188 44cb4032 bpatch patch32_6 ,mem_patch32 
+4189 df200014 arg 20 ,loopcnt 
+418a d8a01000 arg mem_l2cap_rxbuff1 ,contw 
+418b 2040497c call uart_copy_rx_bytes 
+418c da201000 arg mem_l2cap_rxbuff1 ,rega 
+418d 68009000 fetch 1 ,mem_l2cap_rxbuff1 
+418e 2fe1fe12 compare ota_write_req ,pdata ,0xff 
+418f 2040eb19 call prcp_parse_ota_write_req ,true 
+4190 68009000 fetch 1 ,mem_l2cap_rxbuff1 
+4191 2fe1fe13 compare ota_end_cmd ,pdata ,0xff 
+4192 2040eb45 call prcp_parse_ota_end_cmd ,true 
+4193 20204286 branch at_nomal_rev_end 
+
+at_group_name_inquiry:
+4194 da204827 arg mem_prarm_name ,rega 
+4195 df200004 arg 4 ,loopcnt 
+4196 20404232 call at_group_inquiryhead_common 
+4197 6800c702 fetch 1 ,mem_local_name_length 
+4198 1fe27200 copy pdata ,loopcnt 
+4199 d8c04703 arg mem_local_name ,contr 
+419a 20207f74 branch send_mem_to_uart0 
+
+at_group_le_name_inquiry:
+419b da204824 arg mem_prarm_blename ,rega 
+419c 18007207 force 7 ,loopcnt 
+419d 20404232 call at_group_inquiryhead_common 
+419e 20405b08 call le_get_device_name 
+419f e8c08000 ifetch 1 ,contr 
+41a0 1fe27200 copy pdata ,loopcnt 
+41a1 20207f74 branch send_mem_to_uart0 
+
+at_group_adss_inquiry:
+41a2 da20482e arg mem_prarm_adss ,rega 
+41a3 df200004 arg 4 ,loopcnt 
+41a4 20404232 call at_group_inquiryhead_common 
+41a5 da204140 arg mem_lap ,rega 
+41a6 20407e9d call adss_hex2string_to_uart 
+41a7 202068fa branch uartd_send 
+
+at_group_leadss_inquiry:
+41a8 da20482b arg mem_prarm_bleadss ,rega 
+41a9 df200007 arg 7 ,loopcnt 
+41aa 20404232 call at_group_inquiryhead_common 
+41ab da2044f9 arg mem_le_lap ,rega 
+41ac 20407e9d call adss_hex2string_to_uart 
+41ad 202068fa branch uartd_send 
+
+at_group_version_inquiry:
+41ae da204832 arg mem_prarm_vers ,rega 
+41af df200004 arg 4 ,loopcnt 
+41b0 20404232 call at_group_inquiryhead_common 
+41b1 df200006 arg 6 ,loopcnt 
+41b2 d8c04804 arg mem_module_version ,contr 
+41b3 20207f74 branch send_mem_to_uart0 
+
+at_group_class_inquiry:
+41b4 da204836 arg mem_prarm_class ,rega 
+41b5 df200005 arg 5 ,loopcnt 
+41b6 20404232 call at_group_inquiryhead_common 
+41b7 df200003 arg 3 ,loopcnt 
+41b8 d8c0414a arg mem_class ,contr 
+41b9 20207f74 branch send_mem_to_uart0 
+
+at_group_list_inquiry:
+41ba da204853 arg mem_prarm_list ,rega 
+41bb df200004 arg 4 ,loopcnt 
+41bc 20404232 call at_group_inquiryhead_common 
+41bd 20406988 call eeprom_load_bdaddr_list 
+41be 20404253 call at_group_list_reply 
+41bf 202068fa branch uartd_send 
+
+at_group_ldev_inquiry:
+41c0 20406929 call eeprom_load_reconn_bdaddr 
+41c1 da204860 arg mem_prarm_ldev ,rega 
+41c2 df200004 arg 4 ,loopcnt 
+41c3 20404232 call at_group_inquiryhead_common 
+41c4 680081b3 fetch 1 ,mem_record_bt_mode 
+41c5 c019c1c8 beq rec_3_mode ,at_group_ldev_inquiry0 
+41c6 c01a41c8 beq rec_4_mode ,at_group_ldev_inquiry0 
+41c7 202068fa branch uartd_send 
+
+at_group_ldev_inquiry0:
+41c8 e1408000 istore 1 ,contwu 
+41c9 2040424e call at_rev_uart_write_44 
+41ca da2001b4 arg mem_temp_lap ,rega 
+41cb 20407e9d call adss_hex2string_to_uart 
+41cc 202068fa branch uartd_send 
+
+at_group_rssi_inquiry:
+41cd 79200025 set1 mark_ext_patch ,mark 
+41ce 44cbc032 bpatch patch32_7 ,mem_patch32 
+41cf da204864 arg mem_prarm_rssi ,rega 
+41d0 df200004 arg 4 ,loopcnt 
+41d1 20404232 call at_group_inquiryhead_common 
+41d2 204041d4 call at_rssi_result 
+41d3 202068fa branch uartd_send 
+
+at_rssi_result:
+41d4 da200018 arg mem_rssi ,rega 
+41d5 df200001 arg 1 ,loopcnt 
+41d6 20207e9e branch hex2string_to_uart0 
+
+at_group_cdev_inquiry:
+41d7 20600000 rtn 
+
+at_group_cmode_inquiry:
+41d8 da204873 arg mem_prarm_cmode ,rega 
+41d9 df200005 arg 5 ,loopcnt 
+41da 20404232 call at_group_inquiryhead_common 
+41db da204814 arg mem_cmode_addr ,rega 
+41dc 20407e9d call adss_hex2string_to_uart 
+41dd 202068fa branch uartd_send 
+
+at_group_dmstate_inquiry:
+41de da20487c arg mem_prarm_dmstate ,rega 
+41df df200007 arg 7 ,loopcnt 
+41e0 20404232 call at_group_inquiryhead_common 
+41e1 6800c812 fetch 1 ,mem_module_state 
+41e2 1fe22200 copy pdata ,rega 
+41e3 6800c040 fetch 1 ,mem_context 
+41e4 2feffe00 isolate1 state_inconn ,pdata 
+41e5 7920a203 setflag true ,at_state_isconn ,rega 
+41e6 2feffe01 isolate1 state_insniff ,pdata 
+41e7 7920a205 setflag true ,at_state_sniff ,rega 
+41e8 6800c041 fetch 1 ,mem_context + coffset_mode 
+41e9 2feffe01 isolate1 mode_master ,pdata 
+41ea 7920a204 setflag true ,at_state_role ,rega 
+41eb 2feffe00 isolate1 mode_le ,pdata 
+41ec 7920a206 setflag true ,at_state_le ,rega 
+41ed 1a227e00 copy rega ,pdata 
+41ee e1408000 istore 1 ,contwu 
+41ef 202068fa branch uartd_send 
+
+do_at_inquiry:
+41f0 589e8b33 setarg param_glap 
+41f1 6001c147 store 3 ,mem_glap 
+41f2 6800c2a4 fetch 1 ,mem_at_using_flag 
+41f3 79207e00 set1 at_flag_inq ,pdata 
+41f4 6000c2a4 store 1 ,mem_at_using_flag 
+41f5 20204636 branch do_at_inquiry0 
+
+do_at_leinquiry:
+41f6 20403f3e call app_check_conn_device_nums_addr 
+41f7 6800c29a fetch 1 ,mem_device_nums 
+41f8 c080427f bne 0 ,at_error_rev_end 
+41f9 20403f8a call app_ble_start_scan 
+41fa 6800c2a4 fetch 1 ,mem_at_using_flag 
+41fb 79207e01 set1 at_flag_leinq ,pdata 
+41fc 6000c2a4 store 1 ,mem_at_using_flag 
+41fd 58000200 setarg 0x200 
+41fe 6001481a store 2 ,mem_at_scan_time 
+41ff da20486c arg mem_prarm_bleinqr ,rega 
+4200 df200006 arg 6 ,loopcnt 
+4201 20404232 call at_group_inquiryhead_common 
+4202 20407f74 call send_mem_to_uart0 
+4203 2020428c branch at_rev_end 
+
+at_group_pswd_inquiry:
+4204 da20481c arg mem_prarm_pswd ,rega 
+4205 df200004 arg 4 ,loopcnt 
+4206 20404232 call at_group_inquiryhead_common 
+4207 6800854f fetch 1 ,mem_pin_length 
+4208 1fe27200 copy pdata ,loopcnt 
+4209 d8c00550 arg mem_pin ,contr 
+420a 20207f74 branch send_mem_to_uart0 
+
+at_group_sniff_inquiry:
+420b da20485b arg mem_prarm_sniff ,rega 
+420c df200005 arg 5 ,loopcnt 
+420d 20404232 call at_group_inquiryhead_common 
+420e 20404247 call at_rev_uart_write_62 
+420f 58000054 setarg 84 
+4210 e1408000 istore 1 ,contwu 
+4211 20404244 call at_rev_uart_write_colon 
+4212 da204280 arg mem_sniff_param_interval ,rega 
+4213 20407e9b call mem2_hex2string_to_uart 
+4214 20404247 call at_rev_uart_write_62 
+4215 58000041 setarg 65 
+4216 e1408000 istore 1 ,contwu 
+4217 20404244 call at_rev_uart_write_colon 
+4218 da204282 arg mem_sniff_param_attempt ,rega 
+4219 20407e9b call mem2_hex2string_to_uart 
+421a 20404247 call at_rev_uart_write_62 
+421b 5800004f setarg 79 
+421c e1408000 istore 1 ,contwu 
+421d 20404244 call at_rev_uart_write_colon 
+421e da204284 arg mem_sniff_param_timeout ,rega 
+421f 20407e9b call mem2_hex2string_to_uart 
+4220 20207f74 branch send_mem_to_uart0 
+
+at_inquiry_reply:
+4221 20407f6e call get_uart_twptr 
+4222 20404247 call at_rev_uart_write_62 
+4223 da200182 arg extm_lap ,rega 
+4224 20407e9d call adss_hex2string_to_uart 
+4225 2040424e call at_rev_uart_write_44 
+4226 da20017f arg extm_class ,rega 
+4227 20407e99 call mem3_hex2string_to_uart 
+4228 2040424e call at_rev_uart_write_44 
+4229 204041d4 call at_rssi_result 
+422a 202068fa branch uartd_send 
+
+at_set_common:
+422b 2040422d call at_set_setprarm 
+422c 2020497c branch uart_copy_rx_bytes 
+
+at_set_setprarm:
+422d 20404269 call uart_get_remain_length 
+422e 1fe20400 copy pdata ,temp 
+422f 1fe27200 copy pdata ,loopcnt 
+4230 1a220a00 copy rega ,contw 
+4231 20600000 rtn 
+
+at_group_inquiryhead_common:
+4232 20407f6e call get_uart_twptr 
+4233 20404241 call at_rev_uart_write_plus 
+
+at_group_inquiryhead_common0:
+4234 1a220c00 copy rega ,contr 
+4235 20404976 call uart_copy_tx_bytes 
+4236 20204244 branch at_rev_uart_write_colon 
+
+string_compare_uart_follow:
+4237 e8608000 ifetch 1 ,contru 
+4238 ea488000 ifetcht 1 ,regb 
+4239 98467c00 isub temp ,null 
+423a 7840fc00 disable true 
+423b 2422c240 nbranch string_compare_uart_follow_diff ,zero 
+423c 1a40a401 increase 1 ,regb 
+423d c2004237 loop string_compare_uart_follow 
+423e 7820fc00 enable true 
+423f 20600000 rtn 
+
+string_compare_uart_follow_diff:
+4240 20204251 branch restore_contru 
+
+at_rev_uart_write_plus:
+4241 5800002b setarg ui_plus 
+4242 e1408000 istore 1 ,contwu 
+4243 20600000 rtn 
+
+at_rev_uart_write_colon:
+4244 5800003a setarg ui_colon 
+4245 e1408000 istore 1 ,contwu 
+4246 20600000 rtn 
+
+at_rev_uart_write_62:
+4247 5800003e setarg 62 
+4248 e1408000 istore 1 ,contwu 
+4249 20600000 rtn 
+
+at_rev_uart_write_n:
+424a 5800004e setarg 78 
+424b e1408000 istore 1 ,contwu 
+424c 204068fa call uartd_send 
+424d 20204286 branch at_nomal_rev_end 
+
+at_rev_uart_write_44:
+424e 5800002c setarg at_comma 
+424f e1408000 istore 1 ,contwu 
+4250 20600000 rtn 
+
+restore_contru:
+4251 1a220600 copy rega ,contru 
+4252 20600000 rtn 
+
+at_group_list_reply:
+4253 da600195 arg mem_bdaddr_list_buff + 7 ,regc 
+4254 df200004 arg 4 ,loopcnt 
+
+at_group_list_reply_loop:
+4255 1f227e00 copy loopcnt ,pdata 
+4256 60008161 store 1 ,mem_pdatatemp 
+4257 ea608000 ifetch 1 ,regc 
+4258 c019c25b beq rec_3_mode ,at_group_list_isrecord 
+4259 c01a425b beq rec_4_mode ,at_group_list_isrecord 
+425a 20204267 branch at_group_list_notrecord 
+
+at_group_list_isrecord:
+425b 20404247 call at_rev_uart_write_62 
+425c ea608000 ifetch 1 ,regc 
+425d e1408000 istore 1 ,contwu 
+425e 1a60a601 increase 1 ,regc 
+425f 2040424e call at_rev_uart_write_44 
+4260 1a622200 copy regc ,rega 
+4261 20407e9d call adss_hex2string_to_uart 
+
+at_group_list_notrecord0:
+4262 1a60a606 increase 6 ,regc 
+4263 68008161 fetch 1 ,mem_pdatatemp 
+4264 1fe27200 copy pdata ,loopcnt 
+4265 c2004255 loop at_group_list_reply_loop 
+4266 20600000 rtn 
+
+at_group_list_notrecord:
+4267 1a60a601 increase 1 ,regc 
+4268 20204262 branch at_group_list_notrecord0 
+
+uart_get_remain_length:
+4269 79200025 set1 mark_ext_patch ,mark 
+426a 44cc4033 bpatch patch33_0 ,mem_patch33 
+426b 68110058 hfetch 2 ,core_uart_rrptr 
+426c 98667e00 isub contru ,pdata 
+426d 20628000 rtn zero 
+426e 20214273 branch uart_get_remain_length0 ,positive 
+
+uart_get_remain_length_common:
+426f 6809480e fetcht 2 ,mem_current_packet_length 
+4270 9840fe00 iadd temp ,pdata 
+4271 1fe0fffe increase -2 ,pdata 
+4272 20600000 rtn 
+
+uart_get_remain_length0:
+4273 20404278 call uart_get_rx_buff_length 
+4274 98608400 iadd contru ,temp 
+4275 68110058 hfetch 2 ,core_uart_rrptr 
+4276 98467e00 isub temp ,pdata 
+4277 2020426f branch uart_get_remain_length_common 
+
+uart_get_rx_buff_length:
+4278 dfe04fff arg mem_module_rx_buf_end ,pdata 
+4279 1fe0fe01 increase 1 ,pdata 
+427a d8404a00 arg mem_module_rx_buf ,temp 
+427b 98467e00 isub temp ,pdata 
+427c 20600000 rtn 
+
+release_packet:
+427d 6809480e fetcht 2 ,mem_current_packet_length 
+427e 20206903 branch uartd_rxdone_by_len 
+
+at_error_rev_end:
+427f 79200025 set1 mark_ext_patch ,mark 
+4280 44ccc033 bpatch patch33_1 ,mem_patch33 
+4281 20407f6e call get_uart_twptr 
+4282 58525245 setarg 0x525245 
+4283 e1418000 istore 3 ,contwu 
+4284 204068fa call uartd_send 
+4285 2020428c branch at_rev_end 
+
+at_nomal_rev_end:
+4286 79200025 set1 mark_ext_patch ,mark 
+4287 44cd4033 bpatch patch33_2 ,mem_patch33 
+4288 20407f6e call get_uart_twptr 
+4289 58004b4f setarg 0x4b4f 
+428a e1410000 istore 2 ,contwu 
+428b 204068fa call uartd_send 
+
+spp_send_end:
+
+at_rev_end:
+428c 79200025 set1 mark_ext_patch ,mark 
+428d 44cdc033 bpatch patch33_3 ,mem_patch33 
+428e 2040427d call release_packet 
+
+spp_ipc_end:
+428f 58000000 setarg 0 
+4290 6001480e store 2 ,mem_current_packet_length 
+4291 6002480a store 4 ,mem_last_uart_clock 
+4292 20600000 rtn 
+
+le_dongle_init:
+4293 20407db2 call usb_init 
+4294 20403f94 call app_led_start_blink 
+4295 5800429f setarg le_dongle 
+4296 6001428c store 2 ,mem_cb_le_process 
+4297 580042be setarg dongle_process_bb_event 
+4298 60014292 store 2 ,mem_cb_bb_event_process 
+4299 58007cdb setarg usb_isr 
+429a 60014290 store 2 ,mem_cb_idle_process 
+429b 70025a05 jam 5 ,mem_dongle_count 
+429c 70026e00 jam 0 ,mem_dongle_peers 
+429d 7042721b jam hci_cmd_le_create_conn ,mem_hci_cmd 
+429e 20600000 rtn 
+
+le_dongle:
+429f 7840fc00 disable true 
+42a0 20403f3e call app_check_conn_device_nums_addr 
+42a1 70041c1b jam 0x1b ,mem_cmd_le_create_conn 
+42a2 6800c29a fetch 1 ,mem_device_nums 
+42a3 2fe00602 compare 2 ,pdata ,0x3 
+42a4 24608000 nrtn true 
+42a5 7043d200 jam 0 ,mem_le_scan_enable 
+42a6 20600000 rtn 
+
+le_scan_dongle:
+42a7 68008340 fetch 1 ,mem_le_rxbuf 
+42a8 c30042b0 bbit0 0 ,dongle_add_peer 
+42a9 68030342 fetch 6 ,mem_le_rxbuf + 2 
+42aa 680b03d0 fetcht 6 ,mem_le_plap 
+42ab 98467c00 isub temp ,null 
+42ac 24628000 nrtn zero 
+
+dongle_peer_paired:
+42ad 680303d0 fetch 6 ,mem_le_plap 
+42ae 600344e7 store 6 ,mem_le_conn_peer_addr 
+42af 20600000 rtn 
+
+dongle_add_peer:
+42b0 da2000ff arg 0xff ,rega 
+42b1 20405b52 call le_search_adtype 
+42b2 24628000 nrtn zero 
+42b3 e8c10000 ifetch 2 ,contr 
+42b4 68090270 fetcht 2 ,mem_dongle_signature 
+42b5 98467c00 isub temp ,null 
+42b6 24628000 nrtn zero 
+42b7 6800826e fetch 1 ,mem_dongle_peers 
+42b8 1fe0fe01 increase 1 ,pdata 
+42b9 6000826e store 1 ,mem_dongle_peers 
+42ba 6808826f fetcht 1 ,mem_dongle_pairing_cnt 
+42bb 98467c00 isub temp ,null 
+42bc 202142ad branch dongle_peer_paired ,positive 
+42bd 20600000 rtn 
+
+dongle_process_bb_event:
+42be 1a627e00 copy regc ,pdata 
+42bf c00ac2c5 beq bt_evt_le_disconnected ,dongle_le_event_bb_disconnected 
+42c0 c00a42d7 beq bt_evt_le_connected ,dongle_bb_event_connected 
+42c1 1fe1040f and pdata ,0x0f ,temp 
+42c2 1fe17ef0 and_into bt_evt_timer_mask ,pdata 
+42c3 c02842cd beq bt_evt_timer_init ,dongle_bb_event_100ms 
+42c4 20600000 rtn 
+
+dongle_le_event_bb_disconnected:
+42c5 58000000 setarg 0 
+42c6 600344e7 store 6 ,mem_le_conn_peer_addr 
+42c7 70026e00 jam 0 ,mem_dongle_peers 
+42c8 58000000 setarg 0 
+42c9 60028ff1 store 5 ,mem_mouse_data 
+42ca 700ff001 jam send_mouse_data_cmd ,mem_mcmd 
+42cb 20407cdb call usb_isr 
+42cc 20203f8a branch app_ble_start_scan 
+
+dongle_bb_event_100ms:
+42cd 20600000 rtn 
+42ce 6800c3d2 fetch 1 ,mem_le_scan_enable 
+42cf 207a0000 rtn blank 
+42d0 6800825a fetch 1 ,mem_dongle_count 
+42d1 207a0000 rtn blank 
+42d2 1fe0ffff increase -1 ,pdata 
+42d3 6000825a store 1 ,mem_dongle_count 
+42d4 247a0000 nrtn blank 
+42d5 204042d8 call le_change_peer_addr 
+42d6 20203f8e branch app_ble_start_conn 
+
+dongle_bb_event_connected:
+42d7 20203f8c branch app_ble_stop_scan 
+
+le_change_peer_addr:
+42d8 70025a05 jam 5 ,mem_dongle_count 
+42d9 68008267 fetch 1 ,mem_le_peer_state 
+42da c000c2e1 beq le_context_state_kb ,addr_slave2 
+42db c00142dd beq le_context_state_mouse ,addr_slave1 
+42dc 20600000 rtn 
+
+addr_slave1:
+42dd 6803025b fetch 6 ,mem_le_addr_slave1 
+42de 60030268 store 6 ,mem_app_peer_addr 
+42df 70026701 jam le_context_state_kb ,mem_le_peer_state 
+42e0 20600000 rtn 
+
+addr_slave2:
+42e1 68030261 fetch 6 ,mem_le_addr_slave2 
+42e2 60030268 store 6 ,mem_app_peer_addr 
+42e3 70026702 jam le_context_state_mouse ,mem_le_peer_state 
+42e4 20600000 rtn 
+
+hci_rx_bcsp:
+42e5 e8610000 ifetch 2 ,contru 
+42e6 203a4490 branch hci_reset_uart ,blank 
+42e7 98002600 iforce regc 
+42e8 e8608000 ifetch 1 ,contru 
+42e9 60008293 store 1 ,mem_h5rx_tmp 
+42ea 98002200 iforce rega 
+42eb c30342ed bbit0 6 ,hci_rx_bcsp_nocrc 
+42ec 1a60a7fe increase -2 ,regc 
+
+hci_rx_bcsp_nocrc:
+42ed e8610000 ifetch 2 ,contru 
+42ee 1ff1f200 rshift4 pdata ,loopcnt 
+42ef 1fe1100f and pdata ,0xf ,debug 
+42f0 9a20a200 iadd rega ,rega 
+42f1 1fecfe00 rshift8 pdata ,pdata 
+42f2 9a20a200 iadd rega ,rega 
+42f3 e8608000 ifetch 1 ,contru 
+42f4 9a20fe00 iadd rega ,pdata 
+42f5 c0ffc319 bne 0xff ,hci_rx_bcsp_discard_packet 
+42f6 1a60fffc add regc ,-4 ,pdata 
+42f7 9f267c00 isub loopcnt ,null 
+42f8 2422c316 nbranch hci_rx_bcsp_discard_packet_err ,zero 
+42f9 68008293 fetch 1 ,mem_h5rx_tmp 
+42fa 2fec0007 isolate0 7 ,pdata 
+42fb 2020c302 branch hci_rx_bcsp_check_ack_skip ,true 
+42fc 793f801b set0 mark_h5_reset ,mark 
+42fd c50dc302 bmark1 mark_h5_reset ,hci_rx_bcsp_check_ack_skip 
+42fe 1fe17e07 and_into 7 ,pdata 
+42ff 6808828c fetcht 1 ,mem_h5tx_ack 
+4300 98467c00 isub temp ,null 
+4301 2422c316 nbranch hci_rx_bcsp_discard_packet_err ,zero 
+
+hci_rx_bcsp_check_ack_skip:
+4302 58000640 setarg 1600 
+4303 18000e07 force lpo_delay_timer ,queue 
+4304 20407e4c call timer_init 
+4305 19027e00 deposit debug 
+4306 20404320 call hci_bcsp_parse_packet 
+4307 20740000 rtn user 
+4308 68008293 fetch 1 ,mem_h5rx_tmp 
+4309 98002200 iforce rega 
+430a 1fe90400 rshift3 pdata ,temp 
+430b 18410407 and_into 7 ,temp 
+430c 6800828b fetch 1 ,mem_h5rx_ack 
+430d 98467e00 isub temp ,pdata 
+430e 1fe67e00 sub pdata ,0 ,pdata 
+430f 1fe17e07 and_into 7 ,pdata 
+4310 c080c316 bne 1 ,hci_rx_bcsp_discard_packet_err 
+4311 6008828b storet 1 ,mem_h5rx_ack 
+4312 68008272 fetch 1 ,mem_h5rx_ackcnt 
+4313 1fe0fe01 increase 1 ,pdata 
+4314 60008272 store 1 ,mem_h5rx_ackcnt 
+4315 20204319 branch hci_rx_bcsp_discard_packet 
+
+hci_rx_bcsp_discard_packet_err:
+4316 68008273 fetch 1 ,mem_check_err_acl_cont 
+4317 1fe0fe01 increase 1 ,pdata 
+4318 60008273 store 1 ,mem_check_err_acl_cont 
+
+hci_rx_bcsp_discard_packet:
+4319 68110058 hfetch 2 ,core_uart_rrptr 
+431a 98000600 iforce contru 
+431b e8610000 ifetch 2 ,contru 
+431c 98608600 iadd contru ,contru 
+431d 18627e00 deposit contru 
+431e 60110058 hstore 2 ,core_uart_rrptr 
+431f 20600000 rtn 
+
+hci_bcsp_parse_packet:
+4320 78547c00 disable user 
+4321 207a0000 rtn blank 
+4322 c000c328 beq 1 ,parse_bcsp_link_establish 
+4323 c0014346 beq 2 ,parse_bcsp_bccmd 
+4324 c002c507 beq 5 ,process_hci_cmd 
+4325 c00344dd beq 6 ,process_acl 
+4326 c0044a56 beq 8 ,process_hci_patch 
+4327 20600000 rtn 
+
+parse_bcsp_link_establish:
+4328 793f8018 set0 mark_h5_reinit ,mark 
+4329 e8608000 ifetch 1 ,contru 
+432a c06d432f beq 0xda ,parse_bcsp_link_establish_sync 
+432b c0564336 beq 0xac ,parse_bcsp_link_establish_syncrsp 
+432c c056c33a beq 0xad ,parse_bcsp_link_establish_conf 
+432d c06f4344 beq 0xde ,parse_bcsp_link_establish_confrsp 
+432e 20600000 rtn 
+
+parse_bcsp_link_establish_sync:
+432f c50bc333 bmark1 mark_h5_sync ,parse_bcsp_link_establish_send_syncrsp 
+4330 180004da force 0xda ,temp 
+4331 58ededdc setarg 0xededdc 
+4332 2040433c call parse_bcsp_link_establish_send 
+
+parse_bcsp_link_establish_send_syncrsp:
+4333 180004ac force 0xac ,temp 
+4334 58eeefaf setarg 0xeeefaf 
+4335 2020433c branch parse_bcsp_link_establish_send 
+
+parse_bcsp_link_establish_syncrsp:
+4336 79200017 set1 mark_h5_sync ,mark 
+4337 180004ad force 0xad ,temp 
+4338 58edacef setarg 0xedacef 
+4339 2020433c branch parse_bcsp_link_establish_send 
+
+parse_bcsp_link_establish_conf:
+433a 180004de force 0xde ,temp 
+433b 58d0d0ad setarg 0xd0d0ad 
+
+parse_bcsp_link_establish_send:
+433c 1fed7e00 lshift8 pdata ,pdata 
+433d 98418400 ior temp ,temp 
+433e 20404972 call hci_get_packet_ptr 
+433f e14a0000 istoret 4 ,contwu 
+4340 18000e01 force 1 ,queue 
+4341 18007204 force 4 ,loopcnt 
+4342 793f8013 set0 mark_h5tx_rp ,mark 
+4343 20204378 branch bcsp_send_packet 
+
+parse_bcsp_link_establish_confrsp:
+4344 18006000 force 0 ,alarm 
+4345 20204933 branch hci_command_status 
+
+parse_bcsp_bccmd:
+4346 1f226000 copy loopcnt ,alarm 
+4347 20404371 call bcsp_send_ack 
+4348 18002400 force 0 ,regb 
+4349 20404972 call hci_get_packet_ptr 
+434a 1e027200 copy alarm ,loopcnt 
+434b e8608000 ifetch 1 ,contru 
+434c 58000001 setarg 1 
+434d e1408000 istore 1 ,contwu 
+434e 793f801a set0 mark_temp ,mark 
+
+parse_bcsp_bccmd_loop:
+434f e8608000 ifetch 1 ,contru 
+4350 1a40a401 increase 1 ,regb 
+4351 c00e435b beq 0x1c ,parse_bcsp_bccmd_sco_link 
+4352 2a41fe04 compare 4 ,regb ,0xff 
+4353 2420c35d nbranch parse_bcsp_bccmd_next ,true 
+4354 793a001a setflag blank ,mark_temp ,mark 
+4355 c09d435d bne 0x3a ,parse_bcsp_bccmd_next 
+4356 580007d0 setarg 2000 
+4357 18000e00 force h5_reinit_timer ,queue 
+4358 20407e4c call timer_init 
+4359 79200018 set1 mark_h5_reinit ,mark 
+435a 20600000 rtn 
+
+parse_bcsp_bccmd_sco_link:
+435b 2a41fe06 compare 6 ,regb ,0xff 
+435c 2020c366 branch parse_bcsp_bccmd_next_ok ,true 
+
+parse_bcsp_bccmd_next:
+435d 280ffe1a isolate1 mark_temp ,mark 
+435e 2040c368 call parse_bcsp_bccmd_replace ,true 
+435f e1408000 istore 1 ,contwu 
+4360 c200434f loop parse_bcsp_bccmd_loop 
+4361 793f8019 set0 mark_bccmd_patch ,mark 
+4362 1e027200 copy alarm ,loopcnt 
+4363 79200013 set1 mark_h5tx_rp ,mark 
+4364 18000e02 force 2 ,queue 
+4365 20204378 branch bcsp_send_packet 
+
+parse_bcsp_bccmd_next_ok:
+4366 79200019 set1 mark_bccmd_patch ,mark 
+4367 2020435d branch parse_bcsp_bccmd_next 
+
+parse_bcsp_bccmd_replace:
+4368 c60c8000 rtnmark1 mark_bccmd_patch 
+4369 2a41fe0a compare 10 ,regb ,0xff 
+436a 2020c36f branch parse_bcsp_bccmd_replace1 ,true 
+436b 2a41fe0b compare 11 ,regb ,0xff 
+436c 24608000 nrtn true 
+436d 58000012 setarg 0x12 
+436e 20600000 rtn 
+
+parse_bcsp_bccmd_replace1:
+436f 580000e9 setarg 0xe9 
+4370 20600000 rtn 
+
+bcsp_send_ack:
+4371 68008293 fetch 1 ,mem_h5rx_tmp 
+4372 1fe0fe01 increase 1 ,pdata 
+4373 1fe17e07 and_into 7 ,pdata 
+4374 6000828c store 1 ,mem_h5tx_ack 
+4375 18007200 force 0 ,loopcnt 
+4376 18000e00 force 0 ,queue 
+4377 793f8013 set0 mark_h5tx_rp ,mark 
+
+bcsp_send_packet:
+4378 1f20a404 add loopcnt ,4 ,regb 
+4379 6800828c fetch 1 ,mem_h5tx_ack 
+437a 1fe9a600 lshift3 pdata ,regc 
+437b 280c0014 isolate0 mark_h5tx_crc ,mark 
+437c 7d20a606 nsetflag true ,6 ,regc 
+437d 2020c37f branch bcsp_send_packet_nocrc ,true 
+437e 1a40a402 increase 2 ,regb 
+
+bcsp_send_packet_nocrc:
+437f c589c389 bmark0 mark_h5tx_rp ,bcsp_send_packet_form_nonrp 
+4380 79202607 set1 7 ,regc 
+4381 68008294 fetch 1 ,mem_h5tx_seq 
+4382 9a61a600 ior regc ,regc 
+4383 1fe0fe01 increase 1 ,pdata 
+4384 1fe17e07 and_into 7 ,pdata 
+4385 60008294 store 1 ,mem_h5tx_seq 
+4386 68008274 fetch 1 ,mem_rp_packets 
+4387 1fe0fe01 increase 1 ,pdata 
+4388 60008274 store 1 ,mem_rp_packets 
+
+bcsp_send_packet_form_nonrp:
+4389 6801028f fetch 2 ,mem_h5tx_wptr 
+438a 98001400 iforce contwu 
+438b 1a427e00 deposit regb 
+438c 280ffe13 isolate1 mark_h5tx_rp ,mark 
+438d 7920fe0f setflag true ,hci_flag_rp ,pdata 
+438e e1410000 istore 2 ,contwu 
+438f 19422200 copy contwu ,rega 
+4390 1a627e00 deposit regc 
+4391 e1408000 istore 1 ,contwu 
+4392 1f327e00 lshift4 loopcnt ,pdata 
+4393 98e1fe00 ior queue ,pdata 
+4394 9a60a600 iadd regc ,regc 
+4395 e1410000 istore 2 ,contwu 
+4396 1fecfe00 rshift8 pdata ,pdata 
+4397 9a60fe00 iadd regc ,pdata 
+4398 1fe67eff sub pdata ,0xff ,pdata 
+4399 e1408000 istore 1 ,contwu 
+439a c58a439f bmark0 mark_h5tx_crc ,bcsp_send_packet_form_nocrc 
+439b 1f20f204 increase 4 ,loopcnt 
+439c 1a221400 copy rega ,contwu 
+439d 20404986 call calc_tx_crc16 
+439e e1410000 istore 2 ,contwu 
+
+bcsp_send_packet_form_nocrc:
+439f 6801028f fetch 2 ,mem_h5tx_wptr 
+43a0 9a409400 iadd regb ,contwu 
+43a1 19409402 increase 2 ,contwu 
+43a2 19427e00 deposit contwu 
+43a3 6001028f store 2 ,mem_h5tx_wptr 
+43a4 6011005e hstore 2 ,core_uart_twptr 
+43a5 6809028d fetcht 2 ,mem_h5tx_rptr 
+43a6 204043d8 call bcsp_update_free 
+43a7 204043ab call bcsp_init_retransmit 
+43a8 58000640 setarg 1600 
+43a9 18000e07 force lpo_delay_timer ,queue 
+43aa 20207e4c branch timer_init 
+
+bcsp_init_retransmit:
+43ab 58000190 setarg 400 
+43ac 18000e01 force hci_retransmit_timer ,queue 
+43ad 20407e4c call timer_init 
+43ae 79200015 set1 mark_h5tx_retransmit ,mark 
+43af 20600000 rtn 
+
+bcsp_retransmit:
+43b0 c68a8000 rtnmark0 mark_h5tx_retransmit 
+43b1 18000e01 force hci_retransmit_timer ,queue 
+43b2 20407e53 call timer_check 
+43b3 247a0000 nrtn blank 
+43b4 6801028d fetch 2 ,mem_h5tx_rptr 
+43b5 60110060 hstore 2 ,core_uart_trptrp 
+43b6 202043ab branch bcsp_init_retransmit 
+
+bcsp_freepacket:
+43b7 6801028f fetch 2 ,mem_h5tx_wptr 
+43b8 6809028d fetcht 2 ,mem_h5tx_rptr 
+43b9 98467c00 isub temp ,null 
+43ba 2022c3d6 branch bcsp_noretransmit ,zero 
+43bb 18421400 copy temp ,contwu 
+43bc e9410000 ifetch 2 ,contwu 
+43bd 98002200 iforce rega 
+43be 9ea17e00 iand mask3ff ,pdata 
+43bf 99409400 iadd contwu ,contwu 
+43c0 68110110 hfetch 2 ,core_uart_trptr 
+43c1 99467e00 isub contwu ,pdata 
+43c2 9ea12400 iand mask3ff ,regb 
+43c3 6801028f fetch 2 ,mem_h5tx_wptr 
+43c4 99467e00 isub contwu ,pdata 
+43c5 9ea17e00 iand mask3ff ,pdata 
+43c6 9a467e00 isub regb ,pdata 
+43c7 24610000 nrtn positive 
+43c8 2a2c000f isolate0 hci_flag_rp ,rega 
+43c9 2020c3d1 branch bcsp_discardnrp ,true 
+43ca 68008272 fetch 1 ,mem_h5rx_ackcnt 
+43cb 207a0000 rtn blank 
+43cc 1fe0ffff increase -1 ,pdata 
+43cd 60008272 store 1 ,mem_h5rx_ackcnt 
+43ce 68008274 fetch 1 ,mem_rp_packets 
+43cf 1fe0ffff increase -1 ,pdata 
+43d0 60008274 store 1 ,mem_rp_packets 
+
+bcsp_discardnrp:
+43d1 19420400 copy contwu ,temp 
+43d2 6009028d storet 2 ,mem_h5tx_rptr 
+43d3 6801028f fetch 2 ,mem_h5tx_wptr 
+43d4 204043d8 call bcsp_update_free 
+43d5 202043b7 branch bcsp_freepacket 
+
+bcsp_noretransmit:
+43d6 793f8015 set0 mark_h5tx_retransmit ,mark 
+43d7 20600000 rtn 
+
+bcsp_update_free:
+43d8 98467e00 isub temp ,pdata 
+43d9 9ea17e00 iand mask3ff ,pdata 
+43da 9ea67e00 isub mask3ff ,pdata 
+43db 1fe67e00 sub pdata ,0 ,pdata 
+43dc 60010291 store 2 ,mem_h5tx_free 
+43dd 20600000 rtn 
+
+bcsp_get_tx_ptr:
+43de 6801028f fetch 2 ,mem_h5tx_wptr 
+43df 99409400 iadd contwu ,contwu 
+43e0 20600000 rtn 
+
+hci_log:
+43e1 20600000 rtn 
+
+hci_rx_h4:
+43e2 79200025 set1 mark_ext_patch ,mark 
+43e3 44f6403d bpatch patch3d_4 ,mem_patch3d 
+43e4 6800c272 fetch 1 ,mem_hci_cmd 
+43e5 247a0000 nrtn blank 
+
+hci_rx_h4_1:
+43e6 204043e9 call hci_h4_parse_packet 
+43e7 2454440e ncall h4_rx_discard_packet ,user 
+43e8 20600000 rtn 
+
+hci_h4_parse_packet:
+43e9 79200025 set1 mark_ext_patch ,mark 
+43ea 44f6c03d bpatch patch3d_5 ,mem_patch3d 
+43eb 18622200 copy contru ,rega 
+43ec d8400004 arg 4 ,temp 
+43ed e8608000 ifetch 1 ,contru 
+43ee c000c3f4 beq hci_h4_type_cmd ,hci_h4_parse_packet_wait_len 
+43ef 18408401 increase 1 ,temp 
+43f0 c00143f4 beq hci_h4_type_acl ,hci_h4_parse_packet_wait_len 
+43f1 18627e00 copy contru ,pdata 
+43f2 60110058 hstore 2 ,core_uart_rrptr 
+43f3 20600000 rtn 
+
+hci_h4_parse_packet_wait_len:
+43f4 68110112 hfetch 2 ,core_uart_rxitems 
+43f5 98467c00 isub temp ,null 
+43f6 242143f4 nbranch hci_h4_parse_packet_wait_len ,positive 
+43f7 78547c00 disable user 
+43f8 1a220600 copy rega ,contru 
+43f9 20404417 call h4_get_rx_payload_len 
+43fa 98408400 iadd temp ,temp 
+
+hci_h4_parse_packet_wait:
+43fb 68110112 hfetch 2 ,core_uart_rxitems 
+43fc 98467c00 isub temp ,null 
+43fd 242143fb nbranch hci_h4_parse_packet_wait ,positive 
+43fe 1a220600 copy rega ,contru 
+43ff e8608000 ifetch 1 ,contru 
+4400 c000c507 beq hci_h4_type_cmd ,process_hci_cmd 
+4401 c0014403 beq hci_h4_type_acl ,hci_h4_parse_packet_acl 
+4402 20203bf1 branch assert 
+
+hci_h4_parse_packet_acl:
+4403 79200025 set1 mark_ext_patch ,mark 
+4404 44f7403d bpatch patch3d_6 ,mem_patch3d 
+4405 18622200 copy contru ,rega 
+4406 e8610000 ifetch 2 ,contru 
+4407 1a220600 copy rega ,contru 
+4408 68088046 fetcht 1 ,mem_conn_handle 
+4409 a841fe00 icompare 0xff ,temp 
+440a 2020c4dd branch process_acl ,true 
+440b 203b58ea branch le_acl_downgoing ,le 
+440c 78347c00 enable user 
+440d 20600000 rtn 
+
+h4_rx_discard_packet:
+440e 79200025 set1 mark_ext_patch ,mark 
+440f 44f7c03d bpatch patch3d_7 ,mem_patch3d 
+4410 68110058 hfetch 2 ,core_uart_rrptr 
+4411 98000600 iforce contru 
+4412 20404417 call h4_get_rx_payload_len 
+4413 98608600 iadd contru ,contru 
+4414 18627e00 deposit contru 
+4415 60110058 hstore 2 ,core_uart_rrptr 
+4416 20600000 rtn 
+
+h4_get_rx_payload_len:
+4417 e8608000 ifetch 1 ,contru 
+4418 18608602 increase 2 ,contru 
+4419 c001441c beq hci_h4_type_acl ,h4_get_rx_payload_len_acl 
+441a e8608000 ifetch 1 ,contru 
+441b 20600000 rtn 
+
+h4_get_rx_payload_len_acl:
+441c e8610000 ifetch 2 ,contru 
+441d 20600000 rtn 
+
+h4_get_tx_ptr:
+441e 6811005e hfetch 2 ,core_uart_twptr 
+441f 194095fb increase -5 ,contwu 
+4420 99409400 iadd contwu ,contwu 
+4421 20600000 rtn 
+
+h4_send_packet_event:
+4422 d8400004 arg hci_h4_type_event ,temp 
+4423 20204425 branch h4_send_packet 
+
+h4_send_packet_acl:
+4424 d8400002 arg hci_h4_type_acl ,temp 
+
+h4_send_packet:
+4425 79200025 set1 mark_ext_patch ,mark 
+4426 44f8403e bpatch patch3e_0 ,mem_patch3e 
+4427 1f20f201 increase 1 ,loopcnt 
+4428 6811005e hfetch 2 ,core_uart_twptr 
+4429 1fe21400 copy pdata ,contwu 
+442a 1f227e00 copy loopcnt ,pdata 
+442b e1488000 istoret 1 ,contwu 
+442c 1fe0ffff increase -1 ,pdata 
+442d 99409400 iadd contwu ,contwu 
+442e 19427e00 copy contwu ,pdata 
+442f 6001029d store 2 ,mem_hci_acl_tx_trigger_wptr 
+4430 18427e00 copy temp ,pdata 
+4431 c1010000 rtneq hci_h4_type_acl 
+4432 6801029d fetch 2 ,mem_hci_acl_tx_trigger_wptr 
+4433 6011005e hstore 2 ,core_uart_twptr 
+4434 2020443b branch h4_send_acl_trigger_clear 
+
+h4_send_acl_trigger:
+4435 79200025 set1 mark_ext_patch ,mark 
+4436 44f8c03e bpatch patch3e_1 ,mem_patch3e 
+4437 6801029d fetch 2 ,mem_hci_acl_tx_trigger_wptr 
+4438 203a3bf1 branch assert ,blank 
+4439 6011005e hstore 2 ,core_uart_twptr 
+443a 2020443b branch h4_send_acl_trigger_clear 
+
+h4_send_acl_trigger_clear:
+443b 58000000 setarg 0 
+443c 6001029d store 2 ,mem_hci_acl_tx_trigger_wptr 
+443d 20600000 rtn 
+
+h4_tx_buffer_remain:
+443e 68190110 hfetcht 2 ,core_uart_trptr 
+443f 6811005e hfetch 2 ,core_uart_twptr 
+4440 98462200 isub temp ,rega 
+4441 24214447 nbranch h4_tx_buffer_remain_negative ,positive 
+4442 6819005a hfetcht 2 ,core_uart_tsaddr 
+4443 6811005c hfetch 2 ,core_uart_teaddr 
+4444 98467e00 isub temp ,pdata 
+4445 9a260400 isub rega ,temp 
+4446 20600000 rtn 
+
+h4_tx_buffer_remain_negative:
+4447 1a2605ff sub rega ,-1 ,temp 
+4448 20600000 rtn 
+
+hci_dispatch:
+4449 793f8025 set0 mark_ext_patch ,mark 
+444a 44e6c019 bpatch patch19_5 ,mem_patch19 
+444b 6800c132 fetch 1 ,mem_device_option 
+444c c1808000 rtnne dvc_op_hci 
+444d 204044a3 call hci_rx_packet 
+444e 20404494 call hci_check_bcsp_protocol 
+444f 2040c3b0 call bcsp_retransmit ,true 
+4450 20404494 call hci_check_bcsp_protocol 
+4451 2040c3b7 call bcsp_freepacket ,true 
+4452 202044e6 branch process_send_acl 
+4453 c68c0000 rtnmark0 mark_h5_reinit 
+4454 18000e00 force h5_reinit_timer ,queue 
+4455 20407e53 call timer_check 
+4456 247a0000 nrtn blank 
+4457 20404472 call hci_reinit 
+4458 20404494 call hci_check_bcsp_protocol 
+4459 24608000 nrtn true 
+445a 793f8017 set0 mark_h5_sync ,mark 
+445b 180004da force 0xda ,temp 
+445c 58ededdc setarg 0xededdc 
+445d 2040433c call parse_bcsp_link_establish_send 
+445e 580007d0 setarg 2000 
+445f 18000e00 force h5_reinit_timer ,queue 
+4460 20207e4c branch timer_init 
+
+hci_init:
+4461 793f8025 set0 mark_ext_patch ,mark 
+4462 44e74019 bpatch patch19_6 ,mem_patch19 
+4463 20758000 rtn wake 
+4464 58004aed setarg hci_idle_dispatch 
+4465 60014290 store 2 ,mem_cb_idle_process 
+4466 580001a0 setarg uart_baud_115200 
+4467 600142ac store uart_baud_len ,mem_baud 
+
+hci_lpm_init:
+4468 793f8025 set0 mark_ext_patch ,mark 
+4469 44e7c019 bpatch patch19_7 ,mem_patch19 
+446a 20406a0d call init_filter_ram 
+446b 58001800 setarg mem_h5rx_buf 
+446c 60110054 hstore 2 ,core_uart_rsaddr 
+446d 58001bff setarg mem_h5rx_buf_end 
+446e 60110056 hstore 2 ,core_uart_readdr 
+446f 58001c00 setarg mem_h5tx_buf 
+4470 6011005a hstore 2 ,core_uart_tsaddr 
+4471 20404489 call hci_sel_init 
+
+hci_reinit:
+4472 793f8025 set0 mark_ext_patch ,mark 
+4473 44e8401a bpatch patch1a_0 ,mem_patch1a 
+4474 70806200 hjam 0x0 ,core_uart_ctrl 
+4475 70028b00 jam 0 ,mem_h5rx_ack 
+4476 70028c00 jam 0 ,mem_h5tx_ack 
+4477 70029400 jam 0 ,mem_h5tx_seq 
+4478 58001c00 setarg mem_h5tx_buf 
+4479 6001028f store 2 ,mem_h5tx_wptr 
+447a 6001028d store 2 ,mem_h5tx_rptr 
+447b 6011005e hstore 2 ,core_uart_twptr 
+447c 60110060 hstore 2 ,core_uart_trptrp 
+447d 58001800 setarg mem_h5rx_buf 
+447e 60110058 hstore 2 ,core_uart_rrptr 
+447f 60010289 store 2 ,mem_h5rx_rptr 
+
+hci_init_common:
+4480 793f8025 set0 mark_ext_patch ,mark 
+4481 44e8c01a bpatch patch1a_1 ,mem_patch1a 
+4482 68110050 hfetch 2 ,core_clkoff 
+4483 793ffe0f set0 clock_off_uart ,pdata 
+4484 60110050 hstore 2 ,core_clkoff 
+4485 20406909 call uart_set_baud_by_mem 
+4486 70804301 hjam uartclk_dpll ,core_uart_clksel 
+4487 70806281 hjam uart_ctrl_h4 ,core_uart_ctrl 
+4488 20204497 branch hci_init_queue_ack 
+
+hci_sel_init:
+4489 58001fff setarg mem_h5tx_buf_end 
+448a 6011005c hstore 2 ,core_uart_teaddr 
+448b 68108081 hfetch 1 ,core_gpio_sel1 
+448c 1fe1fe07 or_into 0x07 ,pdata 
+448d 60108081 hstore 1 ,core_gpio_sel1 
+448e 70029fff jam 0xff ,mem_ucode_id_local 
+448f 20600000 rtn 
+
+hci_reset_uart:
+4490 68110116 hfetch 2 ,core_uart_rwptr 
+4491 60110058 hstore 2 ,core_uart_rrptr 
+4492 7920001b set1 mark_h5_reset ,mark 
+4493 20600000 rtn 
+
+hci_check_bcsp_protocol:
+4494 68108062 hfetch 1 ,core_uart_ctrl 
+4495 2feffe03 isolate1 uart_ctrl_bit_slip_protocol ,pdata 
+4496 20600000 rtn 
+
+hci_init_queue_ack:
+4497 58004803 setarg mem_hci_acl_queue_start 
+4498 60010295 store 2 ,mem_hci_acl_queue_wptr 
+4499 60010297 store 2 ,mem_hci_acl_queue_rptr 
+449a 18000401 force param_acl_pktcnt ,temp 
+449b 9840fe00 iadd temp ,pdata 
+449c 9840fe00 iadd temp ,pdata 
+449d 1fe0fe02 increase 2 ,pdata 
+449e 60010299 store 2 ,mem_hci_acl_queue_end 
+449f 58000000 setarg 0x00 
+44a0 6000829c store 1 ,mem_hci_acl_cnt 
+44a1 6000829b store 1 ,mem_hci_acl_queue_wcnt 
+44a2 20600000 rtn 
+
+hci_rx_packet:
+44a3 793f8025 set0 mark_ext_patch ,mark 
+44a4 44e9401a bpatch patch1a_2 ,mem_patch1a 
+44a5 6810810c hfetch 1 ,core_uart_status 
+44a6 98002400 iforce regb 
+44a7 c301c4ad bbit0 uart_status_rx_fifo_empty ,hci_rx_packet_cont 
+44a8 68110112 hfetch 2 ,core_uart_rxitems 
+44a9 98002600 iforce regc 
+44aa d840044f arg 0x44f ,temp 
+44ab 98467c00 isub temp ,null 
+44ac 24628000 nrtn zero 
+
+hci_rx_packet_cont:
+44ad 68110058 hfetch 2 ,core_uart_rrptr 
+44ae 98000600 iforce contru 
+44af 20404494 call hci_check_bcsp_protocol 
+44b0 2020c2e5 branch hci_rx_bcsp ,true 
+44b1 202043e2 branch hci_rx_h4 
+
+hci_send_ack:
+44b2 20404494 call hci_check_bcsp_protocol 
+44b3 2020c371 branch bcsp_send_ack ,true 
+44b4 20600000 rtn 
+
+uart_send_byte:
+44b5 6818810c hfetcht 1 ,core_uart_status 
+44b6 284ffe06 isolate1 6 ,temp 
+44b7 2020c4b5 branch uart_send_byte ,true 
+44b8 60108015 hstore 1 ,core_uart_txd 
+44b9 20600000 rtn 
+
+process_acl_into_queue:
+44ba 68090299 fetcht 2 ,mem_hci_acl_queue_end 
+44bb 68010295 fetch 2 ,mem_hci_acl_queue_wptr 
+44bc 98000a00 iforce contw 
+44bd 18627e00 deposit contru 
+44be e0a10000 istore 2 ,contw 
+44bf 18a27e00 deposit contw 
+44c0 60010295 store 2 ,mem_hci_acl_queue_wptr 
+44c1 a841fe00 icompare 0xff ,temp 
+44c2 2040c4c7 call process_acl_into_queue_loop ,true 
+44c3 6800829b fetch 1 ,mem_hci_acl_queue_wcnt 
+44c4 1fe0fe01 increase 1 ,pdata 
+44c5 6000829b store 1 ,mem_hci_acl_queue_wcnt 
+44c6 20600000 rtn 
+
+process_acl_into_queue_loop:
+44c7 58004803 setarg mem_hci_acl_queue_start 
+44c8 60010295 store 2 ,mem_hci_acl_queue_wptr 
+44c9 20600000 rtn 
+
+process_acl_dequeue:
+44ca 6800829b fetch 1 ,mem_hci_acl_queue_wcnt 
+44cb 207a0000 rtn blank 
+44cc 68090299 fetcht 2 ,mem_hci_acl_queue_end 
+44cd 68010297 fetch 2 ,mem_hci_acl_queue_rptr 
+44ce 98000c00 iforce contr 
+44cf e8c10000 ifetch 2 ,contr 
+44d0 98000600 iforce contru 
+44d1 18c27e00 deposit contr 
+44d2 60010297 store 2 ,mem_hci_acl_queue_rptr 
+44d3 a841fe00 icompare 0xff ,temp 
+44d4 2040c4da call process_acl_dequeue_loop ,true 
+44d5 6800829b fetch 1 ,mem_hci_acl_queue_wcnt 
+44d6 1fe0ffff increase -1 ,pdata 
+44d7 6000829b store 1 ,mem_hci_acl_queue_wcnt 
+44d8 18007e01 force 1 ,pdata 
+44d9 20600000 rtn 
+
+process_acl_dequeue_loop:
+44da 58004803 setarg mem_hci_acl_queue_start 
+44db 60010297 store 2 ,mem_hci_acl_queue_rptr 
+44dc 20600000 rtn 
+
+process_acl:
+44dd 793f8025 set0 mark_ext_patch ,mark 
+44de 44e9c01a bpatch patch1a_3 ,mem_patch1a 
+44df 6800829b fetch 1 ,mem_hci_acl_queue_wcnt 
+44e0 1fe67c02 sub pdata ,2 ,null 
+44e1 202144e4 branch process_acl_queue_check_ok ,positive 
+44e2 78347c00 enable user 
+44e3 202044e6 branch process_send_acl 
+
+process_acl_queue_check_ok:
+44e4 204044b2 call hci_send_ack 
+44e5 204044ba call process_acl_into_queue 
+
+process_send_acl:
+44e6 793f8025 set0 mark_ext_patch ,mark 
+44e7 44ea401a bpatch patch1a_4 ,mem_patch1a 
+44e8 c6010000 rtnmark1 mark_tx_l2cap 
+44e9 204044ca call process_acl_dequeue 
+44ea 207a0000 rtn blank 
+44eb e8688000 ifetcht 1 ,contru 
+44ec 204032f7 call context_search_conn_handle2 
+44ed 24628000 nrtn zero 
+44ee e8608000 ifetch 1 ,contru 
+44ef 1ff1fe00 rshift4 pdata ,pdata 
+44f0 1fe17e03 and pdata ,0x3 ,pdata 
+44f1 243a44f3 nbranch process_send_acl_good_lch ,blank 
+44f2 79207e01 set1 1 ,pdata 
+
+process_send_acl_good_lch:
+44f3 79207e02 set1 2 ,pdata 
+44f4 60008090 store 1 ,mem_tx_lch 
+44f5 e8610000 ifetch 2 ,contru 
+44f6 60010091 store 2 ,mem_tx_len 
+44f7 18627e00 deposit contru 
+44f8 60010179 store 2 ,mem_txptr 
+44f9 79200002 set1 mark_tx_l2cap ,mark 
+44fa c584c502 bmark0 mark_context ,process_acl_ncontext 
+44fb 68008046 fetch 1 ,mem_conn_handle 
+44fc 98467c00 isub temp ,null 
+44fd 2422c502 nbranch process_acl_ncontext ,zero 
+44fe 6800804b fetch 1 ,mem_op 
+44ff 79207e06 set1 op_txl2cap ,pdata 
+4500 6000804b store 1 ,mem_op 
+4501 20600000 rtn 
+
+process_acl_ncontext:
+4502 1a20a21b increase coffset_op ,rega 
+4503 ea208000 ifetch 1 ,rega 
+4504 79207e06 set1 op_txl2cap ,pdata 
+4505 e2208000 istore 1 ,rega 
+4506 20600000 rtn 
+
+process_hci_cmd:
+4507 793f8025 set0 mark_ext_patch ,mark 
+4508 44eac01a bpatch patch1a_5 ,mem_patch1a 
+4509 6800c272 fetch 1 ,mem_hci_cmd 
+450a 203a450d branch process_hci_cmd_cont ,blank 
+450b 78347c00 enable user 
+450c 20600000 rtn 
+
+process_hci_cmd_cont:
+450d 204044b2 call hci_send_ack 
+450e e8610000 ifetch 2 ,contru 
+450f 98006000 iforce alarm 
+4510 98000e00 iforce queue 
+4511 e8608000 ifetch 1 ,contru 
+4512 98000400 iforce temp 
+4513 1e0b7e00 rshift2 alarm ,pdata 
+4514 1fecfe00 rshift8 pdata ,pdata 
+4515 c000c51e beq hci_ogf_link_control ,phci_grp_link_control 
+4516 c001453d beq hci_ogf_link_policy ,phci_grp_link_policy 
+4517 c001c54f beq hci_ogf_baseband ,phci_grp_baseband 
+4518 c0024569 beq hci_ogf_info ,phci_grp_info 
+4519 c002c572 beq hci_ogf_status ,phci_grp_status 
+451a c003457c beq hci_ogf_test ,phci_grp_test 
+451b c01fc585 beq hci_ogf_vendor_specific ,phci_grp_vendor_specific 
+451c c00445e0 beq hci_ogf_low_energy ,phci_grp_low_energy 
+451d 20600000 rtn 
+
+phci_grp_link_control:
+451e 793f8025 set0 mark_ext_patch ,mark 
+451f 44eb401a bpatch patch1a_6 ,mem_patch1a 
+4520 18e27e00 deposit queue 
+4521 c000c634 beq hci_inquiry ,phci_inquiry 
+4522 c0014643 beq hci_inquiry_cancel ,phci_inquiry_cancel 
+4523 c001c949 beq hci_periodic_inquiry_mode ,hci_normal_reply 
+4524 c0024949 beq hci_exit_periodic_inquiry_mode ,hci_normal_reply 
+4525 c002c645 beq hci_create_connection ,phci_create_connection 
+4526 c003464f beq hci_disconnect ,phci_disconnect 
+4527 c003c949 beq hci_add_sco_connection ,hci_normal_reply 
+4528 c004465d beq hci_create_connection_cancel ,phci_create_connection_cancel 
+4529 c004c739 beq hci_accept_connection ,phci_accept_connection 
+452a c005473f beq hci_reject_connection ,phci_reject_connection 
+452b c005c664 beq hci_link_key_request_reply ,phci_link_key_request_reply 
+452c c006466a beq hci_link_key_request_negative_reply ,phci_link_key_request_negative_reply 
+452d c006c66d beq hci_pin_code_request_reply ,phci_pin_code_request_reply 
+452e c0074675 beq hci_pin_code_request_negative_reply ,phci_pin_code_request_negative_reply 
+452f c007c743 beq hci_change_connection_packet_type ,phci_change_connection_packet_type 
+4530 c008c688 beq hci_authentication_requested ,phci_authentication_requested 
+4531 c009c68b beq hci_set_connection_encryption ,phci_set_connection_encryption 
+4532 c00ac949 beq hci_change_connection_link_key ,hci_normal_reply 
+4533 c00bc949 beq hci_master_link_key ,hci_normal_reply 
+4534 c00cc690 beq hci_remote_name_request ,phci_remote_name_request 
+4535 c00dc69b beq hci_read_remote_supported_features ,phci_read_remote_supported_features 
+4536 c00e4696 beq hci_read_remote_ext_features ,phci_read_remote_ext_features 
+4537 c00ec6a1 beq hci_read_remote_version_information ,phci_read_remote_version_information 
+4538 c00fc6a7 beq hci_read_clock_offset ,phci_read_clock_offset 
+4539 c01446ab beq hci_setup_sco_connection ,phci_setup_sco_connection 
+453a c014c6b6 beq hci_accept_sco_connection ,phci_accept_sco_connection 
+453b c015c67b beq hci_io_cap_request_reply ,phci_io_cap_request_reply 
+453c 2020474d branch phci_unknown_command 
+
+phci_grp_link_policy:
+453d 793f8025 set0 mark_ext_patch ,mark 
+453e 44ebc01a bpatch patch1a_7 ,mem_patch1a 
+453f 18e27e00 deposit queue 
+4540 c004c6cc beq hci_role_discovery ,phci_role_discovery 
+4541 c006c6d7 beq hci_write_link_policy_settings ,phci_write_link_policy_settings 
+4542 c000c949 beq hci_hold_mode ,hci_normal_reply 
+4543 c001c74f beq hci_sniff_mode ,phci_sniff_mode 
+4544 c002475a beq hci_exit_sniff_mode ,phci_exit_sniff_mode 
+4545 c002c949 beq hci_park_mode ,hci_normal_reply 
+4546 c0034949 beq hci_exit_park_mode ,hci_normal_reply 
+4547 c003c949 beq hci_qos_setup ,hci_normal_reply 
+4548 c005c760 beq hci_switch_role ,phci_switch_role 
+4549 c0064949 beq hci_read_link_policy_settings ,hci_normal_reply 
+454a c0074949 beq hci_read_default_link_policy_settings ,hci_normal_reply 
+454b c007c949 beq hci_write_default_link_policy_settings ,hci_normal_reply 
+454c c0084949 beq hci_flow_specification ,hci_normal_reply 
+454d c008c75f beq hci_sniff_subrating ,phci_sniff_subrating 
+454e 2020474d branch phci_unknown_command 
+
+phci_grp_baseband:
+454f 793f8025 set0 mark_ext_patch ,mark 
+4550 44ec401b bpatch patch1b_0 ,mem_patch1b 
+4551 18e27e00 deposit queue 
+4552 c000c725 beq hci_set_event_mask ,phci_set_event_mask 
+4553 c001c949 beq hci_reset ,hci_normal_reply 
+4554 c00946da beq hci_delete_stored_link_key ,phci_delete_stored_link_key 
+4555 c009c6c2 beq hci_write_local_name ,phci_change_local_name 
+4556 c00a46b8 beq hci_read_local_name ,phci_read_local_name 
+4557 c00c46db beq hci_write_page_timeout ,phci_write_page_timeout 
+4558 c00cc705 beq hci_read_scan_enable ,phci_read_scan_enable 
+4559 c00d46de beq hci_write_scan_enable ,phci_write_scan_enable 
+455a c00e46e1 beq hci_write_page_scan_activity ,phci_write_page_scan_activity 
+455b c00f46e6 beq hci_write_inquiry_scan_activity ,phci_write_inquiry_scan_activity 
+455c c01046ec beq hci_write_authentication_enable ,phci_write_authentication_enable 
+455d c01146eb beq hci_write_encryption_mode ,phci_write_encryption_mode 
+455e c01246ef beq hci_write_class_of_device ,phci_write_class_of_device 
+455f c0134949 beq hci_write_voice_setting ,hci_normal_reply 
+4560 c018c949 beq hci_set_controller_to_host_flow_control ,hci_normal_reply 
+4561 c019c949 beq hci_host_buffer_size ,hci_normal_reply 
+4562 c01ac62e beq hci_host_num_completed_packets ,phci_host_num_completed 
+4563 c021c949 beq hci_write_inquiry_scan_type ,hci_normal_reply 
+4564 c022c949 beq hci_write_inquiry_mode ,hci_normal_reply 
+4565 c023c949 beq hci_write_page_scan_type ,hci_normal_reply 
+4566 c028c6f2 beq hci_read_extended_inquiry_response ,phci_read_ext_inquiry_response 
+4567 c02b4701 beq hci_write_simple_pairing_mode ,phci_write_ssp_mode 
+4568 2020474d branch phci_unknown_command 
+
+phci_grp_info:
+4569 793f8025 set0 mark_ext_patch ,mark 
+456a 44ecc01b bpatch patch1b_1 ,mem_patch1b 
+456b 18e27e00 deposit queue 
+456c c000c70a beq hci_read_local_version_information ,phci_read_local_version_information 
+456d c001c70f beq hci_read_local_supported_features ,phci_read_local_supported_features 
+456e c0024714 beq hci_read_local_ext_features ,phci_read_local_ext_features 
+456f c002c71b beq hci_read_buffer_size ,phci_read_buffer_size 
+4570 c004c720 beq hci_read_bd_addr ,phci_read_bd_addr 
+4571 2020474d branch phci_unknown_command 
+
+phci_grp_status:
+4572 793f8025 set0 mark_ext_patch ,mark 
+4573 44ed401b bpatch patch1b_2 ,mem_patch1b 
+4574 18e27e00 deposit queue 
+4575 c000c949 beq hci_read_failed_contact_counter ,hci_normal_reply 
+4576 c0014726 beq hci_reset_failed_contact_counter ,phci_reset_failed_contact_counter 
+4577 c001c727 beq hci_get_link_quality ,phci_get_link_quality 
+4578 c002c72d beq hci_read_rssi ,phci_read_rssi 
+4579 c0034733 beq hci_read_afh_channel_map ,phci_read_afh_channel_map 
+457a c003c736 beq hci_read_bd_clock ,phci_read_bd_clock 
+457b 2020474d branch phci_unknown_command 
+
+phci_grp_test:
+457c 793f8025 set0 mark_ext_patch ,mark 
+457d 44edc01b bpatch patch1b_3 ,mem_patch1b 
+457e 18e27e00 deposit queue 
+457f c000c949 beq hci_read_loopback_mode ,hci_normal_reply 
+4580 c0014949 beq hci_write_loopback_mode ,hci_normal_reply 
+4581 c001c949 beq hci_enable_device_under_test_mode ,hci_normal_reply 
+4582 c0024949 beq hci_write_simple_pairing_debug_mode ,hci_normal_reply 
+4583 2020474d branch phci_unknown_command 
+4584 20600000 rtn 
+
+phci_grp_vendor_specific:
+4585 793f8025 set0 mark_ext_patch ,mark 
+4586 44ee401b bpatch patch1b_4 ,mem_patch1b 
+4587 18e27e00 deposit queue 
+4588 c0004949 beq hci_vendor_cmd_reset ,hci_normal_reply 
+4589 c000c59d beq hci_vendor_cmd_chipid ,phci_grp_vendor_chipid 
+458a c00145a2 beq hci_vendor_cmd_baud ,phci_grp_vendor_baud 
+458b c001c5a6 beq hci_vendor_cmd_patch ,phci_grp_vendor_patch 
+458c c00245b9 beq hci_vendor_cmd_patch_done ,phci_grp_vendor_done 
+458d c002c949 beq hci_vendor_cmd_echo ,hci_normal_reply 
+458e c00345ca beq hci_vendor_cmd_bdaddr ,phci_grp_vendor_bdaddr 
+458f c003c593 beq hci_vendor_cmd_enter_lpm ,phci_grp_vendor_enter_lpm 
+4590 c00845cd beq hci_vendor_cmd_mem ,phci_grp_vendor_mem 
+4591 c008c5d5 beq hci_vendor_cmd_eep ,phci_grp_vendor_eep 
+4592 20204949 branch hci_normal_reply 
+
+phci_grp_vendor_enter_lpm:
+4593 20404949 call hci_normal_reply 
+4594 20407f68 call wait_uarttx 
+4595 20406a68 call gpio_pu_uart_tx 
+
+hci_enter_lpm:
+4596 20403f5c call app_put_lpm_wake_lock 
+4597 20403f66 call app_l2cap_flow_control_enable 
+4598 20206a7d branch gpio_rx_config_input_with_pu 
+
+hci_exit_lpm:
+4599 7042ae00 jam hci_rx_ready ,mem_hci_lt_rx_state 
+459a 20403f5a call app_get_lpm_wake_lock 
+459b 20404468 call hci_lpm_init 
+459c 20203f68 branch app_l2cap_flow_control_disable 
+
+phci_grp_vendor_chipid:
+459d 2040496e call hci_get_cmd_complete_ptr 
+459e 68110000 hfetch 2 ,core_chipid 
+459f e1410000 istore 2 ,contwu 
+45a0 18007206 force 6 ,loopcnt 
+45a1 2020494c branch hci_command_complete 
+
+phci_grp_vendor_baud:
+45a2 e8610000 ifetch 2 ,contru 
+45a3 600142ac store 2 ,mem_baud 
+45a4 60110052 hstore 2 ,core_uart_baud 
+45a5 20600000 rtn 
+
+phci_grp_vendor_patch:
+45a6 e8608000 ifetch 1 ,contru 
+45a7 1fe20400 copy pdata ,temp 
+45a8 60108024 hstore 1 ,core_ucode_low 
+45a9 e8608000 ifetch 1 ,contru 
+45aa 98408400 iadd temp ,temp 
+45ab 79207e07 set1 7 ,pdata 
+45ac 60108023 hstore 1 ,core_ucode_ctrl 
+45ad e8608000 ifetch 1 ,contru 
+45ae 98408400 iadd temp ,temp 
+45af 1fe27200 copy pdata ,loopcnt 
+
+phci_grp_vendor_patch_loop:
+45b0 e8608000 ifetch 1 ,contru 
+45b1 60108025 hstore 1 ,core_ucode_data 
+45b2 98408400 iadd temp ,temp 
+45b3 c20045b0 loop phci_grp_vendor_patch_loop 
+45b4 184104ff and temp ,0xff ,temp 
+45b5 e8608000 ifetch 1 ,contru 
+45b6 98467c00 isub temp ,null 
+45b7 2422c5c8 nbranch phci_grp_vendor_patch_bad ,zero 
+45b8 20204949 branch hci_normal_reply 
+
+phci_grp_vendor_done:
+45b9 df200020 arg 0x20 ,loopcnt 
+45ba d8a04000 arg mem_patch00 ,contw 
+45bb d8400000 arg 0 ,temp 
+
+phci_grp_vendor_done_loop:
+45bc e8608000 ifetch 1 ,contru 
+45bd e0a08000 istore 1 ,contw 
+45be 98408400 iadd temp ,temp 
+45bf c20045bc loop phci_grp_vendor_done_loop 
+45c0 184104ff and temp ,0xff ,temp 
+45c1 e8608000 ifetch 1 ,contru 
+45c2 98467c00 isub temp ,null 
+45c3 2422c5c8 nbranch phci_grp_vendor_patch_bad ,zero 
+45c4 70802300 hjam 0 ,core_ucode_ctrl 
+45c5 20404949 call hci_normal_reply 
+45c6 2040440e call h4_rx_discard_packet 
+45c7 20203001 branch soft_reset 
+
+phci_grp_vendor_patch_bad:
+45c8 70802300 hjam 0 ,core_ucode_ctrl 
+45c9 20203000 branch start 
+
+phci_grp_vendor_bdaddr:
+45ca e8630000 ifetch 6 ,contru 
+45cb 60034140 store 6 ,mem_lap 
+45cc 20204949 branch hci_normal_reply 
+
+phci_grp_vendor_mem:
+45cd e8608000 ifetch 1 ,contru 
+45ce 600082c1 store 1 ,mem_hci_curr_len 
+45cf 1fe27200 copy pdata ,loopcnt 
+45d0 e8610000 ifetch 2 ,contru 
+45d1 600102c2 store 2 ,mem_hci_curr_target 
+45d2 1fe20a00 copy pdata ,contw 
+45d3 2040497c call uart_copy_rx_bytes 
+45d4 20204949 branch hci_normal_reply 
+
+phci_grp_vendor_eep:
+45d5 e8608000 ifetch 1 ,contru 
+45d6 600082c1 store 1 ,mem_hci_curr_len 
+45d7 1fe27200 copy pdata ,loopcnt 
+45d8 e8610000 ifetch 2 ,contru 
+45d9 600102c2 store 2 ,mem_hci_curr_target 
+45da d8a01000 arg mem_l2cap_rxbuff1 ,contw 
+45db 2040497c call uart_copy_rx_bytes 
+45dc 680882c1 fetcht 1 ,mem_hci_curr_len 
+45dd da201000 arg mem_l2cap_rxbuff1 ,rega 
+45de 680102c2 fetch 2 ,mem_hci_curr_target 
+45df 20206842 branch iicd_write_ota_data 
+
+phci_grp_low_energy:
+45e0 793f8025 set0 mark_ext_patch ,mark 
+45e1 44eec01b bpatch patch1b_5 ,mem_patch1b 
+45e2 18e27e00 deposit queue 
+45e3 c000c949 beq hci_le_set_event_mask ,hci_normal_reply 
+45e4 c00145f3 beq hci_le_read_buffer_size ,phci_le_read_buffer_size 
+45e5 c001c5f8 beq hci_le_read_local_supported_features ,phci_le_read_local_supported_features 
+45e6 c00345ff beq hci_le_set_advertising_parameters ,phci_le_set_adv_param 
+45e7 c0044603 beq hci_le_set_advertising_data ,phci_le_set_adv_data 
+45e8 c004c607 beq hci_le_set_scan_response_data ,phci_le_set_scan_response_data 
+45e9 c005460b beq hci_le_set_advertise_enable ,phci_le_set_adv_enable 
+45ea c005c60e beq hci_le_set_scan_parameters ,phci_le_set_scan_param 
+45eb c0064611 beq hci_le_set_scan_enable ,phci_le_set_scan_enable 
+45ec c006c614 beq hci_le_create_connection ,phci_le_create_conn 
+45ed c0074626 beq hci_le_create_connection_cancel ,phci_le_create_conn_cancel 
+45ee c00ac627 beq hci_le_read_channel_map ,phci_le_read_channel_map 
+45ef c00b4933 beq hci_le_read_remote_used_features ,hci_command_status 
+45f0 c009c949 beq hci_le_connection_update ,hci_normal_reply 
+45f1 2020474d branch phci_unknown_command 
+45f2 20600000 rtn 
+
+phci_le_read_buffer_size:
+45f3 2040496e call hci_get_cmd_complete_ptr 
+45f4 58000000 setarg 0 
+45f5 e1418000 istore 3 ,contwu 
+45f6 18007207 force 0x07 ,loopcnt 
+45f7 2020494c branch hci_command_complete 
+
+phci_le_read_local_supported_features:
+45f8 2040496e call hci_get_cmd_complete_ptr 
+45f9 58000001 setarg 1 
+45fa e1410000 istore 2 ,contwu 
+45fb 58000000 setarg 0 
+45fc e1430000 istore 6 ,contwu 
+45fd 1800720c force 0x0c ,loopcnt 
+45fe 2020494c branch hci_command_complete 
+
+phci_le_set_adv_param:
+45ff df20000f arg 15 ,loopcnt 
+4600 d8a044d7 arg mem_le_adv_param ,contw 
+4601 2040497c call uart_copy_rx_bytes 
+4602 20204949 branch hci_normal_reply 
+
+phci_le_set_adv_data:
+4603 df200020 arg 32 ,loopcnt 
+4604 d8a043d9 arg mem_le_adv_data_len ,contw 
+4605 2040497c call uart_copy_rx_bytes 
+4606 20204949 branch hci_normal_reply 
+
+phci_le_set_scan_response_data:
+4607 df200020 arg 32 ,loopcnt 
+4608 d8a043f9 arg mem_le_scan_data_len ,contw 
+4609 2040497c call uart_copy_rx_bytes 
+460a 20204949 branch hci_normal_reply 
+
+phci_le_set_adv_enable:
+460b e8608000 ifetch 1 ,contru 
+460c 6000c3d8 store 1 ,mem_le_adv_enable 
+460d 20204949 branch hci_normal_reply 
+
+phci_le_set_scan_param:
+460e e8638000 ifetch 7 ,contru 
+460f 6003c4f6 store 7 ,mem_le_scan_params 
+4610 20204949 branch hci_normal_reply 
+
+phci_le_set_scan_enable:
+4611 e8608000 ifetch 1 ,contru 
+4612 6000c3d2 store 1 ,mem_le_scan_enable 
+4613 20204949 branch hci_normal_reply 
+
+phci_le_create_conn:
+4614 e8620000 ifetch 4 ,contru 
+4615 600243d3 store 4 ,mem_le_scan_interval 
+4616 e8608000 ifetch 1 ,contru 
+4617 6000c4f8 store 1 ,mem_le_scan_filter_policy 
+4618 df200014 arg 20 ,loopcnt 
+4619 d8a044e6 arg mem_le_conn_param ,contw 
+461a 2040497c call uart_copy_rx_bytes 
+461b 7043d201 jam 1 ,mem_le_scan_enable 
+461c 6800c4ed fetch 1 ,mem_le_conn_own_addr_type 
+461d 6000c4f7 store 1 ,mem_le_scan_own_addr_type 
+461e 680144f0 fetch 2 ,mem_le_conn_interval_max 
+461f 600143d0 store 2 ,mem_le_conn_interval 
+4620 680144f2 fetch 2 ,mem_le_conn_latency 
+4621 600103ed store 2 ,mem_le_slave_latency 
+4622 680144f4 fetch 2 ,mem_le_conn_superto 
+4623 600103ef store 2 ,mem_le_superto 
+4624 7042721b jam hci_cmd_le_create_conn ,mem_hci_cmd 
+4625 20204933 branch hci_command_status 
+
+phci_le_create_conn_cancel:
+4626 20204949 branch hci_normal_reply 
+
+phci_le_read_channel_map:
+4627 2040496e call hci_get_cmd_complete_ptr 
+4628 e8610000 ifetch 2 ,contru 
+4629 e1410000 istore 2 ,contwu 
+462a 581fffff setarg 0x1fffff 
+462b e1428000 istore 5 ,contwu 
+462c 1800720b force 0x0b ,loopcnt 
+462d 2020494c branch hci_command_complete 
+
+phci_host_num_completed:
+462e e8618000 ifetch 3 ,contru 
+462f e8698000 ifetcht 3 ,contru 
+4630 68014800 fetch 2 ,mem_acl_credits 
+4631 9840fe00 iadd temp ,pdata 
+4632 60014800 store 2 ,mem_acl_credits 
+4633 20600000 rtn 
+
+phci_inquiry:
+4634 e8618000 ifetch 3 ,contru 
+4635 6001c147 store 3 ,mem_glap 
+
+do_at_inquiry0:
+4636 70427201 jam hci_cmd_inquiry ,mem_hci_cmd 
+4637 e8608000 ifetch 1 ,contru 
+4638 d8400640 arg 1600 ,temp 
+4639 984ffe00 imul32 temp ,pdata 
+463a d840ffff arg 0xffff ,temp 
+463b 98467c00 isub temp ,null 
+463c 2421463e nbranch phci_inquiry_nowrap ,positive 
+463d 18427e00 deposit temp 
+
+phci_inquiry_nowrap:
+463e 18000e02 force inquiry_length_timer ,queue 
+463f 20407e4c call timer_init 
+4640 6800c2a4 fetch 1 ,mem_at_using_flag 
+4641 c280428c bbit1 at_flag_inq ,at_rev_end 
+4642 20204933 branch hci_command_status 
+
+phci_inquiry_cancel:
+4643 70427202 jam hci_cmd_inquiry_cancel ,mem_hci_cmd 
+4644 20204949 branch hci_normal_reply 
+
+phci_create_connection:
+4645 20404763 call phci_read_plap 
+4646 e8610000 ifetch 2 ,contru 
+4647 60010275 store 2 ,mem_packet_type 
+4648 e8610000 ifetch 2 ,contru 
+4649 600080f3 store 1 ,mem_page_mode 
+464a 20404776 call phci_read_clock 
+464b e8608000 ifetch 1 ,contru 
+464c 6000c802 store 1 ,mem_allow_switch 
+464d 70427205 jam hci_cmd_create_conn ,mem_hci_cmd 
+464e 20204933 branch hci_command_status 
+
+phci_disconnect:
+464f 70427206 jam hci_cmd_disconn ,mem_hci_cmd 
+4650 e8610000 ifetch 2 ,contru 
+4651 6000c273 store 1 ,mem_hci_conn_handle 
+4652 e8608000 ifetch 1 ,contru 
+4653 60008446 store 1 ,mem_disconn_reason_send 
+4654 7002c016 jam hci_error_connection_terminated_by_local_host ,mem_hci_disconn_reason 
+4655 6800c273 fetch 1 ,mem_hci_conn_handle 
+4656 680880ad fetcht 1 ,mem_sco_handle 
+4657 98467c00 isub temp ,null 
+4658 2422c933 nbranch hci_command_status ,zero 
+4659 70427211 jam hci_cmd_disconn_sco ,mem_hci_cmd 
+465a 680080ac fetch 1 ,mem_sco_asso_handle 
+465b 6000c273 store 1 ,mem_hci_conn_handle 
+465c 20204933 branch hci_command_status 
+
+phci_create_connection_cancel:
+465d 2040496e call hci_get_cmd_complete_ptr 
+465e 20404965 call hci_write_plap 
+465f 1800720a force 10 ,loopcnt 
+4660 2040494c call hci_command_complete 
+4661 7042721a jam hci_cmd_detach ,mem_hci_cmd 
+4662 18000402 force hci_error_no_connection ,temp 
+4663 20204826 branch hci_send_connection_error 
+
+phci_link_key_request_reply:
+4664 20404763 call phci_read_plap 
+4665 d8a04262 arg mem_link_key ,contw 
+4666 18007210 force 16 ,loopcnt 
+4667 2040497c call uart_copy_rx_bytes 
+4668 7042720b jam hci_cmd_linkkey ,mem_hci_cmd 
+4669 20204677 branch phci_pin_code_reply 
+
+phci_link_key_request_negative_reply:
+466a 20404763 call phci_read_plap 
+466b 7042720c jam hci_cmd_nokey ,mem_hci_cmd 
+466c 20204677 branch phci_pin_code_reply 
+
+phci_pin_code_request_reply:
+466d 20404763 call phci_read_plap 
+466e e8608000 ifetch 1 ,contru 
+466f 6000854f store 1 ,mem_pin_length 
+4670 98007200 iforce loopcnt 
+4671 d8a00550 arg mem_pin ,contw 
+4672 2040497c call uart_copy_rx_bytes 
+4673 70427209 jam hci_cmd_pair ,mem_hci_cmd 
+4674 20204677 branch phci_pin_code_reply 
+
+phci_pin_code_request_negative_reply:
+4675 20404763 call phci_read_plap 
+4676 7042720a jam hci_cmd_nopair ,mem_hci_cmd 
+
+phci_pin_code_reply:
+4677 2040496e call hci_get_cmd_complete_ptr 
+4678 20404965 call hci_write_plap 
+4679 1800720a force 10 ,loopcnt 
+467a 2020494c branch hci_command_complete 
+
+phci_io_cap_request_reply:
+467b 18608606 increase 6 ,contru 
+467c e8618000 ifetch 3 ,contru 
+467d 600187e6 store 3 ,mem_sp_iocap_local 
+467e 680087db fetch 1 ,mem_master_sp_state 
+467f c009c683 beq sp_master_stat_start_done ,phci_io_cap_request_reply_master 
+4680 c001c683 beq sp_stat_key_send ,phci_io_cap_request_reply_master 
+4681 70427216 jam hci_cmd_io_cap ,mem_hci_cmd 
+4682 20204684 branch phci_io_cap_request_reply_commom 
+
+phci_io_cap_request_reply_master:
+4683 7007dd01 jam sp_flag_commit ,mem_master_sp_flag 
+
+phci_io_cap_request_reply_commom:
+4684 2040496e call hci_get_cmd_complete_ptr 
+4685 20404965 call hci_write_plap 
+4686 1800720a force 10 ,loopcnt 
+4687 2020494c branch hci_command_complete 
+
+phci_authentication_requested:
+4688 20404766 call phci_read_handle 
+4689 7042720d jam hci_cmd_auth ,mem_hci_cmd 
+468a 20204933 branch hci_command_status 
+
+phci_set_connection_encryption:
+468b 20404766 call phci_read_handle 
+468c e8608000 ifetch 1 ,contru 
+468d 1fe0fe0e increase hci_cmd_stopencrypt ,pdata 
+468e 6000c272 store 1 ,mem_hci_cmd 
+468f 20204933 branch hci_command_status 
+
+phci_remote_name_request:
+4690 20404763 call phci_read_plap 
+4691 e8610000 ifetch 2 ,contru 
+4692 600080f3 store 1 ,mem_page_mode 
+4693 20404776 call phci_read_clock 
+4694 70427203 jam hci_cmd_remote_name_req ,mem_hci_cmd 
+4695 20204933 branch hci_command_status 
+
+phci_read_remote_ext_features:
+4696 e8610000 ifetch 2 ,contru 
+4697 e8608000 ifetch 1 ,contru 
+4698 60008449 store 1 ,mem_ext_features_page 
+4699 70427215 jam hci_cmd_remote_ext_features_req ,mem_hci_cmd 
+469a 20204933 branch hci_command_status 
+
+phci_read_remote_supported_features:
+469b 68008046 fetch 1 ,mem_conn_handle 
+469c 18002202 force hci_error_no_connection ,rega 
+469d 203a493d branch hci_command_status_err ,blank 
+469e 20404766 call phci_read_handle 
+469f 70427204 jam hci_cmd_remote_feature_req ,mem_hci_cmd 
+46a0 20204933 branch hci_command_status 
+
+phci_read_remote_version_information:
+46a1 68008046 fetch 1 ,mem_conn_handle 
+46a2 18002202 force hci_error_no_connection ,rega 
+46a3 203a493d branch hci_command_status_err ,blank 
+46a4 20404766 call phci_read_handle 
+46a5 70427214 jam hci_cmd_remote_version_req ,mem_hci_cmd 
+46a6 20204933 branch hci_command_status 
+
+phci_read_clock_offset:
+46a7 2040476e call phci_status_reply_temp 
+46a8 18000e1c force hci_event_read_clock_offset_complete ,queue 
+46a9 18007205 force 5 ,loopcnt 
+46aa 20204952 branch hci_send_event 
+
+phci_setup_sco_connection:
+46ab 20404766 call phci_read_handle 
+46ac 1860860a increase 10 ,contru 
+46ad e8610000 ifetch 2 ,contru 
+46ae 60010281 store 2 ,mem_voice_setting 
+46af e8608000 ifetch 1 ,contru 
+46b0 60008283 store 1 ,mem_retransmission_effort 
+46b1 e8610000 ifetch 2 ,contru 
+46b2 60010284 store 2 ,mem_sco_ptype 
+46b3 7000ab02 jam 2 ,mem_air_mode 
+46b4 70427210 jam hci_cmd_setup_sco ,mem_hci_cmd 
+46b5 20204933 branch hci_command_status 
+
+phci_accept_sco_connection:
+46b6 7042721c jam hci_cmd_accept_sco_conn ,mem_hci_cmd 
+46b7 20204933 branch hci_command_status 
+
+phci_read_local_name:
+46b8 2040496e call hci_get_cmd_complete_ptr 
+46b9 d8c04703 arg mem_local_name ,contr 
+46ba 18c672ff sub contr ,0xff ,loopcnt 
+46bb 20404976 call uart_copy_tx_bytes 
+46bc 18007e00 force 0 ,pdata 
+46bd 18c67303 sub contr ,mem_local_name ,loopcnt 
+46be 1f20f2f8 increase 0xf8 ,loopcnt 
+46bf 20404982 call uart_write_bytes 
+46c0 180072fc force 0xfc ,loopcnt 
+46c1 2020494c branch hci_command_complete 
+
+phci_change_local_name:
+46c2 d8a04703 arg mem_local_name ,contw 
+46c3 18a672ff sub contw ,0xff ,loopcnt 
+
+phci_change_local_name_loop:
+46c4 e8608000 ifetch 1 ,contru 
+46c5 e0a08000 istore 1 ,contw 
+46c6 203a46c8 branch phci_write_local_name_end ,blank 
+46c7 c20046c4 loop phci_change_local_name_loop 
+
+phci_write_local_name_end:
+46c8 18a67f03 sub contw ,mem_local_name ,pdata 
+46c9 1fe67e00 sub pdata ,0 ,pdata 
+46ca 6000c702 store 1 ,mem_local_name_length 
+46cb 20204949 branch hci_normal_reply 
+
+phci_role_discovery:
+46cc 2040496e call hci_get_cmd_complete_ptr 
+46cd 2040496b call hci_write_handle 
+46ce 18007e00 force 0 ,pdata 
+46cf 7d34fe00 nsetflag master ,0 ,pdata 
+46d0 e1408000 istore 1 ,contwu 
+46d1 18007207 force 7 ,loopcnt 
+46d2 de000809 arg 0x809 ,alarm 
+46d3 2040494c call hci_command_complete 
+46d4 202049bc branch cmd_exit 
+46d5 70427217 jam hci_cmd_role_discovery ,mem_hci_cmd 
+46d6 20600000 rtn 
+
+phci_write_link_policy_settings:
+46d7 20404769 call phci_copy_handle 
+46d8 18007206 force 6 ,loopcnt 
+46d9 2020494c branch hci_command_complete 
+
+phci_delete_stored_link_key:
+46da 20204949 branch hci_normal_reply 
+
+phci_write_page_timeout:
+46db e8610000 ifetch 2 ,contru 
+46dc 60014159 store 2 ,mem_page_to 
+46dd 20204949 branch hci_normal_reply 
+
+phci_write_scan_enable:
+46de e8608000 ifetch 1 ,contru 
+46df 6000c133 store 1 ,mem_scan_mode 
+46e0 20204949 branch hci_normal_reply 
+
+phci_write_page_scan_activity:
+46e1 e8610000 ifetch 2 ,contru 
+46e2 60014153 store 2 ,mem_pscan_interval 
+46e3 e8610000 ifetch 2 ,contru 
+46e4 60014151 store 2 ,mem_pscan_window 
+46e5 20204949 branch hci_normal_reply 
+
+phci_write_inquiry_scan_activity:
+46e6 e8610000 ifetch 2 ,contru 
+46e7 6001414f store 2 ,mem_iscan_interval 
+46e8 e8610000 ifetch 2 ,contru 
+46e9 6001414d store 2 ,mem_iscan_window 
+46ea 20204949 branch hci_normal_reply 
+
+phci_write_encryption_mode:
+46eb 20204949 branch hci_normal_reply 
+
+phci_write_authentication_enable:
+46ec e8608000 ifetch 1 ,contru 
+46ed 60008453 store 1 ,mem_auth_enable 
+46ee 20204949 branch hci_normal_reply 
+
+phci_write_class_of_device:
+46ef e8618000 ifetch 3 ,contru 
+46f0 6001c14a store 3 ,mem_class 
+46f1 20204949 branch hci_normal_reply 
+
+phci_read_ext_inquiry_response:
+46f2 18427e00 deposit temp 
+46f3 203a4949 branch hci_normal_reply ,blank 
+46f4 20404970 call hci_get_payload_ptr 
+46f5 18007e01 force 0x1 ,pdata 
+46f6 e1408000 istore 1 ,contwu 
+46f7 1e027e00 deposit alarm 
+46f8 e1410000 istore 2 ,contwu 
+46f9 18007e12 force hci_error_invalid_hci_command_parameters ,pdata 
+46fa e1408000 istore 1 ,contwu 
+46fb 58000000 setarg 0 
+46fc 1f20f2f1 increase 0xf1 ,loopcnt 
+46fd 20404982 call uart_write_bytes 
+46fe 18000e0e force hci_event_command_complete ,queue 
+46ff 180072f5 force 0xf5 ,loopcnt 
+4700 20204952 branch hci_send_event 
+
+phci_write_ssp_mode:
+4701 e8608000 ifetch 1 ,contru 
+4702 245a6003 ncall ssp_enable ,blank 
+4703 205a6009 call ssp_disable ,blank 
+4704 20204949 branch hci_normal_reply 
+
+phci_read_scan_enable:
+4705 2040496e call hci_get_cmd_complete_ptr 
+4706 6800c133 fetch 1 ,mem_scan_mode 
+4707 e1408000 istore 1 ,contwu 
+4708 18007205 force 5 ,loopcnt 
+4709 2020494c branch hci_command_complete 
+
+phci_read_local_version_information:
+470a 2040496e call hci_get_cmd_complete_ptr 
+470b 68040080 fetch 8 ,mem_hci_version 
+470c e1440000 istore 8 ,contwu 
+470d 1800720c force 12 ,loopcnt 
+470e 2020494c branch hci_command_complete 
+
+phci_read_local_supported_features:
+470f 2040496e call hci_get_cmd_complete_ptr 
+4710 68044138 fetch 8 ,mem_features 
+4711 e1440000 istore 8 ,contwu 
+4712 1800720c force 12 ,loopcnt 
+4713 2020494c branch hci_command_complete 
+
+phci_read_local_ext_features:
+4714 2040496e call hci_get_cmd_complete_ptr 
+4715 58000101 setarg 0x0101 
+4716 e1410000 istore 2 ,contwu 
+4717 58000001 setarg 0x01 
+4718 e1440000 istore 8 ,contwu 
+4719 1800720e force 14 ,loopcnt 
+471a 2020494c branch hci_command_complete 
+
+phci_read_buffer_size:
+471b 2040496e call hci_get_cmd_complete_ptr 
+471c 68038083 fetch 7 ,mem_acl_pktlen 
+471d e1438000 istore 7 ,contwu 
+471e 1800720b force 11 ,loopcnt 
+471f 2020494c branch hci_command_complete 
+
+phci_read_bd_addr:
+4720 2040496e call hci_get_cmd_complete_ptr 
+4721 68034140 fetch 6 ,mem_lap 
+4722 e1430000 istore 6 ,contwu 
+4723 1800720a force 10 ,loopcnt 
+4724 2020494c branch hci_command_complete 
+
+phci_set_event_mask:
+4725 20204949 branch hci_normal_reply 
+
+phci_reset_failed_contact_counter:
+4726 20204949 branch hci_normal_reply 
+
+phci_get_link_quality:
+4727 2040496e call hci_get_cmd_complete_ptr 
+4728 2040496b call hci_write_handle 
+4729 580000ff setarg 0xff 
+472a e1408000 istore 1 ,contwu 
+472b 18007207 force 7 ,loopcnt 
+472c 2020494c branch hci_command_complete 
+
+phci_read_rssi:
+472d 2040496e call hci_get_cmd_complete_ptr 
+472e 2040496b call hci_write_handle 
+472f 58000000 setarg 0x00 
+4730 e1408000 istore 1 ,contwu 
+4731 18007207 force 7 ,loopcnt 
+4732 2020494c branch hci_command_complete 
+
+phci_read_afh_channel_map:
+4733 793f8025 set0 mark_ext_patch ,mark 
+4734 44ef401b bpatch patch1b_6 ,mem_patch1b 
+4735 20204949 branch hci_normal_reply 
+
+phci_read_bd_clock:
+4736 793f8025 set0 mark_ext_patch ,mark 
+4737 44efc01b bpatch patch1b_7 ,mem_patch1b 
+4738 20204949 branch hci_normal_reply 
+
+phci_accept_connection:
+4739 20404763 call phci_read_plap 
+473a 70427207 jam hci_cmd_accept_conn ,mem_hci_cmd 
+473b e8608000 ifetch 1 ,contru 
+473c c000c933 beq 1 ,hci_command_status 
+473d 70427219 jam hci_cmd_accept_with_switch ,mem_hci_cmd 
+473e 20204933 branch hci_command_status 
+
+phci_reject_connection:
+473f 20204739 branch phci_accept_connection 
+4740 20404763 call phci_read_plap 
+4741 70427208 jam hci_cmd_reject_conn ,mem_hci_cmd 
+4742 20204949 branch hci_normal_reply 
+
+phci_change_connection_packet_type:
+4743 20404933 call hci_command_status 
+4744 20404970 call hci_get_payload_ptr 
+4745 58000000 setarg 0 
+4746 e1408000 istore 1 ,contwu 
+4747 e8620000 ifetch 4 ,contru 
+4748 e1420000 istore 4 ,contwu 
+4749 18007208 force 8 ,loopcnt 
+474a d8e0001d arg hci_event_connection_packet_type_changed ,queue 
+474b df200005 arg 5 ,loopcnt 
+474c 20204952 branch hci_send_event 
+
+phci_unknown_command:
+474d 18002201 force hci_error_unknown_hci_command ,rega 
+474e 2020493d branch hci_command_status_err 
+
+phci_sniff_mode:
+474f 20404766 call phci_read_handle 
+4750 e8610000 ifetch 2 ,contru 
+4751 60014280 store 2 ,mem_sniff_param_interval 
+4752 e8610000 ifetch 2 ,contru 
+4753 6001027b store 2 ,mem_hci_sniff_min_interval 
+4754 e8610000 ifetch 2 ,contru 
+4755 60014282 store 2 ,mem_sniff_param_attempt 
+4756 e8610000 ifetch 2 ,contru 
+4757 60014284 store 2 ,mem_sniff_param_timeout 
+4758 70427212 jam hci_cmd_in_sniff ,mem_hci_cmd 
+4759 20204933 branch hci_command_status 
+
+phci_exit_sniff_mode:
+475a 20404766 call phci_read_handle 
+475b 2040475d call exit_sniff 
+475c 20204933 branch hci_command_status 
+
+exit_sniff:
+475d 70427213 jam hci_cmd_exit_sniff ,mem_hci_cmd 
+475e 20600000 rtn 
+
+phci_sniff_subrating:
+475f 20204949 branch hci_normal_reply 
+
+phci_switch_role:
+4760 20404763 call phci_read_plap 
+4761 70427218 jam hci_cmd_role_switch ,mem_hci_cmd 
+4762 20204933 branch hci_command_status 
+
+phci_read_plap:
+4763 e8630000 ifetch 6 ,contru 
+4764 60034274 store 6 ,mem_hci_plap 
+4765 20600000 rtn 
+
+phci_read_handle:
+4766 e8610000 ifetch 2 ,contru 
+4767 6000c273 store 1 ,mem_hci_conn_handle 
+4768 20600000 rtn 
+
+phci_copy_handle:
+4769 20404766 call phci_read_handle 
+476a 2040496e call hci_get_cmd_complete_ptr 
+476b 6800c273 fetch 1 ,mem_hci_conn_handle 
+476c e1410000 istore 2 ,contwu 
+476d 20600000 rtn 
+
+phci_status_reply_temp:
+476e 20404766 call phci_read_handle 
+476f 20404933 call hci_command_status 
+4770 20404970 call hci_get_payload_ptr 
+4771 18007e00 force 0 ,pdata 
+4772 e1408000 istore 1 ,contwu 
+4773 6800c273 fetch 1 ,mem_hci_conn_handle 
+4774 e1410000 istore 2 ,contwu 
+4775 20600000 rtn 
+
+phci_read_clock:
+4776 e8610000 ifetch 2 ,contru 
+4777 9c40fe00 iadd clkn_bt ,pdata 
+4778 1fe17ffc and_into 0x1fc ,pdata 
+4779 600200f4 store 4 ,mem_page_clk 
+477a 20600000 rtn 
+
+hci_inquiry_reply:
+477b 793f8025 set0 mark_ext_patch ,mark 
+477c 44f0401c bpatch patch1c_0 ,mem_patch1c 
+477d 68008274 fetch 1 ,mem_rp_packets 
+477e 1fe67c02 sub pdata ,2 ,null 
+477f 24610000 nrtn positive 
+4780 680b0182 fetcht 6 ,extm_lap 
+4781 204032fc call context_search_plap2 
+4782 20628000 rtn zero 
+4783 20404972 call hci_get_packet_ptr 
+4784 58010f22 setarg 0x10f22 
+4785 e1418000 istore 3 ,contwu 
+4786 68030182 fetch 6 ,extm_lap 
+4787 e1430000 istore 6 ,contwu 
+4788 6800817d fetch 1 ,extm_fhs_misc 
+4789 1fe20400 copy pdata ,temp 
+478a 1fe97e00 rshift3 pdata ,pdata 
+478b 1fe97e00 rshift3 pdata ,pdata 
+478c e1408000 istore 1 ,contwu 
+478d 18427e00 copy temp ,pdata 
+478e 1fe17e30 and pdata ,0x30 ,pdata 
+478f 1fe97e00 rshift3 pdata ,pdata 
+4790 1fe37e00 rshift pdata ,pdata 
+4791 e1408000 istore 1 ,contwu 
+4792 6801817f fetch 3 ,extm_class 
+4793 e1418000 istore 3 ,contwu 
+4794 6802016f fetch 4 ,mem_clke_bt 
+4795 9c467e00 isub clkn_bt ,pdata 
+4796 e1410000 istore 2 ,contwu 
+4797 580000c8 setarg 0xc8 
+4798 e1408000 istore 1 ,contwu 
+4799 1800720f force 15 ,loopcnt 
+479a 20204959 branch hci_send_event_raw 
+
+hci_inquiry_reply_eir:
+479b 793f8025 set0 mark_ext_patch ,mark 
+479c 44f0c01c bpatch patch1c_1 ,mem_patch1c 
+479d 1800041c force 540 ,temp 
+479e 68010291 fetch 2 ,mem_h5tx_free 
+479f 98467c00 isub temp ,null 
+47a0 24610000 nrtn positive 
+47a1 68098286 fetcht 3 ,mem_extm_uap_restore 
+47a2 68018185 fetch 3 ,extm_uap 
+47a3 98467c00 isub temp ,null 
+47a4 20628000 rtn zero 
+47a5 207a0000 rtn blank 
+47a6 60018286 store 3 ,mem_extm_uap_restore 
+47a7 68008274 fetch 1 ,mem_rp_packets 
+47a8 1fe67c02 sub pdata ,2 ,null 
+47a9 24610000 nrtn positive 
+47aa 680b0182 fetcht 6 ,extm_lap 
+47ab 204032fc call context_search_plap2 
+47ac 20628000 rtn zero 
+47ad 204047cc call hci_eir_reply 
+47ae 1800040f force 15 ,temp 
+47af 680084df fetch 1 ,mem_rxbuf + 1 
+47b0 c084c7c5 bne 0x09 ,hci_inquiry_reply_eir_end 
+47b1 680084de fetch 1 ,mem_rxbuf 
+47b2 203a47c5 branch hci_inquiry_reply_eir_end ,blank 
+47b3 98007200 iforce loopcnt 
+47b4 e1408000 istore 1 ,contwu 
+47b5 98408400 iadd temp ,temp 
+47b6 18408401 increase 1 ,temp 
+47b7 d8c004df arg mem_rxbuf + 1 ,contr 
+
+hci_inquiry_name_loop:
+47b8 e8c08000 ifetch 1 ,contr 
+47b9 e1408000 istore 1 ,contwu 
+47ba c20047b8 loop hci_inquiry_name_loop 
+
+hci_inquiry_other_rtn_loop:
+47bb e8c08000 ifetch 1 ,contr 
+47bc 203a47c5 branch hci_inquiry_reply_eir_end ,blank 
+47bd 98007200 iforce loopcnt 
+47be e1408000 istore 1 ,contwu 
+47bf 98408400 iadd temp ,temp 
+47c0 18408401 increase 1 ,temp 
+
+hci_inquiry_other_loop:
+47c1 e8c08000 ifetch 1 ,contr 
+47c2 e1408000 istore 1 ,contwu 
+47c3 c20047c1 loop hci_inquiry_other_loop 
+47c4 202047bb branch hci_inquiry_other_rtn_loop 
+
+hci_inquiry_reply_eir_end:
+47c5 18467eff sub temp ,0xff ,pdata 
+47c6 98007200 iforce loopcnt 
+
+hci_inquiry_fill_zero:
+47c7 58000000 setarg 0x00 
+47c8 e1408000 istore 1 ,contwu 
+47c9 c20047c7 loop hci_inquiry_fill_zero 
+47ca 180072ff force 0xff ,loopcnt 
+47cb 20204959 branch hci_send_event_raw 
+
+hci_eir_reply:
+47cc 793f8025 set0 mark_ext_patch ,mark 
+47cd 44f1401c bpatch patch1c_2 ,mem_patch1c 
+47ce 20404972 call hci_get_packet_ptr 
+47cf 5801ff2f setarg 0x1ff2f 
+47d0 e1418000 istore 3 ,contwu 
+47d1 68030182 fetch 6 ,extm_lap 
+47d2 e1430000 istore 6 ,contwu 
+47d3 6800817d fetch 1 ,extm_fhs_misc 
+47d4 1fe20400 copy pdata ,temp 
+47d5 1fe97e00 rshift3 pdata ,pdata 
+47d6 1fe97e00 rshift3 pdata ,pdata 
+47d7 e1408000 istore 1 ,contwu 
+47d8 18427e00 copy temp ,pdata 
+47d9 1fe17e30 and pdata ,0x30 ,pdata 
+47da 1fe97e00 rshift3 pdata ,pdata 
+47db 1fe37e00 rshift pdata ,pdata 
+47dc e1408000 istore 1 ,contwu 
+47dd 6801817f fetch 3 ,extm_class 
+47de e1418000 istore 3 ,contwu 
+47df 6802016f fetch 4 ,mem_clke_bt 
+47e0 9c467e00 isub clkn_bt ,pdata 
+47e1 e1410000 istore 2 ,contwu 
+47e2 580000c8 setarg 0xc8 
+47e3 e1408000 istore 1 ,contwu 
+47e4 20600000 rtn 
+
+hci_send_remote_features:
+47e5 793f8025 set0 mark_ext_patch ,mark 
+47e6 44f1c01c bpatch patch1c_3 ,mem_patch1c 
+47e7 6800c132 fetch 1 ,mem_device_option 
+47e8 c1808000 rtnne dvc_op_hci 
+47e9 20404968 call hci_write_handle3 
+47ea e14c0000 istoret 8 ,contwu 
+47eb 1800720b force 11 ,loopcnt 
+47ec 18000e0b force hci_event_read_remote_features_complete ,queue 
+47ed 20204952 branch hci_send_event 
+
+hci_send_remote_ext_features_notification:
+47ee 793f8025 set0 mark_ext_patch ,mark 
+47ef 44f2401c bpatch patch1c_4 ,mem_patch1c 
+47f0 6800c132 fetch 1 ,mem_device_option 
+47f1 c1808000 rtnne dvc_op_hci 
+47f2 20404970 call hci_get_payload_ptr 
+47f3 68030040 fetch 6 ,mem_plap 
+47f4 e1430000 istore 6 ,contwu 
+47f5 e14c0000 istoret 8 ,contwu 
+47f6 1800720e force 14 ,loopcnt 
+47f7 18000e3d force hci_event_remote_host_supported_features_notification ,queue 
+47f8 20204952 branch hci_send_event 
+
+hci_send_remote_ext_features_event:
+47f9 793f8025 set0 mark_ext_patch ,mark 
+47fa 44f2c01c bpatch patch1c_5 ,mem_patch1c 
+47fb 6800c132 fetch 1 ,mem_device_option 
+47fc c1808000 rtnne dvc_op_hci 
+47fd 20404968 call hci_write_handle3 
+47fe 68008449 fetch 1 ,mem_ext_features_page 
+47ff e1408000 istore 1 ,contwu 
+4800 58000001 setarg 1 
+4801 e1408000 istore 1 ,contwu 
+4802 e14c0000 istoret 8 ,contwu 
+4803 1800720d force 13 ,loopcnt 
+4804 18000e23 force hci_event_read_remote_ext_features_complete ,queue 
+4805 20204952 branch hci_send_event 
+
+hci_send_version_information:
+4806 793f8025 set0 mark_ext_patch ,mark 
+4807 44f3401c bpatch patch1c_6 ,mem_patch1c 
+4808 6800c132 fetch 1 ,mem_device_option 
+4809 c1808000 rtnne dvc_op_hci 
+480a 20404968 call hci_write_handle3 
+480b e14a8000 istoret 5 ,contwu 
+480c 18007208 force 8 ,loopcnt 
+480d 18000e0c force hci_event_read_remote_version_information_complete ,queue 
+480e 20204952 branch hci_send_event 
+
+hci_send_io_cap_response_event:
+480f 793f8025 set0 mark_ext_patch ,mark 
+4810 44f3c01c bpatch patch1c_7 ,mem_patch1c 
+4811 6800c132 fetch 1 ,mem_device_option 
+4812 c1808000 rtnne dvc_op_hci 
+4813 20404970 call hci_get_payload_ptr 
+4814 68030040 fetch 6 ,mem_plap 
+4815 e1430000 istore 6 ,contwu 
+4816 680187e9 fetch 3 ,mem_sp_iocap_remote 
+4817 e1418000 istore 3 ,contwu 
+4818 18007209 force 9 ,loopcnt 
+4819 18000e32 force hci_event_io_cap_response ,queue 
+481a 20204952 branch hci_send_event 
+
+hci_send_io_cap_req_event:
+481b 793f8025 set0 mark_ext_patch ,mark 
+481c 44f4401d bpatch patch1d_0 ,mem_patch1d 
+481d 6800c132 fetch 1 ,mem_device_option 
+481e c1808000 rtnne dvc_op_hci 
+481f 20404970 call hci_get_payload_ptr 
+4820 68030040 fetch 6 ,mem_plap 
+4821 e1430000 istore 6 ,contwu 
+4822 18007206 force 6 ,loopcnt 
+4823 18000e31 force hci_event_io_cap_req ,queue 
+4824 20204952 branch hci_send_event 
+
+hci_send_connection_complete:
+4825 18000400 force 0 ,temp 
+
+hci_send_connection_error:
+4826 793f8025 set0 mark_ext_patch ,mark 
+4827 44f4c01d bpatch patch1d_1 ,mem_patch1d 
+4828 6800c132 fetch 1 ,mem_device_option 
+4829 c1808000 rtnne dvc_op_hci 
+482a 18000e03 force hci_event_connection_complete ,queue 
+482b 70480005 jam 5 ,mem_acl_credits 
+482c 20404970 call hci_get_payload_ptr 
+482d e1488000 istoret 1 ,contwu 
+482e 2040496b call hci_write_handle 
+482f 20404965 call hci_write_plap 
+4830 18007e01 force 1 ,pdata 
+4831 e1408000 istore 1 ,contwu 
+4832 18007e00 force 0 ,pdata 
+4833 6808804c fetcht 1 ,mem_state_map 
+4834 284ffe02 isolate1 smap_encryption ,temp 
+4835 7920fe00 setflag true ,0 ,pdata 
+4836 e1408000 istore 1 ,contwu 
+4837 1800720b force 11 ,loopcnt 
+4838 20204952 branch hci_send_event 
+
+hci_send_conn_req_event:
+4839 793f8025 set0 mark_ext_patch ,mark 
+483a 44f5401d bpatch patch1d_2 ,mem_patch1d 
+483b 6800c132 fetch 1 ,mem_device_option 
+483c c1808000 rtnne dvc_op_hci 
+483d 18000e04 force hci_event_connection_request ,queue 
+483e 20404970 call hci_get_payload_ptr 
+483f 20404965 call hci_write_plap 
+4840 6801817f fetch 3 ,extm_class 
+4841 e1418000 istore 3 ,contwu 
+4842 e1488000 istoret 1 ,contwu 
+4843 1800720a force 10 ,loopcnt 
+4844 20204952 branch hci_send_event 
+
+hci_send_encryption_change:
+4845 793f8025 set0 mark_ext_patch ,mark 
+4846 44f5c01d bpatch patch1d_3 ,mem_patch1d 
+4847 6800c132 fetch 1 ,mem_device_option 
+4848 c1808000 rtnne dvc_op_hci 
+4849 20404968 call hci_write_handle3 
+484a 18007e00 force 0 ,pdata 
+484b 6808804c fetcht 1 ,mem_state_map 
+484c 284ffe02 isolate1 smap_encryption ,temp 
+484d 7920fe00 setflag true ,0 ,pdata 
+484e e1408000 istore 1 ,contwu 
+484f 18000e08 force hci_event_encryption_change_complete ,queue 
+4850 18007204 force 4 ,loopcnt 
+4851 20204952 branch hci_send_event 
+
+hci_send_linkkey_notification:
+4852 793f8025 set0 mark_ext_patch ,mark 
+4853 44f6401d bpatch patch1d_4 ,mem_patch1d 
+4854 6800c132 fetch 1 ,mem_device_option 
+4855 c1808000 rtnne dvc_op_hci 
+4856 18000e18 force hci_event_link_key_notification ,queue 
+4857 20404970 call hci_get_payload_ptr 
+4858 20404965 call hci_write_plap 
+4859 d8c04262 arg mem_link_key ,contr 
+485a 18007210 force 16 ,loopcnt 
+485b 20404976 call uart_copy_tx_bytes 
+485c 18007e05 force 0x05 ,pdata 
+485d e1408000 istore 1 ,contwu 
+485e 18007217 force 0x17 ,loopcnt 
+485f 20204952 branch hci_send_event 
+
+hci_send_user_confirmation_req:
+4860 6800c132 fetch 1 ,mem_device_option 
+4861 c1808000 rtnne dvc_op_hci 
+4862 18000e33 force hci_event_user_confirmation_request ,queue 
+4863 20404970 call hci_get_payload_ptr 
+4864 20404965 call hci_write_plap 
+4865 680207ec fetch 4 ,mem_sp_gkey 
+4866 e1420000 istore 4 ,contwu 
+4867 1800720a force 0xa ,loopcnt 
+4868 20204952 branch hci_send_event 
+
+hci_send_ssp_complete:
+4869 6800c132 fetch 1 ,mem_device_option 
+486a c1808000 rtnne dvc_op_hci 
+486b 18000e36 force hci_event_simple_pairing_complete ,queue 
+486c 20404970 call hci_get_payload_ptr 
+486d 58000000 setarg 0 
+486e e1408000 istore 1 ,contwu 
+486f 20404965 call hci_write_plap 
+4870 18007207 force 0x7 ,loopcnt 
+4871 20204952 branch hci_send_event 
+
+hci_send_linkkey_req:
+4872 793f8025 set0 mark_ext_patch ,mark 
+4873 44f6c01d bpatch patch1d_5 ,mem_patch1d 
+4874 18000e17 force hci_event_link_key_request ,queue 
+
+hci_send_sec_req:
+4875 6800c132 fetch 1 ,mem_device_option 
+4876 c1808000 rtnne dvc_op_hci 
+4877 20404970 call hci_get_payload_ptr 
+4878 20404965 call hci_write_plap 
+4879 18007206 force 6 ,loopcnt 
+487a 20204952 branch hci_send_event 
+
+hci_send_pincode_req:
+487b 6800c132 fetch 1 ,mem_device_option 
+487c c1808000 rtnne dvc_op_hci 
+487d 18000e16 force hci_event_pin_code_request ,queue 
+487e 20204875 branch hci_send_sec_req 
+
+hci_send_role_change:
+487f 6800c132 fetch 1 ,mem_device_option 
+4880 c1808000 rtnne dvc_op_hci 
+4881 18000e12 force hci_event_role_change ,queue 
+4882 20404970 call hci_get_payload_ptr 
+4883 18007e00 force 0 ,pdata 
+4884 e1408000 istore 1 ,contwu 
+4885 20404965 call hci_write_plap 
+4886 e1488000 istoret 1 ,contwu 
+4887 18007208 force 8 ,loopcnt 
+4888 20204952 branch hci_send_event 
+
+hci_send_role_change_err:
+4889 6800c132 fetch 1 ,mem_device_option 
+488a c1808000 rtnne dvc_op_hci 
+488b 18000400 force 0 ,temp 
+488c 2434c88e nbranch hci_send_role_change_err_slave ,master 
+488d 18000401 force 1 ,temp 
+
+hci_send_role_change_err_slave:
+488e 6800c132 fetch 1 ,mem_device_option 
+488f c1808000 rtnne dvc_op_hci 
+4890 18000e12 force hci_event_role_change ,queue 
+4891 20404970 call hci_get_payload_ptr 
+4892 18007e35 force 0x35 ,pdata 
+4893 e1408000 istore 1 ,contwu 
+4894 20404965 call hci_write_plap 
+4895 e1488000 istoret 1 ,contwu 
+4896 18007208 force 8 ,loopcnt 
+4897 20204952 branch hci_send_event 
+
+hci_send_name:
+4898 793f8025 set0 mark_ext_patch ,mark 
+4899 44f7401d bpatch patch1d_6 ,mem_patch1d 
+489a 6800c132 fetch 1 ,mem_device_option 
+489b c1808000 rtnne dvc_op_hci 
+489c 20404972 call hci_get_packet_ptr 
+489d 5800ff07 setarg 0xff07 
+489e e1410000 istore 2 ,contwu 
+489f 18e27e00 deposit queue 
+48a0 e1408000 istore 1 ,contwu 
+48a1 20404965 call hci_write_plap 
+48a2 d8c00103 arg mem_tmp_buffer ,contr 
+48a3 180072f8 force 248 ,loopcnt 
+
+hci_read_remote_name_loop:
+48a4 e8c08000 ifetch 1 ,contr 
+48a5 e1408000 istore 1 ,contwu 
+48a6 c20048a4 loop hci_read_remote_name_loop 
+48a7 180072ff force 0xff ,loopcnt 
+48a8 20204959 branch hci_send_event_raw 
+
+hci_send_num_complete_packets:
+48a9 793f8025 set0 mark_ext_patch ,mark 
+48aa 44f7c01d bpatch patch1d_7 ,mem_patch1d 
+48ab 6800c132 fetch 1 ,mem_device_option 
+48ac c1808000 rtnne dvc_op_hci 
+48ad 6810810e hfetch 1 ,core_uart_txitems 
+48ae 247a0000 nrtn blank 
+48af 6800804b fetch 1 ,mem_op 
+48b0 c4038000 rtnbit0 op_pkt_comp 
+48b1 793ffe07 set0 op_pkt_comp ,pdata 
+48b2 6000804b store 1 ,mem_op 
+48b3 20404970 call hci_get_payload_ptr 
+48b4 18007e01 force 1 ,pdata 
+48b5 e1408000 istore 1 ,contwu 
+48b6 2040496b call hci_write_handle 
+48b7 18007e01 force 1 ,pdata 
+48b8 e1410000 istore 2 ,contwu 
+48b9 18000e13 force hci_event_num_completed_packets ,queue 
+48ba 18007205 force 5 ,loopcnt 
+48bb 20204952 branch hci_send_event 
+
+hci_send_auth_complete:
+48bc 793f8025 set0 mark_ext_patch ,mark 
+48bd 44f8401e bpatch patch1e_0 ,mem_patch1e 
+48be 6800c132 fetch 1 ,mem_device_option 
+48bf c1808000 rtnne dvc_op_hci 
+48c0 20404968 call hci_write_handle3 
+48c1 18000e06 force hci_event_authentication_complete ,queue 
+48c2 18007203 force 3 ,loopcnt 
+48c3 20204952 branch hci_send_event 
+
+hci_send_disconn_complete:
+48c4 793f8025 set0 mark_ext_patch ,mark 
+48c5 44f8c01e bpatch patch1e_1 ,mem_patch1e 
+48c6 6800c132 fetch 1 ,mem_device_option 
+48c7 c1808000 rtnne dvc_op_hci 
+48c8 20404970 call hci_get_payload_ptr 
+48c9 18007e00 force 0 ,pdata 
+48ca e1408000 istore 1 ,contwu 
+48cb e1490000 istoret 2 ,contwu 
+48cc 680082c0 fetch 1 ,mem_hci_disconn_reason 
+48cd e1408000 istore 1 ,contwu 
+48ce 18000e05 force hci_event_disconnection_complete ,queue 
+48cf 18007204 force 4 ,loopcnt 
+48d0 20204952 branch hci_send_event 
+
+hci_send_le_adv_report_event:
+48d1 793f8025 set0 mark_ext_patch ,mark 
+48d2 44f9401e bpatch patch1e_2 ,mem_patch1e 
+48d3 6800c132 fetch 1 ,mem_device_option 
+48d4 c1808000 rtnne dvc_op_hci ,pdata 
+48d5 20404970 call hci_get_payload_ptr 
+48d6 58000102 setarg 0x0102 
+48d7 e1410000 istore 2 ,contwu 
+48d8 68088340 fetcht 1 ,mem_le_rxbuf 
+48d9 18417e0f and temp ,0xf ,pdata 
+48da e1408000 istore 1 ,contwu 
+48db 1a227e00 copy rega ,pdata 
+48dc e1408000 istore 1 ,contwu 
+48dd 68088341 fetcht 1 ,mem_le_rxbuf + 1 
+48de 184085fa increase -6 ,temp 
+48df 68030342 fetch 6 ,mem_le_rxbuf + 2 
+48e0 e1430000 istore 6 ,contwu 
+48e1 e1488000 istoret 1 ,contwu 
+48e2 18427200 copy temp ,loopcnt 
+48e3 20404976 call uart_copy_tx_bytes 
+48e4 5800007f setarg 127 
+48e5 e1408000 istore 1 ,contwu 
+48e6 18427200 copy temp ,loopcnt 
+48e7 1f20f20c add loopcnt ,12 ,loopcnt 
+48e8 18000e3e force hci_event_le_meta_event ,queue 
+48e9 20204952 branch hci_send_event 
+
+hci_send_le_conn_complete:
+48ea 793f8025 set0 mark_ext_patch ,mark 
+48eb 44f9c01e bpatch patch1e_3 ,mem_patch1e 
+48ec 6800c132 fetch 1 ,mem_device_option 
+48ed c1808000 rtnne dvc_op_hci ,pdata 
+48ee 20404970 call hci_get_payload_ptr 
+48ef 58000001 setarg hci_le_subevent_conn_complete 
+48f0 e1408000 istore 1 ,contwu 
+48f1 e1488000 istoret 1 ,contwu 
+48f2 680083d6 fetch 1 ,mem_le_conn_handle 
+48f3 e1410000 istore 2 ,contwu 
+48f4 680083c1 fetch 1 ,mem_le_mode 
+48f5 1fe37e00 rshift pdata ,pdata 
+48f6 79407e00 setflip 0 ,pdata 
+48f7 e1408000 istore 1 ,contwu 
+48f8 6800c4e6 fetch 1 ,mem_le_conn_peer_addr_type 
+48f9 e1408000 istore 1 ,contwu 
+48fa 680303d0 fetch 6 ,mem_le_plap 
+48fb e1430000 istore 6 ,contwu 
+48fc 680143d0 fetch 2 ,mem_le_conn_interval 
+48fd e1410000 istore 2 ,contwu 
+48fe 680103ed fetch 2 ,mem_le_slave_latency 
+48ff e1410000 istore 2 ,contwu 
+4900 680103ef fetch 2 ,mem_le_superto 
+4901 e1410000 istore 2 ,contwu 
+4902 680083f8 fetch 1 ,mem_le_peer_sca 
+4903 e1408000 istore 1 ,contwu 
+4904 18000e3e force hci_event_le_meta_event ,queue 
+4905 df200013 arg 19 ,loopcnt 
+4906 20204952 branch hci_send_event 
+
+hci_send_mode_change:
+4907 793f8025 set0 mark_ext_patch ,mark 
+4908 44fa401e bpatch patch1e_4 ,mem_patch1e 
+4909 6800c132 fetch 1 ,mem_device_option 
+490a c1808000 rtnne dvc_op_hci 
+490b 20404970 call hci_get_payload_ptr 
+490c 20404968 call hci_write_handle3 
+490d e1488000 istoret 1 ,contwu 
+490e 68010032 fetch 2 ,mem_tsniff 
+490f 1fe37e00 rshift pdata ,pdata 
+4910 e1410000 istore 2 ,contwu 
+4911 18007206 force 6 ,loopcnt 
+4912 18000e14 force hci_event_mode_change ,queue 
+4913 20204952 branch hci_send_event 
+
+hci_send_sco_complete:
+4914 793f8025 set0 mark_ext_patch ,mark 
+4915 44fac01e bpatch patch1e_5 ,mem_patch1e 
+4916 6800c132 fetch 1 ,mem_device_option 
+4917 c1808000 rtnne dvc_op_hci 
+4918 793f8025 set0 mark_ext_patch ,mark 
+4919 44fb401e bpatch patch1e_6 ,mem_patch1e 
+491a 20404970 call hci_get_payload_ptr 
+491b e1488000 istoret 1 ,contwu 
+491c 58000e00 setarg 0xe00 
+491d e1410000 istore 2 ,contwu 
+491e 20404965 call hci_write_plap 
+491f 18007e00 force 0 ,pdata 
+4920 c503c924 bmark1 mark_esco ,hci_send_esco 
+4921 18007e00 force 0 ,pdata 
+4922 e1438000 istore 7 ,contwu 
+4923 2020492c branch hci_send_sco_cont 
+
+hci_send_esco:
+4924 6800c132 fetch 1 ,mem_device_option 
+4925 c1808000 rtnne dvc_op_hci 
+4926 58020602 setarg 0x020602 
+4927 e1418000 istore 3 ,contwu 
+4928 5800001e setarg 30 
+4929 e1410000 istore 2 ,contwu 
+492a 5800001e setarg 30 
+492b e1410000 istore 2 ,contwu 
+
+hci_send_sco_cont:
+492c 6800c132 fetch 1 ,mem_device_option 
+492d c1808000 rtnne dvc_op_hci 
+492e 680080ab fetch 1 ,mem_air_mode 
+492f e1408000 istore 1 ,contwu 
+4930 18000e2c force hci_event_sco_connection_complete ,queue 
+4931 18007211 force 17 ,loopcnt 
+4932 20204952 branch hci_send_event 
+
+hci_command_status:
+4933 793f8025 set0 mark_ext_patch ,mark 
+4934 44fbc01e bpatch patch1e_7 ,mem_patch1e 
+4935 20404970 call hci_get_payload_ptr 
+4936 58000100 setarg 0x100 
+4937 e1410000 istore 2 ,contwu 
+4938 1e027e00 deposit alarm 
+4939 e1410000 istore 2 ,contwu 
+493a 18007204 force 4 ,loopcnt 
+493b 18000e0f force hci_event_command_status ,queue 
+493c 20204952 branch hci_send_event 
+
+hci_command_status_err:
+493d 793f8025 set0 mark_ext_patch ,mark 
+493e 44fc401f bpatch patch1f_0 ,mem_patch1f 
+493f 20404970 call hci_get_payload_ptr 
+4940 1a227e00 deposit rega 
+4941 e1408000 istore 1 ,contwu 
+4942 58000001 setarg 0x01 
+4943 e1408000 istore 1 ,contwu 
+4944 1e027e00 deposit alarm 
+4945 e1410000 istore 2 ,contwu 
+4946 18007204 force 4 ,loopcnt 
+4947 18000e0f force hci_event_command_status ,queue 
+4948 20204952 branch hci_send_event 
+
+hci_normal_reply:
+4949 793f8025 set0 mark_ext_patch ,mark 
+494a 44fcc01f bpatch patch1f_1 ,mem_patch1f 
+494b 18007204 force 4 ,loopcnt 
+
+hci_command_complete:
+494c 20404970 call hci_get_payload_ptr 
+494d 18007e01 force 0x1 ,pdata 
+494e e1408000 istore 1 ,contwu 
+494f 1e027e00 deposit alarm 
+4950 e1418000 istore 3 ,contwu 
+4951 18000e0e force hci_event_command_complete ,queue 
+
+hci_send_event:
+4952 793f8025 set0 mark_ext_patch ,mark 
+4953 44fd401f bpatch patch1f_2 ,mem_patch1f 
+4954 20404972 call hci_get_packet_ptr 
+4955 18e27e00 deposit queue 
+4956 e1408000 istore 1 ,contwu 
+4957 1f227e00 deposit loopcnt 
+4958 e1408000 istore 1 ,contwu 
+
+hci_send_event_raw:
+4959 79200013 set1 mark_h5tx_rp ,mark 
+495a 18000e05 force 5 ,queue 
+495b 1f20f202 increase 2 ,loopcnt 
+
+hci_send_packet:
+495c 20404494 call hci_check_bcsp_protocol 
+495d 2020c378 branch bcsp_send_packet ,true 
+495e 20204422 branch h4_send_packet_event 
+
+hci_send_commu_ready_event:
+495f 18000eff force hci_event_vendor_specific ,queue 
+4960 20404970 call hci_get_payload_ptr 
+4961 58000001 setarg hci_vendor_event_commu_ready 
+4962 e1408000 istore 1 ,contwu 
+4963 18007201 force 1 ,loopcnt 
+4964 20204952 branch hci_send_event 
+
+hci_write_plap:
+4965 68030040 fetch 6 ,mem_plap 
+4966 e1430000 istore 6 ,contwu 
+4967 20600000 rtn 
+
+hci_write_handle3:
+4968 20404970 call hci_get_payload_ptr 
+4969 18007e00 force 0 ,pdata 
+496a e1408000 istore 1 ,contwu 
+
+hci_write_handle:
+496b 68008046 fetch 1 ,mem_conn_handle 
+496c e1410000 istore 2 ,contwu 
+496d 20600000 rtn 
+
+hci_get_cmd_complete_ptr:
+496e 1800140c force 12 ,contwu 
+496f 20204973 branch hci_get_tx_ptr 
+
+hci_get_payload_ptr:
+4970 18001408 force 8 ,contwu 
+4971 20204973 branch hci_get_tx_ptr 
+
+hci_get_packet_ptr:
+4972 18001406 force 6 ,contwu 
+
+hci_get_tx_ptr:
+4973 20404494 call hci_check_bcsp_protocol 
+4974 2020c3de branch bcsp_get_tx_ptr ,true 
+4975 2020441e branch h4_get_tx_ptr 
+
+uart_copy_tx_bytes:
+4976 1f227e00 deposit loopcnt 
+4977 207a0000 rtn blank 
+
+uart_copy_tx_bytes_loop:
+4978 e8c08000 ifetch 1 ,contr 
+4979 e1408000 istore 1 ,contwu 
+497a c2004978 loop uart_copy_tx_bytes_loop 
+497b 20600000 rtn 
+
+uart_copy_rx_bytes:
+497c 1f227e00 deposit loopcnt 
+497d 207a0000 rtn blank 
+
+uart_copy_rx_bytes_loop:
+497e e8608000 ifetch 1 ,contru 
+497f e0a08000 istore 1 ,contw 
+4980 c200497e loop uart_copy_rx_bytes_loop 
+4981 20600000 rtn 
+
+uart_write_bytes:
+4982 e1408000 istore 1 ,contwu 
+4983 1fecfe00 rshift8 pdata ,pdata 
+4984 c2004982 loop uart_write_bytes 
+4985 20600000 rtn 
+
+calc_tx_crc16:
+4986 7827fc00 pulse crc16 
+4987 7824fc00 enable enable_crc 
+
+crcloop:
+4988 e9408000 ifetch 1 ,contwu 
+4989 08008008 inject bucket ,8 
+498a c2004988 loop crcloop 
+498b 78247c00 enable enable_parity 
+498c 08008010 inject bucket ,16 
+498d 78447c00 disable enable_parity 
+498e 7844fc00 disable enable_crc 
+498f 7847fc00 disable crc16 
+4990 1ff0fe00 byteswap pdata ,pdata 
+4991 20600000 rtn 
+
+stop_loop:
+4992 20000001 nop 1 
+4993 70820301 hjam 1 ,0x8203 
+4994 20204992 branch stop_loop 
+
+process_cmd:
+4995 793f8025 set0 mark_ext_patch ,mark 
+4996 44fdc01f bpatch patch1f_3 ,mem_patch1f 
+4997 6800c272 fetch 1 ,mem_hci_cmd 
+4998 207a0000 rtn blank 
+4999 6800807c fetch 1 ,mem_lmo_opcode2 
+499a 247a0000 nrtn blank 
+499b 204049be call cmd_check_plap 
+499c 2422c9aa nbranch process_cmd_conn_handle ,zero 
+499d 6800c272 fetch 1 ,mem_hci_cmd 
+499e c001c9d4 beq hci_cmd_remote_name_req ,cmd_namereq 
+499f c004c9da beq hci_cmd_pair ,cmd_pair 
+49a0 c00549e6 beq hci_cmd_nopair ,cmd_nopair 
+49a1 c005c9ed beq hci_cmd_linkkey ,cmd_has_key 
+49a2 c00649f7 beq hci_cmd_nokey ,cmd_no_key 
+49a3 c0044a32 beq hci_cmd_reject_conn ,cmd_disconn 
+49a4 c00c49cc beq hci_cmd_role_switch ,cmd_role_switch 
+49a5 c003c9c6 beq hci_cmd_accept_conn ,cmd_accept_conn 
+49a6 c00cc9ca beq hci_cmd_accept_with_switch ,cmd_accept_with_switch 
+49a7 c00d4a53 beq hci_cmd_detach ,cmd_detach 
+49a8 c0094a19 beq hci_cmd_in_sniff ,cmd_in_sniff 
+49a9 c009ca28 beq hci_cmd_exit_sniff ,cmd_exit_sniff 
+
+process_cmd_conn_handle:
+49aa 793f8025 set0 mark_ext_patch ,mark 
+49ab 44fe401f bpatch patch1f_4 ,mem_patch1f 
+49ac 204049c2 call cmd_check_handle 
+49ad 247a0000 nrtn blank 
+49ae 6800c272 fetch 1 ,mem_hci_cmd 
+49af c006ca01 beq hci_cmd_auth ,cmd_auth 
+49b0 c007ca0b beq hci_cmd_startencrypt ,cmd_start_encrypt 
+49b1 c0074a0d beq hci_cmd_stopencrypt ,cmd_stop_encrypt 
+49b2 c0084a2a beq hci_cmd_setup_sco ,cmd_setup_sco 
+49b3 c008ca34 beq hci_cmd_disconn_sco ,cmd_disconn_sco 
+49b4 c00e4a38 beq hci_cmd_accept_sco_conn ,cmd_accept_sco_conn 
+49b5 c0024a0f beq hci_cmd_remote_feature_req ,cmd_feature_req 
+49b6 c00aca14 beq hci_cmd_remote_ext_features_req ,cmd_ext_feature_req 
+49b7 c00a4a17 beq hci_cmd_remote_version_req ,cmd_version_req 
+49b8 c00bca48 beq hci_cmd_role_discovery ,cmd_role_discovery 
+49b9 c00b4a51 beq hci_cmd_io_cap ,cmd_io_cap 
+49ba c1830000 rtnne hci_cmd_disconn 
+49bb 20405ed5 call lmp_disconnect 
+
+cmd_exit:
+49bc 70427200 jam 0 ,mem_hci_cmd 
+49bd 20600000 rtn 
+
+cmd_check_plap:
+49be 68034274 fetch 6 ,mem_hci_plap 
+49bf 680b0040 fetcht 6 ,mem_plap 
+49c0 98467c00 isub temp ,null 
+49c1 20600000 rtn 
+
+cmd_check_handle:
+49c2 6800c273 fetch 1 ,mem_hci_conn_handle 
+49c3 68088046 fetcht 1 ,mem_conn_handle 
+49c4 98467e00 isub temp ,pdata 
+49c5 20600000 rtn 
+
+cmd_accept_conn:
+49c6 70007c03 jam lmp_accepted ,mem_lmo_opcode2 
+49c7 70007d33 jam lmp_host_connection_req ,mem_lmi_opcode2 
+49c8 20406212 call tid_set_reply 
+49c9 202049bc branch cmd_exit 
+
+cmd_accept_with_switch:
+49ca 2034ca38 branch cmd_accept_sco_conn ,master 
+49cb 79200004 set1 mark_accept_switch ,mark 
+
+cmd_role_switch:
+49cc 70007c34 jam lmp_slot_offset ,mem_lmo_opcode2 
+49cd 79200003 set1 mark_switch_initiated ,mark 
+49ce 2434c9bc nbranch cmd_exit ,master 
+49cf 70007c13 jam lmp_switch_req ,mem_lmo_opcode2 
+49d0 68008177 fetch 1 ,mem_connection_options 
+49d1 793ffe02 set0 connection_switch ,pdata 
+49d2 60008177 store 1 ,mem_connection_options 
+49d3 202049bc branch cmd_exit 
+
+cmd_namereq:
+49d4 70007c01 jam lmp_name_req ,mem_lmo_opcode2 
+49d5 70005300 jam 0 ,mem_name_offset 
+49d6 202049bc branch cmd_exit 
+
+cmd_ssp:
+49d7 7007dd01 jam sp_flag_commit ,mem_master_sp_flag 
+49d8 7007db12 jam sp_master_stat_start_skip ,mem_master_sp_state 
+49d9 202049bc branch cmd_exit 
+
+cmd_pair:
+49da 6800804b fetch 1 ,mem_op 
+49db c28149df bbit1 op_inrand_req ,cmd_pair_passive 
+49dc 20406209 call tid_initiate 
+49dd 70007c08 jam lmp_in_rand ,mem_lmo_opcode2 
+49de 202049bc branch cmd_exit 
+
+cmd_pair_passive:
+49df 793ffe02 set0 op_inrand_req ,pdata 
+49e0 6000804b store 1 ,mem_op 
+49e1 20405ed0 call lmp_accept_inrand 
+49e2 58000000 setarg 0 
+49e3 7934fe01 setflag master ,smap_lmptid ,pdata 
+49e4 6000807f store 1 ,mem_lmo_tid2 
+49e5 202049bc branch cmd_exit 
+
+cmd_nopair:
+49e6 70044618 jam pairing_not_allowed ,mem_disconn_reason_send 
+49e7 70007c07 jam lmp_detach ,mem_lmo_opcode2 
+49e8 68008030 fetch 1 ,mem_state 
+49e9 c28049bc bbit1 state_inconn ,cmd_exit 
+49ea 18000418 force hci_error_pairing_not_allowed ,temp 
+49eb 20404826 call hci_send_connection_error 
+49ec 202049bc branch cmd_exit 
+
+cmd_has_key:
+49ed 2040321f call linkkey_set 
+49ee 6800804b fetch 1 ,mem_op 
+49ef c280ca08 bbit1 op_auth_req ,cmd_send_aurand 
+49f0 c28049f3 bbit1 op_send_sres ,cmd_send_sres 
+49f1 c28149df bbit1 op_inrand_req ,cmd_pair_passive 
+49f2 202049bc branch cmd_exit 
+
+cmd_send_sres:
+49f3 793ffe00 set0 op_send_sres ,pdata 
+49f4 6000804b store 1 ,mem_op 
+49f5 70007c0c jam lmp_sres ,mem_lmo_opcode2 
+49f6 202049bc branch cmd_exit 
+
+cmd_no_key:
+49f7 6800804b fetch 1 ,mem_op 
+49f8 c28049fb bbit1 op_send_sres ,cmd_no_key_reject 
+49f9 2040487b call hci_send_pincode_req 
+49fa 202049bc branch cmd_exit 
+
+cmd_no_key_reject:
+49fb 793ffe00 set0 op_send_sres ,pdata 
+49fc 6000804b store 1 ,mem_op 
+49fd 70007c04 jam lmp_not_accepted ,mem_lmo_opcode2 
+49fe 70007d0b jam lmp_au_rand ,mem_lmi_opcode2 
+49ff 70007e06 jam key_missing ,mem_lmo_reason2 
+4a00 202049bc branch cmd_exit 
+
+cmd_auth:
+4a01 6800804b fetch 1 ,mem_op 
+4a02 79207e01 set1 op_auth_req ,pdata 
+4a03 6000804b store 1 ,mem_op 
+4a04 68008030 fetch 1 ,mem_state 
+4a05 c283ca08 bbit1 state_linkkey ,cmd_auth_sendaurand 
+4a06 20404872 call hci_send_linkkey_req 
+4a07 202049bc branch cmd_exit 
+
+cmd_send_aurand:
+
+cmd_auth_sendaurand:
+4a08 20406209 call tid_initiate 
+4a09 70007c0b jam lmp_au_rand ,mem_lmo_opcode2 
+4a0a 202049bc branch cmd_exit 
+
+cmd_start_encrypt:
+4a0b 70007c0f jam lmp_encryption_mode_req ,mem_lmo_opcode2 
+4a0c 202049bc branch cmd_exit 
+
+cmd_stop_encrypt:
+4a0d 70007c0f jam lmp_encryption_mode_req ,mem_lmo_opcode2 
+4a0e 202049bc branch cmd_exit 
+
+cmd_feature_req:
+4a0f 793f8025 set0 mark_ext_patch ,mark 
+4a10 44fec01f bpatch patch1f_5 ,mem_patch1f 
+4a11 70007c27 jam lmp_features_req ,mem_lmo_opcode2 
+4a12 70427250 jam hci_cmd_wait_remote_feature ,mem_hci_cmd 
+4a13 20600000 rtn 
+
+cmd_ext_feature_req:
+4a14 70007c83 jam lmp_ext_features_req ,mem_lmo_opcode2 
+4a15 70427251 jam hci_cmd_wait_remote_ext_feature ,mem_hci_cmd 
+4a16 20600000 rtn 
+
+cmd_version_req:
+4a17 70007c25 jam lmp_version_req ,mem_lmo_opcode2 
+4a18 202049bc branch cmd_exit 
+
+cmd_in_sniff:
+4a19 70007c17 jam lmp_sniff_req ,mem_lmo_opcode2 
+4a1a d8a00455 arg mem_sniff_payload ,contw 
+4a1b 58000000 setarg 0 
+4a1c 2d0ffe1b isolate1 27 ,clke_bt 
+4a1d 7920fe01 setflag true ,1 ,pdata 
+4a1e e0a08000 istore 1 ,contw 
+4a1f 58000000 setarg 0 
+4a20 e0a10000 istore 2 ,contw 
+4a21 68014280 fetch 2 ,mem_sniff_param_interval 
+4a22 e0a10000 istore 2 ,contw 
+4a23 6800c282 fetch 1 ,mem_sniff_param_attempt 
+4a24 e0a10000 istore 2 ,contw 
+4a25 6800c284 fetch 1 ,mem_sniff_param_timeout 
+4a26 e0a10000 istore 2 ,contw 
+4a27 202049bc branch cmd_exit 
+
+cmd_exit_sniff:
+4a28 70007c18 jam lmp_unsniff_req ,mem_lmo_opcode2 
+4a29 202049bc branch cmd_exit 
+
+cmd_setup_sco:
+4a2a 20403512 call new_conn_handle 
+4a2b 600080ad store 1 ,mem_sco_handle 
+4a2c 68008046 fetch 1 ,mem_conn_handle 
+4a2d 600080ac store 1 ,mem_sco_asso_handle 
+4a2e 70007c2b jam lmp_sco_link_req ,mem_lmo_opcode2 
+4a2f 79200007 set1 mark_esco ,mark 
+4a30 70007c8c jam lmp_ext_esco_link_req ,mem_lmo_opcode2 
+4a31 202049bc branch cmd_exit 
+
+cmd_disconn:
+4a32 20405ed5 call lmp_disconnect 
+4a33 202049bc branch cmd_exit 
+
+cmd_disconn_sco:
+4a34 70007c2c jam lmp_remove_sco_link_req ,mem_lmo_opcode2 
+4a35 c583c9bc bmark0 mark_esco ,cmd_exit 
+4a36 70007c8d jam lmp_ext_remove_esco_req ,mem_lmo_opcode2 
+4a37 202049bc branch cmd_exit 
+
+cmd_accept_sco_conn:
+4a38 2034ca41 branch cmd_accept_sco_conn_master ,master 
+4a39 70007c03 jam lmp_accepted ,mem_lmo_opcode2 
+4a3a 70007d2b jam lmp_sco_link_req ,mem_lmi_opcode2 
+4a3b c583c9bc bmark0 mark_esco ,cmd_exit 
+4a3c 680080b0 fetch 1 ,mem_esco_type 
+4a3d c083dc04 bne type_hv3 ,parse_lmpext_esco_link_req_change_param 
+4a3e 70007c81 jam lmp_ext_accepted ,mem_lmo_opcode2 
+4a3f 70007d8c jam lmp_ext_esco_link_req ,mem_lmi_opcode2 
+4a40 202049bc branch cmd_exit 
+
+cmd_accept_sco_conn_master:
+4a41 20403512 call new_conn_handle 
+4a42 600080ad store 1 ,mem_sco_handle 
+4a43 68008046 fetch 1 ,mem_conn_handle 
+4a44 600080ac store 1 ,mem_sco_asso_handle 
+4a45 70007c2b jam lmp_sco_link_req ,mem_lmo_opcode2 
+4a46 c583c9bc bmark0 mark_esco ,cmd_exit 
+4a47 20205c04 branch parse_lmpext_esco_link_req_change_param 
+
+cmd_role_discovery:
+4a48 2040496e call hci_get_cmd_complete_ptr 
+4a49 2040496b call hci_write_handle 
+4a4a 18007e00 force 0 ,pdata 
+4a4b 7d34fe00 nsetflag master ,0 ,pdata 
+4a4c e1408000 istore 1 ,contwu 
+4a4d 18007207 force 7 ,loopcnt 
+4a4e de000809 arg 0x809 ,alarm 
+4a4f 2040494c call hci_command_complete 
+4a50 202049bc branch cmd_exit 
+
+cmd_io_cap:
+4a51 70007c9a jam lmp_io_cap_res ,mem_lmo_opcode2 
+4a52 202049bc branch cmd_exit 
+
+cmd_detach:
+4a53 70007c07 jam lmp_detach ,mem_lmo_opcode2 
+4a54 70044613 jam other_end_terminated ,mem_disconn_reason_send 
+4a55 202049bc branch cmd_exit 
+
+process_hci_patch:
+4a56 7002bc00 jam 0 ,mem_check_sum 
+4a57 e8608000 ifetch 1 ,contru 
+4a58 600082bb store 1 ,mem_ucode_id_remote 
+4a59 20404a6d call hci_ucode_checksum_add 
+4a5a 20407e00 call push_stack 
+4a5b 680082bb fetch 1 ,mem_ucode_id_remote 
+4a5c 1fe20400 copy pdata ,temp 
+4a5d 6800829f fetch 1 ,mem_ucode_id_local 
+4a5e 1fe0fe01 increase 1 ,pdata 
+4a5f a841fe00 icompare 0xff ,temp 
+4a60 2420ca77 nbranch hci_nak_ucode_with_stack ,true 
+4a61 6000829f store 1 ,mem_ucode_id_local 
+4a62 20407e0e call pop_stack 
+4a63 e8608000 ifetch 1 ,contru 
+4a64 c000cad8 beq 0x01 ,hci_enable_ucode_load 
+4a65 c0014aae beq 0x02 ,process_hci_ucode 
+4a66 c001cadf beq 0x03 ,hci_disable_ucode_load 
+4a67 c002cac3 beq 0x05 ,process_hci_n_sched_data 
+4a68 c0034a80 beq 0x06 ,hci_write_register 
+4a69 c003ca91 beq 0x07 ,hci_read_register 
+4a6a c0044aa8 beq 0x08 ,hci_enable_ucode 
+4a6b c004cae6 beq 0x09 ,hci_soft_branch 
+4a6c 20600000 rtn 
+
+hci_ucode_checksum_add:
+4a6d 1fe20400 copy pdata ,temp 
+4a6e 20407e00 call push_stack 
+4a6f 680082bc fetch 1 ,mem_check_sum 
+4a70 9840fe00 iadd temp ,pdata 
+4a71 600082bc store 1 ,mem_check_sum 
+4a72 20207e0e branch pop_stack 
+
+hci_ack_ucode:
+4a73 18007e01 force 1 ,pdata 
+4a74 204044b5 call uart_send_byte 
+4a75 6800829f fetch 1 ,mem_ucode_id_local 
+4a76 202044b5 branch uart_send_byte 
+
+hci_nak_ucode_with_stack:
+4a77 20407e0e call pop_stack 
+4a78 20204a7c branch hci_nak_ucode_ucode_id 
+
+hci_nak_ucode:
+4a79 6800829f fetch 1 ,mem_ucode_id_local 
+4a7a 1fe0ffff increase -1 ,pdata 
+4a7b 6000829f store 1 ,mem_ucode_id_local 
+
+hci_nak_ucode_ucode_id:
+4a7c 18007e00 force 0 ,pdata 
+4a7d 204044b5 call uart_send_byte 
+4a7e 6800829f fetch 1 ,mem_ucode_id_local 
+4a7f 202044b5 branch uart_send_byte 
+
+hci_write_register:
+4a80 20404a6d call hci_ucode_checksum_add 
+4a81 e8608000 ifetch 1 ,contru 
+4a82 600082bd store 1 ,mem_ucode_temp 
+4a83 20404a6d call hci_ucode_checksum_add 
+4a84 e8608000 ifetch 1 ,contru 
+4a85 1fed0a00 lshift8 pdata ,contw 
+4a86 20404a6d call hci_ucode_checksum_add 
+4a87 680082bd fetch 1 ,mem_ucode_temp 
+4a88 98a08a00 iadd contw ,contw 
+4a89 e8608000 ifetch 1 ,contru 
+4a8a e0a08000 istore 1 ,contw 
+4a8b 20404a6d call hci_ucode_checksum_add 
+4a8c e8608000 ifetch 1 ,contru 
+4a8d 20404a6d call hci_ucode_checksum_add 
+4a8e 680082bc fetch 1 ,mem_check_sum 
+4a8f c0ffca79 bne 0xff ,hci_nak_ucode 
+4a90 20204a73 branch hci_ack_ucode 
+
+hci_read_register:
+4a91 20404a6d call hci_ucode_checksum_add 
+4a92 e8608000 ifetch 1 ,contru 
+4a93 600082bd store 1 ,mem_ucode_temp 
+4a94 20404a6d call hci_ucode_checksum_add 
+4a95 e8608000 ifetch 1 ,contru 
+4a96 600082be store 1 ,mem_ucode_temp1 
+4a97 20404a6d call hci_ucode_checksum_add 
+4a98 e8608000 ifetch 1 ,contru 
+4a99 20404a6d call hci_ucode_checksum_add 
+4a9a 680082bc fetch 1 ,mem_check_sum 
+4a9b c0ffca79 bne 0xff ,hci_nak_ucode 
+4a9c 680082be fetch 1 ,mem_ucode_temp1 
+4a9d 1fed0400 lshift8 pdata ,temp 
+4a9e 680082bd fetch 1 ,mem_ucode_temp 
+4a9f 98408600 iadd temp ,contru 
+4aa0 e8608000 ifetch 1 ,contru 
+4aa1 600082bd store 1 ,mem_ucode_temp 
+
+hci_read_register_ack:
+4aa2 18007e01 force 1 ,pdata 
+4aa3 204044b5 call uart_send_byte 
+4aa4 680082bd fetch 1 ,mem_ucode_temp 
+4aa5 204044b5 call uart_send_byte 
+4aa6 70029fff jam 0xff ,mem_ucode_id_local 
+4aa7 20600000 rtn 
+
+hci_enable_ucode:
+4aa8 20404a6d call hci_ucode_checksum_add 
+4aa9 e8608000 ifetch 1 ,contru 
+4aaa 20404a6d call hci_ucode_checksum_add 
+4aab 680082bc fetch 1 ,mem_check_sum 
+4aac c0ffca79 bne 0xff ,hci_nak_ucode 
+4aad 20204a73 branch hci_ack_ucode 
+
+process_hci_ucode:
+4aae 20404a6d call hci_ucode_checksum_add 
+4aaf e8608000 ifetch 1 ,contru 
+4ab0 60108024 hstore 1 ,core_ucode_low 
+4ab1 20404a6d call hci_ucode_checksum_add 
+4ab2 e8608000 ifetch 1 ,contru 
+4ab3 79207e07 set1 7 ,pdata 
+4ab4 60108023 hstore 1 ,core_ucode_ctrl 
+4ab5 793ffe07 set0 7 ,pdata 
+4ab6 20404a6d call hci_ucode_checksum_add 
+4ab7 e8608000 ifetch 1 ,contru 
+4ab8 1fe27200 copy pdata ,loopcnt 
+4ab9 20404a6d call hci_ucode_checksum_add 
+
+write_ucode_loop:
+4aba e8608000 ifetch 1 ,contru 
+4abb 60108025 hstore 1 ,core_ucode_data 
+4abc 20404a6d call hci_ucode_checksum_add 
+4abd c2004aba loop write_ucode_loop 
+4abe e8608000 ifetch 1 ,contru 
+4abf 20404a6d call hci_ucode_checksum_add 
+4ac0 680082bc fetch 1 ,mem_check_sum 
+4ac1 c0ffca79 bne 0xff ,hci_nak_ucode 
+4ac2 20204a73 branch hci_ack_ucode 
+
+process_hci_n_sched_data:
+4ac3 20404a6d call hci_ucode_checksum_add 
+4ac4 e8608000 ifetch 1 ,contru 
+4ac5 600082bd store 1 ,mem_ucode_temp 
+4ac6 20404a6d call hci_ucode_checksum_add 
+4ac7 e8608000 ifetch 1 ,contru 
+4ac8 1fed0a00 lshift8 pdata ,contw 
+4ac9 20404a6d call hci_ucode_checksum_add 
+4aca 680082bd fetch 1 ,mem_ucode_temp 
+4acb 98a08a00 iadd contw ,contw 
+4acc e8608000 ifetch 1 ,contru 
+4acd 98007200 iforce loopcnt 
+4ace 20404a6d call hci_ucode_checksum_add 
+
+process_hci_n_sched_loop:
+4acf e8608000 ifetch 1 ,contru 
+4ad0 e0a08000 istore 1 ,contw 
+4ad1 20404a6d call hci_ucode_checksum_add 
+4ad2 c2004acf loop process_hci_n_sched_loop 
+4ad3 e8608000 ifetch 1 ,contru 
+4ad4 20404a6d call hci_ucode_checksum_add 
+4ad5 680082bc fetch 1 ,mem_check_sum 
+4ad6 c0ffca79 bne 0xff ,hci_nak_ucode 
+4ad7 20204a73 branch hci_ack_ucode 
+
+hci_enable_ucode_load:
+4ad8 20404a6d call hci_ucode_checksum_add 
+4ad9 e8608000 ifetch 1 ,contru 
+4ada 20404a6d call hci_ucode_checksum_add 
+4adb 680082bc fetch 1 ,mem_check_sum 
+4adc c0ffca79 bne 0xff ,hci_nak_ucode 
+4add 70802380 hjam 0x80 ,core_ucode_ctrl 
+4ade 20204a73 branch hci_ack_ucode 
+
+hci_disable_ucode_load:
+4adf 20404a6d call hci_ucode_checksum_add 
+4ae0 e8608000 ifetch 1 ,contru 
+4ae1 20404a6d call hci_ucode_checksum_add 
+4ae2 680082bc fetch 1 ,mem_check_sum 
+4ae3 c0ffca79 bne 0xff ,hci_nak_ucode 
+4ae4 70802300 hjam 0 ,core_ucode_ctrl 
+4ae5 20204a73 branch hci_ack_ucode 
+
+hci_soft_branch:
+4ae6 20404a6d call hci_ucode_checksum_add 
+4ae7 e8608000 ifetch 1 ,contru 
+4ae8 20404a6d call hci_ucode_checksum_add 
+4ae9 680082bc fetch 1 ,mem_check_sum 
+4aea c0ffca79 bne 0xff ,hci_nak_ucode 
+4aeb 20404a73 call hci_ack_ucode 
+4aec 20203001 branch soft_reset 
+
+hci_idle_dispatch:
+4aed 20406a8b call gpio_check_uart_state 
+4aee 20608000 rtn true 
+4aef d8400007 arg uart_wakeup_rx ,temp 
+4af0 204069e5 call gpio_get_bit 
+4af1 2420caf4 nbranch uart_wake_up ,true 
+4af2 7042ae01 jam hci_rx_wake ,mem_hci_lt_rx_state 
+4af3 20600000 rtn 
+
+uart_wake_up:
+4af4 6800c2ae fetch 1 ,mem_hci_lt_rx_state 
+4af5 c1808000 rtnne hci_rx_wake 
+4af6 20404599 call hci_exit_lpm 
+4af7 2020495f branch hci_send_commu_ready_event 
+
+hid_rx_process:
+4af8 79200025 set1 mark_ext_patch ,mark 
+4af9 44ce4033 bpatch patch33_4 ,mem_patch33 
+4afa 680102cb fetch 2 ,mem_l2cap_payload_ptr 
+4afb 1fe20c00 copy pdata ,contr 
+4afc e8c08000 ifetch 1 ,contr 
+4afd 1fe1040f and pdata ,0x0f ,temp 
+4afe 1ff1fe00 rshift4 pdata ,pdata 
+4aff c004cb18 beq hid_type_set_idle ,hid_rx_process_handshake 
+4b00 c003cb18 beq hid_type_set_protocol ,hid_rx_process_handshake 
+4b01 c0054b24 beq hid_type_data ,hid_rx_process_data 
+4b02 c002cb11 beq hid_type_set_report ,hid_rx_process_set_report 
+4b03 c000cb05 beq hid_type_control ,hid_rx_process_hid_control 
+4b04 20600000 rtn 
+
+hid_rx_process_hid_control:
+4b05 18427e00 copy temp ,pdata 
+4b06 c002cb09 beq hid_control_p_virtualcableunplug ,hid_rx_process_virtual_cable_unplug 
+4b07 c001cb10 beq hid_control_p_suspend ,hid_rx_process_suspend 
+4b08 20600000 rtn 
+
+hid_rx_process_virtual_cable_unplug:
+4b09 700b7d27 jam bt_evt_virtual_cable_unplug ,mem_fifo_temp 
+4b0a 20407c27 call ui_ipc_send_event 
+4b0b 6800c132 fetch 1 ,mem_device_option 
+4b0c c1830000 rtnne dvc_op_mouse ,pdata 
+4b0d 18427e00 copy temp ,pdata 
+4b0e c002e946 beq hid_control_p_virtualcableunplug ,eeprom_erase_reconn_info 
+4b0f 20600000 rtn 
+
+hid_rx_process_suspend:
+4b10 20600000 rtn 
+
+hid_rx_process_set_report:
+4b11 da200001 arg 0x01 ,rega 
+4b12 20404b2c call hid_malloc_tx_buff 
+4b13 680142b5 fetch 2 ,mem_hid_ctrl_remote_cid 
+4b14 e0a10000 istore 2 ,contw 
+4b15 58000000 setarg 0x00 
+4b16 e0a08000 istore 1 ,contw 
+4b17 20600000 rtn 
+
+hid_rx_process_handshake:
+4b18 da200001 arg 1 ,rega 
+4b19 20404b2c call hid_malloc_tx_buff 
+4b1a 680142b5 fetch 2 ,mem_hid_ctrl_remote_cid 
+4b1b e0a10000 istore 2 ,contw 
+4b1c 58000000 setarg 0 
+4b1d e0a08000 istore 1 ,contw 
+4b1e 7008a801 jam 1 ,mem_ui_data_txbuff_length 
+4b1f 6800c2bb fetch 1 ,mem_hid_control_state 
+4b20 79207e06 set1 l2cap_channel_hid_handshake_done 
+4b21 6000c2bb store 1 ,mem_hid_control_state 
+
+hid_handshake_event:
+4b22 700b7d12 jam bt_evt_hid_handshake ,mem_fifo_temp 
+4b23 20207c27 branch ui_ipc_send_event 
+
+hid_rx_process_data:
+4b24 e8c08000 ifetch 1 ,contr 
+4b25 c000cb27 beq hid_report_id_kb ,hid_rx_process_data_hid_kb 
+4b26 20600000 rtn 
+
+hid_rx_process_data_hid_kb:
+4b27 18c22200 copy contr ,rega 
+4b28 6800c132 fetch 1 ,mem_device_option 
+4b29 c1818000 rtnne dvc_op_kb ,pdata 
+4b2a 1a220c00 copy rega ,contr 
+4b2b 20204c4a branch kb_process_kb_report 
+
+hid_malloc_tx_buff:
+4b2c 20405248 call l2cap_malloc 
+4b2d 1a220400 copy rega ,temp 
+4b2e 600888a8 storet 1 ,mem_ui_data_txbuff_length 
+4b2f 1fe20a00 copy pdata ,contw 
+4b30 1a227e00 copy rega ,pdata 
+4b31 e0a10000 istore 2 ,contw 
+4b32 20600000 rtn 
+
+le_ir_init:
+4b33 58004b5b setarg le_ir 
+4b34 6001428c store 2 ,mem_cb_le_process 
+4b35 58004b44 setarg le_ir_wcb 
+4b36 60014296 store 2 ,mem_cb_att_write 
+4b37 2040691d call eeprom_load_reconn_info 
+4b38 20405347 call le_init_att 
+4b39 7080a29e hjam 158 ,core_pwm_ncnt0 
+4b3a 70808108 hjam 8 ,core_gpio_sel1 
+4b3b 70807505 hjam 5 ,core_gpio_out1 
+4b3c 5fffffff setarg -1 
+4b3d 793ffe01 set0 1 ,pdata 
+4b3e 793ffe15 set0 21 ,pdata 
+4b3f 60120070 hstore 4 ,core_gpio_oe0 
+4b40 70807802 hjam 2 ,core_gpio_pu0 
+4b41 20758000 rtn wake 
+4b42 7043d801 jam 1 ,mem_le_adv_enable 
+4b43 20600000 rtn 
+
+le_ir_wcb:
+4b44 ea208000 ifetch 1 ,rega 
+4b45 6000c803 store 1 ,mem_ir_cmd 
+4b46 c001cb4f beq ircmd_write_pulse ,le_ir_write_pulse 
+4b47 c0024b51 beq ircmd_write_seq ,le_ir_write_seq 
+4b48 c002cb53 beq ircmd_write_next ,le_ir_write_next 
+4b49 c00a4b64 beq ircmd_screen_on ,le_ir_screen_on 
+4b4a c00acb67 beq ircmd_screen_off ,le_ir_screen_off 
+4b4b c1810000 rtnne ircmd_play 
+4b4c e8c08000 ifetch 1 ,contr 
+4b4d 6000c804 store 1 ,mem_ir_play_count 
+4b4e 20600000 rtn 
+
+le_ir_write_pulse:
+4b4f d8a04807 arg mem_ir_pulse_zero ,contw 
+4b50 20204b55 branch le_ir_write 
+
+le_ir_write_seq:
+4b51 d8a04825 arg mem_ir_sequence_len ,contw 
+4b52 20204b55 branch le_ir_write 
+
+le_ir_write_next:
+4b53 68014800 fetch 2 ,mem_ir_ptr 
+4b54 98000a00 iforce contw 
+
+le_ir_write:
+4b55 df200013 arg 19 ,loopcnt 
+4b56 20407e45 call memcpy 
+4b57 18a27e00 deposit contw 
+4b58 60014800 store 2 ,mem_ir_ptr 
+4b59 70480300 jam 0 ,mem_ir_cmd 
+4b5a 20600000 rtn 
+
+le_ir:
+4b5b 6800c803 fetch 1 ,mem_ir_cmd 
+4b5c c000cb71 beq ircmd_record ,le_ir_start_record 
+4b5d c0014b8d beq ircmd_play ,le_ir_play 
+4b5e c0054b7a beq ircmd_report_pulse ,le_ir_report 
+4b5f c005cb7a beq ircmd_report_seq ,le_ir_report 
+4b60 c0064b7a beq ircmd_report_raw ,le_ir_report 
+4b61 c0044b8d beq ircmd_test_play ,le_ir_play 
+4b62 c004cb6a beq ircmd_test_rec ,le_ir_rec 
+4b63 20600000 rtn 
+
+le_ir_screen_on:
+4b64 70421300 jam 0 ,mem_lpm_mult 
+4b65 70480300 jam 0 ,mem_ir_cmd 
+4b66 20600000 rtn 
+
+le_ir_screen_off:
+4b67 7042131e jam 30 ,mem_lpm_mult 
+4b68 70480300 jam 0 ,mem_ir_cmd 
+4b69 20600000 rtn 
+
+le_ir_rec:
+4b6a 70480300 jam 0 ,mem_ir_cmd 
+4b6b db6fffff arg 0xfffff ,stop_watch 
+4b6c 20404b91 call ir_record 
+4b6d 20600000 rtn 
+
+le_ir_next_anchor:
+4b6e 680903c2 fetcht 2 ,mem_le_tsniff 
+4b6f 9840fe00 iadd temp ,pdata 
+4b70 600203c4 store 4 ,mem_le_anchor 
+
+le_ir_start_record:
+4b71 680203c4 fetch 4 ,mem_le_anchor 
+4b72 9d067e00 isub clke_bt ,pdata 
+4b73 24214b6e nbranch le_ir_next_anchor ,positive 
+4b74 1fe33600 rshift pdata ,stop_watch 
+4b75 20404b91 call ir_record 
+4b76 207a0000 rtn blank 
+4b77 7048030c jam ircmd_report_raw ,mem_ir_cmd 
+4b78 d8401800 arg mem_ir_record ,temp 
+4b79 60094800 storet 2 ,mem_ir_ptr 
+
+le_ir_report:
+4b7a 2040561c call le_xtype_fifo_is_full 
+4b7b 247a0000 nrtn blank 
+4b7c 7044c214 jam notify_handle ,mem_le_notify_handle 
+4b7d 700b7d1b jam attop_handle_value_notification ,mem_fifo_temp 
+4b7e 20405620 call le_xtype_fifo_in 
+4b7f 68010419 fetch 2 ,mem_le_notify_attr_start 
+4b80 98000a00 iforce contw 
+4b81 68014800 fetch 2 ,mem_ir_ptr 
+4b82 98000c00 iforce contr 
+4b83 df200014 arg 20 ,loopcnt 
+4b84 20407e45 call memcpy 
+4b85 18c27e00 deposit contr 
+4b86 60014800 store 2 ,mem_ir_ptr 
+4b87 68014805 fetch 2 ,mem_ir_report_len 
+4b88 1fe0ffec increase -20 ,pdata 
+4b89 60014805 store 2 ,mem_ir_report_len 
+4b8a 20610000 rtn positive 
+4b8b 70480300 jam 0 ,mem_ir_cmd 
+4b8c 20600000 rtn 
+
+le_ir_play:
+4b8d 6800c804 fetch 1 ,mem_ir_play_count 
+4b8e 20404be2 call ir_play 
+4b8f 70480300 jam 0 ,mem_ir_cmd 
+4b90 20600000 rtn 
+
+ir_record:
+4b91 20404b97 call ir_receive 
+4b92 58001800 setarg mem_ir_record 
+4b93 98a67e00 isub contw ,pdata 
+4b94 1fe67e00 sub pdata ,0 ,pdata 
+4b95 60014805 store 2 ,mem_ir_report_len 
+4b96 20600000 rtn 
+
+ir_receive:
+4b97 78487c00 disable swfine 
+4b98 d8a01800 arg mem_ir_record ,contw 
+
+ir_receive_waitsync:
+4b99 20618000 rtn timeout 
+4b9a 6810811e hfetch 1 ,core_gpio_in + 2 
+4b9b c302cb99 bbit0 5 ,ir_receive_waitsync 
+4b9c 1b220400 copy clkn ,temp 
+4b9d df200080 arg 0x80 ,loopcnt 
+4b9e 20407e3b call memset0 
+4b9f d8a01800 arg mem_ir_record ,contw 
+4ba0 da600000 arg 0x0 ,regc 
+
+ir_receive_loop:
+4ba1 db6000b4 arg 180 ,stop_watch 
+
+ir_receive_waitedge:
+4ba2 20618000 rtn timeout 
+4ba3 6810811e hfetch 1 ,core_gpio_in + 2 
+4ba4 9a62fe00 ixor regc ,pdata 
+4ba5 c282cba2 bbit1 5 ,ir_receive_waitedge 
+4ba6 1b227e00 copy clkn ,pdata 
+4ba7 98006000 iforce alarm 
+4ba8 20407e78 call clk_diff_rt 
+4ba9 1fe67cff sub pdata ,0xff ,null 
+4baa 20214ba2 branch ir_receive_waitedge ,positive 
+4bab 2a6c0005 isolate0 5 ,regc 
+4bac 7920fe17 setflag true ,23 ,pdata 
+4bad e0a18000 istore 3 ,contw 
+4bae 18acfe00 rshift8 contw ,pdata 
+4baf c10e0000 rtneq mem_ir_record_max 
+4bb0 1e020400 copy alarm ,temp 
+4bb1 1a62a620 xor_into 0x20 ,regc 
+4bb2 20204ba1 branch ir_receive_loop 
+
+ir_get_next_seq:
+4bb3 20344bc7 branch ir_get_next_seq_saved ,user 
+4bb4 20364bca branch ir_get_next_encoded ,user2 
+
+ir_get_next_seq_fetch:
+4bb5 d8404826 arg mem_ir_sequence ,temp 
+4bb6 6800c825 fetch 1 ,mem_ir_sequence_len 
+4bb7 9840fe00 iadd temp ,pdata 
+4bb8 9a267c00 isub rega ,null 
+4bb9 2022cbda branch ir_get_next_seq_exit ,zero 
+4bba ea208000 ifetch 1 ,rega 
+4bbb 18c22200 copy contr ,rega 
+4bbc c303cbc1 bbit0 7 ,ir_get_next_cont 
+4bbd 78367c00 enable user2 
+4bbe 1fe1247f and pdata ,0x7f ,regb 
+4bbf 1a29a200 lshift3 rega ,rega 
+4bc0 20204bca branch ir_get_next_encoded 
+
+ir_get_next_cont:
+4bc1 1ff19000 rshift4 pdata ,debug 
+4bc2 1fe17e0f and_into 0xf ,pdata 
+4bc3 99067c00 isub debug ,null 
+4bc4 20628000 rtn zero 
+4bc5 78347c00 enable user 
+4bc6 20600000 rtn 
+
+ir_get_next_seq_saved:
+4bc7 19027e00 deposit debug 
+4bc8 78547c00 disable user 
+4bc9 20600000 rtn 
+
+ir_get_next_encoded:
+4bca 1a427e00 deposit regb 
+4bcb 203a4bd6 branch ir_get_next_encoded_end ,blank 
+4bcc 1a210e07 and rega ,0x7 ,queue 
+4bcd 1a290c00 rshift3 rega ,contr 
+4bce e8c08000 ifetch 1 ,contr 
+4bcf 1a20a201 increase 1 ,rega 
+4bd0 1a40a5ff increase -1 ,regb 
+4bd1 afec0000 qisolate0 pdata 
+4bd2 6800c807 fetch 1 ,mem_ir_pulse_zero 
+4bd3 2020cbc1 branch ir_get_next_cont ,true 
+4bd4 6800c808 fetch 1 ,mem_ir_pulse_one 
+4bd5 20204bc1 branch ir_get_next_cont 
+
+ir_get_next_encoded_end:
+4bd6 78567c00 disable user2 
+4bd7 1a20a207 increase 7 ,rega 
+4bd8 1a292200 rshift3 rega ,rega 
+4bd9 20204bb5 branch ir_get_next_seq_fetch 
+
+ir_get_next_seq_exit:
+4bda 580000ff setarg 0xff 
+4bdb 20600000 rtn 
+
+ir_get_pulse:
+4bdc 1fe38c00 lshift pdata ,contr 
+4bdd 98c0fe00 iadd contr ,pdata 
+4bde d8c04809 arg mem_ir_pulses ,contr 
+4bdf 98c08c00 iadd contr ,contr 
+4be0 e8c18000 ifetch 3 ,contr 
+4be1 20600000 rtn 
+
+ir_play:
+4be2 78287c00 enable swfine 
+4be3 98007200 iforce loopcnt 
+
+ir_play_nloop:
+4be4 78547c00 disable user 
+4be5 78567c00 disable user2 
+4be6 da204826 arg mem_ir_sequence ,rega 
+
+ir_play_loop:
+4be7 20404bb3 call ir_get_next_seq 
+4be8 c07fcbf1 beq 0xff ,ir_play_end 
+4be9 20404bdc call ir_get_pulse 
+4bea c30bcbed bbit0 23 ,ir_play_silence 
+4beb 793ffe17 set0 23 ,pdata 
+4bec 7080a09e hjam 158 ,core_pwm_pcnt0 
+
+ir_play_silence:
+4bed 98003600 iforce stop_watch 
+4bee 37c18200 until null ,timeout 
+4bef 7080a000 hjam 0 ,core_pwm_pcnt0 
+4bf0 20204be7 branch ir_play_loop 
+
+ir_play_end:
+4bf1 c2004be4 loop ir_play_nloop 
+4bf2 20600000 rtn 
+
+le_kb_init:
+4bf3 20404c21 call kb_init_common 
+4bf4 58004d21 setarg kb_process_idle 
+4bf5 60014290 store 2 ,mem_cb_idle_process 
+4bf6 58004c59 setarg kb_send_process 
+4bf7 6001428e store 2 ,mem_cb_bt_process 
+4bf8 58004d37 setarg kb_process_bb_event 
+4bf9 60014292 store 2 ,mem_cb_bb_event_process 
+4bfa 58004d7e setarg kb_process_lpm_before 
+4bfb 6001428a store 2 ,mem_cb_before_lpm 
+4bfc 58004d7b setarg kb_discovery_timeout_sleep 
+4bfd 60014294 store 2 ,mem_cb_discovry_timeout 
+4bfe 58004d7e setarg kb_before_hibernate 
+4bff 60014288 store 2 ,mem_cb_before_hibernate 
+4c00 58004d22 setarg kb_wakeup_check 
+4c01 60014286 store 2 ,mem_cb_check_wakelock 
+4c02 20758000 rtn wake 
+4c03 680147f4 fetch 2 ,mem_ui_state_map 
+4c04 c2863f79 bbit1 ui_state_btn_down ,app_bt_start_discovery_short 
+4c05 20403f23 call app_check_reconn_target 
+4c06 203a4d79 branch kb_start_discovery ,blank 
+4c07 20403f7e call app_bt_stop_discovery 
+4c08 20203f6e branch app_bt_start_reconnect 
+
+kb_init:
+4c09 20404c21 call kb_init_common 
+4c0a 58004d21 setarg kb_process_idle 
+4c0b 60014290 store 2 ,mem_cb_idle_process 
+4c0c 58004c59 setarg kb_send_process 
+4c0d 6001428e store 2 ,mem_cb_bt_process 
+4c0e 58004d37 setarg kb_process_bb_event 
+4c0f 60014292 store 2 ,mem_cb_bb_event_process 
+4c10 58004d7e setarg kb_process_lpm_before 
+4c11 6001428a store 2 ,mem_cb_before_lpm 
+4c12 58004d7b setarg kb_discovery_timeout_sleep 
+4c13 60014294 store 2 ,mem_cb_discovry_timeout 
+4c14 58004d7e setarg kb_before_hibernate 
+4c15 60014288 store 2 ,mem_cb_before_hibernate 
+4c16 58004d22 setarg kb_wakeup_check 
+4c17 60014286 store 2 ,mem_cb_check_wakelock 
+4c18 20758000 rtn wake 
+4c19 7007dc00 jam 0 ,mem_sp_flag 
+4c1a 7007dd00 jam 0 ,mem_master_sp_flag 
+4c1b 680147f4 fetch 2 ,mem_ui_state_map 
+4c1c c2863f79 bbit1 ui_state_btn_down ,app_bt_start_discovery_short 
+4c1d 20403f23 call app_check_reconn_target 
+4c1e 203a4d79 branch kb_start_discovery ,blank 
+4c1f 20403f7e call app_bt_stop_discovery 
+4c20 20203f6e branch app_bt_start_reconnect 
+
+kb_init_common:
+4c21 79200025 set1 mark_ext_patch ,mark 
+4c22 44db4036 bpatch patch36_6 ,mem_patch36 
+4c23 68008140 fetch 1 ,0x8140 
+4c24 203a3bf1 branch assert ,blank 
+4c25 70807000 hjam 0 ,core_gpio_oe0 
+4c26 708078ff hjam 0xff ,core_gpio_pu0 
+4c27 708071ff hjam 0xff ,core_gpio_oe1 
+4c28 708072ff hjam 0xff ,core_gpio_oe2 
+4c29 68108073 hfetch 1 ,core_gpio_oe3 
+4c2a 1fe1fe0f or_into 0x0f ,pdata 
+4c2b 60108073 hstore 1 ,core_gpio_oe3 
+4c2c 70808000 hjam 0x00 ,core_gpio_sel 
+4c2d 70808100 hjam 0x00 ,core_gpio_sel1 
+4c2e 708083ff hjam 0xff ,core_gpio_key0 
+4c2f 708084ff hjam 0xFf ,core_gpio_key1 
+4c30 68108085 hfetch 1 ,core_gpio_key2 
+4c31 1fe1fe03 or_into 0x03 ,pdata 
+4c32 60108085 hstore 1 ,core_gpio_key2 
+4c33 70806f00 hjam 0x00 ,core_kscn_rowmask 
+4c34 58000013 setarg kb_kscan_col_1 
+4c35 1fe9fe00 lshift3 pdata ,pdata 
+4c36 1fe0fe07 add pdata ,kb_kscan_row_1 ,pdata 
+4c37 60108064 hstore 1 ,core_kscn_rctc 
+4c38 68108043 hfetch 1 ,core_config 
+4c39 79207e02 set1 2 ,pdata 
+4c3a 60108043 hstore 1 ,core_config 
+4c3b 68108051 hfetch 1 ,core_clkoff + 1 
+4c3c 793ffe01 set0 1 ,pdata 
+4c3d 60108051 hstore 1 ,core_clkoff + 1 
+4c3e 7080630d hjam 0xd ,core_kscn_ksctrl 
+4c3f 708067d3 hjam 0xd3 ,core_kscn_m_debounce 
+4c40 70806500 hjam 0 ,core_kscn_scancycle_timer_l 
+4c41 70806631 hjam 0x31 ,core_kscn_scancycle_timer_h 
+4c42 20403e0b call lpm_disable_exen_output 
+4c43 6808c80e fetcht 1 ,mem_led_cap_gpio 
+4c44 204069da call gpio_config_output 
+4c45 6808c80f fetcht 1 ,mem_led_num_gpio 
+4c46 204069da call gpio_config_output 
+4c47 6808c810 fetcht 1 ,mem_led_scl_gpio 
+4c48 204069da call gpio_config_output 
+4c49 20600000 rtn 
+
+kb_process_kb_report:
+4c4a 79200025 set1 mark_ext_patch ,mark 
+4c4b 44dbc036 bpatch patch36_7 ,mem_patch36 
+4c4c e8c08000 ifetch 1 ,contr 
+4c4d 1fe22200 copy pdata ,rega 
+4c4e 6808c80f fetcht 1 ,mem_led_num_gpio 
+4c4f 2a2ffe00 isolate1 kb_num_lock_selected ,rega 
+4c50 204069f0 call gpio_out_flag 
+4c51 6808c80e fetcht 1 ,mem_led_cap_gpio 
+4c52 2a2ffe01 isolate1 kb_caps_lock_selected ,rega 
+4c53 204069f0 call gpio_out_flag 
+4c54 6808c810 fetcht 1 ,mem_led_scl_gpio 
+4c55 2a2ffe02 isolate1 kb_scroll_lock_selected ,rega 
+4c56 204069f0 call gpio_out_flag 
+4c57 70480901 jam 1 ,mem_kb_rcv_led_data 
+4c58 20600000 rtn 
+
+kb_send_process:
+4c59 20404c99 call kb_kscan_check_if_empty 
+4c5a 24740000 nrtn user 
+4c5b 24760000 nrtn user2 
+4c5c 68008450 fetch 1 ,mem_pincode_state 
+4c5d c000cc69 beq pincode_state_wait_pincode ,kb_pincode 
+4c5e 6800c2bc fetch 1 ,mem_hid_interrupt_state 
+4c5f c19f8000 rtnne 0x3f 
+4c60 da20000a arg 10 ,rega 
+4c61 20404b2c call hid_malloc_tx_buff 
+4c62 680142b7 fetch 2 ,mem_hid_int_remote_cid 
+4c63 e0a10000 istore 2 ,contw 
+4c64 580001a1 setarg 0x01a1 
+4c65 e0a10000 istore 2 ,contw 
+4c66 68044800 fetch 8 ,mem_kb_state 
+4c67 e0a40000 istore 8 ,contw 
+4c68 20600000 rtn 
+
+kb_pincode:
+4c69 6808854f fetcht 1 ,mem_pin_length 
+4c6a 58000550 setarg mem_pin 
+4c6b 98408a00 iadd temp ,contw 
+4c6c 6800c802 fetch 1 ,mem_kb_report_data 
+4c6d 203a4c72 branch kb_pincode_rtn ,blank 
+4c6e c0154c74 beq kb_kcode_bksp ,kb_pincode_bksp 
+4c6f c0944c7e bne kb_kcode_enter ,kb_pincode_data 
+4c70 6008854f storet 1 ,mem_pin_length 
+4c71 20203f6a branch app_bt_set_pincode 
+
+kb_pincode_rtn:
+4c72 6008854f storet 1 ,mem_pin_length 
+4c73 20600000 rtn 
+
+kb_pincode_bksp:
+4c74 6800854f fetch 1 ,mem_pin_length 
+4c75 207a0000 rtn blank 
+4c76 1fe0ffff increase -1 ,pdata 
+4c77 6000854f store 1 ,mem_pin_length 
+4c78 d8a00550 arg mem_pin ,contw 
+4c79 98a08a00 iadd contw ,contw 
+4c7a 58000000 setarg 0 
+4c7b e0a08000 istore 1 ,contw 
+4c7c 78367c00 enable user2 
+4c7d 20204c8d branch kb_send_pin 
+
+kb_pincode_data:
+4c7e 1fe67c1d sub pdata ,kb_kcode_1_m1 ,null 
+4c7f 20610000 rtn positive 
+4c80 d8400030 arg 0x30 ,temp 
+4c81 1fe67c27 sub pdata ,kb_kcode_0 ,null 
+4c82 24610000 nrtn positive 
+4c83 2022cc87 branch kb_pincode_0 ,zero 
+4c84 d840001d arg kb_kcode_1_m1 ,temp 
+4c85 98460400 isub temp ,temp 
+4c86 18418430 or_into 0x30 ,temp 
+
+kb_pincode_0:
+4c87 e0a88000 istoret 1 ,contw 
+4c88 6800854f fetch 1 ,mem_pin_length 
+4c89 1fe0fe01 increase 1 ,pdata 
+4c8a 6000854f store 1 ,mem_pin_length 
+4c8b 78567c00 disable user2 
+4c8c 20204c8d branch kb_send_pin 
+
+kb_send_pin:
+4c8d 680142b7 fetch 2 ,mem_hid_int_remote_cid 
+4c8e 207a0000 rtn blank 
+4c8f da200003 arg 3 ,rega 
+4c90 20404b2c call hid_malloc_tx_buff 
+4c91 680142b7 fetch 2 ,mem_hid_int_remote_cid 
+4c92 e0a10000 istore 2 ,contw 
+4c93 5800ffa1 setarg 0xffa1 
+4c94 e0a10000 istore 2 ,contw 
+4c95 58000000 setarg 0 
+4c96 79367e00 setflag user2 ,0 ,pdata 
+4c97 e0a08000 istore 1 ,contw 
+4c98 20600000 rtn 
+
+kb_kscan_check_if_empty:
+4c99 78547c00 disable user 
+4c9a 78567c00 disable user2 
+4c9b 68108119 hfetch 1 ,core_kscn_kstat 
+4c9c c3800000 rtnbit1 kb_kscan_stat_empty 
+
+kb_kscan_check_ghost:
+4c9d 6810811b hfetch 1 ,core_kscn_event_num 
+4c9e c2804ca3 bbit1 kb_kscan_key_event_stat ,kb_kscan_process_event 
+4c9f 68108119 hfetch 1 ,core_kscn_kstat 
+4ca0 c3034ca3 bbit0 kb_kscan_stat_ghost ,kb_kscan_process_event 
+4ca1 6810811a hfetch 1 ,core_kscn_event 
+4ca2 20204c99 branch kb_kscan_check_if_empty 
+
+kb_kscan_process_event:
+4ca3 78347c00 enable user 
+4ca4 78367c00 enable user2 
+4ca5 6810811b hfetch 1 ,core_kscn_event_num 
+4ca6 2fec0000 isolate0 kb_kscan_key_event_stat ,pdata 
+4ca7 6810811a hfetch 1 ,core_kscn_event 
+4ca8 d8c04811 arg mem_kb_map ,contr 
+4ca9 98c08c00 iadd contr ,contr 
+4caa e8c08000 ifetch 1 ,contr 
+4cab c283cce4 bbit1 7 ,kb_kscan_read_statekey 
+4cac 2420cccc nbranch kb_kscan_release_a_key_data ,true 
+4cad 78567c00 disable user2 
+4cae 98000400 iforce temp 
+4caf 6800c808 fetch 1 ,mem_kb_keys 
+4cb0 1fe67c04 sub pdata ,4 ,null 
+4cb1 24610000 nrtn positive 
+4cb2 1fe22200 copy pdata ,rega 
+4cb3 df200003 arg 3 ,loopcnt 
+4cb4 d8c04802 arg mem_kb_report_data ,contr 
+
+kb_kscan_check_report_data:
+4cb5 e8c08000 ifetch 1 ,contr 
+4cb6 98467c00 isub temp ,null 
+4cb7 2022cc99 branch kb_kscan_check_if_empty ,zero 
+4cb8 c2004cb5 loop kb_kscan_check_report_data 
+
+kb_kscan_store_a_key_data:
+4cb9 1a227e00 copy rega ,pdata 
+4cba d8a04802 arg mem_kb_report_data ,contw 
+4cbb 98a08a00 iadd contw ,contw 
+4cbc e0a88000 istoret 1 ,contw 
+4cbd 1fe0fe01 increase 1 ,pdata 
+4cbe 6000c808 store 1 ,mem_kb_keys 
+4cbf 6810811b hfetch 1 ,core_kscn_event_num 
+4cc0 1fe97e00 rshift3 pdata ,pdata 
+4cc1 243a4cc3 nbranch kb_kscan_check_nextevent ,blank 
+4cc2 20204cca branch kb_kscan_prepare_send 
+
+kb_kscan_check_nextevent:
+4cc3 1fe0ffff increase -1 ,pdata 
+4cc4 2022ccca branch kb_kscan_prepare_send ,zero 
+4cc5 6810811b hfetch 1 ,core_kscn_event_num 
+4cc6 1fe17e01 and_into 0x01 ,pdata 
+4cc7 c0004c99 beq kb_kscan_key_press ,kb_kscan_check_if_empty 
+4cc8 c000ccca beq kb_kscan_key_release ,kb_kscan_prepare_send 
+4cc9 20600000 rtn 
+
+kb_kscan_prepare_send:
+4cca 78367c00 enable user2 
+4ccb 20600000 rtn 
+
+kb_kscan_release_a_key_data:
+4ccc 1fe104ff and pdata ,0xff ,temp 
+4ccd 6800c808 fetch 1 ,mem_kb_keys 
+4cce 207a0000 rtn blank 
+4ccf 98007200 iforce loopcnt 
+4cd0 d8c04802 arg mem_kb_report_data ,contr 
+
+kb_kscan_find_same_key_data:
+4cd1 e8c08000 ifetch 1 ,contr 
+4cd2 98467c00 isub temp ,null 
+4cd3 2022ccd6 branch kb_kscan_release_foundkey ,zero 
+4cd4 c2004cd1 loop kb_kscan_find_same_key_data 
+4cd5 20600000 rtn 
+
+kb_kscan_release_foundkey:
+4cd6 18c08bff add contr ,-1 ,contw 
+4cd7 20407e45 call memcpy 
+4cd8 6800c808 fetch 1 ,mem_kb_keys 
+4cd9 1fe0ffff increase -1 ,pdata 
+4cda 6000c808 store 1 ,mem_kb_keys 
+4cdb 6810811b hfetch 1 ,core_kscn_event_num 
+4cdc 1fe97e00 rshift3 pdata ,pdata 
+4cdd 243a4cdf nbranch kb_kscan_check_nextevent2 ,blank 
+4cde 20600000 rtn 
+
+kb_kscan_check_nextevent2:
+4cdf 6810811b hfetch 1 ,core_kscn_event_num 
+4ce0 1fe17e01 and_into 0x01 ,pdata 
+4ce1 c0004cca beq kb_kscan_key_press ,kb_kscan_prepare_send 
+4ce2 c000cc99 beq kb_kscan_key_release ,kb_kscan_check_if_empty 
+4ce3 20600000 rtn 
+
+kb_kscan_read_statekey:
+4ce4 1fe10e07 and pdata ,7 ,queue 
+4ce5 6800c800 fetch 1 ,mem_kb_state 
+4ce6 f920fe00 qsetflag true ,pdata 
+4ce7 6000c800 store 1 ,mem_kb_state 
+4ce8 20600000 rtn 
+
+kb_clear_keys:
+4ce9 58000000 setarg 0 
+4cea 60044800 store 8 ,mem_kb_state 
+4ceb 6000c808 store 1 ,mem_kb_keys 
+4cec 20600000 rtn 
+
+kb_clean_kscan_fifo:
+4ced 6810811b hfetch 1 ,core_kscn_event_num 
+4cee 6810811a hfetch 1 ,core_kscn_event 
+4cef 68108119 hfetch 1 ,core_kscn_kstat 
+4cf0 c3004ced bbit0 kb_kscan_stat_empty ,kb_clean_kscan_fifo 
+4cf1 580000ff setarg 0xff 
+4cf2 78347c00 enable user 
+4cf3 20600000 rtn 
+
+le_keyboard:
+4cf4 680944c2 fetcht 2 ,mem_le_notify_handle 
+4cf5 20405866 call le_att_check_notification_enable 
+4cf6 c4000000 rtnbit0 0 
+4cf7 6800c6f8 fetch 1 ,mem_le_switch_send_data 
+4cf8 c4000000 rtnbit0 0 
+4cf9 2040561c call le_xtype_fifo_is_full 
+4cfa 247a0000 nrtn blank 
+4cfb 20404c99 call kb_kscan_check_if_empty 
+4cfc 24740000 nrtn user 
+4cfd 24760000 nrtn user2 
+
+le_slave_keyboard_send_data:
+4cfe 20403f5e call app_lpm_wake_auto_lock 
+4cff 70421302 jam 2 ,mem_lpm_mult 
+4d00 680944c2 fetcht 2 ,mem_le_notify_handle 
+4d01 20405a88 call le_att_get_handle_ptr 
+4d02 18c08a01 add contr ,1 ,contw 
+4d03 68044800 fetch 8 ,mem_kb_state 
+4d04 e0a40000 istore 8 ,contw 
+4d05 700b7d1b jam attop_handle_value_notification ,mem_fifo_temp 
+4d06 20405620 call le_xtype_fifo_in 
+4d07 680083e4 fetch 1 ,mem_le_op 
+4d08 c281bbf2 bbit1 op_disconn ,loop 
+4d09 20600000 rtn 
+
+le_keyboard_process_bb_event:
+4d0a 1a627e00 copy regc ,pdata 
+4d0b c0084d15 beq bt_evt_button_long_pressed ,le_keyboard_bb_event_discovery_btn 
+4d0c c00a4d13 beq bt_evt_le_connected ,le_kb_connected 
+4d0d c0144d11 beq bt_evt_le_write_request ,le_kb_bb_event_write_request 
+4d0e c014cd11 beq bt_evt_le_enc_info ,le_kb_bb_event_enc_info 
+4d0f c0173f57 beq bt_evt_remote_unsniff ,app_start_auto_sniff 
+4d10 20600000 rtn 
+
+le_kb_bb_event_enc_info:
+
+le_kb_bb_event_write_request:
+4d11 20403fa4 call app_lpm_mult_enable 
+4d12 20203f92 branch app_ble_start_write 
+
+le_kb_connected:
+4d13 20404ced call kb_clean_kscan_fifo 
+4d14 20204ce9 branch kb_clear_keys 
+
+le_keyboard_bb_event_discovery_btn:
+4d15 20405b30 call le_clean_att_list_handle_enable 
+4d16 20403f90 call app_ble_disconnect 
+4d17 20403f88 call app_ble_start_adv 
+4d18 20203f94 branch app_led_start_blink 
+
+le_keyboard_bb_event_hud_ms:
+4d19 6800c42e fetch 1 ,mem_le_led_on_time 
+4d1a 207a0000 rtn blank 
+4d1b 1fe0ffff increase -1 ,pdata 
+4d1c 6000c42e store 1 ,mem_le_led_on_time 
+4d1d 247a0000 nrtn blank 
+4d1e 6800c4db fetch 1 ,mem_le_adv_type 
+4d1f 207a0000 rtn blank 
+4d20 20203f98 branch app_led_off 
+
+kb_process_idle:
+4d21 20204d2e branch kb_pairing_button_check 
+
+kb_wakeup_check:
+4d22 6811811c hfetch 3 ,core_gpio_in 
+4d23 1fe22400 copy pdata ,regb 
+4d24 6810811f hfetch 1 ,core_gpio_in + 3 
+4d25 1fe17e0f and_into 0x0f ,pdata 
+4d26 1ff07e00 lshift16 pdata ,pdata 
+4d27 1fed7e00 lshift8 pdata ,pdata 
+4d28 9a41fe00 ior regb ,pdata 
+4d29 680a480a fetcht 4 ,mem_kb_fast_wake_last 
+4d2a 98467e00 isub temp ,pdata 
+4d2b 207a0000 rtn blank 
+4d2c da4000bb arg 0xbb ,regb 
+4d2d 20203f5e branch app_lpm_wake_auto_lock 
+
+kb_pairing_button_check:
+4d2e 6800c133 fetch 1 ,mem_scan_mode 
+4d2f 247a0000 nrtn blank 
+4d30 6800c27f fetch 1 ,mem_app_handshake_flag 
+4d31 247a0000 nrtn blank 
+4d32 6800c7ea fetch 1 ,mem_ui_button_timer 
+4d33 207a0000 rtn blank 
+4d34 6800c7eb fetch 1 ,mem_ui_button_last_state 
+4d35 247a0000 nrtn blank 
+4d36 20203f9a branch app_enter_hibernate 
+
+kb_process_bb_event:
+4d37 1a627e00 copy regc ,pdata 
+4d38 c0034d8b beq bt_evt_hid_connected ,kb_hid_connected 
+4d39 c0054d7c beq bt_evt_pincode_req ,kb_process_pincode 
+4d3a c0034d8f beq bt_evt_hid_connected ,kb_bt_hid_handshake 
+4d3b c0084d68 beq bt_evt_button_long_pressed ,kb_bb_event_discovery_btn 
+4d3c c0173f57 beq bt_evt_remote_unsniff ,app_start_auto_sniff 
+4d3d c000cd77 beq bt_evt_bb_connected ,kb_stop_discovery 
+4d3e c0014d51 beq bt_evt_bb_disconnected ,kb_bb_disconnected 
+4d3f c0024d4e beq bt_evt_reconn_failed ,kb_bb_event_reconn_failed 
+4d40 c009cd4e beq bt_evt_reconn_page_timeout ,kb_bb_event_reconn_failed 
+4d41 1fe1040f and pdata ,0x0f ,temp 
+4d42 1fe17ef0 and_into bt_evt_timer_mask ,pdata 
+4d43 c0284d45 beq bt_evt_timer_init ,kb_bb_event_timer 
+4d44 20600000 rtn 
+
+kb_bb_event_timer:
+4d45 79200025 set1 mark_ext_patch ,mark 
+4d46 44dc4037 bpatch patch37_0 ,mem_patch37 
+4d47 60088259 storet 1 ,mem_app_evt_timer_count 
+
+kb_bb_event_100ms_loop:
+4d48 68008259 fetch 1 ,mem_app_evt_timer_count 
+4d49 207a0000 rtn blank 
+4d4a 1fe0ffff increase -1 ,pdata 
+4d4b 60008259 store 1 ,mem_app_evt_timer_count 
+4d4c 20404d62 call kb_check_hid_handshake_timer 
+4d4d 20204d48 branch kb_bb_event_100ms_loop 
+
+kb_bb_event_reconn_failed:
+4d4e 680147f4 fetch 2 ,mem_ui_state_map 
+4d4f c2864d79 bbit1 ui_state_btn_down ,kb_start_discovery 
+4d50 20203f10 branch app_bb_hibernate 
+
+kb_bb_disconnected:
+4d51 79200025 set1 mark_ext_patch ,mark 
+4d52 44dcc037 bpatch patch37_1 ,mem_patch37 
+4d53 20404d59 call kb_bb_discon_clear_stack 
+4d54 680142a0 fetch app_disc_rsn_size ,mem_app_disconn_reason 
+4d55 c2803f12 bbit1 app_disc_by_button ,app_disconn_reason_clear 
+4d56 c280cd5c bbit1 app_disc_after_pairing ,kb_event_light_state_pairing 
+4d57 c2814d5f bbit1 app_disc_after_reconn ,kb_event_light_state_reconn 
+4d58 20204d79 branch kb_start_discovery 
+
+kb_bb_discon_clear_stack:
+4d59 70425e00 jam 0 ,mem_link_key_exists 
+4d5a 70448b00 jam 0 ,mem_ltk_exists 
+4d5b 20600000 rtn 
+
+kb_event_light_state_pairing:
+4d5c c282bf10 bbit1 app_disc_after_handshake ,app_bb_hibernate 
+4d5d c281bf10 bbit1 app_disc_after_sniff ,app_bb_hibernate 
+4d5e 20204d79 branch kb_start_discovery 
+
+kb_event_light_state_reconn:
+4d5f 680147f4 fetch 2 ,mem_ui_state_map 
+4d60 c2864d79 bbit1 ui_state_btn_down ,kb_start_discovery 
+4d61 20203f10 branch app_bb_hibernate 
+
+kb_check_hid_handshake_timer:
+4d62 6800c7f2 fetch 1 ,mem_hid_handshake_timer_count 
+4d63 207a0000 rtn blank 
+4d64 1fe0ffff increase -1 ,pdata 
+4d65 6000c7f2 store 1 ,mem_hid_handshake_timer_count 
+4d66 247a0000 nrtn blank 
+4d67 20204d8f branch kb_bt_hid_handshake 
+
+kb_bb_event_discovery_btn:
+4d68 20404d6a call kb_3_0_bb_event_discovery_btn 
+4d69 20204d79 branch kb_start_discovery 
+
+kb_3_0_bb_event_discovery_btn:
+4d6a 79200025 set1 mark_ext_patch ,mark 
+4d6b 44dd4037 bpatch patch37_2 ,mem_patch37 
+4d6c 680147f4 fetch 2 ,mem_ui_state_map 
+4d6d 2feffe07 isolate1 ui_state_bt_reconnect ,pdata 
+4d6e 2040bf75 call app_bt_reconnect_cancel ,true 
+4d6f 680147fe fetch 2 ,mem_discovery_timeout 
+4d70 600147f0 store 2 ,mem_discovery_timeout_timer_count 
+4d71 680142a2 fetch app_disc_rsn_size ,mem_app_disconn_reason_flag 
+4d72 79207e00 set1 app_disc_by_button ,pdata 
+4d73 600142a2 store app_disc_rsn_size ,mem_app_disconn_reason_flag 
+4d74 680147f4 fetch 2 ,mem_ui_state_map 
+4d75 c2803f77 bbit1 ui_state_bt_connected ,app_bt_disconnect 
+4d76 20600000 rtn 
+
+kb_stop_discovery:
+4d77 20403f7e call app_bt_stop_discovery 
+4d78 20203f98 branch app_led_stop_blink 
+
+kb_start_discovery:
+4d79 20403f7c call app_bt_start_discovery 
+4d7a 20203f94 branch app_led_start_blink 
+
+kb_discovery_timeout_sleep:
+4d7b 20203f9a branch app_enter_hibernate 
+
+kb_process_pincode:
+4d7c 70054f00 jam 0 ,mem_pin_length 
+4d7d 20600000 rtn 
+
+kb_before_hibernate:
+
+kb_process_lpm_before:
+4d7e 70808300 hjam 0x00 ,core_gpio_key0 
+4d7f 70808400 hjam 0x00 ,core_gpio_key1 
+4d80 68108085 hfetch 1 ,core_gpio_key2 
+4d81 1fe17ef0 and_into 0xf0 ,pdata 
+4d82 60108085 hstore 1 ,core_gpio_key2 
+4d83 58000000 setarg 0x00 
+4d84 600200a7 store 4 ,mem_gpio_wakeup_high 
+4d85 580000ff setarg 0xff 
+4d86 6808c7fd fetcht 1 ,mem_ui_button_gpio 
+4d87 18420e00 copy temp ,queue 
+4d88 f9207e00 qset1 pdata 
+4d89 600200a3 store 4 ,mem_gpio_wakeup_low 
+4d8a 20600000 rtn 
+
+kb_hid_connected:
+4d8b 58000002 setarg hid_handshake_timeout 
+4d8c 6000c7f2 store 1 ,mem_hid_handshake_timer_count 
+4d8d 20404ced call kb_clean_kscan_fifo 
+4d8e 20204ce9 branch kb_clear_keys 
+
+kb_bt_hid_handshake:
+4d8f 79200025 set1 mark_ext_patch ,mark 
+4d90 44ddc037 bpatch patch37_3 ,mem_patch37 
+4d91 70427f01 jam app_handshake_done ,mem_app_handshake_flag 
+4d92 20403fa4 call app_lpm_mult_enable 
+4d93 20403fa2 call app_bt_store_reconn_info 
+4d94 58000000 setarg 0 
+4d95 600147f0 store 2 ,mem_discovery_timeout_timer_count 
+4d96 6000c7f2 store 1 ,mem_hid_handshake_timer_count 
+4d97 20203f9e branch app_bt_enter_sniff 
+
+l2cap_init:
+4d98 2035cd9d branch l2cap_init_wake ,wake 
+
+l2cap_init_work:
+4d99 580043ce setarg mem_l2cap_xmem_end 
+4d9a d8a042af arg mem_l2cap_xmem_start ,contw 
+4d9b 98a67200 isub contw ,loopcnt 
+4d9c 20407e3f call clear_mem 
+
+l2cap_init_wake:
+4d9d 79200025 set1 mark_ext_patch ,mark 
+4d9e 448b4022 bpatch patch22_6 ,mem_patch22 
+4d9f 580004de setarg mem_sdp_mem_end 
+4da0 d8a004a9 arg mem_sdp_mem_start ,contw 
+4da1 98a67200 isub contw ,loopcnt 
+4da2 20407e3f call clear_mem 
+4da3 58000330 setarg mem_l2cap_mem_end 
+4da4 d8a002c4 arg mem_l2cap_mem_start ,contw 
+4da5 98a67200 isub contw ,loopcnt 
+4da6 20407e3f call clear_mem 
+4da7 2020532a branch l2cap_lpm_load_txbuf 
+
+process_rx_l2cap_pkt:
+4da8 79200025 set1 mark_ext_patch ,mark 
+4da9 448bc022 bpatch patch22_7 ,mem_patch22 
+4daa 18c20400 copy contr ,temp 
+4dab 18420c00 copy temp ,contr 
+4dac e8c10000 ifetch 2 ,contr 
+4dad 600102cd store 2 ,mem_l2cap_rx_pkt_length 
+4dae e8c10000 ifetch 2 ,contr 
+4daf 600102cf store 2 ,mem_l2cap_rx_cid 
+4db0 18c27e00 deposit contr 
+4db1 600102cb store 2 ,mem_l2cap_payload_ptr 
+4db2 6800c7f3 fetch 1 ,memui_reconnect_mode 
+4db3 c0004db5 beq no_reconnection ,l2cap_rx_multiplexing 
+4db4 202050fa branch ml2cap_rx_multiplexing 
+
+l2cap_rx_multiplexing:
+4db5 79200025 set1 mark_ext_patch ,mark 
+4db6 448c4023 bpatch patch23_0 ,mem_patch23 
+4db7 680102cd fetch 2 ,mem_l2cap_rx_pkt_length 
+4db8 203a4dfc branch l2cap_rx_reset_state ,blank 
+4db9 680082cf fetch 1 ,mem_l2cap_rx_cid 
+4dba c000cdc0 beq l2cap_signal_channel ,l2cap_call_proc_signal 
+
+l2cap_rx_multiplexing0:
+4dbb c0284de7 beq l2cap_sdp_channel ,l2cap_call_proc_sdp 
+4dbc c028cdf4 beq l2cap_rfcomm_channel ,l2cap_call_proc_rfcomm 
+4dbd c0294df2 beq l2cap_hid_control_channel ,l2cap_call_proc_hid 
+4dbe c029cdf2 beq l2cap_hid_interrupt_channel ,l2cap_call_proc_hid 
+4dbf 20204dfc branch l2cap_rx_reset_state 
+
+l2cap_call_proc_signal:
+4dc0 2040527a call l2cap_malloc_is_fifo_full 
+4dc1 247a0000 nrtn blank 
+4dc2 7043cd00 jam 0 ,mem_l2cap_pending_item 
+
+l2cap_call_proc_signal0:
+4dc3 204052c4 call l2cap_malloc_signal_channel 
+4dc4 20404e01 call l2cap_process_signal_pkt 
+4dc5 680902d6 fetcht 2 ,mem_l2cap_signal_tx_length 
+4dc6 203a4dfb branch l2cap_call_proc_no_reply ,blank 
+4dc7 204052ce call l2cap_get_signal_tx_buff 
+4dc8 680102d6 fetch 2 ,mem_l2cap_signal_tx_length 
+4dc9 e0a10000 istore 2 ,contw 
+4dca 18007e01 force l2cap_signal_channel ,pdata 
+4dcb e0a10000 istore 2 ,contw 
+4dcc 20204dfc branch l2cap_rx_reset_state 
+
+l2cap_call_proc_sigal_pending:
+4dcd 6800c132 fetch 1 ,mem_device_option 
+4dce c1008000 rtneq dvc_op_hci 
+4dcf 6800c3cd fetch 1 ,mem_l2cap_pending_item 
+4dd0 207a0000 rtn blank 
+4dd1 1fe22200 copy pdata ,rega 
+4dd2 6802033c fetch 4 ,mem_l2cap_sdpres_delay_time 
+4dd3 d8400100 arg 0x100 ,temp 
+4dd4 98408400 iadd temp ,temp 
+4dd5 1c427e00 copy clkn_bt ,pdata 
+4dd6 98467c00 isub temp ,null 
+4dd7 24610000 nrtn positive 
+4dd8 7043cd00 jam 0 ,mem_l2cap_pending_item 
+4dd9 1a227e00 copy rega ,pdata 
+4dda c0284ddc beq l2cap_sdp_channel ,l2cap_sdp_conn_succ 
+4ddb 20203bf1 branch assert 
+
+l2cap_sdp_conn_succ:
+4ddc 204052c4 call l2cap_malloc_signal_channel 
+4ddd 20404e84 call restore_l2cap_req_param 
+4dde 204052d0 call l2cap_get_signal_tx_payload 
+4ddf 20407e1c call save_cont_pointers 
+4de0 20404eb7 call send_connection_sdp_res 
+4de1 204052ce call l2cap_get_signal_tx_buff 
+4de2 5800000c setarg 0x000c 
+4de3 e0a10000 istore 2 ,contw 
+4de4 18007e01 force l2cap_signal_channel ,pdata 
+4de5 e0a10000 istore 2 ,contw 
+4de6 20204dfc branch l2cap_rx_reset_state 
+
+l2cap_call_proc_sdp:
+4de7 2040527e call l2cap_malloc_is_fifo_empty 
+4de8 247a0000 nrtn blank 
+4de9 204052d2 call l2cap_malloc_sdp_channel 
+4dea 20406f72 call sdp_process 
+4deb 204052dc call l2cap_get_sdp_tx_buff 
+4dec 680102dc fetch 2 ,mem_sdp_tx_pkt_length 
+4ded 203a4dfb branch l2cap_call_proc_no_reply ,blank 
+4dee e0a10000 istore 2 ,contw 
+4def 680142b1 fetch 2 ,mem_sdp_remote_cid 
+4df0 e0a10000 istore 2 ,contw 
+4df1 20204dfc branch l2cap_rx_reset_state 
+
+l2cap_call_proc_hid:
+4df2 20404af8 call hid_rx_process 
+4df3 20204dfc branch l2cap_rx_reset_state 
+
+l2cap_call_proc_rfcomm:
+4df4 79200025 set1 mark_ext_patch ,mark 
+4df5 448cc023 bpatch patch23_1 ,mem_patch23 
+4df6 7002eb00 jam rfcomm_malloc_succeed ,mem_rfcomm_malloc_fail_flag 
+4df7 20406bdc call rfcomm_rx_process 
+4df8 680082eb fetch 1 ,mem_rfcomm_malloc_fail_flag 
+4df9 c1008000 rtneq rfcomm_malloc_fail 
+4dfa 20204dfc branch l2cap_rx_reset_state 
+
+l2cap_call_proc_no_reply:
+4dfb 2040526f call l2cap_malloc_discard 
+
+l2cap_rx_reset_state:
+4dfc 58000000 setarg 0 
+4dfd 600102cd store 2 ,mem_l2cap_rx_pkt_length 
+4dfe 600102cf store 2 ,mem_l2cap_rx_cid 
+4dff 7002d101 jam l2cap_rx_done ,mem_l2cap_rx_done 
+4e00 20600000 rtn 
+
+l2cap_process_signal_pkt:
+4e01 79200025 set1 mark_ext_patch ,mark 
+4e02 448d4023 bpatch patch23_2 ,mem_patch23 
+4e03 204052d0 call l2cap_get_signal_tx_payload 
+4e04 18002400 force 0 ,regb 
+4e05 680102cd fetch 2 ,mem_l2cap_rx_pkt_length 
+4e06 1fe22600 copy pdata ,regc 
+4e07 680102cb fetch 2 ,mem_l2cap_payload_ptr 
+4e08 98000c00 iforce contr 
+
+l2cap_process_signal_pkt_loop:
+4e09 20404e11 call l2cap_process_one_signal 
+4e0a 1a627e00 deposit regc 
+4e0b 1a60a7fc increase -4 ,regc 
+4e0c 1fe0fffc increase -4 ,pdata 
+4e0d 243a4e09 nbranch l2cap_process_signal_pkt_loop ,blank 
+4e0e 1a427e00 copy regb ,pdata 
+4e0f 600102d6 store 2 ,mem_l2cap_signal_tx_length 
+4e10 20600000 rtn 
+
+l2cap_process_one_signal:
+4e11 79200025 set1 mark_ext_patch ,mark 
+4e12 448dc023 bpatch patch23_3 ,mem_patch23 
+4e13 e8c08000 ifetch 1 ,contr 
+4e14 c000ce54 beq signal_cmd_reject ,l2cap_proc_signal_cmd_reject 
+4e15 c0014e5c beq signal_connect_req ,l2cap_proc_signal_connect_req 
+4e16 c001cee0 beq signal_connect_rsp ,l2cap_proc_signal_connect_rsp 
+4e17 c0024f0f beq signal_config_req ,l2cap_proc_signal_config_req 
+4e18 c002cfad beq signal_config_rsp ,l2cap_proc_signal_config_rsp 
+4e19 c0034fd5 beq signal_disconnect_req ,l2cap_proc_signal_disconnect_req 
+4e1a c003d024 beq signal_disconnect_rsp ,l2cap_proc_signal_disconnect_rsp 
+4e1b c0045058 beq signal_echo_req ,l2cap_proc_signal_echo_req 
+4e1c c004d068 beq signal_echo_rsp ,l2cap_proc_signal_echo_rsp 
+4e1d c0054e21 beq signal_info_req ,l2cap_proc_signal_info_req 
+4e1e c005d069 beq signal_info_rsp ,l2cap_proc_signal_info_rsp 
+4e1f 2040506a call l2cap_reject_command 
+
+l2cap_process_one_signal_rtn:
+4e20 20600000 rtn 
+
+l2cap_proc_signal_info_req:
+4e21 e8c08000 ifetch 1 ,contr 
+4e22 1fe20e00 copy pdata ,queue 
+4e23 e8c10000 ifetch 2 ,contr 
+4e24 1fe22200 copy pdata ,rega 
+4e25 1a627e00 copy regc ,pdata 
+4e26 9a262600 isub rega ,regc 
+4e27 1a227e00 copy rega ,pdata 
+4e28 98c08c00 iadd contr ,contr 
+4e29 5800000b setarg 0x0b 
+4e2a e0a08000 istore 1 ,contw 
+4e2b 18e27e00 copy queue ,pdata 
+4e2c e0a08000 istore 1 ,contw 
+4e2d 18007e08 force 0x0008 ,pdata 
+4e2e e0a10000 istore 2 ,contw 
+4e2f 18007e02 force 0x0002 ,pdata 
+4e30 e0a10000 istore 2 ,contw 
+4e31 18007e00 force 0x0000 ,pdata 
+4e32 e0a10000 istore 2 ,contw 
+4e33 18007e00 force 0x0400 ,pdata 
+4e34 e0a10000 istore 2 ,contw 
+4e35 18007e00 force 0x0000 ,pdata 
+4e36 e0a10000 istore 2 ,contw 
+4e37 18007e0c force 12 ,pdata 
+4e38 9a40a400 iadd regb ,regb 
+4e39 20204e20 branch l2cap_process_one_signal_rtn 
+
+ml2cap_proc_signal_info_req:
+4e3a e8c08000 ifetch 1 ,contr 
+4e3b 1fe20e00 copy pdata ,queue 
+4e3c e8c10000 ifetch 2 ,contr 
+4e3d 1fe22200 copy pdata ,rega 
+4e3e 1a627e00 copy regc ,pdata 
+4e3f 9a262600 isub rega ,regc 
+4e40 1a227e00 copy rega ,pdata 
+4e41 98c08c00 iadd contr ,contr 
+4e42 204052d0 call l2cap_get_signal_tx_payload 
+4e43 5800000b setarg 0x0b 
+4e44 e0a08000 istore 1 ,contw 
+4e45 18e27e00 copy queue ,pdata 
+4e46 e0a08000 istore 1 ,contw 
+4e47 18007e08 force 0x0008 ,pdata 
+4e48 e0a10000 istore 2 ,contw 
+4e49 18007e02 force 0x0002 ,pdata 
+4e4a e0a10000 istore 2 ,contw 
+4e4b 18007e00 force 0x0000 ,pdata 
+4e4c e0a10000 istore 2 ,contw 
+4e4d 18007e00 force 0x0400 ,pdata 
+4e4e e0a10000 istore 2 ,contw 
+4e4f 18007e00 force 0x0000 ,pdata 
+4e50 e0a10000 istore 2 ,contw 
+4e51 18007e0c force 12 ,pdata 
+4e52 9a40a400 iadd regb ,regb 
+4e53 20204e20 branch l2cap_process_one_signal_rtn 
+
+l2cap_proc_signal_cmd_reject:
+4e54 e8c08000 ifetch 1 ,contr 
+4e55 1fe20e00 copy pdata ,queue 
+4e56 e8c10000 ifetch 2 ,contr 
+4e57 1fe22200 copy pdata ,rega 
+4e58 98c08c00 iadd contr ,contr 
+4e59 1a627e00 copy regc ,pdata 
+4e5a 9a262600 isub rega ,regc 
+
+l2cap_proc_signal_cmd_reject_rtn:
+4e5b 20204e20 branch l2cap_process_one_signal_rtn 
+
+l2cap_proc_signal_connect_req:
+4e5c 20407e1c call save_cont_pointers 
+4e5d 20407e21 call load_cont_pointers 
+4e5e d9000000 arg 0 ,debug 
+4e5f e8c08000 ifetch 1 ,contr 
+4e60 1fe20e00 copy pdata ,queue 
+4e61 e8c10000 ifetch 2 ,contr 
+4e62 1fe22200 copy pdata ,rega 
+4e63 e8c10000 ifetch 2 ,contr 
+4e64 1fe20400 copy pdata ,temp 
+4e65 e8c10000 ifetch 2 ,contr 
+4e66 1fe21600 copy pdata ,timeup 
+4e67 18427e00 copy temp ,pdata 
+4e68 c000ce6e beq psm_sdp ,l2cap_proc_signal_connect_req_sdp 
+4e69 c001ce90 beq psm_rfcomm ,l2cap_proc_signal_connect_req_rfcomm 
+4e6a c008ce9c beq psm_hid_control ,l2cap_proc_signal_connect_req_hid_ctrl 
+4e6b c009cea7 beq psm_hid_interrupt ,l2cap_proc_signal_connect_req_hid_int 
+4e6c 2040506a call l2cap_reject_command 
+4e6d 20204edf branch l2cap_proc_signal_connect_req_rtn 
+
+l2cap_proc_signal_connect_req_sdp:
+4e6e 20407e1c call save_cont_pointers 
+4e6f d8400050 arg l2cap_sdp_channel ,temp 
+4e70 680142b1 fetch 2 ,mem_sdp_remote_cid 
+4e71 243a4ed9 nbranch already_connected ,blank 
+4e72 19627e00 copy timeup ,pdata 
+4e73 600142b1 store 2 ,mem_sdp_remote_cid 
+4e74 1c427e00 copy clkn_bt ,pdata 
+4e75 6002033c store 4 ,mem_l2cap_sdpres_delay_time 
+4e76 20404e78 call store_l2cap_req_param 
+4e77 20204eb3 branch send_connection_pending 
+
+store_l2cap_req_param:
+4e78 6009033a storet 2 ,mem_psm 
+4e79 19627e00 deposit timeup 
+4e7a 60010330 store 2 ,mem_scid 
+4e7b 1a227e00 deposit rega 
+4e7c 60010332 store 2 ,mem_cmd_length 
+4e7d 1a427e00 deposit regb 
+4e7e 60010334 store 2 ,mem_tt2 
+4e7f 1a627e00 deposit regc 
+4e80 60010336 store 2 ,mem_tt3 
+4e81 18e27e00 deposit queue 
+4e82 60010338 store 2 ,mem_id 
+4e83 20600000 rtn 
+
+restore_l2cap_req_param:
+4e84 6809033a fetcht 2 ,mem_psm 
+4e85 68010330 fetch 2 ,mem_scid 
+4e86 1fe21600 copy pdata ,timeup 
+4e87 68010332 fetch 2 ,mem_cmd_length 
+4e88 1fe22200 copy pdata ,rega 
+4e89 68010334 fetch 2 ,mem_tt2 
+4e8a 1fe22400 copy pdata ,regb 
+4e8b 68010336 fetch 2 ,mem_tt3 
+4e8c 1fe22600 copy pdata ,regc 
+4e8d 68010338 fetch 2 ,mem_id 
+4e8e 1fe20e00 copy pdata ,queue 
+4e8f 20600000 rtn 
+
+l2cap_proc_signal_connect_req_rfcomm:
+4e90 20407e1c call save_cont_pointers 
+4e91 58000051 setarg l2cap_rfcomm_channel 
+4e92 d8400051 arg l2cap_rfcomm_channel ,temp 
+4e93 680142b3 fetch 2 ,mem_rfcomm_remote_cid 
+4e94 243a4ed9 nbranch already_connected ,blank 
+4e95 19627e00 copy timeup ,pdata 
+4e96 600142b3 store 2 ,mem_rfcomm_remote_cid 
+4e97 6800c2ba fetch 1 ,mem_rfcomm_state 
+4e98 79207e00 set1 l2cap_channel_state_conn_req ,pdata 
+4e99 79207e01 set1 l2cap_channel_state_conn_res ,pdata 
+4e9a 6000c2ba store 1 ,mem_rfcomm_state 
+4e9b 20204ebb branch send_connection_res 
+
+l2cap_proc_signal_connect_req_hid_ctrl:
+4e9c 20407e1c call save_cont_pointers 
+4e9d d8400052 arg l2cap_hid_control_channel ,temp 
+4e9e 680142b5 fetch 2 ,mem_hid_ctrl_remote_cid 
+4e9f 243a4ed9 nbranch already_connected ,blank 
+4ea0 19627e00 copy timeup ,pdata 
+4ea1 600142b5 store 2 ,mem_hid_ctrl_remote_cid 
+4ea2 6800c2bb fetch 1 ,mem_hid_control_state 
+4ea3 79207e00 set1 l2cap_channel_state_conn_req ,pdata 
+4ea4 79207e01 set1 l2cap_channel_state_conn_res ,pdata 
+4ea5 6000c2bb store 1 ,mem_hid_control_state 
+4ea6 20204ebb branch send_connection_res 
+
+l2cap_proc_signal_connect_req_hid_int:
+4ea7 20407e1c call save_cont_pointers 
+4ea8 1b427e00 deposit clke 
+4ea9 d8400053 arg l2cap_hid_interrupt_channel ,temp 
+4eaa 680142b7 fetch 2 ,mem_hid_int_remote_cid 
+4eab 243a4ed9 nbranch already_connected ,blank 
+4eac 19627e00 copy timeup ,pdata 
+4ead 600142b7 store 2 ,mem_hid_int_remote_cid 
+4eae 6800c2bc fetch 1 ,mem_hid_interrupt_state 
+4eaf 79207e00 set1 l2cap_channel_state_conn_req ,pdata 
+4eb0 79207e01 set1 l2cap_channel_state_conn_res ,pdata 
+4eb1 6000c2bc store 1 ,mem_hid_interrupt_state 
+4eb2 20204ebb branch send_connection_res 
+
+send_connection_pending:
+4eb3 58000001 setarg l2cap_connect_pending 
+4eb4 600102e4 store 2 ,meml2cap_t1 
+4eb5 7043cd50 jam l2cap_sdp_channel ,mem_l2cap_pending_item 
+4eb6 20204ebd branch send_connection_res0 
+
+send_connection_sdp_res:
+4eb7 6800c2b9 fetch 1 ,mem_sdp_state 
+4eb8 79207e00 set1 l2cap_channel_state_conn_req ,pdata 
+4eb9 79207e01 set1 l2cap_channel_state_conn_res ,pdata 
+4eba 6000c2b9 store 1 ,mem_sdp_state 
+
+send_connection_res:
+4ebb 58000000 setarg l2cap_connect_successful 
+4ebc 600102e4 store 2 ,meml2cap_t1 
+
+send_connection_res0:
+4ebd 79200025 set1 mark_ext_patch ,mark 
+4ebe 448e4023 bpatch patch23_4 ,mem_patch23 
+4ebf 20407e21 call load_cont_pointers 
+4ec0 58000003 setarg signal_connect_rsp 
+4ec1 e0a08000 istore 1 ,contw 
+4ec2 18e27e00 copy queue ,pdata 
+4ec3 e0a08000 istore 1 ,contw 
+4ec4 58000008 setarg 0x0008 
+4ec5 e0a10000 istore 2 ,contw 
+4ec6 18427e00 copy temp ,pdata 
+4ec7 e0a10000 istore 2 ,contw 
+4ec8 19627e00 copy timeup ,pdata 
+4ec9 e0a10000 istore 2 ,contw 
+4eca 680102e4 fetch 2 ,meml2cap_t1 
+4ecb c000ced4 beq l2cap_connect_pending ,connect_pending 
+4ecc 290c0000 isolate0 0 ,debug 
+4ecd 2020cecf branch connect_suc ,true 
+4ece 58000004 setarg l2cap_connect_refused_no_resources 
+
+connect_suc:
+4ecf e0a10000 istore 2 ,contw 
+4ed0 18007e00 force 0x0000 ,pdata 
+4ed1 e0a10000 istore 2 ,contw 
+4ed2 5800000c setarg 12 
+4ed3 20204edb branch connect_req_update_byte_counts 
+
+connect_pending:
+4ed4 e0a10000 istore 2 ,contw 
+4ed5 18007e02 force 0x0002 ,pdata 
+4ed6 e0a10000 istore 2 ,contw 
+4ed7 5800000c setarg 12 
+4ed8 20204edb branch connect_req_update_byte_counts 
+
+already_connected:
+4ed9 79201000 set1 0 ,debug 
+4eda 20204ebb branch send_connection_res 
+
+connect_req_update_byte_counts:
+4edb 9a40a400 iadd regb ,regb 
+4edc 1a627e00 copy regc ,pdata 
+4edd 9a262600 isub rega ,regc 
+4ede 20204edf branch l2cap_proc_signal_connect_req_rtn 
+
+l2cap_proc_signal_connect_req_rtn:
+4edf 20204e20 branch l2cap_process_one_signal_rtn 
+
+l2cap_proc_signal_connect_rsp:
+4ee0 e8c08000 ifetch 1 ,contr 
+4ee1 1fe20e00 copy pdata ,queue 
+4ee2 e8c10000 ifetch 2 ,contr 
+4ee3 1fe22200 copy pdata ,rega 
+4ee4 1a627e00 copy regc ,pdata 
+4ee5 9a262600 isub rega ,regc 
+4ee6 e8c10000 ifetch 2 ,contr 
+4ee7 1fe21600 copy pdata ,timeup 
+4ee8 e8c10000 ifetch 2 ,contr 
+4ee9 1fe20400 copy pdata ,temp 
+4eea 58000050 setarg l2cap_sdp_channel 
+4eeb 98467c00 isub temp ,null 
+4eec 2022cef7 branch l2cap_proc_signal_connect_rsp_sdp ,zero 
+4eed 58000051 setarg l2cap_rfcomm_channel 
+4eee 98467c00 isub temp ,null 
+4eef 2022cefd branch l2cap_proc_signal_connect_rsp_rfcomm ,zero 
+4ef0 58000052 setarg l2cap_hid_control_channel 
+4ef1 98467c00 isub temp ,null 
+4ef2 2022cf09 branch l2cap_proc_signal_connect_rsp_hid_ctrl ,zero 
+4ef3 58000053 setarg l2cap_hid_interrupt_channel 
+4ef4 98467c00 isub temp ,null 
+4ef5 2022cf03 branch l2cap_proc_signal_connect_rsp_hid_int ,zero 
+4ef6 20600000 rtn 
+
+l2cap_proc_signal_connect_rsp_sdp:
+4ef7 19627e00 copy timeup ,pdata 
+4ef8 600142b1 store 2 ,mem_sdp_remote_cid 
+4ef9 6800c2b9 fetch 1 ,mem_sdp_state 
+4efa 79207e01 set1 l2cap_channel_state_conn_res ,pdata 
+4efb 6000c2b9 store 1 ,mem_sdp_state 
+4efc 20204e20 branch l2cap_process_one_signal_rtn 
+
+l2cap_proc_signal_connect_rsp_rfcomm:
+4efd 19627e00 copy timeup ,pdata 
+4efe 600142b3 store 2 ,mem_rfcomm_remote_cid 
+4eff 6800c2ba fetch 1 ,mem_rfcomm_state 
+4f00 79207e01 set1 l2cap_channel_state_conn_res ,pdata 
+4f01 6000c2ba store 1 ,mem_rfcomm_state 
+4f02 20600000 rtn 
+
+l2cap_proc_signal_connect_rsp_hid_int:
+4f03 19627e00 copy timeup ,pdata 
+4f04 600142b5 store 2 ,mem_hid_ctrl_remote_cid 
+4f05 6800c2bc fetch 1 ,mem_hid_interrupt_state 
+4f06 79207e01 set1 l2cap_channel_state_conn_res ,pdata 
+4f07 6000c2bc store 1 ,mem_hid_interrupt_state 
+4f08 20600000 rtn 
+
+l2cap_proc_signal_connect_rsp_hid_ctrl:
+4f09 19627e00 copy timeup ,pdata 
+4f0a 600142b7 store 2 ,mem_hid_int_remote_cid 
+4f0b 6800c2bb fetch 1 ,mem_hid_control_state 
+4f0c 79207e01 set1 l2cap_channel_state_conn_res ,pdata 
+4f0d 6000c2bb store 1 ,mem_hid_control_state 
+4f0e 20600000 rtn 
+
+l2cap_proc_signal_config_req:
+4f0f e8c08000 ifetch 1 ,contr 
+4f10 1fe20e00 copy pdata ,queue 
+4f11 e8c10000 ifetch 2 ,contr 
+4f12 1fe22200 copy pdata ,rega 
+4f13 1a627e00 copy regc ,pdata 
+4f14 9a262600 isub rega ,regc 
+4f15 e8c10000 ifetch 2 ,contr 
+4f16 1fe20400 copy pdata ,temp 
+4f17 18422200 copy temp ,rega 
+4f18 58000050 setarg l2cap_sdp_channel 
+4f19 98467c00 isub temp ,null 
+4f1a 2022cf25 branch l2cap_proc_signal_config_req_sdp ,zero 
+4f1b 58000051 setarg l2cap_rfcomm_channel 
+4f1c 98467c00 isub temp ,null 
+4f1d 2022cf43 branch l2cap_proc_signal_config_req_rfcomm ,zero 
+4f1e 58000052 setarg l2cap_hid_control_channel 
+4f1f 98467c00 isub temp ,null 
+4f20 2022cf2f branch l2cap_proc_signal_config_req_hid_ctrl ,zero 
+4f21 58000053 setarg l2cap_hid_interrupt_channel 
+4f22 98467c00 isub temp ,null 
+4f23 2022cf39 branch l2cap_proc_signal_config_req_hid_int ,zero 
+4f24 2020506a branch l2cap_reject_command 
+
+l2cap_proc_signal_config_req_sdp:
+4f25 18a21600 copy contw ,timeup 
+4f26 6800c2b9 fetch 1 ,mem_sdp_state 
+4f27 79207e04 set1 l2cap_channel_state_rcv_cfg_req ,pdata 
+4f28 79207e03 set1 l2cap_channel_state_snd_cfg_res ,pdata 
+4f29 6000c2b9 store 1 ,mem_sdp_state 
+4f2a 19620a00 copy timeup ,contw 
+4f2b d9600050 arg l2cap_sdp_channel ,timeup 
+4f2c 680142b1 fetch 2 ,mem_sdp_remote_cid 
+4f2d 1fe20400 copy pdata ,temp 
+4f2e 20204f4c branch l2cap_send_config_rsp 
+
+l2cap_proc_signal_config_req_hid_ctrl:
+4f2f 18a21600 copy contw ,timeup 
+4f30 6800c2bb fetch 1 ,mem_hid_control_state 
+4f31 79207e04 set1 l2cap_channel_state_rcv_cfg_req ,pdata 
+4f32 79207e03 set1 l2cap_channel_state_snd_cfg_res ,pdata 
+4f33 6000c2bb store 1 ,mem_hid_control_state 
+4f34 19620a00 copy timeup ,contw 
+4f35 d9600052 arg l2cap_hid_control_channel ,timeup 
+4f36 680142b5 fetch 2 ,mem_hid_ctrl_remote_cid 
+4f37 1fe20400 copy pdata ,temp 
+4f38 20204f4c branch l2cap_send_config_rsp 
+
+l2cap_proc_signal_config_req_hid_int:
+4f39 18a21600 copy contw ,timeup 
+4f3a 6800c2bc fetch 1 ,mem_hid_interrupt_state 
+4f3b 79207e04 set1 l2cap_channel_state_rcv_cfg_req ,pdata 
+4f3c 79207e03 set1 l2cap_channel_state_snd_cfg_res ,pdata 
+4f3d 6000c2bc store 1 ,mem_hid_interrupt_state 
+4f3e 19620a00 copy timeup ,contw 
+4f3f d9600053 arg l2cap_hid_interrupt_channel ,timeup 
+4f40 680142b7 fetch 2 ,mem_hid_int_remote_cid 
+4f41 1fe20400 copy pdata ,temp 
+4f42 20204f4c branch l2cap_send_config_rsp 
+
+l2cap_proc_signal_config_req_rfcomm:
+4f43 18a21600 copy contw ,timeup 
+4f44 6800c2ba fetch 1 ,mem_rfcomm_state 
+4f45 79207e04 set1 l2cap_channel_state_rcv_cfg_req ,pdata 
+4f46 79207e03 set1 l2cap_channel_state_snd_cfg_res ,pdata 
+4f47 6000c2ba store 1 ,mem_rfcomm_state 
+4f48 19620a00 copy timeup ,contw 
+4f49 d9600051 arg l2cap_rfcomm_channel ,timeup 
+4f4a 680142b3 fetch 2 ,mem_rfcomm_remote_cid 
+4f4b 1fe20400 copy pdata ,temp 
+
+l2cap_send_config_rsp:
+4f4c 79200025 set1 mark_ext_patch ,mark 
+4f4d 448ec023 bpatch patch23_5 ,mem_patch23 
+4f4e 58000005 setarg signal_config_rsp 
+4f4f e0a08000 istore 1 ,contw 
+4f50 18e27e00 copy queue ,pdata 
+4f51 e0a08000 istore 1 ,contw 
+4f52 58000006 setarg 0x0006 
+4f53 e0a10000 istore 2 ,contw 
+4f54 18427e00 copy temp ,pdata 
+4f55 e0a10000 istore 2 ,contw 
+4f56 18007e00 force 0x00 ,pdata 
+4f57 e0a10000 istore 2 ,contw 
+4f58 18007e00 force l2cap_config_success ,pdata 
+4f59 e0a10000 istore 2 ,contw 
+4f5a 18007e0a force 10 ,pdata 
+4f5b 9a40a400 iadd regb ,regb 
+4f5c 600902e9 storet 2 ,mem_config_req_dest_cid 
+4f5d 18e27e00 copy queue ,pdata 
+4f5e 600082e8 store 1 ,mem_config_identifier 
+4f5f 18007e50 force l2cap_sdp_channel ,pdata 
+4f60 a961fe00 icompare 0xff ,timeup 
+4f61 2020cf63 branch l2cap_send_config_rsp_is_sdp ,true 
+4f62 1fe0fe01 increase 1 ,pdata 
+
+l2cap_send_config_rsp_is_sdp:
+4f63 20600000 rtn 
+
+l2cap_check_channel_state:
+4f64 78547c00 disable user 
+4f65 c3810000 rtnbit1 l2cap_channel_state_snd_cfg_req ,pdata 
+4f66 c4000000 rtnbit0 l2cap_channel_state_conn_req ,pdata 
+4f67 c4008000 rtnbit0 l2cap_channel_state_conn_res ,pdata 
+4f68 79207e02 set1 l2cap_channel_state_snd_cfg_req ,pdata 
+4f69 18c20a00 copy contr ,contw 
+4f6a 18a08bff increase -1 ,contw 
+4f6b e0a08000 istore 1 ,contw 
+4f6c 78347c00 enable user 
+4f6d 20600000 rtn 
+
+l2cap_send_config_req:
+
+l2cap_send_config_req_sdp:
+4f6e 6800c2b9 fetch 1 ,mem_sdp_state 
+4f6f 20404f64 call l2cap_check_channel_state 
+4f70 24344f75 nbranch l2cap_send_config_req_rfcomm ,user 
+4f71 7002e750 jam l2cap_sdp_channel ,mem_send_config_req 
+4f72 680142b1 fetch 2 ,mem_sdp_remote_cid 
+4f73 600102e9 store 2 ,mem_config_req_dest_cid 
+4f74 20204f89 branch l2cap_generate_config_req 
+
+l2cap_send_config_req_rfcomm:
+4f75 6800c2ba fetch 1 ,mem_rfcomm_state 
+4f76 20404f64 call l2cap_check_channel_state 
+4f77 24344f7c nbranch l2cap_send_config_req_hid_ctrl ,user 
+4f78 7002e751 jam l2cap_rfcomm_channel ,mem_send_config_req 
+4f79 680142b3 fetch 2 ,mem_rfcomm_remote_cid 
+4f7a 600102e9 store 2 ,mem_config_req_dest_cid 
+4f7b 20204f89 branch l2cap_generate_config_req 
+
+l2cap_send_config_req_hid_ctrl:
+4f7c 6800c2bb fetch 1 ,mem_hid_control_state 
+4f7d 20404f64 call l2cap_check_channel_state 
+4f7e 24344f83 nbranch l2cap_send_config_req_hid_int ,user 
+4f7f 7002e752 jam l2cap_hid_control_channel ,mem_send_config_req 
+4f80 680142b5 fetch 2 ,mem_hid_ctrl_remote_cid 
+4f81 600102e9 store 2 ,mem_config_req_dest_cid 
+4f82 20204f89 branch l2cap_generate_config_req 
+
+l2cap_send_config_req_hid_int:
+4f83 6800c2bc fetch 1 ,mem_hid_interrupt_state 
+4f84 20404f64 call l2cap_check_channel_state 
+4f85 24740000 nrtn user 
+4f86 7002e753 jam l2cap_hid_interrupt_channel ,mem_send_config_req 
+4f87 680142b7 fetch 2 ,mem_hid_int_remote_cid 
+4f88 600102e9 store 2 ,mem_config_req_dest_cid 
+
+l2cap_generate_config_req:
+4f89 79200025 set1 mark_ext_patch ,mark 
+4f8a 448f4023 bpatch patch23_6 ,mem_patch23 
+4f8b 20405242 call l2cap_get_req_id 
+4f8c 204052c4 call l2cap_malloc_signal_channel 
+4f8d 18002400 force 0 ,regb 
+4f8e 204052d0 call l2cap_get_signal_tx_payload 
+4f8f 18007e04 force signal_config_req ,pdata 
+4f90 e0a08000 istore 1 ,contw 
+4f91 6800c2be fetch 1 ,mem_ml2cap_comm_id 
+4f92 e0a08000 istore 1 ,contw 
+4f93 58000008 setarg 0x0008 
+4f94 e0a10000 istore 2 ,contw 
+4f95 680102e9 fetch 2 ,mem_config_req_dest_cid 
+4f96 e0a10000 istore 2 ,contw 
+4f97 58000000 setarg 0x0000 
+4f98 e0a10000 istore 2 ,contw 
+4f99 18007e01 force 1 ,pdata 
+4f9a e0a08000 istore 1 ,contw 
+4f9b 18007e02 force 2 ,pdata 
+4f9c e0a08000 istore 1 ,contw 
+4f9d 680082e7 fetch 1 ,mem_send_config_req 
+4f9e c028cfa2 beq l2cap_rfcomm_channel ,l2cap_generate_config_req_rfcomm 
+4f9f 58000030 setarg l2cap_config_mtu_sdp 
+4fa0 e0a10000 istore 2 ,contw 
+4fa1 20204fa4 branch l2cap_generate_config_req_done 
+
+l2cap_generate_config_req_rfcomm:
+4fa2 580003e3 setarg l2cap_config_mtu_rfcomm 
+4fa3 e0a10000 istore 2 ,contw 
+
+l2cap_generate_config_req_done:
+4fa4 d840000c arg 0x0c ,temp 
+4fa5 600902d6 storet 2 ,mem_l2cap_signal_tx_length 
+4fa6 204052ce call l2cap_get_signal_tx_buff 
+4fa7 680102d6 fetch 2 ,mem_l2cap_signal_tx_length 
+4fa8 e0a10000 istore 2 ,contw 
+4fa9 18007e01 force l2cap_signal_channel ,pdata 
+4faa e0a10000 istore 2 ,contw 
+4fab 7002e700 jam 0 ,mem_send_config_req 
+
+l2cap_proc_signal_config_req_rtn:
+4fac 20204e20 branch l2cap_process_one_signal_rtn 
+
+l2cap_proc_signal_config_rsp:
+4fad 18c08c01 increase 1 ,contr 
+4fae e8c10000 ifetch 2 ,contr 
+4faf 1fe22200 copy pdata ,rega 
+4fb0 1a627e00 copy regc ,pdata 
+4fb1 9a262600 isub rega ,regc 
+4fb2 e8c10000 ifetch 2 ,contr 
+4fb3 1fe22200 copy pdata ,rega 
+4fb4 58000050 setarg l2cap_sdp_channel 
+4fb5 9a267c00 isub rega ,null 
+4fb6 2022cfc4 branch l2cap_proc_signal_config_rsp_sdp ,zero 
+4fb7 58000051 setarg l2cap_rfcomm_channel 
+4fb8 9a267c00 isub rega ,null 
+4fb9 2022cfc8 branch l2cap_proc_signal_config_rsp_rfcomm ,zero 
+4fba 58000052 setarg l2cap_hid_control_channel 
+4fbb 9a267c00 isub rega ,null 
+4fbc 2022cfcc branch l2cap_proc_signal_config_rsp_hid_ctrl ,zero 
+4fbd 58000053 setarg l2cap_hid_interrupt_channel 
+4fbe 9a267c00 isub rega ,null 
+4fbf 2022cfd0 branch l2cap_proc_signal_config_rsp_hid_int ,zero 
+4fc0 18c08c02 increase 2 ,contr 
+4fc1 e8c10000 ifetch 2 ,contr 
+4fc2 98007c00 iforce null 
+4fc3 20204e20 branch l2cap_process_one_signal_rtn 
+
+l2cap_proc_signal_config_rsp_sdp:
+4fc4 6800c2b9 fetch 1 ,mem_sdp_state 
+4fc5 79207e05 set1 l2cap_channel_state_rcv_cfg_res ,pdata 
+4fc6 6000c2b9 store 1 ,mem_sdp_state 
+4fc7 20204e20 branch l2cap_process_one_signal_rtn 
+
+l2cap_proc_signal_config_rsp_rfcomm:
+4fc8 6800c2ba fetch 1 ,mem_rfcomm_state 
+4fc9 79207e05 set1 l2cap_channel_state_rcv_cfg_res ,pdata 
+4fca 6000c2ba store 1 ,mem_rfcomm_state 
+4fcb 20204e20 branch l2cap_process_one_signal_rtn 
+
+l2cap_proc_signal_config_rsp_hid_ctrl:
+4fcc 6800c2bb fetch 1 ,mem_hid_control_state 
+4fcd 79207e05 set1 l2cap_channel_state_rcv_cfg_res ,pdata 
+4fce 6000c2bb store 1 ,mem_hid_control_state 
+4fcf 20204e20 branch l2cap_process_one_signal_rtn 
+
+l2cap_proc_signal_config_rsp_hid_int:
+4fd0 6800c2bc fetch 1 ,mem_hid_interrupt_state 
+4fd1 79207e05 set1 l2cap_channel_state_rcv_cfg_res ,pdata 
+4fd2 6000c2bc store 1 ,mem_hid_interrupt_state 
+4fd3 700b7d06 jam bt_evt_hid_connected ,mem_fifo_temp 
+4fd4 20207c27 branch ui_ipc_send_event 
+
+l2cap_proc_signal_disconnect_req:
+4fd5 e8c08000 ifetch 1 ,contr 
+4fd6 1fe20e00 copy pdata ,queue 
+4fd7 e8c10000 ifetch 2 ,contr 
+4fd8 1fe22200 copy pdata ,rega 
+4fd9 1a627e00 copy regc ,pdata 
+4fda 9a262600 isub rega ,regc 
+4fdb e8c10000 ifetch 2 ,contr 
+4fdc 1fe22200 copy pdata ,rega 
+4fdd e8c10000 ifetch 2 ,contr 
+4fde 1fe21600 copy pdata ,timeup 
+4fdf 1a220400 copy rega ,temp 
+4fe0 20407e1c call save_cont_pointers 
+4fe1 58000050 setarg l2cap_sdp_channel 
+4fe2 98467c00 isub temp ,null 
+4fe3 2022cffb branch l2cap_proc_signal_disconnect_req_sdp ,zero 
+4fe4 58000051 setarg l2cap_rfcomm_channel 
+4fe5 98467c00 isub temp ,null 
+4fe6 2022d00b branch l2cap_proc_signal_disconnect_req_rfcomm ,zero 
+4fe7 58000052 setarg l2cap_hid_control_channel 
+4fe8 98467c00 isub temp ,null 
+4fe9 2022cfef branch l2cap_proc_signal_disconnect_req_hid_ctrl ,zero 
+4fea 58000053 setarg l2cap_hid_interrupt_channel 
+4feb 98467c00 isub temp ,null 
+4fec 2022cff5 branch l2cap_proc_signal_disconnect_req_hid_int ,zero 
+4fed 2040506a call l2cap_reject_command 
+4fee 20205020 branch l2cap_proc_signal_disconnect_req_err_rtn 
+
+l2cap_proc_signal_disconnect_req_hid_ctrl:
+4fef 19620400 copy timeup ,temp 
+4ff0 680142b5 fetch 2 ,mem_hid_ctrl_remote_cid 
+4ff1 98467c00 isub temp ,null 
+4ff2 2022d001 branch l2cap_disconnect_hid_control_now ,zero 
+4ff3 2040506a call l2cap_reject_command 
+4ff4 20205020 branch l2cap_proc_signal_disconnect_req_err_rtn 
+
+l2cap_proc_signal_disconnect_req_hid_int:
+4ff5 19620400 copy timeup ,temp 
+4ff6 680142b7 fetch 2 ,mem_hid_int_remote_cid 
+4ff7 98467c00 isub temp ,null 
+4ff8 2022d003 branch l2cap_disconnect_hid_interrupt_now ,zero 
+4ff9 2040506a call l2cap_reject_command 
+4ffa 20205020 branch l2cap_proc_signal_disconnect_req_err_rtn 
+
+l2cap_proc_signal_disconnect_req_sdp:
+4ffb 19620400 copy timeup ,temp 
+4ffc 680142b1 fetch 2 ,mem_sdp_remote_cid 
+4ffd 98467c00 isub temp ,null 
+4ffe 2022d007 branch l2cap_disconnect_sdp_now ,zero 
+4fff 2040506a call l2cap_reject_command 
+5000 20205020 branch l2cap_proc_signal_disconnect_req_err_rtn 
+
+l2cap_disconnect_hid_control_now:
+5001 20405081 call l2cap_reset_hid_ctrl_state 
+5002 20205013 branch l2cap_send_disconnect_rsp_pkt 
+
+l2cap_disconnect_hid_interrupt_now:
+5003 20405087 call l2cap_reset_hid_int_state 
+5004 680142b5 fetch 2 ,mem_hid_ctrl_remote_cid 
+5005 203a5013 branch l2cap_send_disconnect_rsp_pkt ,blank 
+5006 20205013 branch l2cap_send_disconnect_rsp_pkt 
+
+l2cap_disconnect_sdp_now:
+5007 2040507c call l2cap_reset_sdp_channel_state 
+5008 680082ef fetch 1 ,mem_upper_sm_ss 
+5009 243a5013 nbranch l2cap_send_disconnect_rsp_pkt ,blank 
+500a 20205013 branch l2cap_send_disconnect_rsp_pkt 
+
+l2cap_proc_signal_disconnect_req_rfcomm:
+500b 19620400 copy timeup ,temp 
+500c 680142b3 fetch 2 ,mem_rfcomm_remote_cid 
+500d 98467c00 isub temp ,null 
+500e 2022d011 branch l2cap_disconnect_rfcomm_now ,zero 
+500f 2040506a call l2cap_reject_command 
+5010 20205020 branch l2cap_proc_signal_disconnect_req_err_rtn 
+
+l2cap_disconnect_rfcomm_now:
+5011 20405077 call l2cap_reset_rfcomm_channel_state 
+5012 20205013 branch l2cap_send_disconnect_rsp_pkt 
+
+l2cap_send_disconnect_rsp_pkt:
+5013 20407e21 call load_cont_pointers 
+5014 58000007 setarg signal_disconnect_rsp 
+5015 e0a08000 istore 1 ,contw 
+5016 18e27e00 copy queue ,pdata 
+5017 e0a08000 istore 1 ,contw 
+5018 58000004 setarg 0x0004 
+5019 e0a10000 istore 2 ,contw 
+501a 1a227e00 copy rega ,pdata 
+501b e0a10000 istore 2 ,contw 
+501c 19627e00 copy timeup ,pdata 
+501d e0a10000 istore 2 ,contw 
+501e 18007e08 force 8 ,pdata 
+501f 20205022 branch l2cap_proc_signal_disconnect_req_rtn 
+
+l2cap_proc_signal_disconnect_req_err_rtn:
+5020 20407e21 call load_cont_pointers 
+5021 20205022 branch l2cap_proc_signal_disconnect_req_rtn 
+
+l2cap_proc_signal_disconnect_req_rtn:
+5022 9a40a400 iadd regb ,regb 
+5023 20204e20 branch l2cap_process_one_signal_rtn 
+
+l2cap_proc_signal_disconnect_rsp:
+5024 e8c08000 ifetch 1 ,contr 
+5025 1fe20e00 copy pdata ,queue 
+5026 e8c10000 ifetch 2 ,contr 
+5027 1fe22200 copy pdata ,rega 
+5028 1a627e00 copy regc ,pdata 
+5029 9a262600 isub rega ,regc 
+502a e8c10000 ifetch 2 ,contr 
+502b 1fe21600 copy pdata ,timeup 
+502c e8c10000 ifetch 2 ,contr 
+502d 1fe20400 copy pdata ,temp 
+502e 20407e1c call save_cont_pointers 
+502f 58000050 setarg l2cap_sdp_channel 
+5030 98467c00 isub temp ,null 
+5031 2022d03d branch l2cap_proc_signal_disconnect_rsp_sdp ,zero 
+5032 58000051 setarg l2cap_rfcomm_channel 
+5033 98467c00 isub temp ,null 
+5034 2022d043 branch l2cap_proc_signal_disconnect_rsp_rfcomm ,zero 
+5035 58000052 setarg l2cap_hid_control_channel 
+5036 98467c00 isub temp ,null 
+5037 2022d049 branch l2cap_proc_signal_disconnect_rsp_hid_ctrl ,zero 
+5038 58000053 setarg l2cap_hid_interrupt_channel 
+5039 98467c00 isub temp ,null 
+503a 2022d04f branch l2cap_proc_signal_disconnect_rsp_hid_int ,zero 
+503b 2040506a call l2cap_reject_command 
+503c 20205057 branch l2cap_proc_signal_disconnect_rsp_err_rtn 
+
+l2cap_proc_signal_disconnect_rsp_sdp:
+503d 18422200 copy temp ,rega 
+503e 19620400 copy timeup ,temp 
+503f 680142b1 fetch 2 ,mem_sdp_remote_cid 
+5040 98467c00 isub temp ,null 
+5041 2042d07c call l2cap_reset_sdp_channel_state ,zero 
+5042 20205055 branch l2cap_proc_signal_disconnect_rsp_rtn 
+
+l2cap_proc_signal_disconnect_rsp_rfcomm:
+5043 18422200 copy temp ,rega 
+5044 19620400 copy timeup ,temp 
+5045 680142b3 fetch 2 ,mem_rfcomm_remote_cid 
+5046 98467c00 isub temp ,null 
+5047 2042d077 call l2cap_reset_rfcomm_channel_state ,zero 
+5048 20205055 branch l2cap_proc_signal_disconnect_rsp_rtn 
+
+l2cap_proc_signal_disconnect_rsp_hid_ctrl:
+5049 18422200 copy temp ,rega 
+504a 19620400 copy timeup ,temp 
+504b 680142b5 fetch 2 ,mem_hid_ctrl_remote_cid 
+504c 98467c00 isub temp ,null 
+504d 2042d081 call l2cap_reset_hid_ctrl_state ,zero 
+504e 20205055 branch l2cap_proc_signal_disconnect_rsp_rtn 
+
+l2cap_proc_signal_disconnect_rsp_hid_int:
+504f 18422200 copy temp ,rega 
+5050 19620400 copy timeup ,temp 
+5051 680142b7 fetch 2 ,mem_hid_int_remote_cid 
+5052 98467c00 isub temp ,null 
+5053 2042d087 call l2cap_reset_hid_int_state ,zero 
+5054 20205055 branch l2cap_proc_signal_disconnect_rsp_rtn 
+
+l2cap_proc_signal_disconnect_rsp_rtn:
+5055 20407e21 call load_cont_pointers 
+5056 20204e20 branch l2cap_process_one_signal_rtn 
+
+l2cap_proc_signal_disconnect_rsp_err_rtn:
+5057 20204e20 branch l2cap_process_one_signal_rtn 
+
+l2cap_proc_signal_echo_req:
+5058 e8c08000 ifetch 1 ,contr 
+5059 1fe20e00 copy pdata ,queue 
+505a e8c10000 ifetch 2 ,contr 
+505b 1fe22200 copy pdata ,rega 
+505c 98c08c00 iadd contr ,contr 
+505d 58000009 setarg 9 
+505e e0a08000 istore 1 ,contw 
+505f 18e27e00 copy queue ,pdata 
+5060 e0a08000 istore 1 ,contw 
+5061 18007e00 force 0x0000 ,pdata 
+5062 e0a10000 istore 2 ,contw 
+5063 18007e04 force 4 ,pdata 
+5064 9a40a400 iadd regb ,regb 
+5065 1a627e00 copy regc ,pdata 
+5066 9a262600 isub rega ,regc 
+5067 20204e20 branch l2cap_process_one_signal_rtn 
+
+l2cap_proc_signal_echo_rsp:
+5068 20204e20 branch l2cap_process_one_signal_rtn 
+
+l2cap_proc_signal_info_rsp:
+5069 20204e20 branch l2cap_process_one_signal_rtn 
+
+l2cap_reject_command:
+506a 18002400 force 0 ,regb 
+506b 204052d0 call l2cap_get_signal_tx_payload 
+506c 58000001 setarg signal_cmd_reject 
+506d e0a08000 istore 1 ,contw 
+506e 18e27e00 copy queue ,pdata 
+506f e0a08000 istore 1 ,contw 
+5070 58000002 setarg 2 
+5071 e0a10000 istore 2 ,contw 
+5072 58000000 setarg cmd_not_understood 
+5073 e0a10000 istore 2 ,contw 
+5074 1a40a406 increase 6 ,regb 
+5075 da600004 arg 4 ,regc 
+5076 20204e20 branch l2cap_process_one_signal_rtn 
+
+l2cap_reset_rfcomm_channel_state:
+5077 58000000 setarg 0 
+5078 600102e2 store 2 ,mem_rfcomm_tx_pkt_length 
+5079 600142b3 store 2 ,mem_rfcomm_remote_cid 
+507a 7042ba00 jam 0 ,mem_rfcomm_state 
+507b 20600000 rtn 
+
+l2cap_reset_sdp_channel_state:
+507c 58000000 setarg 0 
+507d 600102dc store 2 ,mem_sdp_tx_pkt_length 
+507e 600142b1 store 2 ,mem_sdp_remote_cid 
+507f 7042b900 jam 0 ,mem_sdp_state 
+5080 20600000 rtn 
+
+l2cap_reset_hid_ctrl_state:
+5081 58000000 setarg 0 
+5082 600142b5 store 2 ,mem_hid_ctrl_remote_cid 
+5083 7042bb00 jam 0 ,mem_hid_control_state 
+5084 6800c2bc fetch 1 ,mem_hid_interrupt_state 
+5085 c000508d beq 0 ,l2cap_reset_hid_disconnected 
+5086 20600000 rtn 
+
+l2cap_reset_hid_int_state:
+5087 58000000 setarg 0 
+5088 600142b7 store 2 ,mem_hid_int_remote_cid 
+5089 7042bc00 jam 0 ,mem_hid_interrupt_state 
+508a 6800c2bb fetch 1 ,mem_hid_control_state 
+508b c000508d beq 0 ,l2cap_reset_hid_disconnected 
+508c 20600000 rtn 
+
+l2cap_reset_hid_disconnected:
+508d 700b7d07 jam bt_evt_hid_disconnected ,mem_fifo_temp 
+508e 20207c27 branch ui_ipc_send_event 
+
+l2cap_disconnect_interrupt_req:
+508f 680082e6 fetch 1 ,mem_control_tasks 
+5090 793ffe00 set0 l2cap_disconnect_interrupt ,pdata 
+5091 600082e6 store 1 ,mem_control_tasks 
+5092 680142b7 fetch 2 ,mem_hid_int_remote_cid 
+5093 207a0000 rtn blank 
+5094 204052c4 call l2cap_malloc_signal_channel 
+5095 680142b7 fetch 2 ,mem_hid_int_remote_cid 
+5096 1fe22200 copy pdata ,rega 
+5097 18002453 force l2cap_hid_interrupt_channel ,regb 
+5098 202050a2 branch l2cap_generate_disconnect_req 
+
+l2cap_disconnect_control_req:
+5099 680082e6 fetch 1 ,mem_control_tasks 
+509a 793ffe07 set0 l2cap_disconnect_control ,pdata 
+509b 600082e6 store 1 ,mem_control_tasks 
+509c 680142b5 fetch 2 ,mem_hid_ctrl_remote_cid 
+509d 207a0000 rtn blank 
+509e 204052c4 call l2cap_malloc_signal_channel 
+509f 680142b5 fetch 2 ,mem_hid_ctrl_remote_cid 
+50a0 1fe22200 copy pdata ,rega 
+50a1 18002452 force l2cap_hid_control_channel ,regb 
+
+l2cap_generate_disconnect_req:
+50a2 20405242 call l2cap_get_req_id 
+50a3 204052d0 call l2cap_get_signal_tx_payload 
+50a4 18007e06 force signal_disconnect_req ,pdata 
+50a5 e0a08000 istore 1 ,contw 
+50a6 6800c2be fetch 1 ,mem_ml2cap_comm_id 
+50a7 e0a08000 istore 1 ,contw 
+50a8 58000004 setarg 0x0004 
+50a9 e0a10000 istore 2 ,contw 
+50aa 1a227e00 copy rega ,pdata 
+50ab e0a10000 istore 2 ,contw 
+50ac 1a427e00 copy regb ,pdata 
+50ad e0a10000 istore 2 ,contw 
+50ae 18000408 force 0x08 ,temp 
+50af 202050e9 branch ml2cap_send_signal 
+
+ml2cap_send_signal_connect_req:
+50b0 79200025 set1 mark_ext_patch ,mark 
+50b1 448fc023 bpatch patch23_7 ,mem_patch23 
+50b2 20405242 call l2cap_get_req_id 
+50b3 204052d0 call l2cap_get_signal_tx_payload 
+50b4 58000002 setarg signal_connect_req 
+50b5 e0a08000 istore 1 ,contw 
+50b6 6800c2be fetch 1 ,mem_ml2cap_comm_id 
+50b7 e0a08000 istore 1 ,contw 
+50b8 58000004 setarg 0x0004 
+50b9 e0a10000 istore 2 ,contw 
+50ba 18427e00 copy temp ,pdata 
+50bb e0a10000 istore 2 ,contw 
+50bc 19627e00 copy timeup ,pdata 
+50bd e0a10000 istore 2 ,contw 
+50be d8400008 arg 8 ,temp 
+50bf 202050e9 branch ml2cap_send_signal 
+
+ml2cap_send_signal_config_req:
+50c0 79200025 set1 mark_ext_patch ,mark 
+50c1 44904024 bpatch patch24_0 ,mem_patch24 
+50c2 20405242 call l2cap_get_req_id 
+50c3 204052d0 call l2cap_get_signal_tx_payload 
+50c4 58000004 setarg signal_config_req 
+50c5 e0a08000 istore 1 ,contw 
+50c6 6800c2be fetch 1 ,mem_ml2cap_comm_id 
+50c7 e0a08000 istore 1 ,contw 
+50c8 58000008 setarg 0x0008 
+50c9 e0a10000 istore 2 ,contw 
+50ca 18427e00 copy temp ,pdata 
+50cb e0a10000 istore 2 ,contw 
+50cc 58000000 setarg 0x0000 
+50cd e0a10000 istore 2 ,contw 
+50ce 58000001 setarg 0x01 
+50cf e0a08000 istore 1 ,contw 
+50d0 58000002 setarg 0x02 
+50d1 e0a08000 istore 1 ,contw 
+50d2 580003e3 setarg l2cap_config_mtu_rfcomm 
+50d3 e0a10000 istore 2 ,contw 
+50d4 d840000c arg 0xc ,temp 
+50d5 202050e9 branch ml2cap_send_signal 
+
+ml2cap_send_signal_disconn_req:
+50d6 79200025 set1 mark_ext_patch ,mark 
+50d7 4490c024 bpatch patch24_1 ,mem_patch24 
+50d8 20405242 call l2cap_get_req_id 
+50d9 204052d0 call l2cap_get_signal_tx_payload 
+50da 58000006 setarg signal_disconnect_req 
+50db e0a08000 istore 1 ,contw 
+50dc 6800c2be fetch 1 ,mem_ml2cap_comm_id 
+50dd 1fe0fe01 increase 1 ,pdata 
+50de 18a22200 copy contw ,rega 
+50df 6000c2be store 1 ,mem_ml2cap_comm_id 
+50e0 1a220a00 copy rega ,contw 
+50e1 e0a08000 istore 1 ,contw 
+50e2 58000004 setarg 0x0004 
+50e3 e0a10000 istore 2 ,contw 
+50e4 18427e00 copy temp ,pdata 
+50e5 e0a10000 istore 2 ,contw 
+50e6 19627e00 copy timeup ,pdata 
+50e7 e0a10000 istore 2 ,contw 
+50e8 d8400008 arg 0x8 ,temp 
+
+ml2cap_send_signal:
+50e9 600902d6 storet 2 ,mem_l2cap_signal_tx_length 
+50ea 18427e00 copy temp ,pdata 
+50eb 203a526f branch l2cap_malloc_discard ,blank 
+50ec 204052ce call l2cap_get_signal_tx_buff 
+50ed 680102d6 fetch 2 ,mem_l2cap_signal_tx_length 
+50ee e0a10000 istore 2 ,contw 
+50ef 18007e01 force l2cap_signal_channel ,pdata 
+50f0 e0a10000 istore 2 ,contw 
+50f1 20600000 rtn 
+
+msdp_send_req_done:
+50f2 680102dc fetch 2 ,mem_sdp_tx_pkt_length 
+50f3 203a3bf1 branch assert ,blank 
+50f4 204052dc call l2cap_get_sdp_tx_buff 
+50f5 680102dc fetch 2 ,mem_sdp_tx_pkt_length 
+50f6 e0a10000 istore 2 ,contw 
+50f7 680142b1 fetch 2 ,mem_sdp_remote_cid 
+50f8 e0a10000 istore 2 ,contw 
+50f9 20600000 rtn 
+
+ml2cap_rx_multiplexing:
+50fa 79200025 set1 mark_ext_patch ,mark 
+50fb 44914024 bpatch patch24_2 ,mem_patch24 
+50fc 680102cd fetch 2 ,mem_l2cap_rx_pkt_length 
+50fd 203a4dfc branch l2cap_rx_reset_state ,blank 
+50fe 680082cf fetch 1 ,mem_l2cap_rx_cid 
+50ff c000d105 beq l2cap_signal_channel ,ml2cap_call_proc_signal 
+5100 c0284de7 beq l2cap_sdp_channel ,l2cap_call_proc_sdp 
+5101 c028cdf4 beq l2cap_rfcomm_channel ,l2cap_call_proc_rfcomm 
+5102 c0294df2 beq l2cap_hid_control_channel ,l2cap_call_proc_hid 
+5103 c029cdf2 beq l2cap_hid_interrupt_channel ,l2cap_call_proc_hid 
+5104 20204dfc branch l2cap_rx_reset_state 
+
+ml2cap_call_proc_signal:
+5105 79200025 set1 mark_ext_patch ,mark 
+5106 4491c024 bpatch patch24_3 ,mem_patch24 
+5107 204052c4 call l2cap_malloc_signal_channel 
+5108 18002400 force 0 ,regb 
+5109 204052d0 call l2cap_get_signal_tx_payload 
+510a 1fe20a00 copy pdata ,contw 
+510b 680102cd fetch 2 ,mem_l2cap_rx_pkt_length 
+510c 1fe22600 copy pdata ,regc 
+510d 680102cb fetch 2 ,mem_l2cap_payload_ptr 
+510e 98000c00 iforce contr 
+
+ml2cap_proc_one_comm_loop:
+510f 20405115 call ml2cap_proc_one_comm 
+5110 1a60a7fc increase -4 ,regc 
+5111 2422d10f nbranch ml2cap_proc_one_comm_loop ,zero 
+5112 1a420400 copy regb ,temp 
+5113 204050e9 call ml2cap_send_signal 
+5114 20204dfc branch l2cap_rx_reset_state 
+
+ml2cap_proc_one_comm:
+5115 e8c08000 ifetch 1 ,contr 
+5116 c0015120 beq signal_connect_req ,ml2cap_proc_signal_connect_req 
+5117 c000d123 beq signal_cmd_reject ,ml2cap_proc_signal_cmd_reject 
+5118 c001d12d beq signal_connect_rsp ,ml2cap_proc_signal_connect_rsp 
+5119 c002d168 beq signal_config_rsp ,ml2cap_proc_signal_config_rsp 
+511a c0025199 beq signal_config_req ,ml2cap_proc_signal_config_req 
+511b c003d21c beq signal_disconnect_rsp ,ml2cap_proc_signal_disconn_rsp 
+511c c00351eb beq signal_disconnect_req ,ml2cap_proc_signal_disconn_req 
+511d c0045058 beq signal_echo_req ,l2cap_proc_signal_echo_req 
+511e c0054e3a beq signal_info_req ,ml2cap_proc_signal_info_req 
+511f 20205236 branch ml2cap_proc_send_reject 
+
+ml2cap_proc_signal_connect_req:
+5120 20407e1c call save_cont_pointers 
+5121 20407e21 call load_cont_pointers 
+5122 20204e5c branch l2cap_proc_signal_connect_req 
+
+ml2cap_proc_signal_cmd_reject:
+5123 e8c08000 ifetch 1 ,contr 
+5124 1fe20e00 copy pdata ,queue 
+5125 e8c10000 ifetch 2 ,contr 
+5126 1fe22200 copy pdata ,rega 
+5127 1a627e00 copy regc ,pdata 
+5128 9a262600 isub rega ,regc 
+
+mvptr:
+5129 e8c08000 ifetch 1 ,contr 
+512a 1a20a3ff increase -1 ,rega 
+512b 2422d129 nbranch mvptr ,zero 
+512c 20600000 rtn 
+
+ml2cap_proc_signal_connect_rsp:
+512d e8c08000 ifetch 1 ,contr 
+512e 1fe20e00 copy pdata ,queue 
+512f e8c10000 ifetch 2 ,contr 
+5130 1fe22200 copy pdata ,rega 
+5131 e8c10000 ifetch 2 ,contr 
+5132 1fe21600 copy pdata ,timeup 
+5133 e8c10000 ifetch 2 ,contr 
+5134 1fe20400 copy pdata ,temp 
+5135 e8c10000 ifetch 2 ,contr 
+5136 1fe67c00 sub pdata ,0 ,null 
+5137 2022d13f branch ml2cap_proc_signal_connect_rsp_sucessful ,zero 
+5138 c001513b beq l2cap_connect_refused_psm_unsupported ,ml2cap_proc_signal_connect_refused_result 
+5139 c002513b beq l2cap_connect_refused_no_resources ,ml2cap_proc_signal_connect_refused_result 
+513a 2020513d branch ml2cap_proc_signal_connect_rsp_mnosucc 
+
+ml2cap_proc_signal_connect_refused_result:
+513b 700b7d16 jam bt_evt_ml2cap_conn_refused ,mem_fifo_temp 
+513c 20407c27 call ui_ipc_send_event 
+
+ml2cap_proc_signal_connect_rsp_mnosucc:
+513d e8c10000 ifetch 2 ,contr 
+513e 20205165 branch mnosucc 
+
+ml2cap_proc_signal_connect_rsp_sucessful:
+513f 20407e1c call save_cont_pointers 
+5140 58000050 setarg l2cap_sdp_channel 
+5141 98467c00 isub temp ,null 
+5142 2022d14d branch ml2cap_proc_signal_connect_rsp_sdp ,zero 
+5143 58000051 setarg l2cap_rfcomm_channel 
+5144 98467c00 isub temp ,null 
+5145 2022d153 branch ml2cap_proc_signal_connect_rsp_rfcomm ,zero 
+5146 58000053 setarg l2cap_hid_interrupt_channel 
+5147 98467c00 isub temp ,null 
+5148 2022d15f branch ml2cap_proc_signal_connect_rsp_hid_int ,zero 
+5149 58000052 setarg l2cap_hid_control_channel 
+514a 98467c00 isub temp ,null 
+514b 2022d159 branch ml2cap_proc_signal_connect_rsp_hid_ctrl ,zero 
+514c 20205165 branch mnosucc 
+
+ml2cap_proc_signal_connect_rsp_sdp:
+514d 19627e00 copy timeup ,pdata 
+514e 600142b1 store 2 ,mem_sdp_remote_cid 
+514f 6800c2b9 fetch 1 ,mem_sdp_state 
+5150 79207e01 set1 l2cap_channel_state_conn_res 
+5151 6000c2b9 store 1 ,mem_sdp_state 
+5152 20205164 branch mnosucc1 
+
+ml2cap_proc_signal_connect_rsp_rfcomm:
+5153 19627e00 copy timeup ,pdata 
+5154 600142b3 store 2 ,mem_rfcomm_remote_cid 
+5155 6800c2ba fetch 1 ,mem_rfcomm_state 
+5156 79207e01 set1 l2cap_channel_state_conn_res 
+5157 6000c2ba store 1 ,mem_rfcomm_state 
+5158 20205164 branch mnosucc1 
+
+ml2cap_proc_signal_connect_rsp_hid_ctrl:
+5159 19627e00 copy timeup ,pdata 
+515a 600142b5 store 2 ,mem_hid_ctrl_remote_cid 
+515b 6800c2bb fetch 1 ,mem_hid_control_state 
+515c 79207e01 set1 l2cap_channel_state_conn_res 
+515d 6000c2bb store 1 ,mem_hid_control_state 
+515e 20205164 branch mnosucc1 
+
+ml2cap_proc_signal_connect_rsp_hid_int:
+515f 19627e00 copy timeup ,pdata 
+5160 600142b7 store 2 ,mem_hid_int_remote_cid 
+5161 6800c2bc fetch 1 ,mem_hid_interrupt_state 
+5162 79207e01 set1 l2cap_channel_state_conn_res 
+5163 6000c2bc store 1 ,mem_hid_interrupt_state 
+
+mnosucc1:
+5164 20407e21 call load_cont_pointers 
+
+mnosucc:
+5165 1a627e00 copy regc ,pdata 
+5166 9a262600 isub rega ,regc 
+5167 20600000 rtn 
+
+ml2cap_proc_signal_config_rsp:
+5168 e8c08000 ifetch 1 ,contr 
+5169 1fe20e00 copy pdata ,queue 
+516a e8c10000 ifetch 2 ,contr 
+516b 1fe22200 copy pdata ,rega 
+516c 1a627e00 copy regc ,pdata 
+516d 9a262600 isub rega ,regc 
+516e e8c10000 ifetch 2 ,contr 
+516f 1fe21600 copy pdata ,timeup 
+5170 e8c10000 ifetch 2 ,contr 
+5171 e8c10000 ifetch 2 ,contr 
+5172 243a5193 nbranch mcrsdone1 ,blank 
+5173 20407e1c call save_cont_pointers 
+5174 19620400 copy timeup ,temp 
+5175 58000050 setarg l2cap_sdp_channel 
+5176 98467c00 isub temp ,null 
+5177 2022d181 branch ml2cap_proc_signal_config_rsp_sdp ,zero 
+5178 58000051 setarg l2cap_rfcomm_channel 
+5179 98467c00 isub temp ,null 
+517a 2022d185 branch ml2cap_proc_signal_config_rsp_rfcomm ,zero 
+517b 58000052 setarg l2cap_hid_control_channel 
+517c 98467c00 isub temp ,null 
+517d 2022d189 branch ml2cap_proc_signal_config_rsp_hid_ctrl ,zero 
+517e 58000053 setarg l2cap_hid_interrupt_channel 
+517f 98467c00 isub temp ,null 
+5180 2022d18d branch ml2cap_proc_signal_config_rsp_hid_int ,zero 
+
+ml2cap_proc_signal_config_rsp_sdp:
+5181 6800c2b9 fetch 1 ,mem_sdp_state 
+5182 79207e05 set1 l2cap_channel_state_rcv_cfg_res 
+5183 6000c2b9 store 1 ,mem_sdp_state 
+5184 20600000 rtn 
+
+ml2cap_proc_signal_config_rsp_rfcomm:
+5185 6800c2ba fetch 1 ,mem_rfcomm_state 
+5186 79207e05 set1 l2cap_channel_state_rcv_cfg_res 
+5187 6000c2ba store 1 ,mem_rfcomm_state 
+5188 20600000 rtn 
+
+ml2cap_proc_signal_config_rsp_hid_ctrl:
+5189 6800c2bb fetch 1 ,mem_hid_control_state 
+518a 79207e05 set1 l2cap_channel_state_rcv_cfg_res 
+518b 6000c2bb store 1 ,mem_hid_control_state 
+518c 20600000 rtn 
+
+ml2cap_proc_signal_config_rsp_hid_int:
+518d 6800c2bc fetch 1 ,mem_hid_interrupt_state 
+518e 79207e05 set1 l2cap_channel_state_rcv_cfg_res 
+518f 6000c2bc store 1 ,mem_hid_interrupt_state 
+5190 700b7d06 jam bt_evt_hid_connected ,mem_fifo_temp 
+5191 20207c27 branch ui_ipc_send_event 
+
+mcfrsdone:
+5192 20407e21 call load_cont_pointers 
+
+mcrsdone1:
+5193 1a20a3fa increase -6 ,rega 
+
+mloop2:
+5194 2022d198 branch mcrsdone ,zero 
+5195 18c08c01 increase 1 ,contr 
+5196 1a20a3ff increase -1 ,rega 
+5197 20205194 branch mloop2 
+
+mcrsdone:
+5198 20600000 rtn 
+
+ml2cap_proc_signal_config_req:
+5199 e8c08000 ifetch 1 ,contr 
+519a 1fe20e00 copy pdata ,queue 
+519b e8c10000 ifetch 2 ,contr 
+519c 1fe22200 copy pdata ,rega 
+519d 1a627e00 copy regc ,pdata 
+519e 9a262600 isub rega ,regc 
+519f e8c10000 ifetch 2 ,contr 
+51a0 18c08c02 increase 2 ,contr 
+51a1 1fe20400 copy pdata ,temp 
+51a2 58000005 setarg signal_config_rsp 
+51a3 e0a08000 istore 1 ,contw 
+51a4 18e27e00 copy queue ,pdata 
+51a5 e0a08000 istore 1 ,contw 
+51a6 1a20a202 increase 2 ,rega 
+51a7 1a227e00 copy rega ,pdata 
+51a8 e0a10000 istore 2 ,contw 
+51a9 20407e1c call save_cont_pointers 
+51aa 58000050 setarg l2cap_sdp_channel 
+51ab 98467c00 isub temp ,null 
+51ac 2022d1b7 branch ml2cap_proc_signal_config_req_sdp ,zero 
+51ad 58000051 setarg l2cap_rfcomm_channel 
+51ae 98467c00 isub temp ,null 
+51af 2022d1c8 branch ml2cap_proc_signal_config_req_rfcomm ,zero 
+51b0 58000052 setarg l2cap_hid_control_channel 
+51b1 98467c00 isub temp ,null 
+51b2 2022d1ce branch ml2cap_proc_signal_config_req_hid_ctrl ,zero 
+51b3 58000053 setarg l2cap_hid_interrupt_channel 
+51b4 98467c00 isub temp ,null 
+51b5 2022d1d4 branch ml2cap_proc_signal_config_req_hid_int ,zero 
+51b6 202051d9 branch mcfgrq_done 
+
+ml2cap_proc_signal_config_req_sdp:
+51b7 6800c2b9 fetch 1 ,mem_sdp_state 
+51b8 79207e04 set1 l2cap_channel_state_rcv_cfg_req ,pdata 
+51b9 79207e03 set1 l2cap_channel_state_snd_cfg_res ,pdata 
+51ba 6000c2b9 store 1 ,mem_sdp_state 
+51bb c28151c5 bbit1 l2cap_channel_state_snd_cfg_req ,ml2cap_proc_signal_config_req_sdp_nsndreq 
+51bc 680882e6 fetcht 1 ,mem_control_tasks 
+51bd 79200406 set1 l2cap_init_config_req ,temp 
+51be 600882e6 storet 1 ,mem_control_tasks 
+51bf 18e27e00 copy queue ,pdata 
+51c0 1fe0fe01 increase 1 ,pdata 
+51c1 600082e8 store 1 ,mem_config_identifier 
+51c2 6800c2b9 fetch 1 ,mem_sdp_state 
+51c3 79207e02 set1 l2cap_channel_state_snd_cfg_req ,pdata 
+51c4 6000c2b9 store 1 ,mem_sdp_state 
+
+ml2cap_proc_signal_config_req_sdp_nsndreq:
+51c5 680142b1 fetch 2 ,mem_sdp_remote_cid 
+51c6 600102e9 store 2 ,mem_config_req_dest_cid 
+51c7 202051d9 branch mcfgrq_done 
+
+ml2cap_proc_signal_config_req_rfcomm:
+51c8 6800c2ba fetch 1 ,mem_rfcomm_state 
+51c9 79207e04 set1 l2cap_channel_state_rcv_cfg_req ,pdata 
+51ca 79207e03 set1 l2cap_channel_state_snd_cfg_res ,pdata 
+51cb 6000c2ba store 1 ,mem_rfcomm_state 
+51cc 680142b3 fetch 2 ,mem_rfcomm_remote_cid 
+51cd 202051d9 branch mcfgrq_done 
+
+ml2cap_proc_signal_config_req_hid_ctrl:
+51ce 6800c2bb fetch 1 ,mem_hid_control_state 
+51cf 79207e04 set1 l2cap_channel_state_rcv_cfg_req ,pdata 
+51d0 79207e03 set1 l2cap_channel_state_snd_cfg_res ,pdata 
+51d1 6000c2bb store 1 ,mem_hid_control_state 
+51d2 680142b5 fetch 2 ,mem_hid_ctrl_remote_cid 
+51d3 202051d9 branch mcfgrq_done 
+
+ml2cap_proc_signal_config_req_hid_int:
+51d4 6800c2bc fetch 1 ,mem_hid_interrupt_state 
+51d5 79207e04 set1 l2cap_channel_state_rcv_cfg_req ,pdata 
+51d6 79207e03 set1 l2cap_channel_state_snd_cfg_res ,pdata 
+51d7 6000c2bc store 1 ,mem_hid_interrupt_state 
+51d8 680142b7 fetch 2 ,mem_hid_int_remote_cid 
+
+mcfgrq_done:
+51d9 1fe21600 copy pdata ,timeup 
+51da 20407e21 call load_cont_pointers 
+51db 19627e00 copy timeup ,pdata 
+51dc e0a10000 istore 2 ,contw 
+51dd 18007e00 force 0x0000 ,pdata 
+51de e0a10000 istore 2 ,contw 
+51df 18007e00 force 0x0000 ,pdata 
+51e0 e0a10000 istore 2 ,contw 
+51e1 18007e0a force 10 ,pdata 
+51e2 9a40a400 iadd regb ,regb 
+51e3 1a20a3fa increase -6 ,rega 
+
+mloop1:
+51e4 2022d1ea branch mcrqdone ,zero 
+51e5 e8c08000 ifetch 1 ,contr 
+51e6 e0a08000 istore 1 ,contw 
+51e7 1a40a401 increase 1 ,regb 
+51e8 1a20a3ff increase -1 ,rega 
+51e9 202051e4 branch mloop1 
+
+mcrqdone:
+51ea 20600000 rtn 
+
+ml2cap_proc_signal_disconn_req:
+51eb e8c08000 ifetch 1 ,contr 
+51ec 1fe20e00 copy pdata ,queue 
+51ed e8c10000 ifetch 2 ,contr 
+51ee 1fe22200 copy pdata ,rega 
+51ef 1a627e00 copy regc ,pdata 
+51f0 9a262600 isub rega ,regc 
+51f1 e8c10000 ifetch 2 ,contr 
+51f2 1fe22200 copy pdata ,rega 
+51f3 e8c10000 ifetch 2 ,contr 
+51f4 1fe21600 copy pdata ,timeup 
+51f5 20407e1c call save_cont_pointers 
+51f6 58000050 setarg l2cap_sdp_channel 
+51f7 1a220400 copy rega ,temp 
+51f8 98467c00 isub temp ,null 
+51f9 2022d203 branch ml2cap_proc_signal_disconn_sdp ,zero 
+51fa 58000052 setarg l2cap_hid_control_channel 
+51fb 1a220400 copy rega ,temp 
+51fc 98467c00 isub temp ,null 
+51fd 2022d208 branch ml2cap_proc_signal_disconn_hid_ctrl ,zero 
+51fe 58000053 setarg l2cap_hid_interrupt_channel 
+51ff 1a220400 copy rega ,temp 
+5200 98467c00 isub temp ,null 
+5201 2022d20a branch ml2cap_proc_signal_disconn_hid_int ,zero 
+5202 2020520c branch mclsrfc 
+
+ml2cap_proc_signal_disconn_sdp:
+5203 58000000 setarg 0x0000 
+5204 600102dc store 2 ,mem_sdp_tx_pkt_length 
+5205 600142b1 store 2 ,mem_sdp_remote_cid 
+5206 6000c2b9 store 1 ,mem_sdp_state 
+5207 2020520e branch mclssdp 
+
+ml2cap_proc_signal_disconn_hid_ctrl:
+5208 20405081 call l2cap_reset_hid_ctrl_state 
+5209 2020520e branch mclssdp 
+
+ml2cap_proc_signal_disconn_hid_int:
+520a 20405087 call l2cap_reset_hid_int_state 
+520b 2020520e branch mclssdp 
+
+mclsrfc:
+520c 58000000 setarg 0x0000 
+520d 600102e2 store 2 ,mem_rfcomm_tx_pkt_length 
+
+mclssdp:
+520e 20407e21 call load_cont_pointers 
+520f 58000007 setarg signal_disconnect_rsp 
+5210 e0a08000 istore 1 ,contw 
+5211 18e27e00 copy queue ,pdata 
+5212 e0a08000 istore 1 ,contw 
+5213 58000004 setarg 0x0004 
+5214 e0a10000 istore 2 ,contw 
+5215 1a227e00 copy rega ,pdata 
+5216 e0a10000 istore 2 ,contw 
+5217 19627e00 copy timeup ,pdata 
+5218 e0a10000 istore 2 ,contw 
+5219 18007e08 force 8 ,pdata 
+521a 9a40a400 iadd regb ,regb 
+521b 20600000 rtn 
+
+ml2cap_proc_signal_disconn_rsp:
+521c e8c08000 ifetch 1 ,contr 
+521d 1fe20e00 copy pdata ,queue 
+521e e8c10000 ifetch 2 ,contr 
+521f 1fe22200 copy pdata ,rega 
+5220 e8c10000 ifetch 2 ,contr 
+5221 1fe21600 copy pdata ,timeup 
+5222 e8c10000 ifetch 2 ,contr 
+5223 1fe20400 copy pdata ,temp 
+5224 20407e1c call save_cont_pointers 
+5225 6800c2be fetch 1 ,mem_ml2cap_comm_id 
+5226 a8e1fe00 icompare 0xff ,queue 
+5227 2420d232 nbranch mdisdone ,true 
+5228 58000050 setarg l2cap_sdp_channel 
+5229 98467c00 isub temp ,null 
+522a 2022d22f branch ml2cap_proc_signal_disconn_rsp_sdp ,zero 
+522b 58000051 setarg l2cap_rfcomm_channel 
+522c 98467c00 isub temp ,null 
+522d 2022d232 branch ml2cap_proc_signal_disconn_rsp_rfcomm ,zero 
+522e 20205232 branch mdisdone 
+
+ml2cap_proc_signal_disconn_rsp_sdp:
+522f 7042b100 jam 0 ,mem_sdp_remote_cid 
+5230 7042b900 jam 0 ,mem_sdp_state 
+5231 20205232 branch mdisdone 
+
+ml2cap_proc_signal_disconn_rsp_rfcomm:
+
+mdisdone:
+5232 20407e21 call load_cont_pointers 
+5233 1a627e00 copy regc ,pdata 
+5234 9a262600 isub rega ,regc 
+5235 20600000 rtn 
+
+ml2cap_proc_send_reject:
+5236 58000001 setarg signal_cmd_reject 
+5237 e0a08000 istore 1 ,contw 
+5238 e8c08000 ifetch 1 ,contr 
+5239 e0a08000 istore 1 ,contw 
+523a 58000002 setarg 0x0002 
+523b e0a10000 istore 2 ,contw 
+523c 58000000 setarg 0x0000 
+523d e0a10000 istore 2 ,contw 
+523e 58000006 setarg 0x0006 
+523f 9a40a400 iadd regb ,regb 
+5240 18002604 force 4 ,regc 
+5241 20600000 rtn 
+
+l2cap_get_req_id:
+5242 6800c2be fetch 1 ,mem_ml2cap_comm_id 
+5243 1fe0fe01 increase 1 ,pdata 
+5244 c0805246 bne 0 ,l2cap_get_req_id_ok 
+5245 1fe0fe01 increase 1 ,pdata 
+
+l2cap_get_req_id_ok:
+5246 6000c2be store 1 ,mem_ml2cap_comm_id 
+5247 20600000 rtn 
+
+l2cap_malloc:
+5248 79200025 set1 mark_ext_patch ,mark 
+5249 44924024 bpatch patch24_4 ,mem_patch24 
+524a da400000 arg 0 ,regb 
+524b 2040527a call l2cap_malloc_is_fifo_full 
+524c 243a3bf1 nbranch assert ,blank 
+524d 20405287 call l2cap_malloc_get_full_map 
+524e da401800 arg mem_tx_buff0 ,regb 
+524f d8e00000 arg 0 ,queue 
+
+l2cap_malloc_loop:
+5250 6808c2bf fetcht 1 ,mem_used_map 
+5251 a84fffff qisolate1 temp 
+5252 2020d258 branch l2cap_malloc_next ,true 
+5253 204052ab call l2cap_malloc_enough 
+5254 19667c00 sub timeup ,0 ,null 
+5255 20215258 branch l2cap_malloc_next ,positive 
+5256 20405292 call l2cap_malloc_into_fifo 
+5257 2020525e branch l2cap_malloc_rtn 
+
+l2cap_malloc_next:
+5258 1a40a480 increase 128 ,regb 
+5259 18e08e01 increase 1 ,queue 
+525a 58000008 setarg 8 
+525b 98e67c00 isub queue ,null 
+525c 20215250 branch l2cap_malloc_loop ,positive 
+525d da400000 arg 0 ,regb 
+
+l2cap_malloc_rtn:
+525e 1a427e00 copy regb ,pdata 
+525f 203a3bf1 branch assert ,blank 
+5260 20600000 rtn 
+
+l2cap_malloc_fifo_out:
+5261 79200025 set1 mark_ext_patch ,mark 
+5262 4492c024 bpatch patch24_5 ,mem_patch24 
+5263 20405280 call l2cap_malloc_fifo_get_first_ptr 
+5264 18c08c01 increase 1 ,contr 
+5265 e8c10000 ifetch 2 ,contr 
+5266 20600000 rtn 
+
+l2cap_malloc_free:
+5267 79200025 set1 mark_ext_patch ,mark 
+5268 44934024 bpatch patch24_6 ,mem_patch24 
+5269 20405280 call l2cap_malloc_fifo_get_first_ptr 
+526a 18c20a00 copy contr ,contw 
+526b 18c20400 copy contr ,temp 
+526c 58000000 setarg 0 
+526d e0a18000 istore 3 ,contw 
+526e 20600000 rtn 
+
+l2cap_malloc_discard:
+526f 79200025 set1 mark_ext_patch ,mark 
+5270 4493c024 bpatch patch24_7 ,mem_patch24 
+5271 2040527e call l2cap_malloc_is_fifo_empty 
+5272 203a3bf1 branch assert ,blank 
+5273 6801c2c6 fetch 3 ,mem_tx_fifo2 
+5274 6001c2c9 store 3 ,mem_tx_fifo3 
+5275 6801c2c3 fetch 3 ,mem_tx_fifo1 
+5276 6001c2c6 store 3 ,mem_tx_fifo2 
+5277 6801c2c0 fetch 3 ,mem_tx_fifo0 
+5278 6001c2c3 store 3 ,mem_tx_fifo1 
+5279 20600000 rtn 
+
+l2cap_malloc_is_fifo_full:
+527a 6801c2c0 fetch 3 ,mem_tx_fifo0 
+527b 20600000 rtn 
+
+l2cap_malloc_is_fifo_nearly_full:
+527c 6801c2c3 fetch 3 ,mem_tx_fifo1 
+527d 20600000 rtn 
+
+l2cap_malloc_is_fifo_empty:
+527e 6801c2c9 fetch 3 ,mem_tx_fifo3 
+527f 20600000 rtn 
+
+l2cap_malloc_fifo_get_first_ptr:
+5280 2040527e call l2cap_malloc_is_fifo_empty 
+5281 203a3bf1 branch assert ,blank 
+5282 d8c042c0 arg mem_tx_fifo0 ,contr 
+
+l2cap_malloc_free_loop:
+5283 e8c18000 ifetch 3 ,contr 
+5284 203a5283 branch l2cap_malloc_free_loop ,blank 
+5285 18c08dfd increase -3 ,contr 
+5286 20600000 rtn 
+
+l2cap_malloc_get_full_map:
+5287 79200025 set1 mark_ext_patch ,mark 
+5288 44944025 bpatch patch25_0 ,mem_patch25 
+5289 df200004 arg 4 ,loopcnt 
+528a d8c042c0 arg mem_tx_fifo0_map ,contr 
+528b d8400000 arg 0 ,temp 
+
+l2cap_malloc_get_full_map_loop:
+528c e8c18000 ifetch 3 ,contr 
+528d 1fe17eff and pdata ,0xff ,pdata 
+528e 98418400 ior temp ,temp 
+528f c200528c loop l2cap_malloc_get_full_map_loop 
+5290 6008c2bf storet 1 ,mem_used_map 
+5291 20600000 rtn 
+
+l2cap_malloc_into_fifo:
+5292 79200025 set1 mark_ext_patch ,mark 
+5293 4494c025 bpatch patch25_1 ,mem_patch25 
+5294 2040527a call l2cap_malloc_is_fifo_full 
+5295 243a3bf1 nbranch assert ,blank 
+5296 2040527e call l2cap_malloc_is_fifo_empty 
+5297 203a52a0 branch l2cap_malloc_into_fifo_no_push ,blank 
+5298 6801c2c3 fetch 3 ,mem_tx_fifo1 
+5299 6001c2c0 store 3 ,mem_tx_fifo0 
+529a e8c18000 ifetch 3 ,contr 
+529b e0a18000 istore 3 ,contw 
+529c e8c18000 ifetch 3 ,contr 
+529d e0a18000 istore 3 ,contw 
+529e 58000000 setarg 0 
+529f e0a18000 istore 3 ,contw 
+
+l2cap_malloc_into_fifo_no_push:
+52a0 d8400000 arg 0 ,temp 
+52a1 19627e00 copy timeup ,pdata 
+52a2 98e0fe00 iadd queue ,pdata 
+
+l2cap_malloc_into_fifo_loop:
+52a3 f9200400 qset1 temp 
+52a4 18e08e01 increase 1 ,queue 
+52a5 98e67c00 isub queue ,null 
+52a6 2422d2a3 nbranch l2cap_malloc_into_fifo_loop ,zero 
+52a7 1a4d7e00 lshift8 regb ,pdata 
+52a8 9841fe00 ior temp ,pdata 
+52a9 6001c2c9 store 3 ,mem_tx_fifo3 
+52aa 20600000 rtn 
+
+l2cap_malloc_enough:
+52ab 79200025 set1 mark_ext_patch ,mark 
+52ac 44954025 bpatch patch25_2 ,mem_patch25 
+52ad 20405287 call l2cap_malloc_get_full_map 
+52ae 18e22600 copy queue ,regc 
+52af d8400000 arg 0 ,temp 
+52b0 d9600000 arg 0 ,timeup 
+
+l2cap_malloc_enough_loop:
+52b1 18e27e00 copy queue ,pdata 
+52b2 c00452bc beq 8 ,l2cap_malloc_enough_end 
+52b3 6800c2bf fetch 1 ,mem_used_map 
+52b4 afefffff qisolate1 pdata 
+52b5 2020d2bc branch l2cap_malloc_enough_end ,true 
+52b6 18408480 increase 128 ,temp 
+52b7 18e08e01 increase 1 ,queue 
+52b8 1a227e00 copy rega ,pdata 
+52b9 98467c00 isub temp ,null 
+52ba 2022d2bc branch l2cap_malloc_enough_end ,zero 
+52bb 202152b1 branch l2cap_malloc_enough_loop ,positive 
+
+l2cap_malloc_enough_end:
+52bc 18427e00 copy temp ,pdata 
+52bd 9a267c00 isub rega ,null 
+52be 242152c2 nbranch l2cap_malloc_enough_rtn ,positive 
+52bf 18e27e00 copy queue ,pdata 
+52c0 1a620400 copy regc ,temp 
+52c1 98461600 isub temp ,timeup 
+
+l2cap_malloc_enough_rtn:
+52c2 1a620e00 copy regc ,queue 
+52c3 20600000 rtn 
+
+l2cap_malloc_signal_channel:
+52c4 79200025 set1 mark_ext_patch ,mark 
+52c5 4495c025 bpatch patch25_3 ,mem_patch25 
+52c6 da20007f arg l2cap_signal_malloc_size ,rega 
+52c7 20405248 call l2cap_malloc 
+52c8 600102d2 store 2 ,mem_l2cap_signal_tx_buff_ptr 
+52c9 1fe0fe04 increase 4 ,pdata 
+52ca 600102d4 store 2 ,mem_l2cap_signal_tx_payload_ptr 
+52cb 58000000 setarg 0 
+52cc 600102d6 store 2 ,mem_l2cap_signal_tx_length 
+52cd 20600000 rtn 
+
+l2cap_get_signal_tx_buff:
+52ce 680102d2 fetch 2 ,mem_l2cap_signal_tx_buff_ptr 
+52cf 202052f2 branch l2cap_util_pdata_to_contw 
+
+l2cap_get_signal_tx_payload:
+52d0 680102d4 fetch 2 ,mem_l2cap_signal_tx_payload_ptr 
+52d1 202052f2 branch l2cap_util_pdata_to_contw 
+
+l2cap_malloc_sdp_channel:
+52d2 79200025 set1 mark_ext_patch ,mark 
+52d3 44964025 bpatch patch25_4 ,mem_patch25 
+52d4 da2002ff arg sdp_malloc_size ,rega 
+52d5 20405248 call l2cap_malloc 
+52d6 600102d8 store 2 ,mem_sdp_tx_buff_ptr 
+52d7 1fe0fe04 increase 4 ,pdata 
+52d8 600102da store 2 ,mem_sdp_tx_payload_ptr 
+52d9 58000000 setarg 0 
+52da 600102dc store 2 ,mem_sdp_tx_pkt_length 
+52db 20600000 rtn 
+
+l2cap_get_sdp_tx_buff:
+52dc 680102d8 fetch 2 ,mem_sdp_tx_buff_ptr 
+52dd 202052f2 branch l2cap_util_pdata_to_contw 
+
+l2cap_get_sdp_tx_payload:
+52de 680102da fetch 2 ,mem_sdp_tx_payload_ptr 
+52df 202052f2 branch l2cap_util_pdata_to_contw 
+
+l2cap_malloc_rfcomm_channel:
+52e0 79200025 set1 mark_ext_patch ,mark 
+52e1 4496c025 bpatch patch25_5 ,mem_patch25 
+52e2 20407e00 call push_stack 
+52e3 7002eb01 jam rfcomm_malloc_fail ,mem_rfcomm_malloc_fail_flag 
+52e4 2040527a call l2cap_malloc_is_fifo_full 
+52e5 247a0000 nrtn blank 
+52e6 da20007f arg rfcomm_malloc_size ,rega 
+52e7 20405248 call l2cap_malloc 
+52e8 600102de store 2 ,mem_rfcomm_tx_buff_ptr 
+52e9 1fe0fe04 increase 4 ,pdata 
+52ea 600102e0 store 2 ,mem_rfcomm_tx_payload_ptr 
+52eb 58000000 setarg 0 
+52ec 600102e2 store 2 ,mem_rfcomm_tx_pkt_length 
+52ed 7002eb00 jam rfcomm_malloc_succeed ,mem_rfcomm_malloc_fail_flag 
+52ee 20207e0e branch pop_stack 
+
+l2cap_get_rfcomm_tx_buff:
+52ef 680102de fetch 2 ,mem_rfcomm_tx_buff_ptr 
+52f0 202052f2 branch l2cap_util_pdata_to_contw 
+
+l2cap_get_rfcomm_tx_payload:
+52f1 680102e0 fetch 2 ,mem_rfcomm_tx_payload_ptr 
+
+l2cap_util_pdata_to_contw:
+52f2 203a3bf1 branch assert ,blank 
+52f3 1fe20a00 copy pdata ,contw 
+52f4 20600000 rtn 
+
+l2cap_lpm_save_calc_len:
+52f5 79200025 set1 mark_ext_patch ,mark 
+52f6 44974025 bpatch patch25_6 ,mem_patch25 
+52f7 da400000 arg 0 ,regb 
+52f8 da2042c0 arg mem_tx_fifo0_map ,rega 
+52f9 1a20a3fe increase -2 ,rega 
+
+l2cap_lpm_save_calc_len_loop:
+52fa 1a20a202 increase 2 ,rega 
+52fb 580042cc setarg mem_tx_fifo_end 
+52fc 9a267c00 isub rega ,null 
+52fd 2022d306 branch l2cap_lpm_save_calc_len_end ,zero 
+52fe ea208000 ifetch 1 ,rega 
+52ff 1a20a201 increase 1 ,rega 
+5300 203a52fa branch l2cap_lpm_save_calc_len_loop ,blank 
+5301 ea290000 ifetcht 2 ,rega 
+5302 e8410000 ifetch 2 ,temp 
+5303 9a40a400 iadd regb ,regb 
+5304 1a40a404 increase 4 ,regb 
+5305 202052fa branch l2cap_lpm_save_calc_len_loop 
+
+l2cap_lpm_save_calc_len_end:
+5306 1a427e00 copy regb ,pdata 
+5307 20600000 rtn 
+
+l2cap_lpm_get_wake_lock:
+5308 d8e0000c arg wake_lock_l2cap_tx ,queue 
+5309 20203dc2 branch lpm_get_wake_lock 
+
+l2cap_lpm_put_wake_lock:
+530a d8e0000c arg wake_lock_l2cap_tx ,queue 
+530b 20203dc6 branch lpm_put_wake_lock 
+
+l2cap_lpm_save_txbuf:
+530c 79200025 set1 mark_ext_patch ,mark 
+530d 4497c025 bpatch patch25_7 ,mem_patch25 
+530e 20405287 call l2cap_malloc_get_full_map 
+530f 6800c2bf fetch 1 ,mem_used_map 
+5310 207a0000 rtn blank 
+5311 204052f5 call l2cap_lpm_save_calc_len 
+5312 d8400100 arg l2cap_lpm_txbuf_len ,temp 
+5313 98467c00 isub temp ,null 
+5314 20215308 branch l2cap_lpm_get_wake_lock ,positive 
+5315 2040530a call l2cap_lpm_put_wake_lock 
+5316 d8a042cc arg mem_l2cap_lpm_txbuf ,contw 
+5317 da2042c0 arg mem_tx_fifo0 ,rega 
+
+l2cap_lpm_save_txbuf_loop:
+5318 580042cc setarg mem_tx_fifo_end 
+5319 9a267c00 isub rega ,null 
+531a 20628000 rtn zero 
+531b ea208000 ifetch 1 ,rega 
+531c 1a20a201 increase 1 ,rega 
+531d 243a5321 nbranch l2cap_lpm_save_txbuf_nempty ,blank 
+531e e0a10000 istore 2 ,contw 
+531f 1a20a202 increase 2 ,rega 
+5320 20205318 branch l2cap_lpm_save_txbuf_loop 
+
+l2cap_lpm_save_txbuf_nempty:
+5321 ea210000 ifetch 2 ,rega 
+5322 1a20a202 increase 2 ,rega 
+5323 1fe20c00 copy pdata ,contr 
+5324 e8c10000 ifetch 2 ,contr 
+5325 e0a10000 istore 2 ,contw 
+5326 1fe27200 copy pdata ,loopcnt 
+5327 1f20f202 increase 2 ,loopcnt 
+5328 20407e45 call memcpy 
+5329 20205318 branch l2cap_lpm_save_txbuf_loop 
+
+l2cap_lpm_load_txbuf:
+532a 79200025 set1 mark_ext_patch ,mark 
+532b 44984026 bpatch patch26_0 ,mem_patch26 
+532c 20405287 call l2cap_malloc_get_full_map 
+532d 6800c2bf fetch 1 ,mem_used_map 
+532e 207a0000 rtn blank 
+532f da2042c1 arg mem_tx_fifo0_ptr ,rega 
+5330 1a20a3fd increase -3 ,rega 
+5331 d8c042cc arg mem_l2cap_lpm_txbuf ,contr 
+
+l2cap_lpm_load_txbuf_loop:
+5332 1a20a203 increase 3 ,rega 
+5333 580042cd setarg mem_tx_fifo_end + 1 
+5334 9a267c00 isub rega ,null 
+5335 20628000 rtn zero 
+5336 e8c10000 ifetch 2 ,contr 
+5337 203a5332 branch l2cap_lpm_load_txbuf_loop ,blank 
+5338 1fe0fe04 increase 4 ,pdata 
+5339 1fe27200 copy pdata ,loopcnt 
+533a 18c22400 copy contr ,regb 
+533b ea210000 ifetch 2 ,rega 
+533c 1fe20a00 copy pdata ,contw 
+533d 1a420c00 copy regb ,contr 
+533e 18c08dfe increase -2 ,contr 
+533f 20407e45 call memcpy 
+5340 20205332 branch l2cap_lpm_load_txbuf_loop 
+
+le_init_param:
+5341 20758000 rtn wake 
+5342 58000010 setarg param_le_scan_interval 
+5343 600143d3 store 2 ,mem_le_scan_interval 
+5344 58000010 setarg param_le_scan_window 
+5345 600143d5 store 2 ,mem_le_scan_window 
+5346 20600000 rtn 
+
+le_init_att:
+5347 d8400014 arg notify_handle ,temp 
+5348 20405a88 call le_att_get_handle_ptr 
+5349 18c0fe01 add contr ,1 ,pdata 
+534a 60010419 store 2 ,mem_le_notify_attr_start 
+534b 20600000 rtn 
+
+le_init_conn:
+534c 79200025 set1 mark_ext_patch ,mark 
+534d 44994026 bpatch patch26_2 ,mem_patch26 
+534e 7855fc00 disable wake 
+534f 70427e01 jam 1 ,mem_app_state 
+5350 7003d601 jam 1 ,mem_le_conn_handle 
+5351 7003c003 jam 3 ,mem_le_state 
+5352 7003d701 jam 1 ,mem_le_arq 
+5353 5fffffff setarg -1 
+5354 600103da store 2 ,mem_le_event_count 
+5355 18007e00 force 0 ,pdata 
+5356 600083e3 store 1 ,mem_le_conn_sm 
+5357 600083d8 store 1 ,mem_le_ch 
+5358 600083e4 store 1 ,mem_le_op 
+5359 6001c20a store 3 ,mem_sniff_rcv 
+535a 6001c20d store 3 ,mem_sniff_lost 
+535b 6002c465 store 5 ,mem_le_pcnt_tx 
+535c 79207e27 set1 39 ,pdata 
+535d 6002c46a store 5 ,mem_le_pcnt_rx 
+535e 20205a0b branch le_supervision_flush 
+
+le_init_master:
+535f 79200025 set1 mark_ext_patch ,mark 
+5360 4499c026 bpatch patch26_3 ,mem_patch26 
+5361 7834fc00 enable master 
+5362 7003c103 jam lemode_master ,mem_le_mode 
+5363 7003fa01 jam 1 ,mem_le_att_handle 
+5364 7044bc01 jam 1 ,mem_le_search_handle_start 
+5365 5800ffff setarg 0xffff 
+5366 600144be store 2 ,mem_le_search_handle_end 
+5367 18007e00 force 0 ,pdata 
+5368 6002c46a store 5 ,mem_le_pcnt_rx 
+5369 79207e27 set1 39 ,pdata 
+536a 6002c465 store 5 ,mem_le_pcnt_tx 
+536b 2020534c branch le_init_conn 
+
+le_init_slave:
+536c 79200025 set1 mark_ext_patch ,mark 
+536d 449a4026 bpatch patch26_4 ,mem_patch26 
+536e 7854fc00 disable master 
+536f 7003c101 jam lemode_slave ,mem_le_mode 
+5370 7043d800 jam 0 ,mem_le_adv_enable 
+5371 7000a200 jam 0 ,mem_lpm_current_mult 
+5372 2020534c branch le_init_conn 
+
+le_dispatch:
+5373 204053d2 call le_enable 
+5374 204055d3 call le_scan 
+5375 20405a0e call le_adv 
+5376 202053d7 branch le_disable 
+
+le_conn_dispatch:
+5377 79200025 set1 mark_ext_patch ,mark 
+5378 449ac026 bpatch patch26_5 ,mem_patch26 
+5379 204053d2 call le_enable 
+537a 20403e71 call app_process_ble 
+537b 680083c1 fetch 1 ,mem_le_mode 
+537c c001d37e beq lemode_master ,le_master_dispatch 
+537d 20205395 branch le_slave_dispatch 
+
+le_master_dispatch:
+537e 79200025 set1 mark_ext_patch ,mark 
+537f 449b4026 bpatch patch26_6 ,mem_patch26 
+5380 7834fc00 enable master 
+5381 20405a02 call le_supervision_update 
+5382 20215392 branch le_master_disconn ,positive 
+5383 20403e28 call check_ble_disabled 
+5384 2040541c call le_setup 
+5385 20405622 call le_prepare_tx 
+5386 7856fc00 disable match 
+5387 204054b2 call le_transmit_receive_sifs 
+5388 24768000 nrtn match 
+5389 79200025 set1 mark_ext_patch ,mark 
+538a 449bc026 bpatch patch26_7 ,mem_patch26 
+538b 68008005 fetch 1 ,mem_le_conn_rcv 
+538c 1fe0fe01 increase 1 ,pdata 
+538d 60008005 store 1 ,mem_le_conn_rcv 
+538e 204055a2 call le_acknowledge 
+538f 20405a99 call le_conn_sm_master 
+5390 7854fc00 disable master 
+5391 20600000 rtn 
+
+le_master_disconn:
+5392 204053ba call le_disconnect 
+5393 7854fc00 disable master 
+5394 20600000 rtn 
+
+le_slave_dispatch:
+5395 79200025 set1 mark_ext_patch ,mark 
+5396 449c4027 bpatch patch27_0 ,mem_patch27 
+5397 78577c00 disable attempt 
+5398 20405a02 call le_supervision_update 
+5399 202153ba branch le_slave_disconn ,positive 
+539a 20403e28 call check_ble_disabled 
+539b 2040541c call le_setup 
+539c 20405478 call le_receive_slave 
+539d 2436d3ad nbranch le_slave_unsync ,match 
+
+le_slave_match:
+539e 79200025 set1 mark_ext_patch ,mark 
+539f 449cc027 bpatch patch27_1 ,mem_patch27 
+53a0 204053c8 call le_got_first_packet 
+53a1 204055a2 call le_acknowledge 
+53a2 20405622 call le_prepare_tx 
+53a3 68008340 fetch 1 ,mem_le_rxbuf 
+53a4 c28253b4 bbit1 md ,le_slave_more_data 
+53a5 2040561a call le_xtype_fifo_is_empty 
+53a6 243a53b4 nbranch le_slave_more_data ,blank 
+
+le_slave_transmit_last:
+53a7 79200025 set1 mark_ext_patch ,mark 
+53a8 449d4027 bpatch patch27_2 ,mem_patch27 
+53a9 204054bb call le_transmit_norx 
+
+le_slave_cont:
+53aa 20407c45 call check_51cmd 
+53ab 680083e4 fetch 1 ,mem_le_op 
+53ac c281d3ba bbit1 op_disconn ,le_slave_disconn 
+
+le_slave_unsync:
+53ad 79200025 set1 mark_ext_patch ,mark 
+53ae 449dc027 bpatch patch27_3 ,mem_patch27 
+53af 20407f44 call le_savelist 
+53b0 20405b19 call le_lpm_set_mult 
+53b1 20405594 call le_update_channel_map 
+53b2 20405576 call le_update_param 
+53b3 202039ac branch calc_clke_offset 
+
+le_slave_more_data:
+53b4 79200025 set1 mark_ext_patch ,mark 
+53b5 449e4027 bpatch patch27_4 ,mem_patch27 
+53b6 78377c00 enable attempt 
+53b7 204054b2 call le_transmit_receive_sifs 
+53b8 2036d39e branch le_slave_match ,match 
+53b9 202053aa branch le_slave_cont 
+
+le_slave_disconn:
+
+le_disconnect:
+53ba 79200025 set1 mark_ext_patch ,mark 
+53bb 449ec027 bpatch patch27_5 ,mem_patch27 
+53bc 204053c0 call le_clear_connection_info 
+53bd 20403f1d call app_disconn_reason_collect_ble 
+53be 700b7d15 jam bt_evt_le_disconnected ,mem_fifo_temp 
+53bf 20207c27 branch ui_ipc_send_event 
+
+le_clear_connection_info:
+53c0 680883d6 fetcht 1 ,mem_le_conn_handle 
+53c1 7002c008 jam hci_error_connection_timeout ,mem_hci_disconn_reason 
+53c2 204048c4 call hci_send_disconn_complete 
+53c3 7003d600 jam 0 ,mem_le_conn_handle 
+53c4 7003c100 jam lemode_idle ,mem_le_mode 
+53c5 7003c000 jam 0 ,mem_le_state 
+53c6 70427e00 jam 0 ,mem_app_state 
+53c7 20600000 rtn 
+
+le_got_first_packet:
+53c8 68008005 fetch 1 ,mem_le_conn_rcv 
+53c9 1fe0fe01 increase 1 ,pdata 
+53ca 60008005 store 1 ,mem_le_conn_rcv 
+53cb 680083c0 fetch 1 ,mem_le_state 
+53cc c3818000 rtnbit1 lestate_got_first_packet 
+53cd 79207e03 set1 lestate_got_first_packet 
+53ce 600083c0 store 1 ,mem_le_state 
+53cf 58000000 setarg 0 
+53d0 600246f9 store 4 ,mem_le_transmit_window 
+53d1 20600000 rtn 
+
+le_enable:
+53d2 79200025 set1 mark_ext_patch ,mark 
+53d3 449f4027 bpatch patch27_6 ,mem_patch27 
+53d4 783b7c00 enable le 
+53d5 70891407 hjam 7 ,rfen_ulp 
+53d6 20203e28 branch check_ble_disabled 
+
+le_disable:
+53d7 79200025 set1 mark_ext_patch ,mark 
+53d8 449fc027 bpatch patch27_7 ,mem_patch27 
+53d9 785b7c00 disable le 
+53da 70891403 hjam 3 ,rfen_ulp 
+53db db600000 arg 0 ,stop_watch 
+53dc 20600000 rtn 
+
+le_prep:
+53dd 7844fc00 disable enable_crc 
+53de 7843fc00 disable enable_white 
+53df 680183e9 fetch 3 ,mem_le_crcinit 
+53e0 98001e00 iforce crc24_init 
+53e1 68008016 fetch 1 ,mem_le_ch_mapped 
+53e2 1fed8400 reverse pdata ,temp 
+53e3 79200401 set1 1 ,temp 
+53e4 18431c00 rshift temp ,white_init 
+53e5 20600000 rtn 
+
+lerx_setfreq:
+53e6 204053ee call le_setfreq 
+53e7 20403a82 call set_freq_rx 
+53e8 58000500 setarg param_pll_setup 
+53e9 20403bf3 call sleep 
+53ea 20203a87 branch rf_rx_enable 
+
+letx_setfreq:
+53eb 2036ba98 branch txon ,match 
+53ec 204053ee call le_setfreq 
+53ed 20203a91 branch set_freq_tx 
+
+le_setfreq:
+53ee 79200025 set1 mark_ext_patch ,mark 
+53ef 44a04028 bpatch patch28_0 ,mem_patch28 
+53f0 20403a7a call set_sync_on 
+53f1 6800840d fetch 1 ,mem_le_testtype 
+53f2 243a5402 nbranch le_ctf_test ,blank 
+53f3 68008016 fetch 1 ,mem_le_ch_mapped 
+53f4 1fe67c24 sub pdata ,36 ,null 
+53f5 202153fc branch le_ctf_normal ,positive 
+53f6 18000400 force 0 ,temp 
+53f7 c1128000 rtneq 37 
+53f8 18000418 force 24 ,temp 
+53f9 c1130000 rtneq 38 
+53fa 1800044e force 78 ,temp 
+53fb 20600000 rtn 
+
+le_ctf_normal:
+53fc 1fe67c0a sub pdata ,10 ,null 
+53fd 202153ff branch le_ctf_low ,positive 
+53fe 1fe0fe01 increase 1 ,pdata 
+
+le_ctf_low:
+53ff 1fe3fe00 lshift pdata ,pdata 
+5400 1fe08402 add pdata ,2 ,temp 
+5401 20600000 rtn 
+
+le_ctf_test:
+5402 68008016 fetch 1 ,mem_le_ch_mapped 
+5403 1fe38400 lshift pdata ,temp 
+5404 20600000 rtn 
+
+le_sca_map:
+5405 d84001f4 arg 500 ,temp 
+5406 207a0000 rtn blank 
+5407 d84000fa arg 250 ,temp 
+5408 c1008000 rtneq 1 
+5409 d8400096 arg 150 ,temp 
+540a c1010000 rtneq 2 
+540b d8400064 arg 100 ,temp 
+540c c1018000 rtneq 3 
+540d d840004b arg 75 ,temp 
+540e c1020000 rtneq 4 
+540f d8400032 arg 50 ,temp 
+5410 c1028000 rtneq 5 
+5411 d8400028 arg 40 ,temp 
+5412 c1030000 rtneq 6 
+5413 d8400014 arg 20 ,temp 
+5414 20600000 rtn 
+
+le_adv_access:
+5415 588e89be setarg 0x8e89be 
+5416 1fed7e00 lshift8 pdata ,pdata 
+5417 1fe1fed6 or_into 0xd6 ,pdata 
+5418 98001200 iforce access 
+5419 58555555 setarg 0x555555 
+541a 600183e9 store 3 ,mem_le_crcinit 
+541b 20600000 rtn 
+
+le_setup:
+541c 79200025 set1 mark_ext_patch ,mark 
+541d 44a0c028 bpatch patch28_1 ,mem_patch28 
+541e 78287c00 enable swfine 
+541f 680203e5 fetch 4 ,mem_le_access 
+5420 98001200 iforce access 
+5421 20405453 call le_map_channel 
+5422 58000200 setarg 0x200 
+5423 2034d426 branch le_setup_master ,master 
+5424 680103ce fetch 2 ,mem_le_receive_window 
+5425 1fe37e00 rshift pdata ,pdata 
+
+le_setup_master:
+5426 d8400500 arg param_pll_setup ,temp 
+5427 9840fe00 iadd temp ,pdata 
+5428 20403b7d call ahead_window 
+5429 1b427e00 deposit clke 
+542a 60030412 store 6 ,mem_le_rxon_ts 
+542b 20600000 rtn 
+
+le_next_adv_channel:
+542c 79200025 set1 mark_ext_patch ,mark 
+542d 44a14028 bpatch patch28_2 ,mem_patch28 
+542e 68008016 fetch 1 ,mem_le_ch_mapped 
+542f 1fe0fe01 increase 1 ,pdata 
+5430 60008016 store 1 ,mem_le_ch_mapped 
+5431 c1940000 rtnne 40 
+5432 70001625 jam 37 ,mem_le_ch_mapped 
+5433 20600000 rtn 
+
+le_context_nexthop:
+5434 79200025 set1 mark_ext_patch ,mark 
+5435 44a1c028 bpatch patch28_3 ,mem_patch28 
+5436 1a208c01 add rega ,coffset_mode ,contr 
+5437 e8c08000 ifetch 1 ,contr 
+5438 c4000000 rtnbit0 mode_le 
+5439 1a208a1a add rega ,coffset_le_event_cnt ,contw 
+543a e8a10000 ifetch 2 ,contw 
+543b 1fe0fe01 increase 1 ,pdata 
+543c e0a10000 istore 2 ,contw 
+543d 1a208c19 add rega ,coffset_le_hop ,contr 
+543e e8c08000 ifetch 1 ,contr 
+543f 1a208a18 add rega ,coffset_le_ch ,contw 
+5440 e8a88000 ifetcht 1 ,contw 
+5441 9840fe00 iadd temp ,pdata 
+5442 1fe67c24 sub pdata ,36 ,null 
+5443 20215445 branch le_nexthop_nowrap ,positive 
+5444 1fe0ffdb increase -37 ,pdata 
+
+le_nexthop_nowrap:
+5445 e0a08000 istore 1 ,contw 
+5446 20600000 rtn 
+
+le_calc_channel_map:
+5447 79200025 set1 mark_ext_patch ,mark 
+5448 44a24028 bpatch patch28_4 ,mem_patch28 
+5449 680283f1 fetch 5 ,mem_le_channel_map 
+544a 18000400 force 0 ,temp 
+544b 18007225 force 37 ,loopcnt 
+
+le_count_channels_loop:
+544c c300544e bbit0 0 ,le_count_channels_notused 
+544d 18408401 increase 1 ,temp 
+
+le_count_channels_notused:
+544e 1fe37e00 rshift pdata ,pdata 
+544f c200544c loop le_count_channels_loop 
+5450 1840ffff add temp ,-1 ,pdata 
+5451 600083e2 store 1 ,mem_le_channels 
+5452 20600000 rtn 
+
+le_map_channel:
+5453 79200025 set1 mark_ext_patch ,mark 
+5454 44a2c028 bpatch patch28_5 ,mem_patch28 
+5455 680083d8 fetch 1 ,mem_le_ch 
+5456 98000e00 iforce queue 
+5457 680a83f1 fetcht 5 ,mem_le_channel_map 
+5458 a84fffff qisolate1 temp 
+5459 2020d46b branch le_map_channel_end ,true 
+
+le_map_channel_next:
+545a 79200025 set1 mark_ext_patch ,mark 
+545b 44a34028 bpatch patch28_6 ,mem_patch28 
+545c 680083e2 fetch 1 ,mem_le_channels 
+545d 98e67e00 isub queue ,pdata 
+545e 20215461 branch le_map_channel_cont ,positive 
+545f 1fe60fff sub pdata ,-1 ,queue 
+5460 2020545a branch le_map_channel_next 
+
+le_map_channel_cont:
+5461 18e27200 copy queue ,loopcnt 
+5462 18000e00 force 0 ,queue 
+
+le_map_channel_loop:
+5463 a84fffff qisolate1 temp 
+5464 2020d466 branch le_map_channel_skip ,true 
+5465 1f20f201 increase 1 ,loopcnt 
+
+le_map_channel_skip:
+5466 1f227e00 deposit loopcnt 
+5467 203a546b branch le_map_channel_end ,blank 
+5468 18e08e01 increase 1 ,queue 
+5469 1f20f3ff increase -1 ,loopcnt 
+546a 20205463 branch le_map_channel_loop 
+
+le_map_channel_end:
+546b 18e27e00 deposit queue 
+546c 60008016 store 1 ,mem_le_ch_mapped 
+546d 20600000 rtn 
+
+le_wait_tx:
+546e 2034d471 branch le_wait_master ,master 
+546f 37c18200 until null ,timeout 
+5470 20600000 rtn 
+
+le_wait_master:
+5471 d9600ea0 arg 0xea0 ,timeup 
+5472 34730200 until clkn_rt ,meet 
+5473 20600000 rtn 
+
+le_receive_adv:
+5474 78487c00 disable swfine 
+5475 680143d5 fetch 2 ,mem_le_scan_window 
+5476 1fe21600 copy pdata ,timeup 
+5477 2020547e branch le_receive_packet 
+
+le_receive_slave:
+5478 79200025 set1 mark_ext_patch ,mark 
+5479 44a3c028 bpatch patch28_7 ,mem_patch28 
+547a 78287c00 enable swfine 
+547b 680103ce fetch 2 ,mem_le_receive_window 
+547c 680a46f9 fetcht 4 ,mem_le_transmit_window 
+547d 98409600 iadd temp ,timeup 
+
+le_receive_packet:
+547e 204053e6 call lerx_setfreq 
+
+le_receive_rxon:
+547f 79200025 set1 mark_ext_patch ,mark 
+5480 44a44029 bpatch patch29_0 ,mem_patch29 
+5481 204053dd call le_prep 
+5482 7856fc00 disable match 
+5483 7826fc00 enable decode_fec0 
+5484 7830fc00 enable is_rx 
+5485 78507c00 disable is_tx 
+5486 19623600 copy timeup ,stop_watch 
+5487 37c18400 correlate null ,timeout 
+5488 2037548b branch le_receive_on_attempt ,attempt 
+5489 1b420400 copy clke ,temp 
+548a 600b009c storet 6 ,mem_sync_clke 
+
+le_receive_on_attempt:
+548b 242c375c nbranch end_of_packet ,sync 
+548c 20375492 branch le_receive_skip ,attempt 
+548d dd2001e0 arg param_clke_cal_le ,clke_rt 
+548e 1c225000 copy bt_clk ,clke_bt 
+548f 680083c0 fetch 1 ,mem_le_state 
+5490 c301d492 bbit0 lestate_got_first_packet ,le_receive_skip 
+5491 2055bcb6 call lpm_adjust_clk ,wake 
+
+le_receive_skip:
+5492 79200025 set1 mark_ext_patch ,mark 
+5493 44a4c029 bpatch patch29_1 ,mem_patch29 
+5494 20403af3 call save_rssi 
+5495 7823fc00 enable enable_white 
+5496 7824fc00 enable enable_crc 
+5497 09800008 parse demod ,bucket ,8 
+5498 19897e00 rshift3 pwindow ,pdata 
+5499 60008340 store 1 ,mem_le_rxbuf 
+549a 09800008 parse demod ,bucket ,8 
+549b 19897e00 rshift3 pwindow ,pdata 
+549c e0a08000 istore 1 ,contw 
+549d 1fe1723f and pdata ,0x3f ,loopcnt 
+549e 2022d4a3 branch lerx_nopayload ,zero 
+
+lerx_loop:
+549f 09800008 parse demod ,bucket ,8 
+54a0 19897e00 rshift3 pwindow ,pdata 
+54a1 e0a08000 istore 1 ,contw 
+54a2 c200549f loop lerx_loop 
+
+lerx_nopayload:
+54a3 79200025 set1 mark_ext_patch ,mark 
+54a4 44a54029 bpatch patch29_2 ,mem_patch29 
+54a5 09800018 parse demod ,bucket ,24 
+54a6 78287c00 enable swfine 
+54a7 db600664 arg param_sifs ,stop_watch 
+54a8 1fef7e00 rshift32 pdata ,pdata 
+54a9 1ff17e00 rshift16 pdata ,pdata 
+54aa e0a18000 istore 3 ,contw 
+54ab 2023375c branch end_of_packet ,crc_failed 
+54ac 7836fc00 enable match 
+54ad 68008017 fetch 1 ,mem_last_freq 
+54ae 1fe0a202 add pdata ,2 ,rega 
+54af 20403ab6 call rf_write_freq 
+54b0 7846fc00 disable decode_fec0 
+54b1 20203a7a branch set_sync_on 
+
+le_transmit_receive_sifs:
+54b2 79200025 set1 mark_ext_patch ,mark 
+54b3 44a5c029 bpatch patch29_3 ,mem_patch29 
+54b4 204054bd call le_transmit 
+54b5 68088017 fetcht 1 ,mem_last_freq 
+54b6 20403a82 call set_freq_rx 
+54b7 20403a87 call rf_rx_enable 
+54b8 78287c00 enable swfine 
+54b9 d9601388 arg 5000 ,timeup 
+54ba 2020547f branch le_receive_rxon 
+
+le_transmit_norx:
+54bb 204054bd call le_transmit 
+54bc 2020375c branch end_of_packet 
+
+le_transmit:
+54bd 79200025 set1 mark_ext_patch ,mark 
+54be 44a64029 bpatch patch29_4 ,mem_patch29 
+54bf 204053dd call le_prep 
+54c0 204053eb call letx_setfreq 
+54c1 79202a00 set1 txgfsk ,radio_ctrl 
+54c2 782efc00 enable encode_fec0 
+54c3 78307c00 enable is_tx 
+54c4 7850fc00 disable is_rx 
+54c5 2040546e call le_wait_tx 
+54c6 19317e00 rshift16 access ,pdata 
+54c7 1fecfe00 rshift8 pdata ,pdata 
+54c8 1ff1fe00 rshift4 pdata ,pdata 
+54c9 08008628 inject mod ,40 
+54ca 7823fc00 enable enable_white 
+54cb 7824fc00 enable enable_crc 
+54cc 79200025 set1 mark_ext_patch ,mark 
+54cd 44a6c029 bpatch patch29_5 ,mem_patch29 
+54ce 6800c43e fetch 1 ,mem_le_txheader 
+54cf 08008608 inject mod ,8 
+54d0 e8c08000 ifetch 1 ,contr 
+54d1 1fe1723f and pdata ,0x3f ,loopcnt 
+54d2 08008608 inject mod ,8 
+54d3 2022d4d7 branch letr_nopayload ,zero 
+
+letr_loop:
+54d4 e8c08000 ifetch 1 ,contr 
+54d5 08008608 inject mod ,8 
+54d6 c20054d4 loop letr_loop 
+
+letr_nopayload:
+54d7 78247c00 enable enable_parity 
+54d8 08008618 inject mod ,24 
+54d9 78447c00 disable enable_parity 
+54da 37d38200 until null ,tx_clear 
+54db 20000064 nop 100 
+54dc 784efc00 disable encode_fec0 
+54dd 20600000 rtn 
+
+le_send_adv_ind:
+54de 79200025 set1 mark_ext_patch ,mark 
+54df 44a74029 bpatch patch29_6 ,mem_patch29 
+54e0 6800c4db fetch 1 ,mem_le_adv_type 
+54e1 c000d4ef beq adv_direct_ind ,le_send_adv_direct_ind 
+54e2 6800c4dc fetch 1 ,mem_le_adv_own_addr_type 
+54e3 1ff27e00 lshift4 pdata ,pdata 
+54e4 1febfe00 lshift2 pdata ,pdata 
+54e5 6000c43e store 1 ,mem_le_txheader 
+54e6 6808c3d9 fetcht 1 ,mem_le_adv_data_len 
+54e7 1840fe06 add temp ,6 ,pdata 
+54e8 6000c43f store 1 ,mem_le_txlen 
+54e9 680344f9 fetch 6 ,mem_le_lap 
+54ea 60034440 store 6 ,mem_le_txpayload 
+54eb 18427200 copy temp ,loopcnt 
+54ec d8c043da arg mem_le_adv_data ,contr 
+54ed 20407e45 call memcpy 
+54ee 202054ff branch le_send_adv_transmit 
+
+le_send_adv_direct_ind:
+54ef 680944c2 fetcht 2 ,mem_le_notify_handle 
+54f0 20405866 call le_att_check_notification_enable 
+54f1 1a220a00 copy rega ,contw 
+54f2 58000001 setarg 1 
+54f3 e0a08000 istore 1 ,contw 
+54f4 6800c4dd fetch 1 ,mem_le_adv_direct_addr_type 
+54f5 1ff27e00 lshift4 pdata ,pdata 
+54f6 1febfe00 lshift2 pdata ,pdata 
+54f7 1fe0fe01 increase 1 ,pdata 
+54f8 6000c43e store 1 ,mem_le_txheader 
+54f9 5800000c setarg 12 
+54fa 6000c43f store 1 ,mem_le_txlen 
+54fb 680344f9 fetch 6 ,mem_le_lap 
+54fc 60034440 store 6 ,mem_le_txpayload 
+54fd 68034274 fetch 6 ,mem_hci_plap 
+54fe e0a30000 istore 6 ,contw 
+
+le_send_adv_transmit:
+54ff 79200025 set1 mark_ext_patch ,mark 
+5500 44a7c029 bpatch patch29_7 ,mem_patch29 
+5501 68008000 fetch 1 ,mem_le_adv_transmit 
+5502 1fe0fe01 increase 1 ,pdata 
+5503 60008000 store 1 ,mem_le_adv_transmit 
+5504 db600708 arg 1800 ,stop_watch 
+5505 7856fc00 disable match 
+5506 202054b2 branch le_transmit_receive_sifs 
+
+le_send_scan_request:
+5507 79200025 set1 mark_ext_patch ,mark 
+5508 44a8402a bpatch patch2a_0 ,mem_patch2a 
+5509 6800c4f6 fetch 1 ,mem_le_scan_type 
+550a c1808000 rtnne le_scan_type_active ,pdata 
+550b 68008000 fetch 1 ,mem_le_adv_transmit 
+550c 1fe0fe01 increase 1 ,pdata 
+550d 60008000 store 1 ,mem_le_adv_transmit 
+550e d8400c03 arg 0x0c03 ,temp 
+550f 6800c4f7 fetch 1 ,mem_le_scan_own_addr_type 
+5510 7d3a0406 nsetflag blank ,le_sender_addr_bit ,temp 
+5511 1a227e00 copy rega ,pdata 
+5512 7d3a0407 nsetflag blank ,le_receiver_addr_bit ,temp 
+5513 6009443e storet 2 ,mem_le_txheader 
+5514 680344f9 fetch 6 ,mem_le_lap 
+5515 e0a30000 istore 6 ,contw 
+5516 680303d0 fetch 6 ,mem_le_plap 
+5517 e0a30000 istore 6 ,contw 
+5518 202054b2 branch le_transmit_receive_sifs 
+
+le_send_scan_response:
+5519 79200025 set1 mark_ext_patch ,mark 
+551a 44a8c02a bpatch patch2a_1 ,mem_patch2a 
+551b d8400004 arg scan_rsp ,temp 
+551c 6800c4dc fetch 1 ,mem_le_adv_own_addr_type 
+551d 7d3a0406 nsetflag blank ,le_sender_addr_bit ,temp 
+551e 6008c43e storet 1 ,mem_le_txheader 
+551f 6808c3f9 fetcht 1 ,mem_le_scan_data_len 
+5520 1840fe06 add temp ,6 ,pdata 
+5521 6000c43f store 1 ,mem_le_txlen 
+5522 680344f9 fetch 6 ,mem_le_lap 
+5523 60034440 store 6 ,mem_le_txpayload 
+5524 d8c043fa arg mem_le_scan_data ,contr 
+5525 18427200 copy temp ,loopcnt 
+5526 20407e45 call memcpy 
+5527 202054bb branch le_transmit_norx 
+
+le_connect_request:
+5528 79200025 set1 mark_ext_patch ,mark 
+5529 44a9402a bpatch patch2a_2 ,mem_patch2a 
+552a 18007fff force -1 ,pdata 
+552b 38080001 setsect 2 ,1 
+552c 600283f1 store 5 ,mem_le_channel_map 
+552d 20405447 call le_calc_channel_map 
+552e 18007204 force 4 ,loopcnt 
+552f d8a003e5 arg mem_le_access ,contw 
+5530 20406227 call generate_random_loop 
+5531 680144f4 fetch 2 ,mem_le_conn_superto 
+5532 600103ef store 2 ,mem_le_superto 
+
+le_con_req_hop_retry:
+5533 180a7e00 random pdata 
+5534 1fe17e0f and_into 0xf ,pdata 
+5535 1fe67c04 sub pdata ,4 ,null 
+5536 20215533 branch le_con_req_hop_retry ,positive 
+5537 600083d9 store 1 ,mem_le_hop 
+5538 60008682 store 1 ,mem_tmp1 
+5539 79200025 set1 mark_ext_patch ,mark 
+553a 44a9c02a bpatch patch2a_3 ,mem_patch2a 
+553b 680943d0 fetcht 2 ,mem_le_conn_interval 
+553c 600903c2 storet 2 ,mem_le_tsniff 
+553d 18422600 copy temp ,regc 
+553e 1c40fe07 add clkn_bt ,7 ,pdata 
+553f 9a66fc00 idiv regc 
+5540 20407efd call wait_div_end 
+5541 18072200 remainder rega 
+5542 9a267e00 isub rega ,pdata 
+5543 9a60fe00 iadd regc ,pdata 
+5544 680943ce fetcht 2 ,mem_le_dsniff 
+5545 9840fe00 iadd temp ,pdata 
+5546 600203c4 store 4 ,mem_le_anchor 
+5547 9c462200 isub clkn_bt ,rega 
+5548 1a20a3fa increase -6 ,rega 
+5549 da402205 arg 0x2205 ,regb 
+554a 6800c4ed fetch 1 ,mem_le_conn_own_addr_type 
+554b 7d3a2406 nsetflag blank ,le_sender_addr_bit ,regb 
+554c 6800c4e6 fetch 1 ,mem_le_conn_peer_addr_type 
+554d 7d3a2407 nsetflag blank ,le_receiver_addr_bit ,regb 
+554e 1a427e00 copy regb ,pdata 
+554f 6001443e store 2 ,mem_le_txheader 
+5550 680344f9 fetch 6 ,mem_le_lap 
+5551 e0a30000 istore 6 ,contw 
+5552 680303d0 fetch 6 ,mem_le_plap 
+5553 e0a30000 istore 6 ,contw 
+5554 680203e5 fetch 4 ,mem_le_access 
+5555 e0a20000 istore 4 ,contw 
+5556 180a7e00 random pdata 
+5557 e0a10000 istore 2 ,contw 
+5558 180a7e00 random pdata 
+5559 e0a08000 istore 1 ,contw 
+555a 18007e02 force 2 ,pdata 
+555b e0a08000 istore 1 ,contw 
+555c 1a2b7e00 rshift2 rega ,pdata 
+555d e0a10000 istore 2 ,contw 
+555e 1a6b7e00 rshift2 regc ,pdata 
+555f e0a10000 istore 2 ,contw 
+5560 79200025 set1 mark_ext_patch ,mark 
+5561 44aa402a bpatch patch2a_4 ,mem_patch2a 
+5562 680144f2 fetch 2 ,mem_le_conn_latency 
+5563 e0a10000 istore 2 ,contw 
+5564 680144f4 fetch 2 ,mem_le_conn_superto 
+5565 e0a10000 istore 2 ,contw 
+5566 680283f1 fetch 5 ,mem_le_channel_map 
+5567 e0a28000 istore 5 ,contw 
+5568 680083d9 fetch 1 ,mem_le_hop 
+5569 d84000a0 arg param_le_sca ,temp 
+556a 9841fe00 ior temp ,pdata 
+556b e0a08000 istore 1 ,contw 
+556c 204054bb call le_transmit_norx 
+556d 5800443e setarg mem_le_txheader 
+556e 1fe08c12 add pdata ,18 ,contr 
+556f e8c18000 ifetch 3 ,contr 
+5570 600183e9 store 3 ,mem_le_crcinit 
+5571 20600000 rtn 
+
+le_init_adv:
+5572 79200025 set1 mark_ext_patch ,mark 
+5573 44aac02a bpatch patch2a_5 ,mem_patch2a 
+5574 7854fc00 disable master 
+5575 20205415 branch le_adv_access 
+
+le_update_param:
+5576 79200025 set1 mark_ext_patch ,mark 
+5577 44ab402a bpatch patch2a_6 ,mem_patch2a 
+5578 680083c0 fetch 1 ,mem_le_state 
+5579 c4028000 rtnbit0 lestate_update_param 
+557a 680103da fetch 2 ,mem_le_event_count 
+557b 680903e0 fetcht 2 ,mem_le_instant 
+557c 98467e00 isub temp ,pdata 
+557d 24610000 nrtn positive 
+557e 680083c0 fetch 1 ,mem_le_state 
+557f 793ffe05 set0 lestate_update_param ,pdata 
+5580 793ffe03 set0 lestate_got_first_packet ,pdata 
+5581 600083c0 store 1 ,mem_le_state 
+5582 680203c4 fetch 4 ,mem_le_anchor 
+5583 680903c2 fetcht 2 ,mem_le_tsniff 
+5584 98462200 isub temp ,rega 
+5585 79200025 set1 mark_ext_patch ,mark 
+5586 44abc02a bpatch patch2a_7 ,mem_patch2a 
+5587 6800c434 fetch 1 ,mem_le_new_param 
+5588 600083ec store 1 ,mem_le_window_size 
+5589 e8c90000 ifetcht 2 ,contr 
+558a e8c10000 ifetch 2 ,contr 
+558b 1febfe00 lshift2 pdata ,pdata 
+558c 600103c2 store 2 ,mem_le_tsniff 
+558d 184b8400 lshift2 temp ,temp 
+558e 9840fe00 iadd temp ,pdata 
+558f e8ca0000 ifetcht 4 ,contr 
+5590 600a03ed storet 4 ,mem_le_slave_latency 
+5591 9a20fe00 iadd rega ,pdata 
+5592 600203c4 store 4 ,mem_le_anchor 
+5593 20205a2b branch le_receive_window_size 
+
+le_update_channel_map:
+5594 79200025 set1 mark_ext_patch ,mark 
+5595 44ac402b bpatch patch2b_0 ,mem_patch2b 
+5596 680083c0 fetch 1 ,mem_le_state 
+5597 c4030000 rtnbit0 lestate_update_map 
+5598 680103da fetch 2 ,mem_le_event_count 
+5599 680903e0 fetcht 2 ,mem_le_instant 
+559a 98467e00 isub temp ,pdata 
+559b 24610000 nrtn positive 
+559c 680083c0 fetch 1 ,mem_le_state 
+559d 793ffe06 set0 lestate_update_map ,pdata 
+559e 600083c0 store 1 ,mem_le_state 
+559f 6802c42f fetch 5 ,mem_le_new_map 
+55a0 600283f1 store 5 ,mem_le_channel_map 
+55a1 20205447 branch le_calc_channel_map 
+
+le_acknowledge:
+55a2 79200025 set1 mark_ext_patch ,mark 
+55a3 44acc02b bpatch patch2b_1 ,mem_patch2b 
+55a4 20405a0b call le_supervision_flush 
+55a5 204055b7 call le_check_wak 
+55a6 68008340 fetch 1 ,mem_le_rxbuf 
+55a7 1fe37e00 rshift pdata ,pdata 
+55a8 9842fe00 ixor temp ,pdata 
+55a9 2feffe02 isolate1 nesn ,pdata 
+55aa 7920800f setflag true ,mark_old_packet ,mark 
+55ab 68008341 fetch 1 ,mem_le_rxbuf + 1 
+55ac 203a55b2 branch le_ack_unenc ,blank 
+55ad 680083c0 fetch 1 ,mem_le_state 
+55ae c30255b2 bbit0 lestate_encryption ,le_ack_unenc 
+55af 20407599 call load_sk 
+55b0 2040750e call le_decrypt 
+55b1 247a0000 nrtn blank 
+
+le_ack_unenc:
+55b2 c6078000 rtnmark1 mark_old_packet 
+55b3 680883d7 fetcht 1 ,mem_le_arq 
+55b4 79400402 setflip nesn ,temp 
+55b5 600883d7 storet 1 ,mem_le_arq 
+55b6 202058ac branch le_parse 
+
+le_check_wak:
+55b7 79200025 set1 mark_ext_patch ,mark 
+55b8 44ad402b bpatch patch2b_2 ,mem_patch2b 
+55b9 680883d7 fetcht 1 ,mem_le_arq 
+55ba 284c0005 isolate0 wak ,temp 
+55bb 20608000 rtn true 
+55bc 68008340 fetch 1 ,mem_le_rxbuf 
+55bd 1fe3fe00 lshift pdata ,pdata 
+55be 9842fe00 ixor temp ,pdata 
+55bf c4018000 rtnbit0 sn 
+55c0 793f8405 set0 wak ,temp 
+55c1 79400403 setflip sn ,temp 
+55c2 600883d7 storet 1 ,mem_le_arq 
+55c3 28400603 compare 3 ,temp ,3 
+55c4 24608000 nrtn true 
+55c5 6800c440 fetch 1 ,mem_le_txpayload 
+55c6 c1828000 rtnne ll_start_enc_req 
+55c7 680083c0 fetch 1 ,mem_le_state 
+55c8 79207e04 set1 lestate_encryption ,pdata 
+55c9 600083c0 store 1 ,mem_le_state 
+55ca 20600000 rtn 
+
+le_wait_adv:
+55cb 79200025 set1 mark_ext_patch ,mark 
+55cc 44adc02b bpatch patch2b_3 ,mem_patch2b 
+55cd 2040542c call le_next_adv_channel 
+55ce 20405474 call le_receive_adv 
+55cf 68008001 fetch 1 ,mem_le_adv_waitcnt 
+55d0 1fe0fe01 increase 1 ,pdata 
+55d1 60008001 store 1 ,mem_le_adv_waitcnt 
+55d2 20600000 rtn 
+
+le_scan:
+55d3 79200025 set1 mark_ext_patch ,mark 
+55d4 44ae402b bpatch patch2b_4 ,mem_patch2b 
+55d5 6800c3d2 fetch 1 ,mem_le_scan_enable 
+55d6 c1808000 rtnne le_scan_enable 
+55d7 d8e00003 arg le_scan_interval_timer ,queue 
+55d8 20407e53 call timer_check 
+55d9 247a0000 nrtn blank 
+55da 680143d3 fetch 2 ,mem_le_scan_interval 
+55db 680943d5 fetcht 2 ,mem_le_scan_window 
+55dc 98467e00 isub temp ,pdata 
+55dd d8e00003 arg le_scan_interval_timer ,queue 
+55de 20407e4c call timer_init 
+55df 7854fc00 disable master 
+55e0 20405572 call le_init_adv 
+55e1 204055cb call le_wait_adv 
+55e2 24768000 nrtn match 
+55e3 79200025 set1 mark_ext_patch ,mark 
+55e4 44aec02b bpatch patch2b_5 ,mem_patch2b 
+55e5 68030342 fetch 6 ,mem_le_rxbuf + 2 
+55e6 600303d0 store 6 ,mem_le_plap 
+55e7 204042a7 call le_scan_dongle 
+55e8 20405b39 call le_scan_addr_to_uart 
+55e9 68008002 fetch 1 ,mem_le_adv_rcv 
+55ea 1fe0fe01 increase 1 ,pdata 
+55eb 60008002 store 1 ,mem_le_adv_rcv 
+55ec 204055f9 call le_create_conn 
+55ed 20748000 rtn master 
+55ee 204048d1 call hci_send_le_adv_report_event 
+55ef 20405507 call le_send_scan_request 
+55f0 24768000 nrtn match 
+55f1 79200025 set1 mark_ext_patch ,mark 
+55f2 44af402b bpatch patch2b_6 ,mem_patch2b 
+55f3 68008004 fetch 1 ,mem_le_scanrsp_rcv 
+55f4 1fe0fe01 increase 1 ,pdata 
+55f5 60008004 store 1 ,mem_le_scanrsp_rcv 
+55f6 68048348 fetch 9 ,mem_le_rxbuf + 8 
+55f7 60048103 store 9 ,mem_tmp_buffer 
+55f8 202048d1 branch hci_send_le_adv_report_event 
+
+le_create_conn:
+55f9 79200025 set1 mark_ext_patch ,mark 
+55fa 44afc02b bpatch patch2b_7 ,mem_patch2b 
+55fb 6800841c fetch 1 ,mem_cmd_le_create_conn 
+55fc c18d8000 rtnne hci_cmd_le_create_conn ,pdata 
+55fd 680303d0 fetch 6 ,mem_le_plap 
+55fe 680b44e7 fetcht 6 ,mem_le_conn_peer_addr 
+55ff 98467c00 isub temp ,null 
+5600 24628000 nrtn zero 
+5601 204032d6 call context_new 
+5602 24628000 nrtn zero 
+5603 20405528 call le_connect_request 
+5604 2040535f call le_init_master 
+5605 79200025 set1 mark_ext_patch ,mark 
+5606 44b0402c bpatch patch2c_0 ,mem_patch2c 
+5607 70427200 jam 0 ,mem_hci_cmd 
+5608 7003f800 jam 0 ,mem_le_peer_sca 
+5609 6800c132 fetch 1 ,mem_device_option 
+560a c082560c bne dvc_op_dongle ,le_create_conn_ndongle 
+560b 7003e321 jam conn_sm_send_write_req ,mem_le_conn_sm 
+
+le_create_conn_ndongle:
+560c d8400000 arg 0 ,temp 
+560d 204048ea call hci_send_le_conn_complete 
+560e 7043d200 jam 0 ,mem_le_scan_enable 
+560f 70041c00 jam 0 ,mem_cmd_le_create_conn 
+5610 700b7d2c jam xt_ll_version_ind ,mem_fifo_temp 
+5611 20405620 call le_xtype_fifo_in 
+5612 202032bd branch context_save 
+
+le_scan_check_sender_addr_type:
+5613 da200001 arg 1 ,rega 
+5614 68008340 fetch 1 ,mem_le_rxbuf 
+5615 c3830000 rtnbit1 le_sender_addr_bit 
+5616 da200000 arg 0 ,rega 
+5617 20600000 rtn 
+
+le_xtype_fifo_count:
+5618 d8c044ff arg mem_le_xtype_fifo ,contr 
+5619 20207fb2 branch fifo_content_count 
+
+le_xtype_fifo_is_empty:
+561a da2044ff arg mem_le_xtype_fifo ,rega 
+561b 20207fac branch fifo_is_empty 
+
+le_xtype_fifo_is_full:
+561c da2044ff arg mem_le_xtype_fifo ,rega 
+561d 20207fae branch fifo_is_full 
+
+le_xtype_fifo_is_near_full:
+561e da2044ff arg mem_le_xtype_fifo ,rega 
+561f 20207fb0 branch fifo_is_near_full 
+
+le_xtype_fifo_in:
+5620 da2044ff arg mem_le_xtype_fifo ,rega 
+5621 20207f92 branch fifo_in 
+
+le_prepare_tx:
+5622 79200025 set1 mark_ext_patch ,mark 
+5623 44b0c02c bpatch patch2c_1 ,mem_patch2c 
+5624 680083d7 fetch 1 ,mem_le_arq 
+5625 c3828000 rtnbit1 wak 
+5626 da2044ff arg mem_le_xtype_fifo ,rega 
+5627 20407f9f call fifo_out 
+5628 243a5630 nbranch le_prepare_tx_cmd ,blank 
+5629 6800c132 fetch 1 ,mem_device_option 
+562a c080d890 bne dvc_op_hci ,le_send_empty 
+562b d8200000 arg 0 ,type 
+562c 204044a3 call hci_rx_packet 
+562d 18227e00 copy type ,pdata 
+562e 247a0000 nrtn blank 
+562f 20205890 branch le_send_empty 
+
+le_prepare_tx_cmd:
+5630 1fe20400 copy pdata ,temp 
+5631 79200025 set1 mark_ext_patch ,mark 
+5632 44b1402c bpatch patch2c_2 ,mem_patch2c 
+5633 18427e00 copy temp ,pdata 
+5634 c302d64b bbit0 5 ,le_prepare_l2cap 
+5635 18000203 force 3 ,type 
+5636 793ffe05 set0 5 ,pdata 
+5637 6000c440 store 1 ,mem_le_txpayload 
+5638 79200025 set1 mark_ext_patch ,mark 
+5639 44b1c02c bpatch patch2c_3 ,mem_patch2c 
+563a 6800c440 fetch 1 ,mem_le_txpayload 
+563b c000568f beq ll_connection_update_req ,le_send_connection_update_req 
+563c c000d691 beq ll_channel_map_req ,le_send_channel_map_req 
+563d c0015693 beq ll_terminate_ind ,le_send_terminate_ind 
+563e c001d695 beq ll_enc_req ,le_send_enc_req 
+563f c00256a6 beq ll_enc_rsp ,le_send_enc_rsp 
+5640 c002d6b7 beq ll_start_enc_req ,le_send_start_enc_req 
+5641 c00356b9 beq ll_start_enc_rsp ,le_send_start_enc_rsp 
+5642 c003d6bf beq ll_unknown_rsp ,le_send_unknown_rsp 
+5643 c00456c1 beq ll_feature_req ,le_send_feature 
+5644 c004d6c1 beq ll_feature_rsp ,le_send_feature 
+5645 c00556c5 beq ll_pause_enc_req ,le_send_pause_enc_req 
+5646 c005d6c7 beq ll_pause_enc_rsp ,le_send_pause_enc_rsp 
+5647 c00656c9 beq ll_version_ind ,le_send_version_ind 
+5648 c006d6cf beq ll_reject_ind ,le_send_reject_ind 
+5649 c007d6d1 beq ll_connection_param_req ,le_send_conn_param_req 
+564a 20203bf1 branch assert 
+
+le_prepare_l2cap:
+564b 70444300 jam 0 ,mem_le_txcid + 1 
+564c 18000202 force 2 ,type 
+564d c3035662 bbit0 6 ,le_prepare_att 
+564e c0295662 beq attop_write_command ,le_prepare_att 
+564f c0695662 beq attop_signed_write_command ,le_prepare_att 
+5650 70444206 jam le_l2cap_cid_smp ,mem_le_txcid 
+5651 793ffe06 set0 6 ,pdata 
+5652 6000c444 store 1 ,mem_le_l2cap 
+
+le_prepare_smp:
+5653 79200025 set1 mark_ext_patch ,mark 
+5654 44b2402c bpatch patch2c_4 ,mem_patch2c 
+5655 6800c444 fetch 1 ,mem_le_l2cap 
+
+le_prepare_smp0:
+5656 c000d6e5 beq smp_pairing_request ,le_send_smp_pairing_request 
+5657 c00156ed beq smp_pairing_response ,le_send_smp_pairing_response 
+5658 c001d6f5 beq smp_pairing_confirm ,le_send_smp_pairing_confirm 
+5659 c00256fa beq smp_pairing_random ,le_send_smp_pairing_random 
+565a c002d6ff beq smp_pairing_failed ,le_send_smp_pairing_failed 
+565b c0035701 beq smp_encryption_information ,le_send_smp_encryption_information 
+565c c003d70b beq smp_master_identification ,le_send_smp_master_identification 
+565d c0045712 beq smp_identity_information ,le_send_smp_identity_information 
+565e c004d717 beq smp_identity_address_information ,le_send_smp_identity_address_information 
+565f c005571e beq smp_signing_information ,le_send_smp_signing_information 
+5660 c005d721 beq smp_security_request ,le_send_smp_security_request 
+5661 20203bf1 branch assert 
+
+le_prepare_att:
+5662 70444204 jam le_l2cap_cid_att ,mem_le_txcid 
+5663 6000c444 store 1 ,mem_le_l2cap 
+5664 79200025 set1 mark_ext_patch ,mark 
+5665 44b2c02c bpatch patch2c_5 ,mem_patch2c 
+
+le_prepare_att0:
+5666 6800c444 fetch 1 ,mem_le_l2cap 
+5667 c000d729 beq attop_error_response ,le_send_att_error_response 
+5668 c001572f beq attop_exchange_mtu_request ,le_send_att_exchange_mtu 
+5669 c001d72f beq attop_exchange_mtu_response ,le_send_att_exchange_mtu 
+566a c0025732 beq attop_find_information_request ,le_send_att_find_information_request 
+566b c002d737 beq attop_find_information_response ,le_send_att_find_information_response 
+566c c0035748 beq attop_find_by_type_value_request ,le_send_att_find_by_type_value_request 
+566d c003d752 beq attop_find_by_type_value_response ,le_send_att_find_by_type_value_response 
+566e c0045793 beq attop_read_by_type_request ,le_send_att_read_by_type_request 
+566f c004d79b beq attop_read_by_type_response ,le_send_att_read_by_type_response 
+5670 c00557be beq attop_read_request ,le_send_att_read_request 
+5671 c005d7c6 beq attop_read_response ,le_send_att_read_response 
+5672 c00657d1 beq attop_read_blob_request ,le_send_att_read_blob_request 
+5673 c006d7d6 beq attop_read_blob_response ,le_send_att_read_blob_response 
+5674 c00757e5 beq attop_read_multiple_request ,le_send_att_read_multiple_request 
+5675 c007d7ec beq attop_read_multiple_response ,le_send_att_read_multiple_response 
+5676 c0085812 beq attop_read_by_group_type_request ,le_send_att_read_by_group_type_request 
+5677 c008d81a beq attop_read_by_group_type_response ,le_send_att_read_by_group_type_response 
+5678 c009583e beq attop_write_request ,le_send_att_write_request 
+5679 c009d845 beq attop_write_response ,le_send_att_write_response 
+567a c00b585e beq attop_prepare_write_request ,le_send_att_prepare_write_request 
+567b c00bd860 beq attop_prepare_write_response ,le_send_att_prepare_write_response 
+567c c00c5862 beq attop_execute_write_request ,le_send_att_execute_write_request 
+567d c00cd864 beq attop_execute_write_response ,le_send_att_execute_write_response 
+567e c00dd873 beq attop_handle_value_notification ,le_send_att_handle_value_notification 
+567f c00ed882 beq attop_handle_value_indication ,le_send_att_handle_value_indication 
+5680 c00f5884 beq attop_handle_value_confirmation ,le_send_att_handle_value_confirmation 
+5681 c0295886 beq attop_write_command ,le_send_att_write_command 
+5682 c0695888 beq attop_signed_write_command ,le_send_att_signed_write_command 
+5683 c04f5686 beq empty_le_data_pre ,le_send_empty_le_data_pre 
+5684 c04fd688 beq empty_le_data ,le_send_empty_le_data 
+5685 20203bf1 branch assert 
+
+le_send_empty_le_data_pre:
+5686 700b7d10 jam attop_read_by_group_type_request ,mem_fifo_temp 
+5687 20405620 call le_xtype_fifo_in 
+
+le_send_empty_le_data:
+5688 58000011 setarg 0x0011 
+5689 6001443e store 2 ,mem_le_txheader 
+568a 680083d7 fetch 1 ,mem_le_arq 
+568b 79207e05 set1 wak ,pdata 
+568c 600083d7 store 1 ,mem_le_arq 
+568d 700b7d12 jam attop_write_request ,mem_fifo_temp 
+568e 20205620 branch le_xtype_fifo_in 
+
+le_send_connection_update_req:
+568f 1800040c force 12 ,temp 
+5690 20205892 branch le_send_packet 
+
+le_send_channel_map_req:
+5691 18000408 force 8 ,temp 
+5692 20205892 branch le_send_packet 
+
+le_send_terminate_ind:
+5693 18000402 force 2 ,temp 
+5694 20205892 branch le_send_packet 
+
+le_send_enc_req:
+5695 18007e00 force 0 ,pdata 
+5696 e0a40000 istore 8 ,contw 
+5697 e0a10000 istore 2 ,contw 
+5698 18a20400 copy contw ,temp 
+5699 d8a00380 arg mem_le_skdm ,contw 
+569a 18007208 force 8 ,loopcnt 
+569b 20406227 call generate_random_loop 
+569c 68040380 fetch 8 ,mem_le_skdm 
+569d e0440000 istore 8 ,temp 
+569e 18a20400 copy contw ,temp 
+569f d8a04473 arg mem_le_ivm ,contw 
+56a0 18007204 force 4 ,loopcnt 
+56a1 20406227 call generate_random_loop 
+56a2 68024473 fetch 4 ,mem_le_ivm 
+56a3 e0420000 istore 4 ,temp 
+56a4 18000417 force 23 ,temp 
+56a5 20205892 branch le_send_packet 
+
+le_send_enc_rsp:
+56a6 18a20400 copy contw ,temp 
+56a7 d8a00388 arg mem_le_skds ,contw 
+56a8 18007208 force 8 ,loopcnt 
+56a9 20406227 call generate_random_loop 
+56aa 68040388 fetch 8 ,mem_le_skds 
+56ab e0440000 istore 8 ,temp 
+56ac 18a20400 copy contw ,temp 
+56ad d8a04477 arg mem_le_ivs ,contw 
+56ae 18007204 force 4 ,loopcnt 
+56af 20406227 call generate_random_loop 
+56b0 68024477 fetch 4 ,mem_le_ivs 
+56b1 e0420000 istore 4 ,temp 
+56b2 204074b6 call generate_sk 
+56b3 700b7d25 jam xt_ll_start_enc_req ,mem_fifo_temp 
+56b4 20405620 call le_xtype_fifo_in 
+56b5 1800040d force 13 ,temp 
+56b6 20205892 branch le_send_packet 
+
+le_send_start_enc_req:
+56b7 18000401 force 1 ,temp 
+56b8 20205892 branch le_send_packet 
+
+le_send_start_enc_rsp:
+56b9 18000401 force 1 ,temp 
+56ba 2034d892 branch le_send_packet ,master 
+56bb 700b7d46 jam xt_smp_encryption_information ,mem_fifo_temp 
+56bc 20405620 call le_xtype_fifo_in 
+56bd 18000401 force 1 ,temp 
+56be 20205892 branch le_send_packet 
+
+le_send_unknown_rsp:
+56bf 18000402 force 2 ,temp 
+56c0 20205892 branch le_send_packet 
+
+le_send_feature:
+56c1 58000001 setarg param_le_features 
+56c2 e0a40000 istore 8 ,contw 
+56c3 18000409 force 9 ,temp 
+56c4 20205892 branch le_send_packet 
+
+le_send_pause_enc_req:
+56c5 18000406 force 6 ,temp 
+56c6 20205892 branch le_send_packet 
+
+le_send_pause_enc_rsp:
+56c7 18000406 force 6 ,temp 
+56c8 20205892 branch le_send_packet 
+
+le_send_version_ind:
+56c9 58000a06 setarg param_le_version 
+56ca e0a18000 istore 3 ,contw 
+56cb 58001d87 setarg param_le_subversion 
+56cc e0a10000 istore 2 ,contw 
+56cd 18000406 force 6 ,temp 
+56ce 20205892 branch le_send_packet 
+
+le_send_reject_ind:
+56cf 18000402 force 2 ,temp 
+56d0 20205892 branch le_send_packet 
+
+le_send_conn_param_req:
+56d1 18a08bff increase -1 ,contw 
+56d2 5800000c setarg 0x000c 
+56d3 e0a10000 istore 2 ,contw 
+56d4 58000005 setarg 0x0005 
+56d5 e0a10000 istore 2 ,contw 
+56d6 5800b412 setarg 0xb412 
+56d7 e0a10000 istore 2 ,contw 
+56d8 58000008 setarg 0x0008 
+56d9 e0a10000 istore 2 ,contw 
+56da 58000008 setarg 0x0008 
+56db e0a10000 istore 2 ,contw 
+56dc 58000010 setarg 0x0010 
+56dd e0a10000 istore 2 ,contw 
+56de 58000000 setarg 0 
+56df e0a10000 istore 2 ,contw 
+56e0 5800012c setarg 0x012c 
+56e1 e0a10000 istore 2 ,contw 
+56e2 2040588a call le_send_autolen 
+56e3 18000202 force 2 ,type 
+56e4 20205892 branch le_send_packet 
+
+le_send_smp_pairing_request:
+56e5 59000401 setarg 0x1000401 
+56e6 600244ae store 4 ,mem_le_preq 
+56e7 58070710 setarg 0x070710 
+56e8 e0a18000 istore 3 ,contw 
+56e9 680344af fetch 6 ,mem_le_preq + 1 
+56ea 60034445 store 6 ,mem_le_l2cap_response 
+56eb 1800040b force 11 ,temp 
+56ec 20205892 branch le_send_packet 
+
+le_send_smp_pairing_response:
+56ed 59000302 setarg param_smp_paring_response 
+56ee 600244b5 store 4 ,mem_le_pres 
+56ef 58010410 setarg param_smp_key_dist 
+56f0 e0a18000 istore 3 ,contw 
+56f1 680344b6 fetch 6 ,mem_le_pres + 1 
+56f2 60034445 store 6 ,mem_le_l2cap_response 
+56f3 1800040b force 11 ,temp 
+56f4 20205892 branch le_send_packet 
+
+le_send_smp_pairing_confirm:
+56f5 204074b0 call generate_confirm 
+56f6 d8a04445 arg mem_le_l2cap_response ,contw 
+56f7 204075a3 call store_aes_result 
+56f8 18000415 force 21 ,temp 
+56f9 20205892 branch le_send_packet 
+
+le_send_smp_pairing_random:
+56fa 680403b0 fetch 8 ,mem_le_mrand 
+56fb 2034d6fd branch le_send_smp_mrandom ,master 
+56fc 6804449c fetch 8 ,mem_le_srand 
+
+le_send_smp_mrandom:
+56fd 20405723 call le_send_smp_128 
+56fe 20205892 branch le_send_packet 
+
+le_send_smp_pairing_failed:
+56ff 18000406 force 6 ,temp 
+5700 20205892 branch le_send_packet 
+
+le_send_smp_encryption_information:
+5701 700b7d29 jam bt_evt_le_enc_info ,mem_fifo_temp 
+5702 20407c27 call ui_ipc_send_event 
+5703 700b7d47 jam xt_smp_master_identification ,mem_fifo_temp 
+5704 20405620 call le_xtype_fifo_in 
+5705 d8a003a0 arg mem_le_my_ltk ,contw 
+5706 20406226 call generate_random 
+5707 680403a0 fetch 8 ,mem_le_my_ltk 
+5708 6804447b fetch 8 ,mem_le_ltk 
+5709 20405723 call le_send_smp_128 
+570a 20205892 branch le_send_packet 
+
+le_send_smp_master_identification:
+570b 700b7d48 jam xt_smp_identity_information ,mem_fifo_temp 
+570c 20405620 call le_xtype_fifo_in 
+570d d8a04445 arg mem_le_l2cap_response ,contw 
+570e 18007208 force 8 ,loopcnt 
+570f 20406227 call generate_random_loop 
+5710 1800040f force 15 ,temp 
+5711 20205892 branch le_send_packet 
+
+le_send_smp_identity_information:
+5712 700b7d49 jam xt_smp_identity_address_information ,mem_fifo_temp 
+5713 20405620 call le_xtype_fifo_in 
+5714 d8a04445 arg mem_le_l2cap_response ,contw 
+5715 20406226 call generate_random 
+5716 2020588a branch le_send_autolen 
+
+le_send_smp_identity_address_information:
+5717 700b7d4a jam xt_smp_signing_information ,mem_fifo_temp 
+5718 20405620 call le_xtype_fifo_in 
+5719 18007e00 force 0 ,pdata 
+571a 6000c445 store 1 ,mem_le_l2cap_response 
+571b 680344f9 fetch 6 ,mem_le_lap 
+571c e0a30000 istore 6 ,contw 
+571d 2020588a branch le_send_autolen 
+
+le_send_smp_signing_information:
+571e d8a04445 arg mem_le_l2cap_response ,contw 
+571f 20406226 call generate_random 
+5720 2020588a branch le_send_autolen 
+
+le_send_smp_security_request:
+5721 18000406 force 6 ,temp 
+5722 20205892 branch le_send_packet 
+
+le_send_smp_128:
+5723 60044445 store 8 ,mem_le_l2cap_response 
+5724 e8c40000 ifetch 8 ,contr 
+5725 e0a40000 istore 8 ,contw 
+5726 18000415 force 21 ,temp 
+5727 20600000 rtn 
+
+le_send_att_error_response_notfound:
+5728 7003fc0a jam att_err_attribute_not_found ,mem_le_err_code 
+
+le_send_att_error_response:
+5729 70444401 jam attop_error_response ,mem_le_l2cap 
+572a 680183f9 fetch 3 ,mem_le_att_opcode 
+572b 6001c445 store 3 ,mem_le_l2cap_response 
+572c 680083fc fetch 1 ,mem_le_err_code 
+572d e0a08000 istore 1 ,contw 
+572e 2020588a branch le_send_autolen 
+
+le_send_att_exchange_mtu:
+572f 58000017 setarg param_le_mtu 
+5730 e0a10000 istore 2 ,contw 
+5731 2020588a branch le_send_autolen 
+
+le_send_att_find_information_request:
+5732 680144bc fetch 2 ,mem_le_search_handle_start 
+5733 60014445 store 2 ,mem_le_l2cap_response 
+5734 680144be fetch 2 ,mem_le_search_handle_end 
+5735 e0a10000 istore 2 ,contw 
+5736 2020588a branch le_send_autolen 
+
+le_send_att_find_information_response:
+5737 18007e01 force 1 ,pdata 
+5738 6000c445 store 1 ,mem_le_l2cap_response 
+5739 20405a74 call le_init_attlist_search 
+
+le_send_att_find_information_res_loop:
+573a 20405a7d call le_att_handle_inrange 
+573b 203a5746 branch le_send_att_find_information_res_end ,blank 
+573c 24215744 nbranch le_send_att_find_information_res_next ,positive 
+573d 78547c00 disable user 
+573e e0a10000 istore 2 ,contw 
+573f e8c10000 ifetch 2 ,contr 
+5740 e0a10000 istore 2 ,contw 
+
+le_send_att_find_information_res_cont:
+5741 e8c08000 ifetch 1 ,contr 
+5742 98c08c00 iadd contr ,contr 
+5743 2020573a branch le_send_att_find_information_res_loop 
+
+le_send_att_find_information_res_next:
+5744 18c08c02 increase 2 ,contr 
+5745 20205741 branch le_send_att_find_information_res_cont 
+
+le_send_att_find_information_res_end:
+5746 20345728 branch le_send_att_error_response_notfound ,user 
+5747 2020588a branch le_send_autolen 
+
+le_send_att_find_by_type_value_request:
+5748 680144bc fetch 2 ,mem_le_search_handle_start 
+5749 203a5688 branch le_send_empty_le_data ,blank 
+574a 60014445 store 2 ,mem_le_l2cap_response 
+574b 680144be fetch 2 ,mem_le_search_handle_end 
+574c e0a10000 istore 2 ,contw 
+574d 680144c4 fetch 2 ,mem_le_uuid 
+574e e0a10000 istore 2 ,contw 
+574f 680144c0 fetch 2 ,mem_le_search_att_type 
+5750 e0a10000 istore 2 ,contw 
+5751 2020588a branch le_send_autolen 
+
+le_send_att_find_by_type_value_response:
+5752 2040577b call le_start_end_handle_check_1 
+5753 20740000 rtn user 
+5754 680944c4 fetcht 2 ,mem_le_uuid 
+5755 58002800 setarg uuid_gatt_primary_service 
+5756 98467c00 isub temp ,null 
+5757 2022d762 branch le_send_att_find_by_type_value_res_primary ,zero 
+5758 58002801 setarg uuid_gatt_secondary_service 
+5759 98467c00 isub temp ,null 
+575a 2022d728 branch le_send_att_error_response_notfound ,zero 
+575b 58002802 setarg uuid_gatt_include 
+575c 98467c00 isub temp ,null 
+575d 2022d728 branch le_send_att_error_response_notfound ,zero 
+575e 58002803 setarg uuid_gatt_characteristic 
+575f 98467c00 isub temp ,null 
+5760 2022d728 branch le_send_att_error_response_notfound ,zero 
+5761 20205728 branch le_send_att_error_response_notfound 
+
+le_send_att_find_by_type_value_res_primary:
+5762 680944c0 fetcht 2 ,mem_le_search_att_type 
+5763 18c08c02 increase 2 ,contr 
+5764 e8c08000 ifetch 1 ,contr 
+5765 1fe22600 icopy regc 
+5766 1a60a601 increase 1 ,regc 
+
+le_send_att_find_by_type_value_res_primary_search_loop:
+5767 1a60a7ff increase -1 ,regc 
+5768 2022d728 branch le_send_att_error_response_notfound ,zero 
+5769 e8c10000 ifetch 2 ,contr 
+576a 98467c00 isub temp ,null 
+576b 2022d76e branch le_send_att_find_by_type_value_res_primary_search_end ,zero 
+576c 18c08c04 increase 4 ,contr 
+576d 20205767 branch le_send_att_find_by_type_value_res_primary_search_loop 
+
+le_send_att_find_by_type_value_res_primary_search_end:
+576e e8c10000 ifetch 2 ,contr 
+576f 1fe22200 icopy rega 
+5770 e8c10000 ifetch 2 ,contr 
+5771 1fe22400 icopy regb 
+5772 20405785 call le_start_end_handle_check_2 
+5773 20740000 rtn user 
+5774 70444407 jam attop_find_by_type_value_response ,mem_le_l2cap 
+5775 1a227e00 deposit rega 
+5776 60014445 store 2 ,mem_le_l2cap_response 
+5777 1a427e00 deposit regb 
+5778 e0a10000 istore 2 ,contw 
+5779 18000409 force 9 ,temp 
+577a 20205892 branch le_send_packet 
+
+le_start_end_handle_check_1:
+577b 78547c00 disable user 
+577c 680944bc fetcht 2 ,mem_le_search_handle_start 
+577d 680144be fetch 2 ,mem_le_search_handle_end 
+577e 98467c00 isub temp ,null 
+577f 24215782 nbranch le_start_end_handle_check_1_fail ,positive 
+5780 18427e00 deposit temp 
+5781 c1800000 rtnne 0 
+
+le_start_end_handle_check_1_fail:
+5782 78347c00 enable user 
+
+le_send_att_invalid_handle:
+5783 7003fc01 jam att_err_invalid_handle ,mem_le_err_code 
+5784 20205729 branch le_send_att_error_response 
+
+le_start_end_handle_check_2:
+5785 78547c00 disable user 
+5786 680944bc fetcht 2 ,mem_le_search_handle_start 
+5787 1a227e00 deposit rega 
+5788 98467c00 isub temp ,null 
+5789 24215791 nbranch le_start_end_handle_check_2_fail ,positive 
+578a 680144be fetch 2 ,mem_le_search_handle_end 
+578b 9a467c00 isub regb ,null 
+578c 24215791 nbranch le_start_end_handle_check_2_fail ,positive 
+578d 1a427e00 deposit regb 
+578e 9a267c00 isub rega ,null 
+578f 24215791 nbranch le_start_end_handle_check_2_fail ,positive 
+5790 20600000 rtn 
+
+le_start_end_handle_check_2_fail:
+5791 78347c00 enable user 
+5792 20205728 branch le_send_att_error_response_notfound 
+
+le_send_att_read_by_type_request:
+5793 680144bc fetch 2 ,mem_le_search_handle_start 
+5794 e0a10000 istore 2 ,contw 
+5795 680144be fetch 2 ,mem_le_search_handle_end 
+5796 e0a10000 istore 2 ,contw 
+5797 680144c0 fetch 2 ,mem_le_search_att_type 
+5798 e0a10000 istore 2 ,contw 
+5799 1800040b force 11 ,temp 
+579a 20205892 branch le_send_packet 
+
+le_send_att_read_by_type_response:
+579b 680944c0 fetcht 2 ,mem_le_search_att_type 
+579c 58002803 setarg uuid_gatt_characteristic 
+579d 98467c00 isub temp ,null 
+579e 58000007 setarg 7 
+579f 2022d7a5 branch le_send_att_read_by_type_res_cont ,zero 
+57a0 58002800 setarg uuid_gatt_primary_service 
+57a1 98467c00 isub temp ,null 
+57a2 58000006 setarg 6 
+57a3 2022d7a5 branch le_send_att_read_by_type_res_cont ,zero 
+57a4 20205728 branch le_send_att_error_response_notfound 
+
+le_send_att_read_by_type_res_cont:
+57a5 6000c445 store 1 ,mem_le_l2cap_response 
+57a6 20405a74 call le_init_attlist_search 
+57a7 18006003 force 3 ,alarm 
+
+le_send_att_read_by_type_res_loop:
+57a8 20405a7d call le_att_handle_inrange 
+57a9 203a57bc branch le_send_att_read_by_type_res_end ,blank 
+57aa 242157b8 nbranch le_send_att_read_by_type_res_next ,positive 
+57ab 98002200 iforce rega 
+57ac e8c10000 ifetch 2 ,contr 
+57ad 98467c00 isub temp ,null 
+57ae 2422d7b9 nbranch le_send_att_read_by_type_res_next2 ,zero 
+57af 78547c00 disable user 
+57b0 1a227e00 deposit rega 
+57b1 e0a10000 istore 2 ,contw 
+57b2 e8c08000 ifetch 1 ,contr 
+57b3 1fe0f204 add pdata ,4 ,loopcnt 
+57b4 20407e45 call memcpy 
+57b5 1e00e1ff increase -1 ,alarm 
+57b6 2022d7bc branch le_send_att_read_by_type_res_end ,zero 
+57b7 202057b9 branch le_send_att_read_by_type_res_next2 
+
+le_send_att_read_by_type_res_next:
+57b8 18c08c02 increase 2 ,contr 
+
+le_send_att_read_by_type_res_next2:
+57b9 e8c08000 ifetch 1 ,contr 
+57ba 98c08c00 iadd contr ,contr 
+57bb 202057a8 branch le_send_att_read_by_type_res_loop 
+
+le_send_att_read_by_type_res_end:
+57bc 20345728 branch le_send_att_error_response_notfound ,user 
+57bd 2020588a branch le_send_autolen 
+
+le_send_att_read_request:
+57be 6800c43d fetch 1 ,mem_le_temp 
+57bf 1fe0ffff increase -1 ,pdata 
+57c0 6000c43d store 1 ,mem_le_temp 
+57c1 1fe3fe00 lshift pdata ,pdata 
+57c2 98c08c00 iadd contr ,contr 
+57c3 e8c90000 ifetcht 2 ,contr 
+57c4 60094445 storet 2 ,mem_le_l2cap_response 
+57c5 2020588a branch le_send_autolen 
+
+le_send_att_read_response:
+57c6 680903fa fetcht 2 ,mem_le_att_handle 
+57c7 20405a88 call le_att_get_handle_ptr 
+57c8 203a5728 branch le_send_att_error_response_notfound ,blank 
+57c9 e8c08000 ifetch 1 ,contr 
+57ca 203a588a branch le_send_autolen ,blank 
+57cb 1fe67c16 sub pdata ,22 ,null 
+57cc 202157ce branch le_send_att_read_response_less ,positive 
+57cd 18007e16 force 22 ,pdata 
+
+le_send_att_read_response_less:
+57ce 1fe27200 icopy loopcnt 
+57cf 20407e45 call memcpy 
+57d0 2020588a branch le_send_autolen 
+
+le_send_att_read_blob_request:
+57d1 58000003 setarg 0x0003 
+57d2 60014445 store 2 ,mem_le_l2cap_response 
+57d3 58000008 setarg 0x0008 
+57d4 e0a10000 istore 2 ,contw 
+57d5 2020588a branch le_send_autolen 
+
+le_send_att_read_blob_response:
+57d6 680144c0 fetch 2 ,mem_le_att_offset 
+57d7 98002200 iforce rega 
+57d8 680903fa fetcht 2 ,mem_le_att_handle 
+57d9 20405a88 call le_att_get_handle_ptr 
+57da 203a5728 branch le_send_att_error_response_notfound ,blank 
+57db e8c08000 ifetch 1 ,contr 
+57dc 9a267200 isub rega ,loopcnt 
+57dd 24215728 nbranch le_send_att_error_response_notfound ,positive 
+57de 1f267c16 sub loopcnt ,22 ,null 
+57df 202157e1 branch le_send_att_read_blob_response_less ,positive 
+57e0 18007216 force 22 ,loopcnt 
+
+le_send_att_read_blob_response_less:
+57e1 1a227e00 deposit rega 
+57e2 98c08c00 iadd contr ,contr 
+57e3 20407e45 call memcpy 
+57e4 2020588a branch le_send_autolen 
+
+le_send_att_read_multiple_request:
+57e5 58000003 setarg 0x0003 
+57e6 e0a10000 istore 2 ,contw 
+57e7 58000007 setarg 0x0007 
+57e8 e0a10000 istore 2 ,contw 
+57e9 58000009 setarg 0x0009 
+57ea e0a10000 istore 2 ,contw 
+57eb 2020588a branch le_send_autolen 
+
+le_send_att_read_multiple_response:
+57ec 6800c43d fetch 1 ,mem_le_temp 
+57ed 1fe22600 icopy regc 
+57ee da200347 arg mem_le_rxbuf + 7 ,rega 
+57ef da404445 arg mem_le_l2cap_response ,regb 
+57f0 d9600000 arg 0 ,timeup 
+57f1 7858fc00 disable user7 
+
+le_send_att_read_multiple_response_loop:
+57f2 1a220c00 copy rega ,contr 
+57f3 e8c90000 ifetcht 2 ,contr 
+57f4 18c22200 copy contr ,rega 
+57f5 20405a88 call le_att_get_handle_ptr 
+57f6 203a5805 branch le_send_att_read_multiple_response_end ,blank 
+57f7 e8c08000 ifetch 1 ,contr 
+57f8 1fe27200 icopy loopcnt 
+57f9 99609600 iadd timeup ,timeup 
+57fa 19667c18 sub timeup ,24 ,null 
+57fb 2421580a nbranch le_send_att_read_multiple_response_end_1 ,positive 
+57fc 1a420a00 copy regb ,contw 
+
+le_copy_att_value_loop_3:
+57fd e8c08000 ifetch 1 ,contr 
+57fe e0a08000 istore 1 ,contw 
+57ff c20057fd loop le_copy_att_value_loop_3 
+5800 18a22400 copy contw ,regb 
+5801 7838fc00 enable user7 
+5802 1a60a7ff increase -1 ,regc 
+5803 2022d805 branch le_send_att_read_multiple_response_end ,zero 
+5804 202057f2 branch le_send_att_read_multiple_response_loop 
+
+le_send_att_read_multiple_response_end:
+5805 2438d810 nbranch le_send_att_read_multiple_response_fail ,user7 
+5806 7858fc00 disable user7 
+5807 19620400 copy timeup ,temp 
+5808 18408405 increase 5 ,temp 
+5809 20205892 branch le_send_packet 
+
+le_send_att_read_multiple_response_end_1:
+580a 2438d810 nbranch le_send_att_read_multiple_response_fail ,user7 
+580b 7858fc00 disable user7 
+580c 19627e00 deposit timeup 
+580d 9f260400 isub loopcnt ,temp 
+580e 18408405 increase 5 ,temp 
+580f 20205892 branch le_send_packet 
+
+le_send_att_read_multiple_response_fail:
+5810 7003fc10 jam att_err_unsupported_group_type ,mem_le_err_code 
+5811 20205729 branch le_send_att_error_response 
+
+le_send_att_read_by_group_type_request:
+5812 680103fa fetch 2 ,mem_le_att_handle 
+5813 203a5688 branch le_send_empty_le_data ,blank 
+5814 e0a10000 istore 2 ,contw 
+5815 5800ffff setarg 0xffff 
+5816 e0a10000 istore 2 ,contw 
+5817 58002800 setarg 0x2800 
+5818 e0a10000 istore 2 ,contw 
+5819 2020588a branch le_send_autolen 
+
+le_send_att_read_by_group_type_response:
+581a 58000006 setarg 0x06 
+581b 6000c445 store 1 ,mem_le_l2cap_response 
+581c 680144c0 fetch 2 ,mem_le_search_att_type 
+581d 98002200 iforce rega 
+581e 20405a74 call le_init_attlist_search 
+581f 18007203 force 3 ,loopcnt 
+
+le_send_att_read_by_group_type_response_loop:
+5820 20405a7d call le_att_handle_inrange 
+5821 203a5835 branch le_send_att_read_by_group_type_response_last ,blank 
+5822 2421583a nbranch le_send_att_read_by_group_type_response_next ,positive 
+5823 98006000 iforce alarm 
+5824 e8c10000 ifetch 2 ,contr 
+5825 9a267c00 isub rega ,null 
+5826 2422d83b nbranch le_send_att_read_by_group_type_response_cont ,zero 
+5827 1e027e00 deposit alarm 
+5828 2034582f branch le_send_att_read_by_group_type_response_first ,user 
+5829 1fe0ffff increase -1 ,pdata 
+582a e0a10000 istore 2 ,contw 
+582b e0a90000 istoret 2 ,contw 
+582c 1fe0fe01 increase 1 ,pdata 
+582d 1f20f3ff increase -1 ,loopcnt 
+582e 2022d88a branch le_send_autolen ,zero 
+
+le_send_att_read_by_group_type_response_first:
+582f 78547c00 disable user 
+5830 e0a10000 istore 2 ,contw 
+5831 18c08c01 increase 1 ,contr 
+5832 e8c90000 ifetcht 2 ,contr 
+5833 18c08dfd increase -3 ,contr 
+5834 2020583b branch le_send_att_read_by_group_type_response_cont 
+
+le_send_att_read_by_group_type_response_last:
+5835 20345728 branch le_send_att_error_response_notfound ,user 
+5836 18007fff force -1 ,pdata 
+5837 e0a10000 istore 2 ,contw 
+5838 e0a90000 istoret 2 ,contw 
+5839 2020588a branch le_send_autolen 
+
+le_send_att_read_by_group_type_response_next:
+583a 18c08c02 increase 2 ,contr 
+
+le_send_att_read_by_group_type_response_cont:
+583b e8c08000 ifetch 1 ,contr 
+583c 98c08c00 iadd contr ,contr 
+583d 20205820 branch le_send_att_read_by_group_type_response_loop 
+
+le_send_att_write_request:
+583e 680144c2 fetch 2 ,mem_le_notify_handle 
+583f 60014445 store 2 ,mem_le_l2cap_response 
+5840 6800c4c6 fetch 1 ,mem_le_handle_data_len 
+5841 1fe27200 copy pdata ,loopcnt 
+5842 d8c044c7 arg mem_le_handle_data ,contr 
+5843 20407e45 call memcpy 
+5844 2020588a branch le_send_autolen 
+
+le_send_att_write_response:
+5845 680903fa fetcht 2 ,mem_le_att_handle 
+5846 20405a88 call le_att_get_handle_ptr 
+5847 203a585c branch le_send_att_write_response_go ,blank 
+5848 18c08dfe increase -2 ,contr 
+5849 e8c90000 ifetcht 2 ,contr 
+584a 58002902 setarg uuid_client_characteristic 
+584b 98467c00 isub temp ,null 
+584c 2422d85c nbranch le_send_att_write_response_go ,zero 
+584d 18c08c01 increase 1 ,contr 
+584e e8c90000 ifetcht 2 ,contr 
+584f 58000001 setarg 0x0001 
+5850 98467c00 isub temp ,null 
+5851 2022d856 branch le_send_att_write_response_notify ,zero 
+5852 58000000 setarg 0x0000 
+5853 98467c00 isub temp ,null 
+5854 2422d85c nbranch le_send_att_write_response_go ,zero 
+5855 2020585c branch le_send_att_write_response_go 
+
+le_send_att_write_response_notify:
+5856 18c08df9 increase -7 ,contr 
+5857 e8c10000 ifetch 2 ,contr 
+5858 1fe0ffff increase -1 ,pdata 
+5859 600144c2 store 2 ,mem_le_notify_handle 
+585a 700b7d1b jam attop_handle_value_notification ,mem_fifo_temp 
+585b 20405620 call le_xtype_fifo_in 
+
+le_send_att_write_response_go:
+585c 18000405 force 5 ,temp 
+585d 20205892 branch le_send_packet 
+
+le_send_att_prepare_write_request:
+585e 18000406 force 6 ,temp 
+585f 20205892 branch le_send_packet 
+
+le_send_att_prepare_write_response:
+5860 18000406 force 6 ,temp 
+5861 20205892 branch le_send_packet 
+
+le_send_att_execute_write_request:
+5862 18000406 force 6 ,temp 
+5863 20205892 branch le_send_packet 
+
+le_send_att_execute_write_response:
+5864 18000406 force 6 ,temp 
+5865 20205892 branch le_send_packet 
+
+le_att_check_notification_enable:
+5866 79200025 set1 mark_ext_patch ,mark 
+5867 44b3402c bpatch patch2c_6 ,mem_patch2c 
+5868 18408401 increase 1 ,temp 
+5869 20405a88 call le_att_get_handle_ptr 
+586a 18c08dfe increase -2 ,contr 
+586b e8c10000 ifetch 2 ,contr 
+586c d8402902 arg client_charactertic_configuration ,temp 
+586d 98467c00 isub temp ,null 
+586e 24628000 nrtn zero 
+586f 18c08c01 increase 1 ,contr 
+5870 18c22200 copy contr ,rega 
+5871 e8c08000 ifetch 1 ,contr 
+5872 20600000 rtn 
+
+le_send_att_handle_value_notification:
+5873 70041b00 jam 0 ,mem_le_notify_len 
+5874 68014298 fetch 2 ,mem_cb_update_notify_value 
+5875 20407f66 call callback_func 
+5876 d8a04444 arg mem_le_l2cap ,contw 
+5877 18a08a01 increase 1 ,contw 
+5878 680944c2 fetcht 2 ,mem_le_notify_handle 
+5879 e0a90000 istoret 2 ,contw 
+587a 20405a88 call le_att_get_handle_ptr 
+587b e8c08000 ifetch 1 ,contr 
+587c 1fe27200 icopy loopcnt 
+587d 20407e45 call memcpy 
+587e 6808841b fetcht 1 ,mem_le_notify_len 
+587f 18408407 increase 7 ,temp 
+5880 20405892 call le_send_packet 
+5881 20205ace branch le_clear_notify_att 
+
+le_send_att_handle_value_indication:
+5882 18000406 force 6 ,temp 
+5883 20205892 branch le_send_packet 
+
+le_send_att_handle_value_confirmation:
+5884 18000406 force 6 ,temp 
+5885 20205892 branch le_send_packet 
+
+le_send_att_write_command:
+5886 18000406 force 6 ,temp 
+5887 20205892 branch le_send_packet 
+
+le_send_att_signed_write_command:
+5888 18000406 force 6 ,temp 
+5889 20205892 branch le_send_packet 
+
+le_send_autolen:
+588a 79200025 set1 mark_ext_patch ,mark 
+588b 44b3c02c bpatch patch2c_7 ,mem_patch2c 
+588c 58004440 setarg mem_le_txpayload 
+588d 98a67e00 isub contw ,pdata 
+588e 1fe60400 sub pdata ,0 ,temp 
+588f 20205892 branch le_send_packet 
+
+le_send_empty:
+5890 18000400 force 0 ,temp 
+5891 18000201 force 1 ,type 
+
+le_send_packet:
+5892 79200025 set1 mark_ext_patch ,mark 
+5893 44b4402d bpatch patch2d_0 ,mem_patch2d 
+5894 6008c43f storet 1 ,mem_le_txlen 
+5895 28200602 compare 2 ,type ,3 
+5896 2420d899 nbranch le_send_non_l2cap ,true 
+5897 1840fffc add temp ,-4 ,pdata 
+5898 60014440 store 2 ,mem_le_txpayload 
+
+le_send_non_l2cap:
+5899 680883d7 fetcht 1 ,mem_le_arq 
+589a 2040561a call le_xtype_fifo_is_empty 
+589b 7d3a0404 nsetflag blank ,md ,temp 
+589c 79200405 set1 wak ,temp 
+589d 18417efc and temp ,0xfc ,pdata 
+589e 9821fe00 ior type ,pdata 
+589f 600083d7 store 1 ,mem_le_arq 
+58a0 1fe17e1f and_into 0x1f ,pdata 
+58a1 6000c43e store 1 ,mem_le_txheader 
+58a2 79200025 set1 mark_ext_patch ,mark 
+58a3 44b4c02d bpatch patch2d_1 ,mem_patch2d 
+58a4 6800c43e fetch 1 ,mem_le_txheader 
+58a5 28200601 compare 1 ,type ,3 
+58a6 20608000 rtn true 
+58a7 6803c43f fetch 7 ,mem_le_txheader + 1 
+58a8 680083c0 fetch 1 ,mem_le_state 
+58a9 c4020000 rtnbit0 lestate_encryption 
+58aa 20407599 call load_sk 
+58ab 202074f7 branch le_encrypt 
+
+le_parse:
+58ac 79200025 set1 mark_ext_patch ,mark 
+58ad 44b5402d bpatch patch2d_2 ,mem_patch2d 
+58ae 2040561c call le_xtype_fifo_is_full 
+58af 243a3bf1 nbranch assert ,blank 
+58b0 247a0000 nrtn blank 
+58b1 68008341 fetch 1 ,mem_le_rxbuf + 1 
+58b2 207a0000 rtn blank 
+58b3 68008340 fetch 1 ,mem_le_rxbuf 
+58b4 2fe00601 compare 1 ,pdata ,3 
+58b5 2020d8cf branch le_parse_l2cap ,true 
+58b6 68038341 fetch 7 ,mem_le_rxbuf + 1 
+58b7 68008340 fetch 1 ,mem_le_rxbuf 
+58b8 2fe00602 compare 2 ,pdata ,3 
+58b9 2020d8cf branch le_parse_l2cap ,true 
+58ba 68008342 fetch 1 ,mem_le_rxbuf + 2 
+58bb 60008418 store 1 ,mem_le_rx_ll_opcode 
+58bc 1fe22600 copy pdata ,regc 
+58bd 79200025 set1 mark_ext_patch ,mark 
+58be 44b5c02d bpatch patch2d_3 ,mem_patch2d 
+58bf 1a627e00 copy regc ,pdata 
+58c0 c0005924 beq ll_connection_update_req ,le_parse_connection_update_req 
+58c1 c000d92c beq ll_channel_map_req ,le_parse_channel_map_req 
+58c2 c0015934 beq ll_terminate_ind ,le_parse_terminate_ind 
+58c3 c001d938 beq ll_enc_req ,le_parse_enc_req 
+58c4 c002593f beq ll_enc_rsp ,le_parse_enc_rsp 
+58c5 c002d944 beq ll_start_enc_req ,le_parse_start_enc_req 
+58c6 c0035949 beq ll_start_enc_rsp ,le_parse_start_enc_rsp 
+58c7 c003d94c beq ll_unknown_rsp ,le_parse_unknown_rsp 
+58c8 c004594d beq ll_feature_req ,le_parse_feature_req 
+58c9 c004d94f beq ll_feature_rsp ,le_parse_feature_rsp 
+58ca c0055950 beq ll_pause_enc_req ,le_parse_pause_enc_req 
+58cb c005d951 beq ll_pause_enc_rsp ,le_parse_pause_enc_rsp 
+58cc c0065952 beq ll_version_ind ,le_parse_version_ind 
+58cd c006d955 beq ll_reject_ind ,le_parse_reject_ind 
+58ce 20203bf1 branch assert 
+
+le_parse_l2cap:
+58cf 68008341 fetch 1 ,mem_le_rxbuf + 1 
+58d0 1fe17e1f and pdata ,0x1f ,pdata 
+58d1 207a0000 rtn blank 
+58d2 6800c132 fetch 1 ,mem_device_option 
+58d3 c000d8d8 beq dvc_op_hci ,le_acl_upgoing 
+58d4 68010344 fetch 2 ,mem_le_rxbuf + 4 
+58d5 c0025903 beq le_l2cap_cid_att ,le_parse_att 
+58d6 c00358f4 beq le_l2cap_cid_smp ,le_parse_smp 
+58d7 20600000 rtn 
+
+le_acl_upgoing:
+58d8 79200025 set1 mark_ext_patch ,mark 
+58d9 44b6402d bpatch patch2d_4 ,mem_patch2d 
+58da 20404972 call hci_get_packet_ptr 
+58db 680083d6 fetch 1 ,mem_le_conn_handle 
+58dc 68088340 fetcht 1 ,mem_le_rxbuf 
+58dd 18410403 and_into 3 ,temp 
+58de 184d0400 lshift8 temp ,temp 
+58df 18520400 lshift4 temp ,temp 
+58e0 9841fe00 ior temp ,pdata 
+58e1 e1410000 istore 2 ,contwu 
+58e2 68088341 fetcht 1 ,mem_le_rxbuf + 1 
+58e3 1841041f and temp ,0x1f ,temp 
+58e4 e1490000 istoret 2 ,contwu 
+58e5 18427200 copy temp ,loopcnt 
+58e6 20404976 call uart_copy_tx_bytes 
+58e7 1840f204 add temp ,4 ,loopcnt 
+58e8 20404424 call h4_send_packet_acl 
+58e9 20204435 branch h4_send_acl_trigger 
+
+le_acl_downgoing:
+58ea 79200025 set1 mark_ext_patch ,mark 
+58eb 44b6c02d bpatch patch2d_5 ,mem_patch2d 
+58ec d8200002 arg 0x2 ,type 
+58ed e8610000 ifetch 2 ,contru 
+58ee e8610000 ifetch 2 ,contru 
+58ef 203a3bf1 branch assert ,blank 
+58f0 1fe27200 copy pdata ,loopcnt 
+58f1 d8a04440 arg mem_le_txpayload ,contw 
+58f2 2040497c call uart_copy_rx_bytes 
+58f3 2020588a branch le_send_autolen 
+
+le_parse_smp:
+58f4 79200025 set1 mark_ext_patch ,mark 
+58f5 44b7402d bpatch patch2d_6 ,mem_patch2d 
+58f6 e8c08000 ifetch 1 ,contr 
+58f7 c000d956 beq smp_pairing_request ,le_parse_smp_pairing_request 
+58f8 c001595b beq smp_pairing_response ,le_parse_smp_pairing_response 
+58f9 c001d960 beq smp_pairing_confirm ,le_parse_smp_pairing_confirm 
+58fa c0025966 beq smp_pairing_random ,le_parse_smp_pairing_random 
+58fb c002d96f beq smp_pairing_failed ,le_parse_smp_pairing_failed 
+58fc c0035970 beq smp_encryption_information ,le_parse_smp_encryption_information 
+58fd c003d972 beq smp_master_identification ,le_parse_smp_master_identification 
+58fe c0045973 beq smp_identity_information ,le_parse_smp_identity_information 
+58ff c004d974 beq smp_identity_address_information ,le_parse_smp_identity_address_information 
+5900 c0055975 beq smp_signing_information ,le_parse_smp_signing_information 
+5901 c005d976 beq smp_security_request ,le_parse_smp_security_request 
+5902 20203bf1 branch assert 
+
+le_parse_att:
+5903 79200025 set1 mark_ext_patch ,mark 
+5904 44b7c02d bpatch patch2d_7 ,mem_patch2d 
+5905 e8c18000 ifetch 3 ,contr 
+5906 600183f9 store 3 ,mem_le_att_opcode 
+
+le_parse_att_p:
+5907 c000d977 beq attop_error_response ,le_parse_att_error_response 
+5908 c001598e beq attop_exchange_mtu_request ,le_parse_att_exchange_mtu_request 
+5909 c001d990 beq attop_exchange_mtu_response ,le_parse_att_exchange_mtu_response 
+590a c0025991 beq attop_find_information_request ,le_parse_att_find_information_request 
+590b c002d997 beq attop_find_information_response ,le_parse_att_find_information_response 
+590c c003599a beq attop_find_by_type_value_request ,le_parse_att_find_by_type_value_request 
+590d c003d9a4 beq attop_find_by_type_value_response ,le_parse_att_find_by_type_value_response 
+590e c00459a5 beq attop_read_by_type_request ,le_parse_att_read_by_type_request 
+590f c004d9ad beq attop_read_by_type_response ,le_parse_att_read_by_type_response 
+5910 c00559ae beq attop_read_request ,le_parse_att_read_request 
+5911 c005d9b2 beq attop_read_response ,le_parse_att_read_response 
+5912 c00659b5 beq attop_read_blob_request ,le_parse_att_read_blob_request 
+5913 c006d9b9 beq attop_read_blob_response ,le_parse_att_read_blob_response 
+5914 c00759ba beq attop_read_multiple_request ,le_parse_att_read_multiple_request 
+5915 c007d9c0 beq attop_read_multiple_response ,le_parse_att_read_multiple_response 
+5916 c00859c1 beq attop_read_by_group_type_request ,le_parse_att_read_by_group_type_request 
+5917 c008d9c9 beq attop_read_by_group_type_response ,le_parse_att_read_by_group_type_response 
+5918 c00959ca beq attop_write_request ,le_parse_att_write_request 
+5919 c009d9da beq attop_write_response ,le_parse_att_write_response 
+591a c00b59dc beq attop_prepare_write_request ,le_parse_att_prepare_write_request 
+591b c00bd9dd beq attop_prepare_write_response ,le_parse_att_prepare_write_response 
+591c c00c59de beq attop_execute_write_request ,le_parse_att_execute_write_request 
+591d c00cd9df beq attop_execute_write_response ,le_parse_att_execute_write_response 
+591e c00dd9e0 beq attop_handle_value_notification ,le_parse_att_handle_value_notification 
+591f c00ed9eb beq attop_handle_value_indication ,le_parse_att_handle_value_indication 
+5920 c00f59ec beq attop_handle_value_confirmation ,le_parse_att_handle_value_confirmation 
+5921 c02959ed beq attop_write_command ,le_parse_att_write_command 
+5922 c0695a01 beq attop_signed_write_command ,le_parse_att_signed_write_command 
+5923 20203bf1 branch assert 
+
+le_parse_connection_update_req:
+5924 e8c48000 ifetch 9 ,contr 
+5925 6004c434 store 9 ,mem_le_new_param 
+5926 e8c10000 ifetch 2 ,contr 
+5927 600103e0 store 2 ,mem_le_instant 
+5928 680083c0 fetch 1 ,mem_le_state 
+5929 79207e05 set1 lestate_update_param ,pdata 
+592a 600083c0 store 1 ,mem_le_state 
+592b 20600000 rtn 
+
+le_parse_channel_map_req:
+592c e8c28000 ifetch 5 ,contr 
+592d 6002c42f store 5 ,mem_le_new_map 
+592e e8c10000 ifetch 2 ,contr 
+592f 600103e0 store 2 ,mem_le_instant 
+5930 680083c0 fetch 1 ,mem_le_state 
+5931 79207e06 set1 lestate_update_map ,pdata 
+5932 600083c0 store 1 ,mem_le_state 
+5933 20600000 rtn 
+
+le_parse_terminate_ind:
+5934 680083e4 fetch 1 ,mem_le_op 
+5935 79207e03 set1 op_disconn ,pdata 
+5936 600083e4 store 1 ,mem_le_op 
+5937 20600000 rtn 
+
+le_parse_enc_req:
+5938 18c08c0a increase 10 ,contr 
+5939 e8c40000 ifetch 8 ,contr 
+593a 60040380 store 8 ,mem_le_skdm 
+593b e8c20000 ifetch 4 ,contr 
+593c 60024473 store 4 ,mem_le_ivm 
+593d 700b7d24 jam xt_ll_enc_rsp ,mem_fifo_temp 
+593e 20205620 branch le_xtype_fifo_in 
+
+le_parse_enc_rsp:
+593f e8c40000 ifetch 8 ,contr 
+5940 60040388 store 8 ,mem_le_skds 
+5941 e8c20000 ifetch 4 ,contr 
+5942 60024477 store 4 ,mem_le_ivs 
+5943 202074b6 branch generate_sk 
+
+le_parse_start_enc_req:
+5944 680083c0 fetch 1 ,mem_le_state 
+5945 79207e04 set1 lestate_encryption ,pdata 
+5946 600083c0 store 1 ,mem_le_state 
+5947 700b7d26 jam xt_ll_start_enc_rsp ,mem_fifo_temp 
+5948 20205620 branch le_xtype_fifo_in 
+
+le_parse_start_enc_rsp:
+5949 20748000 rtn master 
+594a 700b7d26 jam xt_ll_start_enc_rsp ,mem_fifo_temp 
+594b 20205620 branch le_xtype_fifo_in 
+
+le_parse_unknown_rsp:
+594c 20600000 rtn 
+
+le_parse_feature_req:
+594d 700b7d29 jam xt_ll_feature_rsp ,mem_fifo_temp 
+594e 20205620 branch le_xtype_fifo_in 
+
+le_parse_feature_rsp:
+594f 20600000 rtn 
+
+le_parse_pause_enc_req:
+5950 20600000 rtn 
+
+le_parse_pause_enc_rsp:
+5951 20600000 rtn 
+
+le_parse_version_ind:
+5952 20748000 rtn master 
+5953 700b7d2c jam xt_ll_version_ind ,mem_fifo_temp 
+5954 20205620 branch le_xtype_fifo_in 
+
+le_parse_reject_ind:
+5955 20600000 rtn 
+
+le_parse_smp_pairing_request:
+5956 6000c4ae store 1 ,mem_le_preq 
+5957 e8c30000 ifetch 6 ,contr 
+5958 e0a30000 istore 6 ,contw 
+5959 700b7d42 jam xt_smp_pairing_response ,mem_fifo_temp 
+595a 20205620 branch le_xtype_fifo_in 
+
+le_parse_smp_pairing_response:
+595b 6000c4b5 store 1 ,mem_le_pres 
+595c e8c30000 ifetch 6 ,contr 
+595d e0a30000 istore 6 ,contw 
+595e 700b7d43 jam xt_smp_pairing_confirm ,mem_fifo_temp 
+595f 20205620 branch le_xtype_fifo_in 
+
+le_parse_smp_pairing_confirm:
+5960 d8a0448c arg mem_le_rconfirm ,contw 
+5961 20407e35 call memcpy16 
+5962 700b7d44 jam xt_smp_pairing_random ,mem_fifo_temp 
+5963 2034d620 branch le_xtype_fifo_in ,master 
+5964 700b7d43 jam xt_smp_pairing_confirm ,mem_fifo_temp 
+5965 20205620 branch le_xtype_fifo_in 
+
+le_parse_smp_pairing_random:
+5966 204074a8 call authenticate_rconfirm 
+5967 2022d96a branch le_parse_smp_pairing_random_success ,zero 
+5968 700b7d45 jam xt_smp_pairing_failed ,mem_fifo_temp 
+5969 20205620 branch le_xtype_fifo_in 
+
+le_parse_smp_pairing_random_success:
+596a 204074a5 call generate_stk 
+596b 700b7d23 jam xt_ll_enc_req ,mem_fifo_temp 
+596c 2034d620 branch le_xtype_fifo_in ,master 
+596d 700b7d44 jam xt_smp_pairing_random ,mem_fifo_temp 
+596e 20205620 branch le_xtype_fifo_in 
+
+le_parse_smp_pairing_failed:
+596f 20600000 rtn 
+
+le_parse_smp_encryption_information:
+5970 d8a00390 arg mem_le_peer_ltk ,contw 
+5971 20207e35 branch memcpy16 
+
+le_parse_smp_master_identification:
+5972 20600000 rtn 
+
+le_parse_smp_identity_information:
+5973 20600000 rtn 
+
+le_parse_smp_identity_address_information:
+5974 20600000 rtn 
+
+le_parse_smp_signing_information:
+5975 20600000 rtn 
+
+le_parse_smp_security_request:
+5976 20600000 rtn 
+
+le_parse_att_error_response:
+5977 18c08dfe increase -2 ,contr 
+5978 e8c88000 ifetcht 1 ,contr 
+5979 58000006 setarg attop_find_by_type_value_request 
+597a 98467c00 isub temp ,null 
+597b 2022d989 branch le_parse_att_error_res_find_by_type_value ,zero 
+597c 58000004 setarg attop_find_information_request 
+597d 98467c00 isub temp ,null 
+597e 2022d98a branch le_parse_att_error_res_find_info ,zero 
+597f 58000008 setarg attop_read_by_type_request 
+5980 98467c00 isub temp ,null 
+5981 2022d98b branch le_parse_att_error_res_read_by_type ,zero 
+5982 5800000c setarg attop_read_blob_request 
+5983 98467c00 isub temp ,null 
+5984 2022d98c branch le_parse_att_error_res_read_blob ,zero 
+5985 5800000e setarg attop_read_multiple_request 
+5986 98467c00 isub temp ,null 
+5987 2022d98d branch le_parse_att_error_res_read_multiple ,zero 
+5988 20600000 rtn 
+
+le_parse_att_error_res_find_by_type_value:
+5989 20600000 rtn 
+
+le_parse_att_error_res_find_info:
+598a 20600000 rtn 
+
+le_parse_att_error_res_read_by_type:
+598b 20600000 rtn 
+
+le_parse_att_error_res_read_blob:
+598c 20600000 rtn 
+
+le_parse_att_error_res_read_multiple:
+598d 20600000 rtn 
+
+le_parse_att_exchange_mtu_request:
+598e 700b7d03 jam attop_exchange_mtu_response ,mem_fifo_temp 
+598f 20205620 branch le_xtype_fifo_in 
+
+le_parse_att_exchange_mtu_response:
+5990 20600000 rtn 
+
+le_parse_att_find_information_request:
+5991 1fecfe00 rshift8 pdata ,pdata 
+5992 600144bc store 2 ,mem_le_search_handle_start 
+5993 e8c10000 ifetch 2 ,contr 
+5994 600144be store 2 ,mem_le_search_handle_end 
+5995 700b7d05 jam attop_find_information_response ,mem_fifo_temp 
+5996 20205620 branch le_xtype_fifo_in 
+
+le_parse_att_find_information_response:
+5997 20600000 rtn 
+
+le_parse_att_find_info_res_multi:
+5998 20600000 rtn 
+
+le_parse_att_find_info_res_error:
+5999 20600000 rtn 
+
+le_parse_att_find_by_type_value_request:
+599a 1fecfe00 rshift8 pdata ,pdata 
+599b 600144bc store 2 ,mem_le_search_handle_start 
+599c e8c10000 ifetch 2 ,contr 
+599d 600144be store 2 ,mem_le_search_handle_end 
+599e e8c10000 ifetch 2 ,contr 
+599f 600144c4 store 2 ,mem_le_uuid 
+59a0 e8c10000 ifetch 2 ,contr 
+59a1 600144c0 store 2 ,mem_le_search_att_type 
+59a2 700b7d07 jam attop_find_by_type_value_response ,mem_fifo_temp 
+59a3 20205620 branch le_xtype_fifo_in 
+
+le_parse_att_find_by_type_value_response:
+59a4 20600000 rtn 
+
+le_parse_att_read_by_type_request:
+59a5 1fecfe00 rshift8 pdata ,pdata 
+59a6 600144bc store 2 ,mem_le_search_handle_start 
+59a7 e8c10000 ifetch 2 ,contr 
+59a8 600144be store 2 ,mem_le_search_handle_end 
+59a9 e8c10000 ifetch 2 ,contr 
+59aa 600144c0 store 2 ,mem_le_search_att_type 
+59ab 700b7d09 jam attop_read_by_type_response ,mem_fifo_temp 
+59ac 20205620 branch le_xtype_fifo_in 
+
+le_parse_att_read_by_type_response:
+59ad 20600000 rtn 
+
+le_parse_att_read_request:
+59ae 68010347 fetch 2 ,mem_le_rxbuf + 7 
+59af 600103fa store 2 ,mem_le_att_handle 
+59b0 700b7d0b jam attop_read_response ,mem_fifo_temp 
+59b1 20205620 branch le_xtype_fifo_in 
+
+le_parse_att_read_response:
+59b2 20600000 rtn 
+
+le_send_att_read_res_end:
+59b3 20600000 rtn 
+
+le_prepare_descriptor:
+59b4 20600000 rtn 
+
+le_parse_att_read_blob_request:
+59b5 e8c10000 ifetch 2 ,contr 
+59b6 600144c0 store 2 ,mem_le_att_offset 
+59b7 700b7d0d jam attop_read_blob_response ,mem_fifo_temp 
+59b8 20205620 branch le_xtype_fifo_in 
+
+le_parse_att_read_blob_response:
+59b9 20600000 rtn 
+
+le_parse_att_read_multiple_request:
+59ba 68008341 fetch 1 ,mem_le_rxbuf + 1 
+59bb 1fe0fffb increase -5 ,pdata 
+59bc 1fe37e00 rshift pdata ,pdata 
+59bd 6000c43d store 1 ,mem_le_temp 
+59be 700b7d0f jam attop_read_multiple_response ,mem_fifo_temp 
+59bf 20205620 branch le_xtype_fifo_in 
+
+le_parse_att_read_multiple_response:
+59c0 20600000 rtn 
+
+le_parse_att_read_by_group_type_request:
+59c1 1fecfe00 rshift8 pdata ,pdata 
+59c2 600144bc store 2 ,mem_le_search_handle_start 
+59c3 e8c10000 ifetch 2 ,contr 
+59c4 600144be store 2 ,mem_le_search_handle_end 
+59c5 e8c10000 ifetch 2 ,contr 
+59c6 600144c0 store 2 ,mem_le_search_att_type 
+59c7 700b7d11 jam attop_read_by_group_type_response ,mem_fifo_temp 
+59c8 20205620 branch le_xtype_fifo_in 
+
+le_parse_att_read_by_group_type_response:
+59c9 20600000 rtn 
+
+le_parse_att_write_request:
+59ca 68008341 fetch 1 ,mem_le_rxbuf + 1 
+59cb 1fe0fff9 increase -7 ,pdata 
+59cc 1fe27200 icopy loopcnt 
+59cd 680903fa fetcht 2 ,mem_le_att_handle 
+59ce 20405a88 call le_att_get_handle_ptr 
+59cf 203a59d8 branch le_parse_att_write_request_fail ,blank 
+59d0 e8c08000 ifetch 1 ,contr 
+59d1 9f267c00 isub loopcnt ,null 
+59d2 242159d8 nbranch le_parse_att_write_request_fail ,positive 
+59d3 18c20a00 copy contr ,contw 
+59d4 d8c00349 arg mem_le_rxbuf + 9 ,contr 
+59d5 20407e45 call memcpy 
+59d6 700b7d28 jam bt_evt_le_write_request ,mem_fifo_temp 
+59d7 20407c27 call ui_ipc_send_event 
+
+le_parse_att_write_request_fail:
+59d8 700b7d13 jam attop_write_response ,mem_fifo_temp 
+59d9 20205620 branch le_xtype_fifo_in 
+
+le_parse_att_write_response:
+59da 680083e3 fetch 1 ,mem_le_conn_sm 
+59db 20600000 rtn 
+
+le_parse_att_prepare_write_request:
+59dc 20600000 rtn 
+
+le_parse_att_prepare_write_response:
+59dd 20600000 rtn 
+
+le_parse_att_execute_write_request:
+59de 20600000 rtn 
+
+le_parse_att_execute_write_response:
+59df 20600000 rtn 
+
+le_parse_att_handle_value_notification:
+59e0 e8c28000 ifetch 5 ,contr 
+59e1 60028ff1 store 5 ,mem_mouse_data 
+59e2 700ff001 jam send_mouse_data_cmd ,mem_mcmd 
+59e3 20407cdb call usb_isr 
+59e4 20600000 rtn 
+
+le_kb_handle_value_notification:
+59e5 1a220c00 copy rega ,contr 
+59e6 e8c40000 ifetch 8 ,contr 
+59e7 60040ff1 store 8 ,mem_mouse_data 
+59e8 700ff002 jam send_kb_data_cmd ,mem_mcmd 
+59e9 20407cdb call usb_isr 
+59ea 20600000 rtn 
+
+le_parse_att_handle_value_indication:
+59eb 20600000 rtn 
+
+le_parse_att_handle_value_confirmation:
+59ec 20600000 rtn 
+
+le_parse_att_write_command:
+59ed 68008341 fetch 1 ,mem_le_rxbuf + 1 
+59ee 1fe0fff9 increase -7 ,pdata 
+59ef 1fe27200 icopy loopcnt 
+59f0 680903fa fetcht 2 ,mem_le_att_handle 
+59f1 20405a88 call le_att_get_handle_ptr 
+59f2 203a59fd branch le_parse_att_write_command_fail ,blank 
+59f3 e8c08000 ifetch 1 ,contr 
+59f4 9f267c00 isub loopcnt ,null 
+59f5 242159fd nbranch le_parse_att_write_command_fail ,positive 
+59f6 18c20a00 copy contr ,contw 
+59f7 18c22200 copy contr ,rega 
+59f8 1f222400 copy loopcnt ,regb 
+59f9 d8c00349 arg mem_le_rxbuf + 9 ,contr 
+59fa 20407e45 call memcpy 
+59fb 70048101 jam prcp_le ,mem_prcp 
+59fc 204059fe call le_writeatt_cb 
+
+le_parse_att_write_command_fail:
+59fd 20600000 rtn 
+
+le_writeatt_cb:
+59fe 68014296 fetch 2 ,mem_cb_att_write 
+59ff 207a0000 rtn blank 
+5a00 98007a00 iforce pc 
+
+le_parse_att_signed_write_command:
+5a01 20600000 rtn 
+
+le_supervision_update:
+5a02 680a03dc fetcht 4 ,mem_le_supervision_timer 
+5a03 20403bde call get_clkbt 
+5a04 98461600 isub temp ,timeup 
+5a05 19627e00 deposit timeup 
+5a06 680903ef fetcht 2 ,mem_le_superto 
+5a07 18520400 lshift4 temp ,temp 
+5a08 18438400 lshift temp ,temp 
+5a09 98467e00 isub temp ,pdata 
+5a0a 20600000 rtn 
+
+le_supervision_flush:
+5a0b 20403bde call get_clkbt 
+5a0c 600203dc store 4 ,mem_le_supervision_timer 
+5a0d 20600000 rtn 
+
+le_adv:
+5a0e 79200025 set1 mark_ext_patch ,mark 
+5a0f 44b8402e bpatch patch2e_0 ,mem_patch2e 
+5a10 6800c3d8 fetch 1 ,mem_le_adv_enable 
+5a11 207a0000 rtn blank 
+5a12 d8e00001 arg le_adv_interval_timer ,queue 
+5a13 20407e53 call timer_check 
+5a14 247a0000 nrtn blank 
+5a15 7854fc00 disable master 
+5a16 78287c00 enable swfine 
+5a17 20405572 call le_init_adv 
+5a18 2040542c call le_next_adv_channel 
+5a19 204054de call le_send_adv_ind 
+5a1a 2436da24 nbranch le_adv_not_match ,match 
+5a1b 79200025 set1 mark_ext_patch ,mark 
+5a1c 44b8c02e bpatch patch2e_1 ,mem_patch2e 
+5a1d 68008003 fetch 1 ,mem_le_req_rcv 
+5a1e 1fe0fe01 increase 1 ,pdata 
+5a1f 60008003 store 1 ,mem_le_req_rcv 
+5a20 68008340 fetch 1 ,mem_le_rxbuf 
+5a21 1fe17e0f and pdata ,0x0f ,pdata 
+5a22 c001d519 beq scan_req ,le_send_scan_response 
+5a23 c002da41 beq connect_req ,parse_connect_req 
+
+le_adv_not_match:
+5a24 20002710 nop 10000 
+5a25 68008016 fetch 1 ,mem_le_ch_mapped 
+5a26 c093da0e bne 39 ,le_adv 
+5a27 20405ad8 call le_ledoff 
+5a28 d8e00001 arg le_adv_interval_timer ,queue 
+5a29 680144d9 fetch 2 ,mem_le_adv_interval_max 
+5a2a 20207e4c branch timer_init 
+
+le_receive_window_size:
+5a2b 79200025 set1 mark_ext_patch ,mark 
+5a2c 44b9402e bpatch patch2e_2 ,mem_patch2e 
+5a2d 680083f8 fetch 1 ,mem_le_peer_sca 
+5a2e 20405405 call le_sca_map 
+5a2f 680103c2 fetch 2 ,mem_le_tsniff 
+5a30 984ffe00 imul32 temp ,pdata 
+5a31 d8400177 arg 375 ,temp 
+5a32 984ffe00 imul32 temp ,pdata 
+5a33 d84186a0 arg 100000 ,temp 
+5a34 9846fc00 idiv temp 
+5a35 680083ec fetch 1 ,mem_le_window_size 
+5a36 d8404e20 arg 20000 ,temp 
+5a37 984ffe00 imul32 temp ,pdata 
+5a38 600246f9 store 4 ,mem_le_transmit_window 
+5a39 79200025 set1 mark_ext_patch ,mark 
+5a3a 44b9c02e bpatch patch2e_3 ,mem_patch2e 
+5a3b 68014161 fetch 2 ,mem_rx_window_sniff 
+5a3c 20407efd call wait_div_end 
+5a3d 18078400 quotient temp 
+5a3e 9840fe00 iadd temp ,pdata 
+5a3f 600103ce store 2 ,mem_le_receive_window 
+5a40 20600000 rtn 
+
+parse_connect_req:
+5a41 79200025 set1 mark_ext_patch ,mark 
+5a42 44ba402e bpatch patch2e_4 ,mem_patch2e 
+5a43 68030348 fetch 6 ,mem_le_rxbuf + 8 
+5a44 680b44f9 fetcht 6 ,mem_le_lap 
+5a45 98467c00 isub temp ,null 
+5a46 24628000 nrtn zero 
+5a47 20405613 call le_scan_check_sender_addr_type 
+5a48 1a227e00 copy rega ,pdata 
+5a49 6000c4e6 store 1 ,mem_le_conn_peer_addr_type 
+5a4a 68038355 fetch 7 ,mem_le_rxbuf + 21 
+5a4b 60038103 store 7 ,mem_tmp_buffer 
+5a4c e8c40000 ifetch 8 ,contr 
+5a4d e0a40000 istore 8 ,contw 
+5a4e 68030342 fetch 6 ,mem_le_rxbuf + 2 
+5a4f 600303d0 store 6 ,mem_le_plap 
+5a50 79200025 set1 mark_ext_patch ,mark 
+5a51 44bac02e bpatch patch2e_5 ,mem_patch2e 
+5a52 18c08c06 increase 6 ,contr 
+5a53 e8c40000 ifetch 8 ,contr 
+5a54 600403e5 store 8 ,mem_le_access 
+5a55 e8c90000 ifetcht 2 ,contr 
+5a56 184b8400 lshift2 temp ,temp 
+5a57 e8c10000 ifetch 2 ,contr 
+5a58 1febfe00 lshift2 pdata ,pdata 
+5a59 600103c2 store 2 ,mem_le_tsniff 
+5a5a 600203c4 store 4 ,mem_le_anchor 
+5a5b 98467e00 isub temp ,pdata 
+5a5c 1fe0d1fe add pdata ,-2 ,clke_bt 
+5a5d e8c48000 ifetch 9 ,contr 
+5a5e 600483ed store 9 ,mem_le_slave_latency 
+5a5f 79200025 set1 mark_ext_patch ,mark 
+5a60 44bb402e bpatch patch2e_6 ,mem_patch2e 
+5a61 e8c08000 ifetch 1 ,contr 
+5a62 1ff18400 rshift4 pdata ,temp 
+5a63 18430400 rshift temp ,temp 
+5a64 600883f8 storet 1 ,mem_le_peer_sca 
+5a65 1fe17e1f and_into 0x1f ,pdata 
+5a66 600083d9 store 1 ,mem_le_hop 
+5a67 20405a2b call le_receive_window_size 
+5a68 20405447 call le_calc_channel_map 
+5a69 2040536c call le_init_slave 
+5a6a 204032d6 call context_new 
+5a6b 24628000 nrtn zero 
+5a6c 79200025 set1 mark_ext_patch ,mark 
+5a6d 44bbc02e bpatch patch2e_7 ,mem_patch2e 
+5a6e d8400000 arg 0 ,temp 
+5a6f 204048ea call hci_send_le_conn_complete 
+5a70 204039ac call calc_clke_offset 
+5a71 700b7d14 jam bt_evt_le_connected ,mem_fifo_temp 
+5a72 20407c27 call ui_ipc_send_event 
+5a73 202032bd branch context_save 
+
+le_init_attlist_search:
+5a74 79200025 set1 mark_ext_patch ,mark 
+5a75 44bc402f bpatch patch2f_0 ,mem_patch2f 
+5a76 680144bc fetch 2 ,mem_le_search_handle_start 
+5a77 98002400 iforce regb 
+5a78 680144be fetch 2 ,mem_le_search_handle_end 
+5a79 98002600 iforce regc 
+5a7a d8c04504 arg mem_le_att_list ,contr 
+5a7b 78347c00 enable user 
+5a7c 20600000 rtn 
+
+le_att_handle_inrange:
+5a7d e8c10000 ifetch 2 ,contr 
+5a7e 207a0000 rtn blank 
+5a7f 9a467c00 isub regb ,null 
+5a80 24610000 nrtn positive 
+5a81 9a667c00 isub regc ,null 
+5a82 20628000 rtn zero 
+5a83 20215a86 branch le_att_handle_blank ,positive 
+5a84 18007c01 force 1 ,null 
+5a85 20600000 rtn 
+
+le_att_handle_blank:
+5a86 18007e00 force 0 ,pdata 
+5a87 20600000 rtn 
+
+le_att_get_handle_ptr:
+5a88 d8c04504 arg mem_le_att_list ,contr 
+
+le_att_get_handle_loop:
+5a89 e8c10000 ifetch 2 ,contr 
+5a8a 207a0000 rtn blank 
+5a8b 18c08c02 increase 2 ,contr 
+5a8c 98467c00 isub temp ,null 
+5a8d 20628000 rtn zero 
+5a8e e8c08000 ifetch 1 ,contr 
+5a8f 98c08c00 iadd contr ,contr 
+5a90 20205a89 branch le_att_get_handle_loop 
+
+le_data_send_write_req:
+5a91 7044c602 jam 0x2 ,mem_le_handle_data_len 
+5a92 58000001 setarg 0x0001 
+5a93 600144c7 store 2 ,mem_le_handle_data 
+5a94 7003e325 jam conn_sm_wait_write_res ,mem_le_conn_sm 
+5a95 700b7d12 jam attop_write_request ,mem_fifo_temp 
+5a96 20205620 branch le_xtype_fifo_in 
+
+le_data_wait_write_res:
+5a97 20600000 rtn 
+
+le_data_wait_write_res1:
+5a98 20600000 rtn 
+
+le_conn_sm_master:
+5a99 79200025 set1 mark_ext_patch ,mark 
+5a9a 44bcc02f bpatch patch2f_1 ,mem_patch2f 
+5a9b 6800c132 fetch 1 ,mem_device_option 
+5a9c c1820000 rtnne dvc_op_dongle 
+5a9d 680083e3 fetch 1 ,mem_le_conn_sm 
+5a9e c010da91 beq conn_sm_send_write_req ,le_data_send_write_req 
+5a9f c012da97 beq conn_sm_wait_write_res ,le_data_wait_write_res 
+5aa0 c0135a98 beq conn_sm_wait_write_res1 ,le_data_wait_write_res1 
+5aa1 20600000 rtn 
+
+le_ukey_init:
+5aa2 58005aae setarg le_ukey 
+5aa3 6001428c store 2 ,mem_cb_le_process 
+5aa4 70806281 hjam uart_ctrl_normal ,core_uart_ctrl 
+5aa5 580001a0 setarg uart_baud_115200 
+5aa6 60110052 hstore uart_baud_len ,core_uart_baud 
+5aa7 70804301 hjam uartclk_dpll ,core_uart_clksel 
+5aa8 70808104 hjam 0x4 ,core_gpio_sel1 
+5aa9 58005ac6 setarg le_ukey_wcb 
+5aaa 60014296 store 2 ,mem_cb_att_write 
+5aab 20405347 call le_init_att 
+5aac 20758000 rtn wake 
+5aad 2020691d branch eeprom_load_reconn_info 
+
+le_ukey:
+5aae 680083c1 fetch 1 ,mem_le_mode 
+5aaf 2fe1fe01 compare lemode_slave ,pdata ,0xff 
+5ab0 58000005 setarg 5 
+5ab1 2040ea04 call set_pwm_steadyon ,true 
+5ab2 2440e9ff ncall set_pwm_blink ,true 
+5ab3 204068fd call uartd_prepare_rx 
+5ab4 203a5abe branch le_ukey_senddata ,blank 
+5ab5 68010419 fetch 2 ,mem_le_notify_attr_start 
+5ab6 98000a00 iforce contw 
+5ab7 1f267c14 sub loopcnt ,20 ,null 
+5ab8 20215aba branch le_ukey_loop ,positive 
+5ab9 18007214 force 20 ,loopcnt 
+
+le_ukey_loop:
+5aba e8608000 ifetch 1 ,contru 
+5abb e0a08000 istore 1 ,contw 
+5abc c2005aba loop le_ukey_loop 
+5abd 20406906 call uartd_rxdone 
+
+le_ukey_senddata:
+5abe 7044c214 jam notify_handle ,mem_le_notify_handle 
+5abf 68090419 fetcht 2 ,mem_le_notify_attr_start 
+5ac0 e8408000 ifetch 1 ,temp 
+5ac1 207a0000 rtn blank 
+5ac2 2040561c call le_xtype_fifo_is_full 
+5ac3 247a0000 nrtn blank 
+5ac4 700b7d1b jam attop_handle_value_notification ,mem_fifo_temp 
+5ac5 20205620 branch le_xtype_fifo_in 
+
+le_ukey_wcb:
+5ac6 1a420400 copy regb ,temp 
+5ac7 204068f7 call uartd_prepare_tx 
+5ac8 1a220c00 copy rega ,contr 
+5ac9 1a427200 copy regb ,loopcnt 
+
+le_writeatt_cb_loop:
+5aca e8c08000 ifetch 1 ,contr 
+5acb e1408000 istore 1 ,contwu 
+5acc c2005aca loop le_writeatt_cb_loop 
+5acd 202068fa branch uartd_send 
+
+le_clear_notify_att:
+5ace 6800c132 fetch 1 ,mem_device_option 
+5acf c1830000 rtnne dvc_op_ukey 
+5ad0 680144c2 fetch 2 ,mem_le_notify_handle 
+5ad1 c18a0000 rtnne notify_handle 
+5ad2 68090419 fetcht 2 ,mem_le_notify_attr_start 
+5ad3 58000000 setarg 0 
+5ad4 e0448000 istore 9 ,temp 
+5ad5 e0a48000 istore 9 ,contw 
+5ad6 e0a10000 istore 2 ,contw 
+5ad7 20600000 rtn 
+
+le_ledoff:
+5ad8 6808c3d7 fetcht 1 ,mem_le_adv_led 
+5ad9 79400407 setflip gpio_active_bit ,temp 
+5ada 202069f3 branch gpio_out 
+
+le_modified_name:
+5adb 79200025 set1 mark_ext_patch ,mark 
+5adc 44bd402f bpatch patch2f_2 ,mem_patch2f 
+5add 20405adf call le_modified_name_att_list 
+5ade 20205aed branch le_modified_name_adv 
+
+le_modified_name_att_list:
+5adf 6800c419 fetch 1 ,mem_le_name_len 
+5ae0 1fe27200 copy pdata ,loopcnt 
+5ae1 d8402a00 arg uuid_chrctr_device_name ,temp 
+5ae2 20405b0c call le_att_get_uuid_ptr 
+5ae3 18c08c01 increase 1 ,contr 
+5ae4 18c20a00 copy contr ,contw 
+5ae5 d8c0441a arg mem_le_name ,contr 
+5ae6 20407e45 call memcpy 
+5ae7 6800c419 fetch 1 ,mem_le_name_len 
+5ae8 1fe67214 sub pdata ,max_name_len ,loopcnt 
+5ae9 1f220400 copy loopcnt ,temp 
+5aea 1f227e00 copy loopcnt ,pdata 
+5aeb 245a5b15 ncall memcpy_empty ,blank 
+5aec 20600000 rtn 
+
+le_modified_name_adv:
+5aed 6800c3d9 fetch 1 ,mem_le_adv_data_len 
+5aee 6808c3da fetcht 1 ,mem_le_adv_data 
+5aef 98467e00 isub temp ,pdata 
+5af0 1fe27200 copy pdata ,loopcnt 
+5af1 1fe22200 copy pdata ,rega 
+5af2 6800c3da fetch 1 ,mem_le_adv_data 
+5af3 1fe0fe01 increase 1 ,pdata 
+5af4 d8c043da arg mem_le_adv_data ,contr 
+5af5 98c08c00 iadd contr ,contr 
+5af6 d8a0041d arg mem_le_adv_temp ,contw 
+5af7 20407e45 call memcpy 
+5af8 79200025 set1 mark_ext_patch ,mark 
+5af9 44bdc02f bpatch patch2f_3 ,mem_patch2f 
+5afa 6800c419 fetch 1 ,mem_le_name_len 
+5afb 1fe27200 copy pdata ,loopcnt 
+5afc 1fe0fe01 increase 1 ,pdata 
+5afd 6000c3da store 1 ,mem_le_adv_data 
+5afe d8a043dc arg mem_le_adv_data + 2 ,contw 
+5aff d8c0441a arg mem_le_name ,contr 
+5b00 20407e45 call memcpy 
+5b01 1a227200 copy rega ,loopcnt 
+5b02 d8c0041d arg mem_le_adv_temp ,contr 
+5b03 20407e45 call memcpy 
+5b04 6800c3da fetch 1 ,mem_le_adv_data 
+5b05 9a20fe00 iadd rega ,pdata 
+5b06 6000c3d9 store 1 ,mem_le_adv_data_len 
+5b07 20600000 rtn 
+
+le_get_device_name:
+5b08 79200025 set1 mark_ext_patch ,mark 
+5b09 44be402f bpatch patch2f_4 ,mem_patch2f 
+5b0a d8402a00 arg uuid_chrctr_device_name ,temp 
+5b0b 20205b0c branch le_att_get_uuid_ptr 
+
+le_att_get_uuid_ptr:
+5b0c d8c04504 arg mem_le_att_list ,contr 
+
+le_att_get_uuid_loop:
+5b0d e8c10000 ifetch 2 ,contr 
+5b0e 203a3bf1 branch assert ,blank 
+5b0f e8c10000 ifetch 2 ,contr 
+5b10 98467c00 isub temp ,null 
+5b11 20628000 rtn zero 
+5b12 e8c08000 ifetch 1 ,contr 
+5b13 98c08c00 iadd contr ,contr 
+5b14 20205b0d branch le_att_get_uuid_loop 
+
+memcpy_empty:
+5b15 58000020 setarg space 
+5b16 e0a08000 istore 1 ,contw 
+5b17 c2005b15 loop memcpy_empty 
+5b18 20600000 rtn 
+
+le_lpm_set_mult:
+5b19 79200025 set1 mark_ext_patch ,mark 
+5b1a 44bec02f bpatch patch2f_5 ,mem_patch2f 
+5b1b 7855fc00 disable wake 
+5b1c 20375b1e branch le_lpm_set_mult_attempt ,attempt 
+5b1d 2436db2a nbranch le_lpm_lost ,match 
+
+le_lpm_set_mult_attempt:
+5b1e 20403d76 call lpm_match 
+5b1f 68014161 fetch 2 ,mem_rx_window_sniff 
+5b20 600103ce store 2 ,mem_le_receive_window 
+5b21 68008340 fetch 1 ,mem_le_rxbuf 
+5b22 2fe00601 compare 1 ,pdata ,3 
+5b23 2420bd8a nbranch lpm_mult_short ,true 
+5b24 6800c43e fetch 1 ,mem_le_txheader 
+5b25 2fe00601 compare 1 ,pdata ,3 
+5b26 2420bd8a nbranch lpm_mult_short ,true 
+5b27 680083c0 fetch 1 ,mem_le_state 
+5b28 c282bd8a bbit1 lestate_update_param ,lpm_mult_short 
+5b29 20203d6f branch lpm_mult_wait_timeout 
+
+le_lpm_lost:
+5b2a 68094161 fetcht 2 ,mem_rx_window_sniff 
+5b2b 18430400 rshift temp ,temp 
+5b2c 680103ce fetch 2 ,mem_le_receive_window 
+5b2d 9840fe00 iadd temp ,pdata 
+5b2e 600103ce store 2 ,mem_le_receive_window 
+5b2f 20203d82 branch lpm_lost 
+
+le_clean_att_list_handle_enable:
+5b30 79200025 set1 mark_ext_patch ,mark 
+5b31 44bf402f bpatch patch2f_6 ,mem_patch2f 
+5b32 7046f800 jam 0 ,mem_le_switch_send_data 
+5b33 680944c2 fetcht 2 ,mem_le_notify_handle 
+5b34 20405866 call le_att_check_notification_enable 
+5b35 1a220a00 copy rega ,contw 
+5b36 58000000 setarg 0 
+5b37 e0a08000 istore 1 ,contw 
+5b38 20600000 rtn 
+
+le_scan_addr_to_uart:
+5b39 6800c132 fetch 1 ,mem_device_option 
+5b3a c1850000 rtnne dvc_op_module 
+5b3b 20407f6e call get_uart_twptr 
+5b3c da2003d0 arg mem_le_plap ,rega 
+5b3d 20407e9d call adss_hex2string_to_uart 
+5b3e 5800002c setarg 0x2c 
+5b3f e1408000 istore 1 ,contwu 
+5b40 204041d4 call at_rssi_result 
+5b41 202068fa branch uartd_send 
+
+prcp_le_tx:
+5b42 d8400014 arg prcp_tx_le ,temp 
+5b43 20405866 call le_att_check_notification_enable 
+5b44 c4000000 rtnbit0 0 
+5b45 2040561c call le_xtype_fifo_is_full 
+5b46 247a0000 nrtn blank 
+5b47 d8400014 arg prcp_tx_le ,temp 
+5b48 600944c2 storet 2 ,mem_le_notify_handle 
+5b49 20405a88 call le_att_get_handle_ptr 
+5b4a 203a3bf1 branch assert ,blank 
+5b4b 18c08a01 add contr ,1 ,contw 
+5b4c df200014 arg prcp_tx_data_len ,loopcnt 
+5b4d d8c0046d arg mem_prcp_data ,contr 
+5b4e 20407e45 call memcpy 
+5b4f 700b7d1b jam attop_handle_value_notification ,mem_fifo_temp 
+5b50 20205620 branch le_xtype_fifo_in 
+
+prcp_tx:
+5b51 20600000 rtn 
+
+le_search_adtype:
+5b52 79200025 set1 mark_ext_patch ,mark 
+5b53 44bfc02f bpatch patch2f_7 ,mem_patch2f 
+5b54 68008341 fetch 1 ,mem_le_rxbuf + 1 
+5b55 d8c00348 arg mem_le_rxbuf + 8 ,contr 
+5b56 98c0f200 iadd contr ,loopcnt 
+
+le_search_adtype_loop:
+5b57 e8c88000 ifetcht 1 ,contr 
+5b58 e8c08000 ifetch 1 ,contr 
+5b59 9a267c00 isub rega ,null 
+5b5a 20628000 rtn zero 
+5b5b 1840ffff add temp ,-1 ,pdata 
+5b5c 98c08c00 iadd contr ,contr 
+5b5d 1f227e00 deposit loopcnt 
+5b5e 98c67c00 isub contr ,null 
+5b5f 20215b57 branch le_search_adtype_loop ,positive 
+5b60 18007c01 force 1 ,null 
+5b61 20600000 rtn 
+
+init_lmp:
+5b62 20758000 rtn wake 
+
+init_lmp_work:
+5b63 58000000 setarg 0 
+5b64 60008048 store 1 ,mem_lmp_to_send 
+5b65 60008055 store 1 ,mem_conn_sm 
+5b66 60008078 store 1 ,mem_lmo_opcode1 
+5b67 6000807c store 1 ,mem_lmo_opcode2 
+5b68 6000c1f9 store 1 ,mem_esco_addr 
+5b69 60008453 store 1 ,mem_auth_enable 
+5b6a 60008177 store 1 ,mem_connection_options 
+5b6b 600087e1 store 1 ,mem_pairing_auth 
+5b6c 70474800 jam switch_flag_init ,mem_switch_flag 
+5b6d 70025800 jam 0 ,mem_switch_fail_master_count 
+5b6e 70045400 jam null_encryp ,mem_wait_encryption 
+
+init_lmp_reinit:
+5b6f 79200025 set1 mark_ext_patch ,mark 
+5b70 44f0403c bpatch patch3c_0 ,mem_patch3c 
+5b71 7007e100 jam 0 ,mem_pairing_auth 
+5b72 7007e000 jam 0 ,mem_sp_localsm 
+5b73 70044d00 jam 0 ,mem_lmp_conn_state 
+5b74 6800c132 fetch 1 ,mem_device_option 
+5b75 c1808000 rtnne dvc_op_hci ,pdata 
+5b76 70425e00 jam 0 ,mem_link_key_exists 
+
+parse_rx_done:
+5b77 20600000 rtn 
+
+parse_lmp:
+5b78 79200025 set1 mark_ext_patch ,mark 
+5b79 44f0c03c bpatch patch3c_1 ,mem_patch3c 
+5b7a 2054e219 call setlocalsm_master ,master 
+5b7b 2454e21d ncall setlocalsm_slave ,master 
+5b7c 6800807c fetch 1 ,mem_lmo_opcode2 
+5b7d 245a61d9 ncall lmo_fifo_process ,blank 
+5b7e 6800807c fetch 1 ,mem_lmo_opcode2 
+5b7f 247a0000 nrtn blank 
+5b80 6800804c fetch 1 ,mem_state_map 
+5b81 c4030000 rtnbit0 smap_rxlmp 
+5b82 793ffe06 set0 smap_rxlmp ,pdata 
+5b83 793f8001 set0 mark_rxbuf_inuse ,mark 
+5b84 6000804c store 1 ,mem_state_map 
+5b85 680084de fetch 1 ,mem_rxbuf 
+5b86 6808804c fetcht 1 ,mem_state_map 
+5b87 2feffe00 isolate1 smap_lmptidinit ,pdata 
+5b88 79208401 setflag true ,smap_lmptid ,temp 
+5b89 6008804c storet 1 ,mem_state_map 
+5b8a 18410402 and_into 0x2 ,temp 
+5b8b 6008807f storet 1 ,mem_lmo_tid2 
+5b8c 6808804c fetcht 1 ,mem_state_map 
+5b8d 1fe37e00 rshift pdata ,pdata 
+5b8e 6000807d store 1 ,mem_lmi_opcode2 
+5b8f 79200025 set1 mark_ext_patch ,mark 
+5b90 44f1403c bpatch patch3c_2 ,mem_patch3c 
+5b91 6800807d fetch 1 ,mem_lmi_opcode2 
+5b92 c03fdbdc beq lmp_escape ,parse_lmp_escape 
+5b93 c001dc56 beq lmp_accepted ,parse_lmp_accepted 
+5b94 c0025c67 beq lmp_not_accepted ,parse_lmp_not_accepted 
+5b95 c01e5bcf beq lmp_set_afh ,parse_lmp_set_afh 
+5b96 c002dbcb beq lmp_clkoffset_req ,parse_lmp_clkoffset_req 
+5b97 c007de48 beq lmp_encryption_mode_req ,parse_lmp_encryption_mode_req 
+5b98 c0085ce1 beq lmp_encryption_key_size_req ,parse_lmp_crypt_key 
+5b99 c011dcff beq lmp_auto_rate ,parse_lmp_auto_rate 
+5b9a c01cde67 beq lmp_test_control ,parse_lmp_test_control 
+5b9b c01c5e62 beq lmp_test_activate ,parse_lmp_test_activate 
+5b9c c018dce4 beq lmp_setup_complete ,parse_lmp_setup_complete 
+5b9d c01bdd72 beq lmp_supervision_timeout ,parse_lmp_supervision_timeout 
+5b9e c013dd6e beq lmp_features_req ,parse_lmp_features_req 
+5b9f c019dd68 beq lmp_host_connection_req ,parse_lmp_conn_req 
+5ba0 c012dd70 beq lmp_version_req ,parse_lmp_version_req 
+5ba1 c0135cfb beq lmp_version_res ,parse_lmp_version_res 
+5ba2 c003dcf3 beq lmp_detach ,parse_lmp_detach 
+5ba3 c016dcea beq lmp_max_slot ,parse_lmp_max_slot 
+5ba4 c0175ceb beq lmp_max_slot_req ,parse_lmp_max_slot_req 
+5ba5 c000dd64 beq lmp_name_req ,parse_lmp_name_req 
+5ba6 c0015d4f beq lmp_name_res ,parse_lmp_name_res 
+5ba7 c0145e53 beq lmp_features_res ,parse_lmp_features_res 
+5ba8 c004dd45 beq lmp_comb_key ,parse_lmp_comb_key 
+5ba9 c005dd1a beq lmp_au_rand ,parse_lmp_au_rand 
+5baa c0045d00 beq lmp_in_rand ,parse_lmp_in_rand 
+5bab c0065d2c beq lmp_sres ,parse_lmp_sres 
+5bac c00fdcf7 beq lmp_incr_power_req ,parse_lmp_incr_power 
+5bad c0105cf9 beq lmp_decr_power_req ,parse_lmp_decr_power 
+5bae c010dd8d beq lmp_max_power ,parse_lmp_max_power 
+5baf c0115d8e beq lmp_min_power ,parse_lmp_min_power 
+5bb0 c01add8f beq lmp_page_mode_req ,parse_lmp_page_mode_req 
+5bb1 c01b5d90 beq lmp_page_scan_mode_req ,parse_lmp_page_scan_mode_req 
+5bb2 c0125d91 beq lmp_preferred_rate ,parse_lmp_preferred_rate 
+5bb3 c0165d92 beq lmp_remove_sco_link_req ,parse_lmp_remove_sco_link_req 
+5bb4 c015dd95 beq lmp_sco_link_req ,parse_lmp_sco_link_req 
+5bb5 c01a5d9f beq lmp_slot_offset ,parse_lmp_slot_offset 
+5bb6 c00bdda2 beq lmp_sniff_req ,parse_lmp_sniff_req 
+5bb7 c008ddb7 beq lmp_start_encryption_req ,parse_lmp_start_encryption_req 
+5bb8 c0095dbb beq lmp_stop_encryption_req ,parse_lmp_stop_encryption_req 
+5bb9 c009ddbd beq lmp_switch_req ,parse_lmp_switch_req 
+5bba c006ddcf beq lmp_temp_rand ,parse_lmp_temp_rand 
+5bbb c0075dd0 beq lmp_temp_key ,parse_lmp_temp_key 
+5bbc c017dd6c beq lmp_timing_accuracy_req ,parse_lmp_timing_accuracy_req 
+5bbd c0185dd1 beq lmp_timing_accuracy_res ,parse_lmp_timing_accuracy_res 
+5bbe c0055dd2 beq lmp_unit_key ,parse_lmp_unit_key 
+5bbf c00c5dd3 beq lmp_unsniff_req ,parse_lmp_unsniff_req 
+5bc0 c0195dda beq lmp_use_semi_permanent_key ,parse_lmp_use_semi_permanend_key 
+5bc1 c01edddb beq lmp_encapsulated_header ,parse_lmp_encapsulated_header 
+5bc2 c01f5dff beq lmp_encapsulated_payload ,parse_lmp_encapsulated_payload 
+5bc3 c01fddf9 beq lmp_simple_pairing_confirm ,parse_simple_pairing_confirm 
+5bc4 c0205e22 beq lmp_simple_pairing_number ,parse_lmp_simple_pairing_number 
+5bc5 c020de34 beq lmp_dhkey_check ,parse_dhkey_check 
+5bc6 c0035e47 beq lmp_clkoffset_res ,parse_lmp_clkoffset_res 
+5bc7 c01d5bcd beq lmp_enc_key_size_mask_req ,parse_enc_key_size_mask_req 
+
+reject_unknown_packet:
+5bc8 70007e19 jam unknown_lmp_pdu ,mem_lmo_reason2 
+
+reject_lmp_packet:
+5bc9 70007c04 jam lmp_not_accepted ,mem_lmo_opcode2 
+5bca 20600000 rtn 
+
+parse_lmp_clkoffset_req:
+5bcb 70007c06 jam lmp_clkoffset_res ,mem_lmo_opcode2 
+5bcc 20600000 rtn 
+
+parse_enc_key_size_mask_req:
+5bcd 70007c3b jam lmp_enc_key_size_mask_res ,mem_lmo_opcode2 
+5bce 20600000 rtn 
+
+parse_lmp_set_afh:
+5bcf 680204df fetch 4 ,mem_rxbuf + 1 
+5bd0 1fe3fe00 lshift pdata ,pdata 
+5bd1 60024173 store 4 ,mem_afh_instant 
+5bd2 680084e3 fetch 1 ,mem_rxbuf + 5 
+5bd3 6000c17a store 1 ,mem_afh_new_mod 
+5bd4 680284e4 fetch 5 ,mem_rxbuf + 6 
+5bd5 6002c188 store 5 ,mem_afh_map_new 
+5bd6 680284e9 fetch 5 ,mem_rxbuf + 11 
+5bd7 e0a28000 istore 5 ,contw 
+5bd8 68008031 fetch 1 ,mem_mode 
+5bd9 79207e03 set1 afh_change ,pdata 
+5bda 60008031 store 1 ,mem_mode 
+5bdb 20600000 rtn 
+
+parse_lmp_escape:
+5bdc 680084df fetch 1 ,mem_rxbuf + 1 
+5bdd 79207e07 set1 7 ,pdata 
+5bde 6000807d store 1 ,mem_lmi_opcode2 
+5bdf c040dc26 beq lmp_ext_accepted ,parse_lmpext_accepted 
+5be0 c0415c2e beq lmp_not_accepted_ext ,parse_lmpext_not_accepted 
+5be1 c04add73 beq lmp_sniff_subrating_req ,parse_lmp_sniff_subrating_req 
+5be2 c04b5d8c beq lmp_sniff_subrating_res ,parse_lmp_sniff_subrating_res 
+5be3 c045dd81 beq lmp_packet_type_table_req ,parse_lmpext_packet_type_table_req 
+5be4 c041dc49 beq lmp_ext_features_req ,parse_lmpext_features_req 
+5be5 c0425c4b beq lmp_ext_features_res ,parse_lmpext_features_res 
+5be6 c0485bf1 beq lmp_ext_chn_classification_req ,parse_lmpext_chn_classification_req 
+5be7 c04bdc42 beq lmp_pause_encryption_req ,parse_lmpext_pause_encrypt 
+5be8 c04c5c47 beq lmp_resume_encryption_req ,parse_lmpext_resume_encrypt 
+5be9 c04cdc14 beq lmp_io_cap_req ,parse_lmpext_iocap_req 
+5bea c04d5c19 beq lmp_io_cap_res ,parse_lmpext_iocap_res 
+5beb c046dc11 beq lmp_ext_remove_esco_req ,parse_lmpext_remove_esco_req 
+5bec c0465bf4 beq lmp_ext_esco_link_req ,parse_lmpext_esco_link_req 
+5bed c1420000 rtneq lmp_ext_features_res 
+
+reject_unknown_ext_packet:
+5bee 70007c82 jam lmp_not_accepted_ext ,mem_lmo_opcode2 
+5bef 70007e19 jam unknown_lmp_pdu ,mem_lmo_reason2 
+5bf0 20600000 rtn 
+
+parse_lmpext_chn_classification_req:
+5bf1 70007c82 jam lmp_not_accepted_ext ,mem_lmo_opcode2 
+5bf2 70007e2e jam not_support_chn_classification ,mem_lmo_reason2 
+5bf3 20600000 rtn 
+
+parse_lmpext_esco_link_req:
+5bf4 680084e0 fetch 1 ,mem_rxbuf + 2 
+5bf5 600080ad store 1 ,mem_sco_handle 
+5bf6 680084e1 fetch 1 ,mem_rxbuf + 3 
+5bf7 6000c1f9 store 1 ,mem_esco_addr 
+5bf8 680084e3 fetch 1 ,mem_rxbuf + 5 
+5bf9 600080af store 1 ,mem_esco_desco 
+5bfa 680084e7 fetch 1 ,mem_rxbuf + 9 
+5bfb 600080b0 store 1 ,mem_esco_type 
+5bfc 680084ec fetch 1 ,mem_rxbuf + 14 
+5bfd 600080ab store 1 ,mem_air_mode 
+5bfe c503dc07 bmark1 mark_esco ,check_esco_prarm 
+5bff 79200007 set1 mark_esco ,mark 
+5c00 20405d16 call push_tid_follow 
+5c01 60008452 store 1 ,mem_accptsco_tid 
+5c02 18000400 force 0 ,temp 
+5c03 20204839 branch hci_send_conn_req_event 
+
+parse_lmpext_esco_link_req_change_param:
+5c04 70007c8c jam lmp_ext_esco_link_req ,mem_lmo_opcode2 
+5c05 7000b101 jam prarm_neogotiation ,mem_neogotiation_state 
+5c06 202049bc branch cmd_exit 
+
+check_esco_prarm:
+5c07 680080b0 fetch 1 ,mem_esco_type 
+5c08 c083dc0b bne type_hv3 ,reject_esco_prarm 
+5c09 70007c81 jam lmp_ext_accepted ,mem_lmo_opcode2 
+5c0a 20205c0f branch esco_prarm_common 
+
+reject_esco_prarm:
+5c0b 793f8007 set0 mark_esco ,mark 
+5c0c 70007c82 jam lmp_not_accepted_ext ,mem_lmo_opcode2 
+5c0d 18000401 force hci_error_unknown_hci_command ,temp 
+5c0e 20404914 call hci_send_sco_complete 
+
+esco_prarm_common:
+5c0f 70007d8c jam lmp_ext_esco_link_req ,mem_lmi_opcode2 
+5c10 20600000 rtn 
+
+parse_lmpext_remove_esco_req:
+5c11 70007c81 jam lmp_ext_accepted ,mem_lmo_opcode2 
+5c12 70007d8d jam lmp_ext_remove_esco_req ,mem_lmi_opcode2 
+5c13 20203869 branch stop_esco 
+
+parse_lmpext_iocap_req:
+5c14 20405c1d call iocap_lmpext_load 
+5c15 6800c132 fetch 1 ,mem_device_option 
+5c16 c000dc21 beq dvc_op_hci ,iocap_lmpext_hci 
+5c17 70007c9a jam lmp_io_cap_res ,mem_lmo_opcode2 
+5c18 20600000 rtn 
+
+parse_lmpext_iocap_res:
+5c19 20405c1d call iocap_lmpext_load 
+5c1a 6800c132 fetch 1 ,mem_device_option 
+5c1b c000dc21 beq dvc_op_hci ,iocap_lmpext_hci 
+5c1c 20205c22 branch iocap_lmpext_common 
+
+iocap_lmpext_load:
+5c1d d8a007e9 arg mem_sp_iocap_remote ,contw 
+5c1e 680184e0 fetch 3 ,mem_rxbuf + 2 
+5c1f e0a18000 istore 3 ,contw 
+5c20 20600000 rtn 
+
+iocap_lmpext_hci:
+5c21 2040480f call hci_send_io_cap_response_event 
+
+iocap_lmpext_common:
+5c22 20406216 call check_localsm 
+5c23 2440c81b ncall hci_send_io_cap_req_event ,true 
+5c24 2020f80f branch master_set_mem_master_sp_flag ,true 
+5c25 20600000 rtn 
+
+parse_lmpext_accepted:
+5c26 680084e1 fetch 1 ,mem_rxbuf + 3 
+5c27 79207e07 set1 7 ,pdata 
+5c28 60008445 store 1 ,mem_lmi_accepted_opcode 
+5c29 c045dc36 beq lmp_packet_type_table_req ,parse_lmpext_accepted_ptt 
+5c2a c046384a beq lmp_ext_esco_link_req ,play_sco 
+5c2b c046dc2d beq lmp_ext_remove_esco_req ,parse_lmpext_stop_esco 
+5c2c 20600000 rtn 
+
+parse_lmpext_stop_esco:
+5c2d 20203869 branch stop_esco 
+
+parse_lmpext_not_accepted:
+5c2e 680084e1 fetch 1 ,mem_rxbuf + 3 
+5c2f 79207e07 set1 7 ,pdata 
+5c30 60008445 store 1 ,mem_lmi_accepted_opcode 
+5c31 c045dc3a beq lmp_packet_type_table_req ,parse_lmpext_not_accepted_ptt 
+5c32 c0465c34 beq lmp_ext_esco_link_req ,parse_lmpext_not_accepted_esco 
+5c33 20600000 rtn 
+
+parse_lmpext_not_accepted_esco:
+5c34 793f8007 set0 mark_esco ,mark 
+5c35 20600000 rtn 
+
+parse_lmpext_accepted_ptt:
+5c36 6800c1fb fetch 1 ,mem_ptt 
+5c37 6808804c fetcht 1 ,mem_state_map 
+5c38 7d3a0405 nsetflag blank ,smap_edr ,temp 
+5c39 6008804c storet 1 ,mem_state_map 
+
+parse_lmpext_not_accepted_ptt:
+5c3a 68008030 fetch 1 ,mem_state 
+5c3b c4028000 rtnbit0 state_init_seq 
+5c3c 793ffe05 set0 state_init_seq ,pdata 
+5c3d 60008030 store 1 ,mem_state 
+5c3e 68008453 fetch 1 ,mem_auth_enable 
+5c3f 243a4872 nbranch hci_send_linkkey_req ,blank 
+5c40 70007c31 jam lmp_setup_complete ,mem_lmo_opcode2 
+5c41 20600000 rtn 
+
+parse_lmpext_pause_encrypt:
+5c42 2434dc45 nbranch parse_lmpext_pause_encrypt_slave ,master 
+5c43 70007c12 jam lmp_stop_encryption_req ,mem_lmo_opcode2 
+5c44 20206205 branch tid_reply 
+
+parse_lmpext_pause_encrypt_slave:
+5c45 70007c97 jam lmp_pause_encryption_req ,mem_lmo_opcode2 
+5c46 20600000 rtn 
+
+parse_lmpext_resume_encrypt:
+5c47 20406205 call tid_reply 
+5c48 20205ecd branch lmp_start_encryption 
+
+parse_lmpext_features_req:
+5c49 70007c84 jam lmp_ext_features_res ,mem_lmo_opcode2 
+5c4a 20600000 rtn 
+
+parse_lmpext_features_res:
+5c4b 680884e2 fetcht 1 ,mem_rxbuf + 4 
+5c4c 18410401 and temp ,0x1 ,temp 
+5c4d 6008844c storet 1 ,mem_remote_sppcap 
+5c4e 6800c272 fetch 1 ,mem_hci_cmd 
+5c4f c0a8dc52 bne hci_cmd_wait_remote_ext_feature ,parse_lmpext_features_res_not_hci 
+5c50 70427200 jam 0 ,mem_hci_cmd 
+5c51 204047f9 call hci_send_remote_ext_features_event 
+
+parse_lmpext_features_res_not_hci:
+5c52 68008055 fetch 1 ,mem_conn_sm 
+5c53 c18a8000 rtnne conn_sm_wait_features_ext 
+5c54 70005504 jam conn_sm_send_conn_req ,mem_conn_sm 
+5c55 20206235 branch process_conn_sm 
+
+parse_lmp_accepted:
+5c56 680084df fetch 1 ,mem_rxbuf + 1 
+5c57 60008445 store 1 ,mem_lmi_accepted_opcode 
+5c58 c019dc7d beq lmp_host_connection_req ,parse_lmp_accepted_hostconn 
+5c59 c0045c90 beq lmp_in_rand ,parse_lmp_accepted_inrand 
+5c5a c007dc97 beq lmp_encryption_mode_req ,parse_lmp_accepted_enc_mode 
+5c5b c0085c9d beq lmp_encryption_key_size_req ,parse_lmp_accepted_enc_keysize 
+5c5c c008dc9e beq lmp_start_encryption_req ,parse_lmp_accepted_start_enc 
+5c5d c0095ca6 beq lmp_stop_encryption_req ,parse_lmp_accepted_stop_enc 
+5c5e c00c5ccc beq lmp_unsniff_req ,parse_lmp_accepted_unsniff_req 
+5c5f c00bdcd1 beq lmp_sniff_req ,parse_lmp_accepted_sniff_req 
+5c60 c015b84a beq lmp_sco_link_req ,play_sco 
+5c61 c009dc74 beq lmp_switch_req ,parse_lmp_accepted_switch 
+5c62 c01edde9 beq lmp_encapsulated_header ,parse_lmp_accepted_encapsulated_header 
+5c63 c01f5e18 beq lmp_encapsulated_payload ,parse_lmp_accepted_encapsulated_payload 
+5c64 c0205deb beq lmp_simple_pairing_number ,parse_lmp_accepted_simple_pairing_number 
+5c65 c020ddef beq lmp_dhkey_check ,parse_lmp_accepted_dhkey_check 
+5c66 20600000 rtn 
+
+parse_lmp_not_accepted:
+5c67 680084df fetch 1 ,mem_rxbuf + 1 
+5c68 60008445 store 1 ,mem_lmi_accepted_opcode 
+5c69 c000dcc3 beq lmp_name_req ,parse_lmp_not_accepted_name_req 
+5c6a c019dc87 beq lmp_host_connection_req ,parse_lmp_not_accepted_hostconn 
+5c6b c005dca7 beq lmp_au_rand ,parse_lmp_not_accepted_aurand 
+5c6c c015dc8e beq lmp_sco_link_req ,parse_lmp_not_accepted_sco_link_req 
+5c6d c0045cba beq lmp_in_rand ,parse_lmp_not_accepted_inrand 
+5c6e c009dc77 beq lmp_switch_req ,parse_lmp_not_accepted_switch 
+5c6f c0205cc4 beq lmp_simple_pairing_number ,parse_lmp_not_accepted_simple_pairing_number 
+5c70 c020dcc7 beq lmp_dhkey_check ,parse_lmp_not_accepted_dhkey_check 
+5c71 c00c5cca beq lmp_unsniff_req ,parse_lmp_not_accepted_unsniff_req 
+5c72 c00bdcdf beq lmp_sniff_req ,parse_lmp_not_acdcept_sniff_req 
+5c73 20600000 rtn 
+
+parse_lmp_accepted_switch:
+5c74 700b7d20 jam bt_evt_switch_accept ,mem_fifo_temp 
+5c75 20407c27 call ui_ipc_send_event 
+5c76 20203245 branch role_switch_prepare0 
+
+parse_lmp_not_accepted_switch:
+5c77 700b7d19 jam bt_evt_switch_not_accept ,mem_fifo_temp 
+5c78 20407c27 call ui_ipc_send_event 
+5c79 70474802 jam switch_flag_not_accept ,mem_switch_flag 
+5c7a 58000050 setarg timer_switch_waite 
+5c7b d8e0000a arg switch_wait_timer ,queue 
+5c7c 20207e4c branch timer_init 
+
+parse_lmp_accepted_hostconn:
+5c7d 6800844d fetch 1 ,mem_lmp_conn_state 
+5c7e 79207e00 set1 received_conn_req ,pdata 
+5c7f 6000844d store 1 ,mem_lmp_conn_state 
+5c80 700b7d01 jam bt_evt_bb_connected ,mem_fifo_temp 
+5c81 20407c27 call ui_ipc_send_event 
+5c82 70007c8b jam lmp_packet_type_table_req ,mem_lmo_opcode2 
+
+parse_lmp_accepted_hostconn_ctn:
+5c83 68008055 fetch 1 ,mem_conn_sm 
+5c84 c082db77 bne conn_sm_wait_conn_accept ,parse_rx_done 
+5c85 70005506 jam conn_sm_auth_pair ,mem_conn_sm 
+5c86 20600000 rtn 
+
+parse_lmp_not_accepted_hostconn:
+5c87 7004460b jam acl_connection_already_exists ,mem_disconn_reason_send 
+5c88 70007c07 jam lmp_detach ,mem_lmo_opcode2 
+5c89 18000410 force hci_error_host_timeout ,temp 
+5c8a 20404826 call hci_send_connection_error 
+5c8b 70005500 jam conn_sm_standby ,mem_conn_sm 
+5c8c 2020db77 branch parse_rx_done ,true 
+5c8d 20600000 rtn 
+
+parse_lmp_not_accepted_sco_link_req:
+5c8e 70007c2b jam lmp_sco_link_req ,mem_lmo_opcode2 
+5c8f 20600000 rtn 
+
+parse_lmp_accepted_inrand:
+5c90 6800c25e fetch 1 ,mem_link_key_exists 
+5c91 247a0000 nrtn blank 
+5c92 20403507 call clear_linkkey 
+5c93 20405ecb call lmp_generate_key 
+5c94 20748000 rtn master 
+5c95 79200021 set1 mark_slave_in_rand_accepted ,mark 
+5c96 20600000 rtn 
+
+parse_lmp_accepted_enc_mode:
+5c97 24748000 nrtn master 
+5c98 70007c10 jam lmp_encryption_key_size_req ,mem_lmo_opcode2 
+5c99 6800804c fetch 1 ,mem_state_map 
+5c9a c4010000 rtnbit0 smap_encryption 
+5c9b 70007c12 jam lmp_stop_encryption_req ,mem_lmo_opcode2 
+5c9c 20600000 rtn 
+
+parse_lmp_accepted_enc_keysize:
+5c9d 20205ecd branch lmp_start_encryption 
+
+parse_lmp_accepted_start_enc:
+5c9e 20405f2d call send_create_conn_start_l2cap_timer_sm 
+5c9f 68008030 fetch 1 ,mem_state 
+5ca0 c3820000 rtnbit1 state_conn_comp 
+5ca1 70007c31 jam lmp_setup_complete ,mem_lmo_opcode2 
+5ca2 68008055 fetch 1 ,mem_conn_sm 
+5ca3 c1850000 rtnne conn_sm_encrypt_wait 
+5ca4 7000550b jam conn_sm_encrypt_wait_clear ,mem_conn_sm 
+5ca5 20600000 rtn 
+
+parse_lmp_accepted_stop_enc:
+5ca6 20600000 rtn 
+
+parse_lmp_not_accepted_aurand:
+5ca7 6800c132 fetch 1 ,mem_device_option 
+5ca8 c080dcb7 bne dvc_op_hci ,parse_lmp_not_accepted_aurand_send_detach 
+5ca9 6800c25e fetch 1 ,mem_link_key_exists 
+5caa 207a0000 rtn blank 
+5cab 68088055 fetcht 1 ,mem_conn_sm 
+5cac 70005500 jam 0 ,mem_conn_sm 
+5cad 70425e00 jam 0 ,mem_link_key_exists 
+5cae 680084e0 fetch 1 ,mem_rxbuf + 2 
+5caf c1830000 rtnne key_missing 
+5cb0 60088055 storet 1 ,mem_conn_sm 
+5cb1 7007e001 jam local_statemachine ,mem_sp_localsm 
+5cb2 6801044a fetch 2 ,mem_lmpext_ssp_enable 
+5cb3 6808844c fetcht 1 ,mem_remote_sppcap 
+5cb4 98417e00 iand temp ,pdata 
+5cb5 203a49da branch cmd_pair ,blank 
+5cb6 202049d7 branch cmd_ssp 
+
+parse_lmp_not_accepted_aurand_send_detach:
+5cb7 70007c07 jam lmp_detach ,mem_lmo_opcode2 
+5cb8 70044613 jam other_end_terminated ,mem_disconn_reason_send 
+5cb9 20600000 rtn 
+
+parse_lmp_not_accepted_inrand:
+5cba 680084e0 fetch 1 ,mem_rxbuf + 2 
+5cbb c0035cc0 beq key_missing ,parse_lmp_inrand_key_missing 
+5cbc c18c0000 rtnne pairing_not_allowed 
+5cbd 70044618 jam pairing_not_allowed ,mem_disconn_reason_send 
+5cbe 70007c07 jam lmp_detach ,mem_lmo_opcode2 
+5cbf 20600000 rtn 
+
+parse_lmp_inrand_key_missing:
+5cc0 70044606 jam key_missing ,mem_disconn_reason_send 
+5cc1 70007c07 jam lmp_detach ,mem_lmo_opcode2 
+5cc2 20600000 rtn 
+
+parse_lmp_not_accepted_name_req:
+5cc3 20600000 rtn 
+
+parse_lmp_not_accepted_simple_pairing_number:
+5cc4 7007da00 jam sp_stat_null ,mem_sp_state 
+5cc5 70007c07 jam lmp_detach ,mem_lmo_opcode2 
+5cc6 20205b77 branch parse_rx_done 
+
+parse_lmp_not_accepted_dhkey_check:
+5cc7 7007da00 jam sp_stat_null ,mem_sp_state 
+5cc8 70007c07 jam lmp_detach ,mem_lmo_opcode2 
+5cc9 20205b77 branch parse_rx_done 
+
+parse_lmp_not_accepted_unsniff_req:
+5cca 700b7d24 jam bt_evt_unsniff_not_accept ,mem_fifo_temp 
+5ccb 20207c27 branch ui_ipc_send_event 
+
+parse_lmp_accepted_unsniff_req:
+5ccc 700b7d23 jam bt_evt_unsniff_accept ,mem_fifo_temp 
+5ccd 20407c27 call ui_ipc_send_event 
+5cce 20403806 call sniff_exit 
+5ccf 18000400 force 0 ,temp 
+5cd0 20204907 branch hci_send_mode_change 
+
+parse_lmp_accepted_sniff_req:
+5cd1 700b7d22 jam bt_evt_sniff_accept ,mem_fifo_temp 
+5cd2 20407c27 call ui_ipc_send_event 
+5cd3 18000402 force 0x02 ,temp 
+5cd4 20404907 call hci_send_mode_change 
+5cd5 58000000 setarg 0 
+5cd6 60010075 store 2 ,mem_dsniff 
+5cd7 68014280 fetch 2 ,mem_sniff_param_interval 
+5cd8 1fe3fe00 lshift pdata ,pdata 
+5cd9 60010032 store 2 ,mem_tsniff 
+5cda 6800c282 fetch 1 ,mem_sniff_param_attempt 
+5cdb 60008073 store 1 ,mem_sniff_attempt 
+5cdc 6800c284 fetch 1 ,mem_sniff_param_timeout 
+5cdd 60008074 store 1 ,mem_sniff_timeout 
+5cde 202037e1 branch sniff_init 
+
+parse_lmp_not_acdcept_sniff_req:
+5cdf 700b7d21 jam bt_evt_sniff_not_accept ,mem_fifo_temp 
+5ce0 20207c27 branch ui_ipc_send_event 
+
+parse_lmp_crypt_key:
+5ce1 680884df fetcht 1 ,mem_rxbuf + 1 
+5ce2 60088054 storet 1 ,mem_key_size 
+5ce3 20205cf5 branch accept_lmp_msg 
+
+parse_lmp_setup_complete:
+5ce4 6800844d fetch 1 ,mem_lmp_conn_state 
+5ce5 79207e02 set1 received_setup_complete ,pdata 
+5ce6 6000844d store 1 ,mem_lmp_conn_state 
+5ce7 c3818000 rtnbit1 sent_setup_complete 
+5ce8 70007c31 jam lmp_setup_complete ,mem_lmo_opcode2 
+5ce9 20205b77 branch parse_rx_done 
+
+parse_lmp_max_slot:
+5cea 20600000 rtn 
+
+parse_lmp_max_slot_req:
+5ceb 6800c171 fetch 1 ,mem_max_slot 
+5cec 680884df fetcht 1 ,mem_rxbuf + 1 
+5ced 98467c00 isub temp ,null 
+5cee 20215cf5 branch accept_lmp_msg ,positive 
+5cef 70007c04 jam lmp_not_accepted ,mem_lmo_opcode2 
+5cf0 70007e1f jam unspecified_error ,mem_lmo_reason2 
+5cf1 70007d2e jam lmp_max_slot_req ,mem_lmi_opcode2 
+5cf2 20600000 rtn 
+
+parse_lmp_detach:
+5cf3 2040605a call prepare_disconnect 
+5cf4 20205cf5 branch accept_lmp_msg 
+
+accept_lmp_msg:
+5cf5 70007c03 jam lmp_accepted ,mem_lmo_opcode2 
+5cf6 20600000 rtn 
+
+parse_lmp_incr_power:
+5cf7 70007c21 jam lmp_max_power ,mem_lmo_opcode2 
+5cf8 20600000 rtn 
+
+parse_lmp_decr_power:
+5cf9 70007c22 jam lmp_min_power ,mem_lmo_opcode2 
+5cfa 20600000 rtn 
+
+parse_lmp_version_res:
+5cfb 68008055 fetch 1 ,mem_conn_sm 
+5cfc c1098000 rtneq conn_sm_wait_version 
+5cfd 70005502 jam conn_sm_send_features ,mem_conn_sm 
+5cfe 20600000 rtn 
+
+parse_lmp_auto_rate:
+5cff 20600000 rtn 
+
+parse_lmp_in_rand:
+5d00 20405ec8 call lmp_copy_rand 
+5d01 70045001 jam pincode_state_wait_pincode ,mem_pincode_state 
+5d02 6800c132 fetch 1 ,mem_device_option 
+5d03 c000dd06 beq dvc_op_hci ,parse_lmp_in_rand_hci 
+5d04 700b7d0a jam bt_evt_pincode_req ,mem_fifo_temp 
+5d05 20407c27 call ui_ipc_send_event 
+
+parse_lmp_in_rand_hci:
+5d06 2040487b call hci_send_pincode_req 
+5d07 2040620d call tid_check 
+5d08 2420ded0 nbranch lmp_accept_inrand ,true 
+5d09 2434dd0e nbranch parse_lmp_inrand_res ,master 
+5d0a 70007c04 jam lmp_not_accepted ,mem_lmo_opcode2 
+5d0b 70007d08 jam lmp_in_rand ,mem_lmi_opcode2 
+5d0c 70007e23 jam transaction_collision ,mem_lmo_reason2 
+5d0d 20600000 rtn 
+
+parse_lmp_inrand_res:
+5d0e 6800804b fetch 1 ,mem_op 
+5d0f 79207e02 set1 op_inrand_req ,pdata 
+5d10 6000804b store 1 ,mem_op 
+5d11 20600000 rtn 
+
+pop_tid_follow:
+5d12 6808804c fetcht 1 ,mem_state_map 
+5d13 7d3a0401 nsetflag blank ,smap_lmptid ,temp 
+5d14 6008804c storet 1 ,mem_state_map 
+5d15 20600000 rtn 
+
+push_tid_follow:
+5d16 6800807f fetch 1 ,mem_lmo_tid2 
+5d17 1fe37e00 rshift pdata ,pdata 
+5d18 1fe17e01 and_into 1 ,pdata 
+5d19 20600000 rtn 
+
+parse_lmp_au_rand:
+5d1a 20405d16 call push_tid_follow 
+5d1b 60008451 store 1 ,mem_sres_tid 
+5d1c 20405ec8 call lmp_copy_rand 
+5d1d 70007c0c jam lmp_sres ,mem_lmo_opcode2 
+5d1e 6800c25e fetch 1 ,mem_link_key_exists 
+5d1f 247a0000 nrtn blank 
+5d20 68008030 fetch 1 ,mem_state 
+5d21 c3830000 rtnbit1 state_combkey 
+5d22 70007e06 jam key_missing ,mem_lmo_reason2 
+5d23 6800c132 fetch 1 ,mem_device_option 
+5d24 c080dbc9 bne dvc_op_hci ,reject_lmp_packet 
+5d25 68008453 fetch 1 ,mem_auth_enable 
+5d26 243a5bc9 nbranch reject_lmp_packet ,blank 
+5d27 70007c00 jam 0 ,mem_lmo_opcode2 
+
+parse_lmp_inrand_sres:
+5d28 6800804b fetch 1 ,mem_op 
+5d29 79207e00 set1 op_send_sres ,pdata 
+5d2a 6000804b store 1 ,mem_op 
+5d2b 20204872 branch hci_send_linkkey_req 
+
+parse_lmp_sres:
+5d2c da200040 arg mem_plap ,rega 
+5d2d 2040739d call function_e1 
+5d2e 680204df fetch 4 ,mem_rxbuf + 1 
+5d2f 680a051f fetcht 4 ,mem_input_store 
+5d30 98467c00 isub temp ,null 
+5d31 2022dd35 branch authentication_ok ,zero 
+5d32 70007c07 jam lmp_detach ,mem_lmo_opcode2 
+5d33 70044605 jam authentication_failure_error ,mem_disconn_reason_send 
+5d34 20600000 rtn 
+
+authentication_ok:
+5d35 2040749b call copy_aco 
+5d36 20403211 call linkkey_ready 
+5d37 6800804b fetch 1 ,mem_op 
+5d38 2feffe01 isolate1 op_auth_req ,pdata 
+5d39 793ffe01 set0 op_auth_req ,pdata 
+5d3a 6000804b store 1 ,mem_op 
+5d3b 2040c8bc call hci_send_auth_complete ,true 
+5d3c 68008055 fetch 1 ,mem_conn_sm 
+5d3d c00cdd40 beq conn_sm_auth_wait ,authentication_ok_conn_sm 
+5d3e c00c5d40 beq conn_sm_pairing_wait ,authentication_ok_conn_sm 
+5d3f 20600000 rtn 
+
+authentication_ok_conn_sm:
+5d40 680087e1 fetch 1 ,mem_pairing_auth 
+5d41 c1800000 rtnne defalt_pairing_auth 
+5d42 6800804c fetch 1 ,mem_state_map 
+5d43 c3810000 rtnbit1 smap_encryption 
+5d44 202062cf branch host_create_conn_encrypt 
+
+parse_lmp_comb_key:
+5d45 da2004df arg mem_rxbuf + 1 ,rega 
+5d46 da40050f arg mem_kinit ,regb 
+5d47 d8a004ef arg mem_random_number ,contw 
+5d48 20407467 call xor16 
+5d49 da200040 arg mem_plap ,rega 
+5d4a 2040622b call generate_linkkey 
+5d4b 70007c0b jam lmp_au_rand ,mem_lmo_opcode2 
+5d4c 68008030 fetch 1 ,mem_state 
+5d4d c3035ecb bbit0 state_combkey ,lmp_generate_key 
+5d4e 20600000 rtn 
+
+parse_lmp_name_res:
+5d4f 68010169 fetch 2 ,mem_len 
+5d50 1fe0f3fd add pdata ,-3 ,loopcnt 
+5d51 680884df fetcht 1 ,mem_rxbuf + 1 
+5d52 58000103 setarg mem_tmp_buffer 
+5d53 98408a00 iadd temp ,contw 
+5d54 d8c004e1 arg mem_rxbuf + 3 ,contr 
+5d55 20407e45 call memcpy 
+5d56 68088053 fetcht 1 ,mem_name_offset 
+5d57 680084e0 fetch 1 ,mem_rxbuf + 2 
+5d58 98467e00 isub temp ,pdata 
+5d59 1fe67c0e sub pdata ,14 ,null 
+5d5a 20215d5f branch parse_lmp_name_res_end ,positive 
+5d5b 1840fe0e add temp ,14 ,pdata 
+5d5c 60008053 store 1 ,mem_name_offset 
+5d5d 70007c01 jam lmp_name_req ,mem_lmo_opcode2 
+5d5e 20600000 rtn 
+
+parse_lmp_name_res_end:
+5d5f 6800804c fetch 1 ,mem_state_map 
+5d60 79207e03 set1 smap_name_res ,pdata 
+5d61 6000804c store 1 ,mem_state_map 
+5d62 c2825ed5 bbit1 smap_name_req ,lmp_disconnect 
+5d63 20600000 rtn 
+
+parse_lmp_name_req:
+5d64 680084df fetch 1 ,mem_rxbuf + 1 
+5d65 6000807d store 1 ,mem_lmi_opcode2 
+5d66 70007c02 jam lmp_name_res ,mem_lmo_opcode2 
+5d67 20600000 rtn 
+
+parse_lmp_conn_req:
+5d68 6800c132 fetch 1 ,mem_device_option 
+5d69 c080dcf5 bne dvc_op_hci ,accept_lmp_msg 
+5d6a 18000401 force 1 ,temp 
+5d6b 20204839 branch hci_send_conn_req_event 
+
+parse_lmp_timing_accuracy_req:
+5d6c 70007c30 jam lmp_timing_accuracy_res ,mem_lmo_opcode2 
+5d6d 20600000 rtn 
+
+parse_lmp_features_req:
+5d6e 70007c28 jam lmp_features_res ,mem_lmo_opcode2 
+5d6f 20600000 rtn 
+
+parse_lmp_version_req:
+5d70 70007c26 jam lmp_version_res ,mem_lmo_opcode2 
+5d71 20600000 rtn 
+
+parse_lmp_supervision_timeout:
+5d72 20600000 rtn 
+
+parse_lmp_sniff_subrating_req:
+5d73 68010032 fetch 2 ,mem_tsniff 
+5d74 98000400 iforce temp 
+5d75 680084e0 fetch 1 ,mem_rxbuf + 2 
+5d76 60008097 store 1 ,mem_subsniff_rate 
+5d77 984f8400 imul32 temp ,temp 
+5d78 680104e1 fetch 2 ,mem_rxbuf + 3 
+5d79 1fe3fe00 lshift pdata ,pdata 
+5d7a 60010098 store 2 ,mem_subsniff_tcmax 
+5d7b 680204e3 fetch 4 ,mem_rxbuf + 5 
+5d7c 1fe3fe00 lshift pdata ,pdata 
+5d7d 60020093 store 4 ,mem_subsniff_instant 
+5d7e 18427e00 deposit temp 
+5d7f 6001009a store 2 ,mem_subsniff_tsniff 
+5d80 20600000 rtn 
+
+parse_lmpext_packet_type_table_req:
+5d81 6808c1fb fetcht 1 ,mem_ptt 
+5d82 680084e0 fetch 1 ,mem_rxbuf + 2 
+5d83 9842fc00 ixor temp ,null 
+5d84 2422dbee nbranch reject_unknown_ext_packet ,zero 
+5d85 2feffe00 isolate1 0 ,pdata 
+5d86 6800804c fetch 1 ,mem_state_map 
+5d87 7920fe05 setflag true ,smap_edr ,pdata 
+5d88 6000804c store 1 ,mem_state_map 
+5d89 70007c81 jam lmp_ext_accepted ,mem_lmo_opcode2 
+5d8a 70007d8b jam lmp_packet_type_table_req ,mem_lmi_opcode2 
+5d8b 20600000 rtn 
+
+parse_lmp_sniff_subrating_res:
+5d8c 20600000 rtn 
+
+parse_lmp_max_power:
+5d8d 20600000 rtn 
+
+parse_lmp_min_power:
+5d8e 20600000 rtn 
+
+parse_lmp_page_mode_req:
+5d8f 20205cf5 branch accept_lmp_msg 
+
+parse_lmp_page_scan_mode_req:
+5d90 20205cf5 branch accept_lmp_msg 
+
+parse_lmp_preferred_rate:
+5d91 20600000 rtn 
+
+parse_lmp_remove_sco_link_req:
+5d92 2040385e call stop_sco 
+5d93 70007d2c jam lmp_remove_sco_link_req ,mem_lmi_opcode2 
+5d94 20205cf5 branch accept_lmp_msg 
+
+parse_lmp_sco_link_req:
+5d95 680084df fetch 1 ,mem_rxbuf + 1 
+5d96 600080ad store 1 ,mem_sco_handle 
+5d97 680084e1 fetch 1 ,mem_rxbuf + 3 
+5d98 600080af store 1 ,mem_esco_desco 
+5d99 680084e4 fetch 1 ,mem_rxbuf + 6 
+5d9a 600080ab store 1 ,mem_air_mode 
+5d9b 20405d16 call push_tid_follow 
+5d9c 60008452 store 1 ,mem_accptsco_tid 
+5d9d 18000400 force 0 ,temp 
+5d9e 20204839 branch hci_send_conn_req_event 
+
+parse_lmp_slot_offset:
+5d9f 680104df fetch 2 ,mem_rxbuf + 1 
+5da0 6001017b store 2 ,mem_slot_offset 
+5da1 20600000 rtn 
+
+parse_lmp_sniff_req:
+5da2 68008030 fetch 1 ,mem_state 
+5da3 c280ddb5 bbit1 state_insniff ,lmp_reject_sniff 
+5da4 680104e0 fetch 2 ,mem_rxbuf + 2 
+5da5 1fe3fe00 lshift pdata ,pdata 
+5da6 60010075 store 2 ,mem_dsniff 
+5da7 680104e2 fetch 2 ,mem_rxbuf + 4 
+5da8 1fe3fe00 lshift pdata ,pdata 
+5da9 60010032 store 2 ,mem_tsniff 
+5daa 680104e4 fetch 2 ,mem_rxbuf + 6 
+5dab 60008073 store 1 ,mem_sniff_attempt 
+5dac 98000400 iforce temp 
+5dad 680104e6 fetch 2 ,mem_rxbuf + 8 
+5dae 60008074 store 1 ,mem_sniff_timeout 
+5daf 98467c00 isub temp ,null 
+5db0 24215db2 nbranch set_big_value_to_attempt ,positive 
+5db1 60008073 store 1 ,mem_sniff_attempt 
+
+set_big_value_to_attempt:
+5db2 70007c03 jam lmp_accepted ,mem_lmo_opcode2 
+5db3 70007d17 jam lmp_sniff_req ,mem_lmi_opcode2 
+5db4 20600000 rtn 
+
+lmp_reject_sniff:
+5db5 70007e24 jam pdu_not_allowed ,mem_lmo_reason2 
+5db6 20205bc9 branch reject_lmp_packet 
+
+parse_lmp_start_encryption_req:
+5db7 20405cf5 call accept_lmp_msg 
+5db8 20405ec8 call lmp_copy_rand 
+5db9 204073a0 call function_e3 
+5dba 202037d0 branch start_encryption 
+
+parse_lmp_stop_encryption_req:
+5dbb 20405cf5 call accept_lmp_msg 
+5dbc 202037da branch stop_encryption 
+
+parse_lmp_switch_req:
+5dbd 680204df fetch 4 ,mem_rxbuf + 1 
+5dbe 1fe3fe00 lshift pdata ,pdata 
+5dbf 2034ddc9 branch parse_lmp_switch_accept ,master 
+5dc0 6808c25e fetcht 1 ,mem_link_key_exists 
+5dc1 243a5dc6 nbranch parse_lmp_switch_req_clear_mark ,blank 
+
+parse_lmp_switch_req_not_accept:
+5dc2 70007c04 jam lmp_not_accepted ,mem_lmo_opcode2 
+5dc3 70007d13 jam lmp_switch_req ,mem_lmi_opcode2 
+5dc4 70007e24 jam pdu_not_allowed ,mem_lmo_reason2 
+5dc5 20600000 rtn 
+
+parse_lmp_switch_req_clear_mark:
+5dc6 70007c34 jam lmp_slot_offset ,mem_lmo_opcode2 
+5dc7 70005500 jam 0 ,mem_conn_sm 
+5dc8 20203241 branch role_switch_prepare 
+
+parse_lmp_switch_accept:
+5dc9 20403241 call role_switch_prepare 
+5dca 79200022 set1 mark_reconn_recieve_switch ,mark 
+5dcb 68008177 fetch 1 ,mem_connection_options 
+5dcc 793ffe02 set0 connection_switch ,pdata 
+5dcd 60008177 store 1 ,mem_connection_options 
+5dce 20205cf5 branch accept_lmp_msg 
+
+parse_lmp_temp_rand:
+5dcf 20600000 rtn 
+
+parse_lmp_temp_key:
+5dd0 20600000 rtn 
+
+parse_lmp_timing_accuracy_res:
+5dd1 20600000 rtn 
+
+parse_lmp_unit_key:
+5dd2 20600000 rtn 
+
+parse_lmp_unsniff_req:
+5dd3 70007c03 jam lmp_accepted ,mem_lmo_opcode2 
+5dd4 70007d18 jam lmp_unsniff_req ,mem_lmi_opcode2 
+5dd5 700b7d2e jam bt_evt_remote_unsniff ,mem_fifo_temp 
+5dd6 20407c27 call ui_ipc_send_event 
+5dd7 18000400 force 0 ,temp 
+5dd8 20404907 call hci_send_mode_change 
+5dd9 20203806 branch sniff_exit 
+
+parse_lmp_use_semi_permanend_key:
+5dda 20600000 rtn 
+
+parse_lmp_encapsulated_header:
+5ddb 680084df fetch 1 ,mem_rxbuf + 1 
+5ddc c080dde7 bne encapsulated_major_type_p192 ,parse_lmp_encapsulated_header_reject 
+5ddd 680084e0 fetch 1 ,mem_rxbuf + 2 
+5dde c080dde7 bne encapsulated_minor_type_p192 ,parse_lmp_encapsulated_header_reject 
+5ddf 680084e1 fetch 1 ,mem_rxbuf + 3 
+5de0 c0985de7 bne encapsulated_len_p192 ,parse_lmp_encapsulated_header_reject 
+5de1 20406216 call check_localsm 
+5de2 2020dde4 branch parse_lmp_encapsulated_header_master ,true 
+5de3 7007da01 jam sp_stat_key_recv ,mem_sp_state 
+
+parse_lmp_encapsulated_header_master:
+5de4 70007c03 jam lmp_accepted ,mem_lmo_opcode2 
+5de5 70007d3d jam lmp_encapsulated_header ,mem_lmi_opcode2 
+5de6 20205b77 branch parse_rx_done 
+
+parse_lmp_encapsulated_header_reject:
+5de7 70007e24 jam pdu_not_allowed ,mem_lmo_reason2 
+5de8 20205bc9 branch reject_lmp_packet 
+
+parse_lmp_accepted_encapsulated_header:
+5de9 70007c3e jam lmp_encapsulated_payload ,mem_lmo_opcode2 
+5dea 20600000 rtn 
+
+parse_lmp_accepted_simple_pairing_number:
+5deb 20406216 call check_localsm 
+5dec 20608000 rtn true 
+5ded 7007da08 jam sp_stat_confirm_recv ,mem_sp_state 
+5dee 20600000 rtn 
+
+parse_lmp_accepted_dhkey_check:
+5def 20406216 call check_localsm 
+5df0 2440fa9d ncall g_noninit ,true 
+5df1 2040faab call g_init ,true 
+5df2 20404860 call hci_send_user_confirmation_req 
+5df3 20404869 call hci_send_ssp_complete 
+5df4 20406216 call check_localsm 
+5df5 20608000 rtn true 
+5df6 7007da0c jam sp_stat_link_key_calc ,mem_sp_state 
+5df7 7007dc01 jam sp_flag_commit ,mem_sp_flag 
+5df8 20600000 rtn 
+
+parse_simple_pairing_confirm:
+5df9 d8a00888 arg mem_sp_confirm_remote ,contw 
+5dfa 680404df fetch 8 ,mem_rxbuf + 1 
+5dfb e0a40000 istore 8 ,contw 
+5dfc 680404e7 fetch 8 ,mem_rxbuf + 9 
+5dfd e0a40000 istore 8 ,contw 
+5dfe 2020780f branch master_set_mem_master_sp_flag 
+
+parse_lmp_encapsulated_payload:
+5dff 680087db fetch 1 ,mem_master_sp_state 
+5e00 c003de03 beq sp_stat_random_send ,parse_encapsulated_payload_master 
+5e01 680087da fetch 1 ,mem_sp_state 
+5e02 c080de16 bne sp_stat_key_recv ,parse_lmp_encapsulated_payload_reject 
+
+parse_encapsulated_payload_master:
+5e03 680087e3 fetch 1 ,mem_sp_remote_key_recv_count 
+5e04 1fe60a20 sub pdata ,0x20 ,contw 
+5e05 24215e16 nbranch parse_lmp_encapsulated_payload_reject ,positive 
+5e06 d8a007f0 arg mem_sp_pubkey_remote ,contw 
+5e07 98a08a00 iadd contw ,contw 
+5e08 680404df fetch 8 ,mem_rxbuf + 1 
+5e09 e0a40000 istore 8 ,contw 
+5e0a 680404e7 fetch 8 ,mem_rxbuf + 9 
+5e0b e0a40000 istore 8 ,contw 
+5e0c 680087e3 fetch 1 ,mem_sp_remote_key_recv_count 
+5e0d 1fe0fe10 increase 16 ,pdata 
+5e0e 600087e3 store 1 ,mem_sp_remote_key_recv_count 
+5e0f c0985cf5 bne encapsulated_len_p192 ,accept_lmp_msg 
+
+parse_lmp_encapsulated_payload_completed:
+5e10 20406216 call check_localsm 
+5e11 2020dcf5 branch accept_lmp_msg ,true 
+5e12 7007e401 jam sp_key_valid ,mem_sp_remote_key_invalid 
+5e13 7007da02 jam sp_stat_key_generate ,mem_sp_state 
+5e14 7007dc01 jam sp_flag_commit ,mem_sp_flag 
+5e15 20205cf5 branch accept_lmp_msg 
+
+parse_lmp_encapsulated_payload_reject:
+5e16 70007e24 jam pdu_not_allowed ,mem_lmo_reason2 
+5e17 20205bc9 branch reject_lmp_packet 
+
+parse_lmp_accepted_encapsulated_payload:
+5e18 680087e2 fetch 1 ,mem_sp_local_key_send_count 
+5e19 c0185e1c beq encapsulated_len_p192 ,parse_lmp_encapsulated_payload_all_accepted 
+5e1a 70007c3e jam lmp_encapsulated_payload ,mem_lmo_opcode2 
+5e1b 20205b77 branch parse_rx_done 
+
+parse_lmp_encapsulated_payload_all_accepted:
+5e1c 20406216 call check_localsm 
+5e1d 2020de21 branch parse_lmp_encapsulated_payload_all_accepted_master ,true 
+5e1e 7007dc01 jam sp_flag_commit ,mem_sp_flag 
+5e1f 7007da04 jam sp_stat_commit_calc ,mem_sp_state 
+5e20 20205b77 branch parse_rx_done 
+
+parse_lmp_encapsulated_payload_all_accepted_master:
+5e21 20205b77 branch parse_rx_done 
+
+parse_lmp_simple_pairing_number:
+5e22 680087db fetch 1 ,mem_master_sp_state 
+5e23 c003de26 beq sp_stat_random_send ,parse_lmp_simple_pairing_number_master 
+5e24 680087da fetch 1 ,mem_sp_state 
+5e25 c0835e32 bne sp_stat_random_recv ,parse_lmp_simple_pairing_number_reject 
+
+parse_lmp_simple_pairing_number_master:
+5e26 d8a00848 arg mem_sp_random_remote ,contw 
+5e27 680404df fetch 8 ,mem_rxbuf + 1 
+5e28 e0a40000 istore 8 ,contw 
+5e29 680404e7 fetch 8 ,mem_rxbuf + 9 
+5e2a e0a40000 istore 8 ,contw 
+5e2b 20406216 call check_localsm 
+5e2c 2020de30 branch parse_lmp_simple_pairing_number_master0 ,true 
+5e2d 7007da07 jam sp_stat_random_send ,mem_sp_state 
+5e2e 7007dc01 jam sp_flag_commit ,mem_sp_flag 
+5e2f 20205cf5 branch accept_lmp_msg 
+
+parse_lmp_simple_pairing_number_master0:
+5e30 7007db04 jam sp_stat_commit_calc ,mem_master_sp_state 
+5e31 2020780f branch master_set_mem_master_sp_flag 
+
+parse_lmp_simple_pairing_number_reject:
+5e32 70007e24 jam pdu_not_allowed ,mem_lmo_reason2 
+5e33 20205bc9 branch reject_lmp_packet 
+
+parse_dhkey_check:
+5e34 680087db fetch 1 ,mem_master_sp_state 
+5e35 c005de38 beq sp_stat_confirm_send ,parse_dhkey_check_master 
+5e36 680087da fetch 1 ,mem_sp_state 
+5e37 c0845e45 bne sp_stat_confirm_recv ,parse_lmp_dhkey_check_reject 
+
+parse_dhkey_check_master:
+5e38 d8a00878 arg mem_sp_check_result ,contw 
+5e39 680404df fetch 8 ,mem_rxbuf + 1 
+5e3a e0a40000 istore 8 ,contw 
+5e3b 680404e7 fetch 8 ,mem_rxbuf + 9 
+5e3c e0a40000 istore 8 ,contw 
+5e3d 20406216 call check_localsm 
+5e3e 2020de42 branch parse_dhkey_check_master0 ,true 
+5e3f 7007da09 jam sp_stat_confirm_check ,mem_sp_state 
+5e40 7007dc01 jam sp_flag_commit ,mem_sp_flag 
+5e41 20205b77 branch parse_rx_done 
+
+parse_dhkey_check_master0:
+5e42 7007db09 jam sp_stat_confirm_check ,mem_master_sp_state 
+5e43 7007dd01 jam sp_flag_commit ,mem_master_sp_flag 
+5e44 20205b77 branch parse_rx_done 
+
+parse_lmp_dhkey_check_reject:
+5e45 70007e24 jam pdu_not_allowed ,mem_lmo_reason2 
+5e46 20205bc9 branch reject_lmp_packet 
+
+parse_lmp_clkoffset_res:
+5e47 20205b77 branch parse_rx_done 
+
+parse_lmp_encryption_mode_req:
+5e48 68008177 fetch 1 ,mem_connection_options 
+5e49 793ffe01 set0 connection_encrypt 
+5e4a 60008177 store 1 ,mem_connection_options 
+5e4b 20405cf5 call accept_lmp_msg 
+5e4c 24748000 nrtn master 
+5e4d 680084df fetch 1 ,mem_rxbuf + 1 
+5e4e 6808804b fetcht 1 ,mem_op 
+5e4f 793a0404 setflag blank ,op_stop_enc ,temp 
+5e50 7d3a0405 nsetflag blank ,op_start_enc ,temp 
+5e51 6008804b storet 1 ,mem_op 
+5e52 20600000 rtn 
+
+parse_lmp_features_res:
+5e53 680c04df fetcht 8 ,mem_rxbuf + 1 
+5e54 6800c272 fetch 1 ,mem_hci_cmd 
+5e55 c0a85e58 bne hci_cmd_wait_remote_feature ,parse_lmp_features_res_not_hci 
+5e56 70427200 jam 0 ,mem_hci_cmd 
+5e57 204047e5 call hci_send_remote_features 
+
+parse_lmp_features_res_not_hci:
+5e58 68008055 fetch 1 ,mem_conn_sm 
+5e59 c1818000 rtnne conn_sm_wait_features_res 
+5e5a 6800c132 fetch 1 ,mem_device_option 
+5e5b c000de5e beq dvc_op_hci ,parse_lmp_feature_ext_sm 
+5e5c 68008177 fetch 1 ,mem_connection_options 
+5e5d c3025e60 bbit0 connection_feature_ext ,parse_lmp_send_conn 
+
+parse_lmp_feature_ext_sm:
+5e5e 70005514 jam conn_sm_send_features_ext ,mem_conn_sm 
+5e5f 20600000 rtn 
+
+parse_lmp_send_conn:
+5e60 70005504 jam conn_sm_send_conn_req ,mem_conn_sm 
+5e61 20600000 rtn 
+
+parse_lmp_test_activate:
+5e62 68008189 fetch 1 ,mem_debug_config 
+5e63 6000815d store 1 ,mem_test_mode_old_debug_config 
+5e64 70007c03 jam lmp_accepted ,mem_lmo_opcode2 
+5e65 70007d38 jam lmp_test_activate ,mem_lmi_opcode2 
+5e66 20600000 rtn 
+
+parse_lmp_test_control:
+5e67 70007c03 jam lmp_accepted ,mem_lmo_opcode2 
+5e68 70007d39 jam lmp_test_control ,mem_lmi_opcode2 
+5e69 18007209 force 9 ,loopcnt 
+5e6a d8c004df arg mem_rxbuf + 1 ,contr 
+5e6b d8a00154 arg mem_temp_payload ,contw 
+
+parse_lmp_test_xor:
+5e6c e8c08000 ifetch 1 ,contr 
+5e6d 1fe2fe55 xor_into 0x55 ,pdata 
+5e6e e0a08000 istore 1 ,contw 
+5e6f c2005e6c loop parse_lmp_test_xor 
+5e70 68008154 fetch 1 ,test_mode_scenario 
+5e71 68088153 fetcht 1 ,mem_tester_emulate 
+5e72 793f8407 set0 tester_no_whitening ,temp 
+5e73 793f8404 set0 tester_pattern_test ,temp 
+5e74 c07fde80 beq exit_test_mode ,parse_lmp_test_control_exit 
+5e75 c0005e99 beq pause_test_mode ,parse_lmp_test_control_pause 
+5e76 c002de8d beq closed_loop_back_acl ,parse_lmp_test_control_loopback 
+5e77 c003de8c beq acl_without_whitening ,parse_lmp_test_control_loopback_nowhite 
+5e78 c0035e8d beq closed_loop_back_sco ,parse_lmp_test_control_loopback 
+5e79 c0045e8c beq sco_without_whitening ,parse_lmp_test_control_loopback_nowhite 
+5e7a c000de85 beq zero_pattern ,parse_lmp_test_control_pattern 
+5e7b c0015e85 beq one_pattern ,parse_lmp_test_control_pattern 
+5e7c c001de85 beq alt_pattern ,parse_lmp_test_control_pattern 
+5e7d c004de85 beq alt2_pattern ,parse_lmp_test_control_pattern 
+5e7e c0025e85 beq pseudorandom ,parse_lmp_test_control_pattern 
+5e7f 20600000 rtn 
+
+parse_lmp_test_control_exit:
+5e80 68008153 fetch 1 ,mem_tester_emulate 
+5e81 79207e03 set1 tester_exit ,pdata 
+5e82 79207e02 set1 tester_change ,pdata 
+5e83 60008153 store 1 ,mem_tester_emulate 
+5e84 20600000 rtn 
+
+parse_lmp_test_control_pattern:
+5e85 79200404 set1 tester_pattern_test ,temp 
+5e86 70018a05 jam 5 ,mem_lch_code 
+5e87 6801015b fetch 2 ,test_mode_data_length 
+5e88 98007200 iforce loopcnt 
+5e89 60010169 store 2 ,mem_len 
+5e8a d8a004de arg mem_rxbuf ,contw 
+5e8b 20407ed8 call pn9 
+
+parse_lmp_test_control_loopback_nowhite:
+5e8c 79200407 set1 tester_no_whitening ,temp 
+
+parse_lmp_test_control_loopback:
+5e8d 79200402 set1 tester_change ,temp 
+5e8e 18007e00 force 0 ,pdata 
+5e8f 6000800b store 1 ,mem_slave_rcvcnt 
+5e90 600100fc store 2 ,mem_tst_pktcnt_crc 
+5e91 600100fe store 2 ,mem_tst_pktcnt_dmh 
+5e92 600100fa store 2 ,mem_tst_pktcnt_hec 
+5e93 600100f8 store 2 ,mem_tst_pktcnt_sync 
+5e94 68008155 fetch 1 ,test_mode_hopping_mode 
+5e95 2fe1fe00 compare fixed_freq ,pdata ,0xff 
+5e96 79208406 setflag true ,tester_fixed_freq ,temp 
+5e97 60088153 storet 1 ,mem_tester_emulate 
+5e98 20600000 rtn 
+
+parse_lmp_test_control_pause:
+5e99 793f8011 set0 mark_testmode ,mark 
+5e9a 70015300 jam 0 ,mem_tester_emulate 
+5e9b 68008189 fetch 1 ,mem_debug_config 
+5e9c 793ffe06 set0 debug_tx_pattern ,pdata 
+5e9d 60008189 store 1 ,mem_debug_config 
+5e9e 20600000 rtn 
+
+check_test_cond:
+5e9f 68008153 fetch 1 ,mem_tester_emulate 
+5ea0 c4010000 rtnbit0 tester_change 
+5ea1 6800815e fetch 1 ,mem_tester_cnt 
+5ea2 1fe0fe01 increase 1 ,pdata 
+5ea3 6000815e store 1 ,mem_tester_cnt 
+5ea4 c1828000 rtnne 5 
+5ea5 70015e00 jam 0 ,mem_tester_cnt 
+5ea6 68008153 fetch 1 ,mem_tester_emulate 
+5ea7 793ffe02 set0 tester_change ,pdata 
+5ea8 60008153 store 1 ,mem_tester_emulate 
+5ea9 c281dec0 bbit1 tester_exit ,check_test_exit 
+5eaa 2feffe07 isolate1 tester_no_whitening ,pdata 
+5eab 2040ff86 call test_no_white ,true 
+5eac 2440ff8a ncall test_enable_white ,true 
+5ead 6800815a fetch 1 ,test_mode_packet_type 
+5eae 2fe06020 compare 0x20 ,pdata ,0x30 
+5eaf 6800804c fetch 1 ,mem_state_map 
+5eb0 7920fe05 setflag true ,smap_edr ,pdata 
+5eb1 6000804c store 1 ,mem_state_map 
+5eb2 68008153 fetch 1 ,mem_tester_emulate 
+5eb3 68088189 fetcht 1 ,mem_debug_config 
+5eb4 2feffe04 isolate1 tester_pattern_test ,pdata 
+5eb5 79208406 setflag true ,debug_tx_pattern ,temp 
+5eb6 2feffe06 isolate1 tester_fixed_freq ,pdata 
+5eb7 79208404 setflag true ,debug_tx_fixed_freq ,temp 
+5eb8 79208405 setflag true ,debug_rx_fixed_freq ,temp 
+5eb9 60088189 storet 1 ,mem_debug_config 
+5eba 68008156 fetch 1 ,test_mode_tx_freq 
+5ebb 60008447 store 1 ,mem_tx_fixed_freq 
+5ebc 68008157 fetch 1 ,test_mode_rx_freq 
+5ebd 60008448 store 1 ,mem_rx_fixed_freq 
+5ebe 79200011 set1 mark_testmode ,mark 
+5ebf 20600000 rtn 
+
+check_test_exit:
+5ec0 793f8011 set0 mark_testmode ,mark 
+5ec1 70015300 jam 0 ,mem_tester_emulate 
+5ec2 6800815d fetch 1 ,mem_test_mode_old_debug_config 
+5ec3 60008189 store 1 ,mem_debug_config 
+5ec4 68108043 hfetch 1 ,core_config 
+5ec5 1fe17efb and_into 0xfb ,pdata 
+5ec6 60108043 hstore 1 ,core_config 
+5ec7 20600000 rtn 
+
+lmp_copy_rand:
+5ec8 d8c004df arg mem_rxbuf + 1 ,contr 
+5ec9 d8a004ef arg mem_random_number ,contw 
+5eca 20207e35 branch memcpy16 
+
+lmp_generate_key:
+5ecb 70007c09 jam lmp_comb_key ,mem_lmo_opcode2 
+5ecc 20600000 rtn 
+
+lmp_start_encryption:
+5ecd 24748000 nrtn master 
+5ece 70007c11 jam lmp_start_encryption_req ,mem_lmo_opcode2 
+5ecf 20600000 rtn 
+
+lmp_accept_inrand:
+5ed0 da204140 arg mem_lap ,rega 
+5ed1 2040736a call generate_kinit 
+5ed2 70007c03 jam lmp_accepted ,mem_lmo_opcode2 
+5ed3 70007d08 jam lmp_in_rand ,mem_lmi_opcode2 
+5ed4 20600000 rtn 
+
+lmp_disconnect:
+5ed5 7000720a jam 10 ,mem_conn_timer 
+5ed6 70007c07 jam lmp_detach ,mem_lmo_opcode2 
+5ed7 70044616 jam local_host ,mem_disconn_reason_send 
+5ed8 20600000 rtn 
+
+send_lmp:
+5ed9 79200025 set1 mark_ext_patch ,mark 
+5eda 44f1c03c bpatch patch3c_3 ,mem_patch3c 
+5edb 78547c00 disable user 
+5edc 204061d9 call lmo_fifo_process 
+5edd 68008048 fetch 1 ,mem_lmp_to_send 
+5ede 207a0000 rtn blank 
+5edf c283df10 bbit1 7 ,send_lmp_escape 
+5ee0 c000e072 beq lmp_name_req ,send_lmp_name_req 
+5ee1 c0015f9b beq lmp_name_res ,send_lmp_name_res 
+5ee2 c001df1d beq lmp_accepted ,send_lmp_accepted 
+5ee3 c0025f36 beq lmp_not_accepted ,send_lmp_not_accepted 
+5ee4 c013e0f2 beq lmp_features_req ,send_lmp_features_req 
+5ee5 c0145fbf beq lmp_features_res ,send_lmp_features_res 
+5ee6 c0185fab beq lmp_timing_accuracy_res ,send_lmp_timing_accuracy_res 
+5ee7 c012e0ed beq lmp_version_req ,send_lmp_version_req 
+5ee8 c0135fba beq lmp_version_res ,send_lmp_version_res 
+5ee9 c018e0dc beq lmp_setup_complete ,send_lmp_setup_complete 
+5eea c01be06d beq lmp_supervision_timeout ,send_lmp_superto 
+5eeb c019e05f beq lmp_host_connection_req ,send_lmp_no_payload 
+5eec c0046174 beq lmp_in_rand ,send_lmp_inrand 
+5eed c004e16a beq lmp_comb_key ,send_lmp_comb_key 
+5eee c005e17f beq lmp_au_rand ,send_lmp_aurand 
+5eef c0066188 beq lmp_sres ,send_lmp_sres 
+5ef0 c007e065 beq lmp_encryption_mode_req ,send_lmp_encryption_mode_req 
+5ef1 c00861af beq lmp_encryption_key_size_req ,send_lmp_encryption_key_size_req 
+5ef2 c008e1a5 beq lmp_start_encryption_req ,send_lmp_start_encryption 
+5ef3 c003e055 beq lmp_detach ,send_lmp_detach 
+5ef4 c0156081 beq lmp_quality_of_service_req ,send_lmp_quality_of_service_req 
+5ef5 c0056082 beq lmp_unit_key ,send_lmp_unit_key 
+5ef6 c015e0b5 beq lmp_sco_link_req ,send_lmp_sco_link_req 
+5ef7 c0035fb0 beq lmp_clkoffset_res ,send_lmp_clkoffset_res 
+5ef8 c010e062 beq lmp_max_power ,send_lmp_nopayload_reply 
+5ef9 c016e0d2 beq lmp_max_slot ,send_lmp_max_slot 
+5efa c01760d7 beq lmp_max_slot_req ,send_lmp_max_slot_req 
+5efb c0116062 beq lmp_min_power ,send_lmp_nopayload_reply 
+5efc c01660cb beq lmp_remove_sco_link_req ,send_lmp_remove_sco_link_req 
+5efd c01a6083 beq lmp_slot_offset ,send_lmp_slot_offset 
+5efe c009e098 beq lmp_switch_req ,send_lmp_switch_req 
+5eff c00be0a7 beq lmp_sniff_req ,send_lmp_sniff_req 
+5f00 c00961ac beq lmp_stop_encryption_req ,send_lmp_stop_encryption_req 
+5f01 c017e0ad beq lmp_timing_accuracy_req ,send_lmp_timing_accuracy_req 
+5f02 c00c60b2 beq lmp_unsniff_req ,send_lmp_unsniff_req 
+5f03 c01ee119 beq lmp_encapsulated_header ,send_lmp_encapsulated_header 
+5f04 c01f6125 beq lmp_encapsulated_payload ,send_lmp_encapsulated_payload 
+5f05 c01fe137 beq lmp_simple_pairing_confirm ,send_lmp_simple_pairing_comfirm 
+5f06 c0206142 beq lmp_simple_pairing_number ,send_lmp_simple_pairing_number 
+5f07 c020e157 beq lmp_dhkey_check ,send_lmp_dhkey_check 
+5f08 c011e166 beq lmp_auto_rate ,send_lmp_auto_rate 
+5f09 c01de161 beq lmp_enc_key_size_mask_res ,send_lmp_enc_key_size_mask_res 
+5f0a c002e167 beq lmp_clkoffset_req ,send_lmp_clkoffset_req 
+5f0b c014e168 beq lmp_quality_of_service ,send_lmp_quality_of_service 
+5f0c c01c6169 beq lmp_test_activate ,send_lmp_test_activate 
+5f0d c01ce078 beq lmp_test_control ,send_lmp_test_control 
+
+send_lmp_error:
+5f0e 20203bf1 branch assert 
+5f0f 20600000 rtn 
+
+send_lmp_escape:
+5f10 c0465fc4 beq lmp_ext_esco_link_req ,send_lmpext_esco_req 
+5f11 c046dfe3 beq lmp_ext_remove_esco_req ,send_lmpext_remove_esco 
+5f12 c040df43 beq lmp_ext_accepted ,send_lmpext_accepted 
+5f13 c0425f76 beq lmp_ext_features_res ,send_lmpext_features_res 
+5f14 c0415f50 beq lmp_not_accepted_ext ,send_lmpext_not_accepted 
+5f15 c041dfec beq lmp_ext_features_req ,send_lmpext_features_req 
+5f16 c045dff7 beq lmp_packet_type_table_req ,send_lmpext_packet_type_table_req 
+5f17 c04be051 beq lmp_pause_encryption_req ,send_lmpext_pause_encryption_req 
+5f18 c04cdf8c beq lmp_io_cap_req ,send_lmp_io_cap_req 
+5f19 c04d5f81 beq lmp_io_cap_res ,send_lmpext_io_cap_res 
+5f1a c04adf91 beq lmp_sniff_subrating_req ,send_lmpext_sniff_subrating_req 
+5f1b c04b5f92 beq lmp_sniff_subrating_res ,send_lmpext_sniff_subrating_res 
+5f1c 20203bf1 branch assert 
+
+send_lmp_accepted:
+5f1d 18007e02 force 2 ,pdata 
+5f1e 204061b5 call msg_send_lmp 
+5f1f 68008049 fetch 1 ,mem_lmi_opcode 
+5f20 e0a08000 istore 1 ,contw 
+5f21 c015df5a beq lmp_sco_link_req ,send_lmp_accptsco 
+5f22 204061c4 call send_lmp_follow 
+5f23 68008049 fetch 1 ,mem_lmi_opcode 
+5f24 c0045f5d beq lmp_in_rand ,send_lmp_accepted_inrand 
+5f25 c007df61 beq lmp_encryption_mode_req ,send_lmp_accepted_enc_mode 
+5f26 c0085f6c beq lmp_encryption_key_size_req ,send_lmp_accepted_enc_key 
+5f27 c00bdf33 beq lmp_sniff_req ,send_lmp_accept_sniff_req 
+5f28 c019df6f beq lmp_host_connection_req ,send_lmp_accepted_connection 
+5f29 c0165f74 beq lmp_remove_sco_link_req ,send_lmp_accept_remove_sco_link_req 
+5f2a c020df75 beq lmp_dhkey_check ,send_lmp_accept_dhkey_check 
+5f2b c008df2d beq lmp_start_encryption_req ,send_create_conn_start_l2cap_timer_sm 
+5f2c 20600000 rtn 
+
+send_create_conn_start_l2cap_timer_sm:
+5f2d 68008055 fetch 1 ,mem_conn_sm 
+5f2e 207a0000 rtn blank 
+5f2f 7000551b jam conn_sm_wait_done ,mem_conn_sm 
+5f30 5800000c setarg timer_enpt_waite 
+5f31 d8e0000b arg enpt_delay_timer ,queue 
+5f32 20207e4c branch timer_init 
+
+send_lmp_accept_sniff_req:
+5f33 18000402 force 0x02 ,temp 
+5f34 20404907 call hci_send_mode_change 
+5f35 202037e1 branch sniff_init 
+
+send_lmp_not_accepted:
+5f36 18007e03 force 3 ,pdata 
+5f37 204061b5 call msg_send_lmp 
+5f38 68008049 fetch 1 ,mem_lmi_opcode 
+5f39 c005df3e beq lmp_au_rand ,send_not_accept_aurand 
+5f3a e0a08000 istore 1 ,contw 
+5f3b 6800804a fetch 1 ,mem_lmo_reason 
+5f3c e0a08000 istore 1 ,contw 
+5f3d 202061c4 branch send_lmp_follow 
+
+send_not_accept_aurand:
+5f3e e0a08000 istore 1 ,contw 
+5f3f 6800804a fetch 1 ,mem_lmo_reason 
+5f40 e0a08000 istore 1 ,contw 
+5f41 d8400451 arg mem_sres_tid ,temp 
+5f42 202061fb branch special_tid_store 
+
+send_lmpext_accepted:
+5f43 18000e04 force 4 ,queue 
+5f44 204061bd call send_lmpext 
+5f45 5800007f setarg lmp_escape 
+5f46 e0a08000 istore 1 ,contw 
+5f47 68008049 fetch 1 ,mem_lmi_opcode 
+5f48 793ffe07 set0 7 ,pdata 
+5f49 e0a08000 istore 1 ,contw 
+5f4a 68008049 fetch 1 ,mem_lmi_opcode 
+5f4b c0465f5a beq lmp_ext_esco_link_req ,send_lmp_accptsco 
+5f4c 204061c4 call send_lmp_follow 
+5f4d 68008049 fetch 1 ,mem_lmi_opcode 
+5f4e c046df74 beq lmp_ext_remove_esco_req ,send_lmp_accept_remove_sco_link_req 
+5f4f 20600000 rtn 
+
+send_lmpext_not_accepted:
+5f50 18000e05 force 5 ,queue 
+5f51 204061bd call send_lmpext 
+5f52 5800007f setarg lmp_escape 
+5f53 e0a08000 istore 1 ,contw 
+5f54 68008049 fetch 1 ,mem_lmi_opcode 
+5f55 793ffe07 set0 7 ,pdata 
+5f56 e0a08000 istore 1 ,contw 
+5f57 6800804a fetch 1 ,mem_lmo_reason 
+5f58 e0a08000 istore 1 ,contw 
+5f59 202061c4 branch send_lmp_follow 
+
+send_lmp_accptsco:
+5f5a 2040384a call play_sco 
+5f5b d8400452 arg mem_accptsco_tid ,temp 
+5f5c 202061fb branch special_tid_store 
+
+send_lmp_accepted_inrand:
+5f5d 20403507 call clear_linkkey 
+5f5e 2040620d call tid_check 
+5f5f 20608000 rtn true 
+5f60 20205ecb branch lmp_generate_key 
+
+send_lmp_accepted_enc_mode:
+5f61 6800804b fetch 1 ,mem_op 
+5f62 c282df68 bbit1 op_start_enc ,send_lmp_accepted_enc_start 
+5f63 c4020000 rtnbit0 op_stop_enc 
+5f64 70007c12 jam lmp_stop_encryption_req ,mem_lmo_opcode2 
+5f65 793ffe04 set0 op_stop_enc ,pdata 
+5f66 20406205 call tid_reply 
+5f67 20205f6a branch send_lmp_accepted_enc_exit 
+
+send_lmp_accepted_enc_start:
+5f68 70007c10 jam lmp_encryption_key_size_req ,mem_lmo_opcode2 
+5f69 793ffe05 set0 op_start_enc ,pdata 
+
+send_lmp_accepted_enc_exit:
+5f6a 6000804b store 1 ,mem_op 
+5f6b 20600000 rtn 
+
+send_lmp_accepted_enc_key:
+5f6c 20406216 call check_localsm 
+5f6d 2020decd branch lmp_start_encryption ,true 
+5f6e 20600000 rtn 
+
+send_lmp_accepted_connection:
+5f6f 6800844d fetch 1 ,mem_lmp_conn_state 
+5f70 79207e00 set1 received_conn_req ,pdata 
+5f71 6000844d store 1 ,mem_lmp_conn_state 
+5f72 700b7d01 jam bt_evt_bb_connected ,mem_fifo_temp 
+5f73 20207c27 branch ui_ipc_send_event 
+
+send_lmp_accept_remove_sco_link_req:
+5f74 20600000 rtn 
+
+send_lmp_accept_dhkey_check:
+5f75 20600000 rtn 
+
+send_lmpext_features_res:
+5f76 18000e0c force 12 ,queue 
+5f77 204061bd call send_lmpext 
+5f78 58000001 setarg 0x01 
+5f79 e0a08000 istore 1 ,contw 
+5f7a 6801044a fetch 2 ,mem_lmpext_ssp_enable 
+5f7b e0a10000 istore 2 ,contw 
+5f7c 58000000 setarg 0 
+5f7d e0a18000 istore 3 ,contw 
+5f7e 58000000 setarg 0x00 
+5f7f e0a20000 istore 4 ,contw 
+5f80 202061cd branch send_lmp_reply 
+
+send_lmpext_io_cap_res:
+5f81 18000e05 force 5 ,queue 
+5f82 204061bd call send_lmpext 
+5f83 6800c132 fetch 1 ,mem_device_option 
+5f84 c000df89 beq dvc_op_hci ,send_lmpext_io_cap_res_hci 
+5f85 58040003 setarg 0x040003 
+5f86 e0a18000 istore 3 ,contw 
+5f87 600187e6 store 3 ,mem_sp_iocap_local 
+5f88 202061cd branch send_lmp_reply 
+
+send_lmpext_io_cap_res_hci:
+5f89 680187e6 fetch 3 ,mem_sp_iocap_local 
+5f8a e0a18000 istore 3 ,contw 
+5f8b 202061cd branch send_lmp_reply 
+
+send_lmp_io_cap_req:
+5f8c 18000e05 force 5 ,queue 
+5f8d 204061bd call send_lmpext 
+5f8e 680187e6 fetch 3 ,mem_sp_iocap_local 
+5f8f e0a18000 istore 3 ,contw 
+5f90 202061cf branch send_lmp_request 
+
+send_lmpext_sniff_subrating_req:
+5f91 20600000 rtn 
+
+send_lmpext_sniff_subrating_res:
+5f92 18000e09 force 9 ,queue 
+5f93 204061bd call send_lmpext 
+5f94 68008097 fetch 1 ,mem_subsniff_rate 
+5f95 e0a08000 istore 1 ,contw 
+5f96 68010098 fetch 2 ,mem_subsniff_tcmax 
+5f97 e0a10000 istore 2 ,contw 
+5f98 68020093 fetch 4 ,mem_subsniff_instant 
+5f99 e0a20000 istore 4 ,contw 
+5f9a 202061cd branch send_lmp_reply 
+
+send_lmp_name_res:
+5f9b 18007e11 force 17 ,pdata 
+5f9c 204061b5 call msg_send_lmp 
+5f9d 68008049 fetch 1 ,mem_lmi_opcode 
+5f9e 1fe20400 copy pdata ,temp 
+5f9f c0005fa3 beq 0x00 ,send_lmp_name_res_offset_ok 
+5fa0 c0075fa3 beq 0x0e ,send_lmp_name_res_offset_ok 
+5fa1 c00e5fa3 beq 0x1c ,send_lmp_name_res_offset_ok 
+5fa2 20600000 rtn 
+
+send_lmp_name_res_offset_ok:
+5fa3 e0a08000 istore 1 ,contw 
+5fa4 6800c702 fetch 1 ,mem_local_name_length 
+5fa5 e0a08000 istore 1 ,contw 
+5fa6 1fe27200 copy pdata ,loopcnt 
+5fa7 58004703 setarg mem_local_name 
+5fa8 98408c00 iadd temp ,contr 
+5fa9 20407e45 call memcpy 
+5faa 202061cd branch send_lmp_reply 
+
+send_lmp_timing_accuracy_res:
+5fab 18007e03 force 3 ,pdata 
+5fac 204061b5 call msg_send_lmp 
+5fad 58000114 setarg 0x0114 
+5fae e0a10000 istore 2 ,contw 
+5faf 202061cd branch send_lmp_reply 
+
+send_lmp_clkoffset_res:
+5fb0 18007e03 force 3 ,pdata 
+5fb1 204061b5 call msg_send_lmp 
+5fb2 6802016f fetch 4 ,mem_clke_bt 
+5fb3 9c467e00 isub clkn_bt ,pdata 
+5fb4 2034dfb6 branch send_lmp_clkoffset_res_master ,master 
+5fb5 1fe67e00 sub pdata ,0 ,pdata 
+
+send_lmp_clkoffset_res_master:
+5fb6 1feb7e00 rshift2 pdata ,pdata 
+5fb7 793ffe0f set0 15 ,pdata 
+5fb8 e0a10000 istore 2 ,contw 
+5fb9 202061cd branch send_lmp_reply 
+
+send_lmp_version_res:
+5fba 18007e06 force 6 ,pdata 
+5fbb 204061b5 call msg_send_lmp 
+5fbc 6802c6fd fetch 5 ,mem_lmp_version 
+5fbd e0a28000 istore 5 ,contw 
+5fbe 202061cd branch send_lmp_reply 
+
+send_lmp_features_res:
+5fbf 18007e09 force 9 ,pdata 
+5fc0 204061b5 call msg_send_lmp 
+5fc1 68044138 fetch 8 ,mem_features 
+5fc2 e0a40000 istore 8 ,contw 
+5fc3 202061cd branch send_lmp_reply 
+
+send_lmpext_esco_req:
+5fc4 2034dfc6 branch send_lmpext_esco_req_master ,master 
+5fc5 20205fc7 branch send_lmpext_esco_req_slave 
+
+send_lmpext_esco_req_master:
+5fc6 7041f907 jam 0x07 ,mem_esco_addr 
+
+send_lmpext_esco_req_slave:
+5fc7 7000af00 jam 0 ,mem_esco_desco 
+5fc8 18000e10 force 16 ,queue 
+5fc9 204061bd call send_lmpext 
+5fca 680080ad fetch 1 ,mem_sco_handle 
+5fcb e0a08000 istore 1 ,contw 
+5fcc 6800c1f9 fetch 1 ,mem_esco_addr 
+5fcd e0a08000 istore 1 ,contw 
+5fce 58000000 setarg 0 
+5fcf e0a08000 istore 1 ,contw 
+5fd0 680080af fetch 1 ,mem_esco_desco 
+5fd1 e0a08000 istore 1 ,contw 
+5fd2 58000006 setarg 6 
+5fd3 e0a08000 istore 1 ,contw 
+5fd4 58000002 setarg 2 
+5fd5 e0a08000 istore 1 ,contw 
+5fd6 58000007 setarg 7 
+5fd7 e0a08000 istore 1 ,contw 
+5fd8 e0a08000 istore 1 ,contw 
+5fd9 5800001e setarg 30 
+5fda e0a10000 istore 2 ,contw 
+5fdb e0a10000 istore 2 ,contw 
+5fdc 680080ab fetch 1 ,mem_air_mode 
+5fdd e0a08000 istore 1 ,contw 
+5fde 680080b1 fetch 1 ,mem_neogotiation_state 
+5fdf e0a08000 istore 1 ,contw 
+5fe0 243a61cd nbranch send_lmp_reply ,blank 
+5fe1 2034e1cd branch send_lmp_reply ,master 
+5fe2 202061cf branch send_lmp_request 
+
+send_lmpext_remove_esco:
+5fe3 18000e04 force 4 ,queue 
+5fe4 204061bd call send_lmpext 
+5fe5 680080ad fetch 1 ,mem_sco_handle 
+5fe6 e0a08000 istore 1 ,contw 
+5fe7 68008446 fetch 1 ,mem_disconn_reason_send 
+5fe8 e0a08000 istore 1 ,contw 
+5fe9 680080b4 fetch 1 ,mem_esco_saved_arq 
+5fea 60008047 store 1 ,mem_arq 
+5feb 202061cf branch send_lmp_request 
+
+send_lmpext_features_req:
+5fec 18000e0c force 12 ,queue 
+5fed 204061bd call send_lmpext 
+5fee 58000001 setarg 0x01 
+5fef e0a08000 istore 1 ,contw 
+5ff0 6801044a fetch 2 ,mem_lmpext_ssp_enable 
+5ff1 e0a10000 istore 2 ,contw 
+5ff2 58000000 setarg 0 
+5ff3 e0a18000 istore 3 ,contw 
+5ff4 58000000 setarg 0x00 
+5ff5 e0a20000 istore 4 ,contw 
+5ff6 202061cf branch send_lmp_request 
+
+send_lmpext_packet_type_table_req:
+5ff7 18000e03 force 3 ,queue 
+5ff8 204061bd call send_lmpext 
+5ff9 6800c1fb fetch 1 ,mem_ptt 
+5ffa e0a08000 istore 1 ,contw 
+5ffb 78547c00 disable user 
+5ffc 204061cf call send_lmp_request 
+5ffd 24740000 nrtn user 
+5ffe 24748000 nrtn master 
+5fff 6800c179 fetch 1 ,mem_afh_cfg 
+6000 c4000000 rtnbit0 afh_cfg_on 
+6001 2040600f call afh_init 
+6002 20206019 branch afh_open_all_channels 
+
+ssp_enable:
+6003 6800c13e fetch 1 ,mem_features + 6 
+6004 79207e03 set1 param_featrue_ssp ,pdata 
+6005 6000c13e store 1 ,mem_features + 6 
+6006 58000101 setarg param_lmpext_ssp_enable 
+6007 6001044a store 2 ,mem_lmpext_ssp_enable 
+6008 20600000 rtn 
+
+ssp_disable:
+6009 6800c13e fetch 1 ,mem_features + 6 
+600a 793ffe03 set0 param_featrue_ssp ,pdata 
+600b 6000c13e store 1 ,mem_features + 6 
+600c 58000000 setarg 0 
+600d 6001044a store 2 ,mem_lmpext_ssp_enable 
+600e 20600000 rtn 
+
+afh_init:
+600f 70417903 jam 0x3 ,mem_afh_cfg 
+6010 58000000 setarg 0 
+6011 600241e3 store 4 ,mem_afh_timer 
+6012 d8a0417b arg mem_afh_map_lo ,contw 
+6013 20406023 call afh_reset_map 
+6014 d8a04188 arg mem_afh_map_new ,contw 
+6015 20406023 call afh_reset_map 
+6016 d8a041e7 arg mem_afh_classify_channel_map ,contw 
+6017 20406023 call afh_reset_map 
+6018 2020602a branch afh_clear_error_counter 
+
+afh_open_all_channels:
+6019 d8a04188 arg mem_afh_map_new ,contw 
+601a 20406023 call afh_reset_map 
+601b 2040602a call afh_clear_error_counter 
+601c 2020602d branch afh_set_send_flag 
+
+afh_open_classify_map:
+601d 6802c1e7 fetch 5 ,mem_afh_classify_channel_map 
+601e 6002c188 store 5 ,mem_afh_map_new 
+601f e8c28000 ifetch 5 ,contr 
+6020 e0a28000 istore 5 ,contw 
+6021 2040602a call afh_clear_error_counter 
+6022 2020602d branch afh_set_send_flag 
+
+afh_reset_map:
+6023 58ffffff setarg 0xffffff 
+6024 e0a18000 istore 3 ,contw 
+6025 e0a18000 istore 3 ,contw 
+6026 e0a18000 istore 3 ,contw 
+6027 5800007f setarg 0x7f 
+6028 e0a08000 istore 1 ,contw 
+6029 20600000 rtn 
+
+afh_clear_error_counter:
+602a 58000000 setarg 0 
+602b 60014177 store 2 ,mem_afh_error_total 
+602c 20600000 rtn 
+
+afh_set_send_flag:
+602d 6800c179 fetch 1 ,mem_afh_cfg 
+602e 79207e02 set1 send_lmp_set_afh ,pdata 
+602f 6000c179 store 1 ,mem_afh_cfg 
+6030 20600000 rtn 
+
+send_set_afh:
+6031 24748000 nrtn master 
+6032 18007e10 force 16 ,pdata 
+6033 204061b5 call msg_send_lmp 
+6034 1c427e00 deposit clkn_bt 
+6035 d84001dc arg 476 ,temp 
+6036 9840fe00 iadd temp ,pdata 
+6037 1fe37e00 rshift pdata ,pdata 
+6038 1fe0fe01 increase 1 ,pdata 
+6039 793ffe00 set0 0 ,pdata 
+603a e0a20000 istore 4 ,contw 
+603b 1fe20400 copy pdata ,temp 
+603c 58000001 setarg 1 
+603d e0a08000 istore 1 ,contw 
+603e 6802c188 fetch 5 ,mem_afh_map_new 
+603f e0a28000 istore 5 ,contw 
+6040 e8c28000 ifetch 5 ,contr 
+6041 e0a28000 istore 5 ,contw 
+6042 18438400 lshift temp ,temp 
+6043 600a4173 storet 4 ,mem_afh_instant 
+6044 204061cf call send_lmp_request 
+6045 68008031 fetch 1 ,mem_mode 
+6046 79207e03 set1 afh_change ,pdata 
+6047 60008031 store 1 ,mem_mode 
+6048 70417a01 jam 1 ,mem_afh_new_mod 
+6049 68024173 fetch 4 ,mem_afh_instant 
+604a d842ee00 arg timer_one_minute ,temp 
+604b 9840fe00 iadd temp ,pdata 
+604c 600241e3 store 4 ,mem_afh_timer 
+604d 6800c179 fetch 1 ,mem_afh_cfg 
+604e c3820000 rtnbit1 afh_cfg_master_sent_req 
+604f 70007c90 jam lmp_ext_chn_classification_req ,mem_lmo_opcode2 
+6050 20600000 rtn 
+
+send_lmpext_pause_encryption_req:
+6051 18000e02 force 2 ,queue 
+6052 204061bd call send_lmpext 
+6053 2434e1cd nbranch send_lmp_reply ,master 
+6054 202061cf branch send_lmp_request 
+
+send_lmp_detach:
+6055 18007e02 force 2 ,pdata 
+6056 204061b5 call msg_send_lmp 
+6057 68008446 fetch 1 ,mem_disconn_reason_send 
+6058 e0a08000 istore 1 ,contw 
+6059 204061cf call send_lmp_request 
+
+prepare_disconnect:
+605a 6800804b fetch 1 ,mem_op 
+605b 79207e03 set1 op_disconn ,pdata 
+605c 6000804b store 1 ,mem_op 
+605d 70007232 jam 50 ,mem_conn_timer 
+605e 20600000 rtn 
+
+send_lmp_no_payload:
+605f 18007e01 force 1 ,pdata 
+6060 204061b5 call msg_send_lmp 
+6061 202061cf branch send_lmp_request 
+
+send_lmp_nopayload_reply:
+6062 18007e01 force 1 ,pdata 
+6063 204061b5 call msg_send_lmp 
+6064 202061cd branch send_lmp_reply 
+
+send_lmp_encryption_mode_req:
+6065 18007e02 force 2 ,pdata 
+6066 204061b5 call msg_send_lmp 
+6067 6800804c fetch 1 ,mem_state_map 
+6068 2fec0002 isolate0 smap_encryption ,pdata 
+6069 7920fe00 setflag true ,0 ,pdata 
+606a 1fe17e01 and_into 1 ,pdata 
+606b e0a08000 istore 1 ,contw 
+606c 202061cf branch send_lmp_request 
+
+send_lmp_superto:
+606d 18007e03 force 3 ,pdata 
+606e 204061b5 call msg_send_lmp 
+606f 68010051 fetch 2 ,mem_supervision_to 
+6070 e0a10000 istore 2 ,contw 
+6071 202061cf branch send_lmp_request 
+
+send_lmp_name_req:
+6072 700072fa jam 250 ,mem_conn_timer 
+6073 18007e02 force 2 ,pdata 
+6074 204061b5 call msg_send_lmp 
+6075 68008053 fetch 1 ,mem_name_offset 
+6076 e0a08000 istore 1 ,contw 
+6077 202061cf branch send_lmp_request 
+
+send_lmp_test_control:
+6078 18007e0a force 10 ,pdata 
+6079 204061b5 call msg_send_lmp 
+607a d8c00154 arg mem_temp_payload ,contr 
+607b 18007209 force 9 ,loopcnt 
+
+send_lmp_test_control_loop:
+607c e8c08000 ifetch 1 ,contr 
+607d 1fe2fe55 xor_into 0x55 ,pdata 
+607e e0a08000 istore 1 ,contw 
+607f c200607c loop send_lmp_test_control_loop 
+6080 202061cf branch send_lmp_request 
+
+send_lmp_quality_of_service_req:
+6081 202061cf branch send_lmp_request 
+
+send_lmp_unit_key:
+6082 202061cf branch send_lmp_request 
+
+send_lmp_slot_offset:
+6083 20748000 rtn master 
+6084 20403997 call calc_slot_offset 
+6085 18007e09 force 9 ,pdata 
+6086 204061b5 call msg_send_lmp 
+6087 6801017b fetch 2 ,mem_slot_offset 
+6088 e0a10000 istore 2 ,contw 
+6089 6801c140 fetch 3 ,mem_lap 
+608a e0a18000 istore 3 ,contw 
+608b 6800c143 fetch 1 ,mem_uap 
+608c e0a08000 istore 1 ,contw 
+608d 68014144 fetch 2 ,mem_nap 
+608e e0a10000 istore 2 ,contw 
+608f c581e094 bmark0 mark_switch_initiated ,send_lmp_slot_offset_reply 
+6090 793f8003 set0 mark_switch_initiated ,mark 
+6091 204061cf call send_lmp_request 
+6092 70007c13 jam lmp_switch_req ,mem_lmo_opcode2 
+6093 20600000 rtn 
+
+send_lmp_slot_offset_reply:
+6094 204061cd call send_lmp_reply 
+6095 70007c03 jam lmp_accepted ,mem_lmo_opcode2 
+6096 70007d13 jam lmp_switch_req ,mem_lmi_opcode2 
+6097 20600000 rtn 
+
+send_lmp_switch_req:
+6098 d8400200 arg 0x200 ,temp 
+6099 2034e09c branch switch_on_native ,master 
+609a 1d027e00 deposit clke_bt 
+609b 2020609d branch switch_slack 
+
+switch_on_native:
+609c 1c427e00 deposit clkn_bt 
+
+switch_slack:
+609d 1c227e00 deposit bt_clk 
+609e 9840fe00 iadd temp ,pdata 
+609f 1fe17ffc and_into 0x1fc ,pdata 
+60a0 60020034 store 4 ,mem_sniff_anchor 
+60a1 18007e05 force 5 ,pdata 
+60a2 204061b5 call msg_send_lmp 
+60a3 68020034 fetch 4 ,mem_sniff_anchor 
+60a4 1fe37e00 rshift pdata ,pdata 
+60a5 e0a20000 istore 4 ,contw 
+60a6 202061cf branch send_lmp_request 
+
+send_lmp_sniff_req:
+60a7 18007e0a force 10 ,pdata 
+60a8 204061b5 call msg_send_lmp 
+60a9 d8c00455 arg mem_sniff_payload ,contr 
+60aa e8c48000 ifetch 9 ,contr 
+60ab e0a48000 istore 9 ,contw 
+60ac 202061cf branch send_lmp_request 
+
+send_lmp_timing_accuracy_req:
+60ad 18007e03 force 3 ,pdata 
+60ae 204061b5 call msg_send_lmp 
+60af 58000114 setarg 0x0114 
+60b0 e0a10000 istore 2 ,contw 
+60b1 202061cf branch send_lmp_request 
+
+send_lmp_unsniff_req:
+60b2 18007e01 force 1 ,pdata 
+60b3 204061b5 call msg_send_lmp 
+60b4 202061cf branch send_lmp_request 
+
+send_lmp_sco_link_req:
+60b5 2034e0ba branch send_lmp_sco_link_master ,master 
+60b6 7000ad00 jam 0x00 ,mem_sco_handle 
+60b7 68008031 fetch 1 ,mem_mode 
+60b8 79207e04 set1 send_sco_when_slave ,pdata 
+60b9 60008031 store 1 ,mem_mode 
+
+send_lmp_sco_link_master:
+60ba 7000af00 jam 0 ,mem_esco_desco 
+60bb 18007e07 force 7 ,pdata 
+60bc 204061b5 call msg_send_lmp 
+60bd 680080ad fetch 1 ,mem_sco_handle 
+60be e0a08000 istore 1 ,contw 
+60bf 58000000 setarg 0x00 
+60c0 e0a08000 istore 1 ,contw 
+60c1 680080af fetch 1 ,mem_esco_desco 
+60c2 e0a08000 istore 1 ,contw 
+60c3 58000006 setarg 0x06 
+60c4 e0a08000 istore 1 ,contw 
+60c5 58000002 setarg 0x02 
+60c6 e0a08000 istore 1 ,contw 
+60c7 680080ab fetch 1 ,mem_air_mode 
+60c8 e0a08000 istore 1 ,contw 
+60c9 2034e1cd branch send_lmp_reply ,master 
+60ca 202061ca branch send_lmp_tid 
+
+send_lmp_remove_sco_link_req:
+60cb 18007e03 force 3 ,pdata 
+60cc 204061b5 call msg_send_lmp 
+60cd 680080ad fetch 1 ,mem_sco_handle 
+60ce e0a08000 istore 1 ,contw 
+60cf 18007e13 force other_end_terminated ,pdata 
+60d0 e0a08000 istore 1 ,contw 
+60d1 202061cf branch send_lmp_request 
+
+send_lmp_max_slot:
+60d2 18007e02 force 2 ,pdata 
+60d3 204061b5 call msg_send_lmp 
+60d4 6800c171 fetch 1 ,mem_max_slot 
+60d5 e0a08000 istore 1 ,contw 
+60d6 202061cf branch send_lmp_request 
+
+send_lmp_max_slot_req:
+60d7 18007e02 force 2 ,pdata 
+60d8 204061b5 call msg_send_lmp 
+60d9 58000005 setarg 0x05 
+60da e0a08000 istore 1 ,contw 
+60db 202061cf branch send_lmp_request 
+
+send_lmp_setup_complete:
+60dc 68008030 fetch 1 ,mem_state 
+60dd 79207e04 set1 state_conn_comp ,pdata 
+60de 60008030 store 1 ,mem_state 
+60df 1c427e00 copy clkn_bt ,pdata 
+60e0 60020465 store 4 ,mem_aurand_send_delay_time 
+60e1 6800844d fetch 1 ,mem_lmp_conn_state 
+60e2 c281e0eb bbit1 sent_setup_complete ,send_lmp_setup_complete_has_sent 
+60e3 79207e03 set1 sent_setup_complete ,pdata 
+60e4 6000844d store 1 ,mem_lmp_conn_state 
+60e5 700b7d05 jam bt_evt_setup_complete ,mem_fifo_temp 
+60e6 20407c27 call ui_ipc_send_event 
+60e7 20404825 call hci_send_connection_complete 
+60e8 18007e01 force 1 ,pdata 
+60e9 204061b5 call msg_send_lmp 
+60ea 202061cf branch send_lmp_request 
+
+send_lmp_setup_complete_has_sent:
+60eb 70004800 jam 0 ,mem_lmp_to_send 
+60ec 20600000 rtn 
+
+send_lmp_version_req:
+60ed 18007e06 force 6 ,pdata 
+60ee 204061b5 call msg_send_lmp 
+60ef 6802c6fd fetch 5 ,mem_lmp_version 
+60f0 e0a28000 istore 5 ,contw 
+60f1 202061cf branch send_lmp_request 
+
+send_lmp_features_req:
+60f2 18007e09 force 9 ,pdata 
+60f3 204061b5 call msg_send_lmp 
+60f4 68044138 fetch 8 ,mem_features 
+60f5 e0a40000 istore 8 ,contw 
+60f6 202061cf branch send_lmp_request 
+
+sp_master_send_io_cap_get:
+60f7 2040481b call hci_send_io_cap_req_event 
+60f8 6800c132 fetch 1 ,mem_device_option 
+60f9 c000e0fd beq dvc_op_hci ,sp_master_send_io_cap_get_hci 
+60fa 7007dd01 jam sp_flag_commit ,mem_master_sp_flag 
+60fb 6800c793 fetch 1 ,mem_sp_local_key_invalid 
+60fc c1808000 rtnne sp_key_valid 
+
+sp_master_send_io_cap_get_hci:
+60fd 7007db13 jam sp_master_stat_start_done ,mem_master_sp_state 
+60fe 20600000 rtn 
+
+sp_master_send_io_cap_send:
+60ff 20406209 call tid_initiate 
+6100 70007c99 jam lmp_io_cap_req ,mem_lmo_opcode2 
+6101 7007db03 jam sp_stat_key_send ,mem_master_sp_state 
+6102 20600000 rtn 
+
+sp_master_send_lmp_encapsulated_header:
+6103 20406209 call tid_initiate 
+6104 70007c3d jam lmp_encapsulated_header ,mem_lmo_opcode2 
+6105 7007db07 jam sp_stat_random_send ,mem_master_sp_state 
+6106 20600000 rtn 
+
+sp_master_commitment_compare:
+6107 da200868 arg mem_sp_calc_result_high ,rega 
+6108 da400888 arg mem_sp_confirm_remote ,regb 
+6109 df200010 arg 16 ,loopcnt 
+610a 20407f25 call string_compare 
+610b 2022e111 branch sp_master_commitment_compare_success ,zero 
+610c 7007db00 jam sp_stat_null ,mem_master_sp_state 
+610d 20407811 call master_clear_mem_master_sp_flag 
+610e 70007e24 jam pdu_not_allowed ,mem_lmo_reason2 
+610f 70007d40 jam lmp_simple_pairing_number ,mem_lmi_opcode2 
+6110 20205bc9 branch reject_lmp_packet 
+
+sp_master_commitment_compare_success:
+6111 7007db0a jam sp_stat_confirm_calc ,mem_master_sp_state 
+6112 2040780f call master_set_mem_master_sp_flag 
+6113 70007d40 jam lmp_simple_pairing_number ,mem_lmi_opcode2 
+6114 20205cf5 branch accept_lmp_msg 
+
+sp_master_send_lmp_simple_pairing_number:
+6115 70007c40 jam lmp_simple_pairing_number ,mem_lmo_opcode2 
+6116 20600000 rtn 
+
+sp_send_lmp_encapsulated_header:
+6117 70007c3d jam lmp_encapsulated_header ,mem_lmo_opcode2 
+6118 20600000 rtn 
+
+send_lmp_encapsulated_header:
+6119 7007e200 jam 0 ,mem_sp_local_key_send_count 
+611a 18007e04 force 4 ,pdata 
+611b 204061b5 call msg_send_lmp 
+611c 18007e01 force encapsulated_major_type_p192 ,pdata 
+611d e0a08000 istore 1 ,contw 
+611e 18007e01 force encapsulated_minor_type_p192 ,pdata 
+611f e0a08000 istore 1 ,contw 
+6120 18007e30 force encapsulated_len_p192 ,pdata 
+6121 e0a08000 istore 1 ,contw 
+6122 20406216 call check_localsm 
+6123 2020e1cf branch send_lmp_request ,true 
+6124 202061cd branch send_lmp_reply 
+
+send_lmp_encapsulated_payload:
+6125 18007e11 force 17 ,pdata 
+6126 204061b5 call msg_send_lmp 
+6127 680087e2 fetch 1 ,mem_sp_local_key_send_count 
+6128 d8c047ac arg mem_sp_pubkey_local ,contr 
+6129 98c08c00 iadd contr ,contr 
+612a e8c40000 ifetch 8 ,contr 
+612b e0a40000 istore 8 ,contw 
+612c e8c40000 ifetch 8 ,contr 
+612d e0a40000 istore 8 ,contw 
+612e 680087e2 fetch 1 ,mem_sp_local_key_send_count 
+612f 1fe0fe10 increase 16 ,pdata 
+6130 600087e2 store 1 ,mem_sp_local_key_send_count 
+6131 20406216 call check_localsm 
+6132 2020e1cf branch send_lmp_request ,true 
+6133 202061cd branch send_lmp_reply 
+
+sp_send_lmp_simple_pairing_comfirm:
+6134 7007da06 jam sp_stat_random_recv ,mem_sp_state 
+6135 70007c3f jam lmp_simple_pairing_confirm ,mem_lmo_opcode2 
+6136 20600000 rtn 
+
+send_lmp_simple_pairing_comfirm:
+6137 18007e11 force 17 ,pdata 
+6138 204061b5 call msg_send_lmp 
+6139 d8c00868 arg mem_sp_calc_result_high ,contr 
+613a e8c40000 ifetch 8 ,contr 
+613b e0a40000 istore 8 ,contw 
+613c e8c40000 ifetch 8 ,contr 
+613d e0a40000 istore 8 ,contw 
+613e 202061cd branch send_lmp_reply 
+
+sp_send_lmp_simple_pairing_number:
+613f 204061d9 call lmo_fifo_process 
+6140 70007c40 jam lmp_simple_pairing_number ,mem_lmo_opcode2 
+6141 20600000 rtn 
+
+send_lmp_simple_pairing_number:
+6142 20406216 call check_localsm 
+6143 2040f74d call sp_local_random_key_generator ,true 
+6144 18007e11 force 17 ,pdata 
+6145 204061b5 call msg_send_lmp 
+6146 d8c00838 arg mem_sp_random_local ,contr 
+6147 e8c40000 ifetch 8 ,contr 
+6148 e0a40000 istore 8 ,contw 
+6149 e8c40000 ifetch 8 ,contr 
+614a e0a40000 istore 8 ,contw 
+614b 20406216 call check_localsm 
+614c 2420e1cd nbranch send_lmp_reply ,true 
+614d 2020e1cf branch send_lmp_request ,true 
+
+master_sp_sm_end:
+614e 7007db0f jam sp_stat_done ,mem_master_sp_state 
+
+sp_aurand_send:
+614f 20406209 call tid_initiate 
+6150 70007c0b jam lmp_au_rand ,mem_lmo_opcode2 
+6151 20406221 call check_localsm_master 
+6152 2020f785 branch sp_master_key_prarm_push ,true 
+6153 2020778f branch sp_link_key_prarm_push 
+
+master_sp_send_lmp_dhkey_check:
+6154 20406205 call tid_reply 
+
+sp_send_lmp_dhkey_check:
+6155 70007c41 jam lmp_dhkey_check ,mem_lmo_opcode2 
+6156 20600000 rtn 
+
+send_lmp_dhkey_check:
+6157 18007e11 force 17 ,pdata 
+6158 204061b5 call msg_send_lmp 
+6159 d8c00868 arg mem_sp_calc_result_high ,contr 
+615a e8c40000 ifetch 8 ,contr 
+615b e0a40000 istore 8 ,contw 
+615c e8c40000 ifetch 8 ,contr 
+615d e0a40000 istore 8 ,contw 
+615e 20406216 call check_localsm 
+615f 2420e1cd nbranch send_lmp_reply ,true 
+6160 2020e1cf branch send_lmp_request ,true 
+
+send_lmp_enc_key_size_mask_res:
+6161 18007e03 force 3 ,pdata 
+6162 204061b5 call msg_send_lmp 
+6163 5800fffe setarg 0xfffe 
+6164 e0a10000 istore 2 ,contw 
+6165 202061cd branch send_lmp_reply 
+
+send_lmp_auto_rate:
+6166 202061cf branch send_lmp_request 
+
+send_lmp_clkoffset_req:
+6167 202061cf branch send_lmp_request 
+
+send_lmp_quality_of_service:
+6168 202061cf branch send_lmp_request 
+
+send_lmp_test_activate:
+6169 202061cf branch send_lmp_request 
+
+send_lmp_comb_key:
+616a 20406225 call generate_random_number 
+616b da204140 arg mem_lap ,rega 
+616c 2040622b call generate_linkkey 
+616d 18007e11 force 17 ,pdata 
+616e 204061b5 call msg_send_lmp 
+616f da20050f arg mem_kinit ,rega 
+6170 da4004ef arg mem_random_number ,regb 
+6171 20407467 call xor16 
+6172 2434e1c4 nbranch send_lmp_follow ,master 
+6173 202061ca branch send_lmp_tid 
+
+send_lmp_inrand:
+6174 20406225 call generate_random_number 
+6175 da200040 arg mem_plap ,rega 
+6176 2040736a call generate_kinit 
+
+send_lmp_rand:
+6177 18007e11 force 17 ,pdata 
+6178 204061b5 call msg_send_lmp 
+6179 d8c004ef arg mem_random_number ,contr 
+617a 20407e35 call memcpy16 
+617b 68008055 fetch 1 ,mem_conn_sm 
+617c c00ce1cf beq conn_sm_auth_wait ,send_lmp_request 
+617d c00c61cf beq conn_sm_pairing_wait ,send_lmp_request 
+617e 202061ca branch send_lmp_tid 
+
+send_lmp_aurand:
+617f 680087e1 fetch 1 ,mem_pairing_auth 
+6180 203a6185 branch send_lmp_aurand_notpairing ,blank 
+6181 20406216 call check_localsm 
+6182 2040e209 call tid_initiate ,true 
+6183 2440e205 ncall tid_reply ,true 
+6184 20206186 branch send_lmp_aurand_common 
+
+send_lmp_aurand_notpairing:
+6185 20406209 call tid_initiate 
+
+send_lmp_aurand_common:
+6186 20406225 call generate_random_number 
+6187 20206177 branch send_lmp_rand 
+
+send_lmp_sres:
+6188 da204140 arg mem_lap ,rega 
+6189 2040739d call function_e1 
+618a 18007e05 force 5 ,pdata 
+618b 204061b5 call msg_send_lmp 
+618c 6802051f fetch 4 ,mem_input_store 
+618d e0a20000 istore 4 ,contw 
+618e d8400451 arg mem_sres_tid ,temp 
+618f 204061fb call special_tid_store 
+6190 2040749b call copy_aco 
+6191 20406216 call check_localsm 
+6192 2020e197 branch send_lmp_sres_master ,true 
+6193 70045401 jam done_encryp ,mem_wait_encryption 
+6194 680087e1 fetch 1 ,mem_pairing_auth 
+6195 207a0000 rtn blank 
+6196 70007c0b jam lmp_au_rand ,mem_lmo_opcode2 
+
+send_lmp_sres_master:
+6197 6800c25e fetch 1 ,mem_link_key_exists 
+6198 207a0000 rtn blank 
+6199 20406216 call check_localsm 
+619a 2040c852 call hci_send_linkkey_notification ,true 
+
+send_lmp_sres_startenc:
+619b 20406216 call check_localsm 
+619c 2420e1a1 nbranch send_lmp_sres_startenc_slave ,true 
+619d 68008453 fetch 1 ,mem_auth_enable 
+619e 207a0000 rtn blank 
+619f 70007c0f jam lmp_encryption_mode_req ,mem_lmo_opcode2 
+61a0 20600000 rtn 
+
+send_lmp_sres_startenc_slave:
+61a1 c6908000 rtnmark0 mark_slave_in_rand_accepted 
+61a2 793f8021 set0 mark_slave_in_rand_accepted ,mark 
+61a3 70007c0f jam lmp_encryption_mode_req ,mem_lmo_opcode2 
+61a4 20600000 rtn 
+
+send_lmp_start_encryption:
+61a5 20406225 call generate_random_number 
+61a6 204073a0 call function_e3 
+61a7 18007e11 force 17 ,pdata 
+61a8 204061b5 call msg_send_lmp 
+61a9 d8c004ef arg mem_random_number ,contr 
+61aa 20407e35 call memcpy16 
+61ab 202061ca branch send_lmp_tid 
+
+send_lmp_stop_encryption_req:
+61ac 18007e01 force 1 ,pdata 
+61ad 204061b5 call msg_send_lmp 
+61ae 202061ca branch send_lmp_tid 
+
+send_lmp_encryption_key_size_req:
+61af 18007e02 force 2 ,pdata 
+61b0 204061b5 call msg_send_lmp 
+61b1 18007e10 force 16 ,pdata 
+61b2 e0a08000 istore 1 ,contw 
+61b3 60008054 store 1 ,mem_key_size 
+61b4 202061ca branch send_lmp_tid 
+
+msg_send_lmp:
+61b5 1fe9fe00 lshift3 pdata ,pdata 
+61b6 1fe1fe07 or_into 0x07 ,pdata 
+61b7 60008432 store 1 ,mem_lmo_header_length 
+61b8 df200011 arg 17 ,loopcnt 
+61b9 d8a00434 arg mem_lmo_payload ,contw 
+61ba 20407e3f call clear_mem 
+61bb d8a00434 arg mem_lmo_payload ,contw 
+61bc 20600000 rtn 
+
+send_lmpext:
+61bd 1fe1227f and pdata ,0x7f ,rega 
+61be 7000487f jam lmp_escape ,mem_lmp_to_send 
+61bf 18e27e00 deposit queue 
+61c0 204061b5 call msg_send_lmp 
+61c1 1a227e00 deposit rega 
+61c2 e0a08000 istore 1 ,contw 
+61c3 20600000 rtn 
+
+send_lmp_follow:
+61c4 68008048 fetch 1 ,mem_lmp_to_send 
+61c5 1fe3fe00 lshift pdata ,pdata 
+61c6 6808804c fetcht 1 ,mem_state_map 
+61c7 284ffe01 isolate1 smap_lmptid ,temp 
+61c8 7920fe00 setflag true ,0 ,pdata 
+61c9 202061d4 branch send_lmp_exit 
+
+send_lmp_tid:
+61ca 6808804c fetcht 1 ,mem_state_map 
+61cb 18410401 and_into 1 ,temp 
+61cc 202061d0 branch send_lmp_end 
+
+send_lmp_reply:
+61cd 18000400 force 0 ,temp 
+61ce 202061d0 branch send_lmp_end 
+
+send_lmp_request:
+61cf 18000401 force 1 ,temp 
+
+send_lmp_end:
+61d0 68008048 fetch 1 ,mem_lmp_to_send 
+61d1 1fe3fe00 lshift pdata ,pdata 
+61d2 7934fe00 setflag master ,0 ,pdata 
+61d3 9842fe00 ixor temp ,pdata 
+
+send_lmp_exit:
+61d4 60008433 store 1 ,mem_lmo_header_opcode 
+61d5 70004800 jam 0 ,mem_lmp_to_send 
+61d6 204061e0 call lmo_fifo_process_lmo0empty 
+61d7 78347c00 enable user 
+61d8 20600000 rtn 
+
+lmo_fifo_process:
+61d9 79200025 set1 mark_ext_patch ,mark 
+61da 44f2403c bpatch patch3c_4 ,mem_patch3c 
+61db 68008048 fetch 1 ,mem_lmp_to_send 
+61dc 203a61e0 branch lmo_fifo_process_lmo0empty ,blank 
+61dd 68008078 fetch 1 ,mem_lmo_opcode1 
+61de 247a0000 nrtn blank 
+61df 202061ea branch lmo_fifo_process_lmo2to1 
+
+lmo_fifo_process_lmo0empty:
+61e0 68008078 fetch 1 ,mem_lmo_opcode1 
+61e1 203a61f0 branch lmo_fifo_process_lmo1_empty ,blank 
+61e2 68018078 fetch 3 ,mem_lmo_opcode1 
+61e3 60018048 store 3 ,mem_lmp_to_send 
+61e4 6808807b fetcht 1 ,mem_lmo_tid1 
+61e5 6800804c fetch 1 ,mem_state_map 
+61e6 793ffe01 set0 smap_lmptid ,pdata 
+61e7 9841fe00 ior temp ,pdata 
+61e8 6000804c store 1 ,mem_state_map 
+61e9 70007800 jam 0 ,mem_lmo_opcode1 
+
+lmo_fifo_process_lmo2to1:
+61ea 6800807c fetch 1 ,mem_lmo_opcode2 
+61eb 207a0000 rtn blank 
+61ec 6802007c fetch 4 ,mem_lmo_opcode2 
+61ed 60020078 store 4 ,mem_lmo_opcode1 
+61ee 70007c00 jam 0 ,mem_lmo_opcode2 
+61ef 20600000 rtn 
+
+lmo_fifo_process_lmo1_empty:
+61f0 6800807c fetch 1 ,mem_lmo_opcode2 
+61f1 207a0000 rtn blank 
+61f2 6801807c fetch 3 ,mem_lmo_opcode2 
+61f3 60018048 store 3 ,mem_lmp_to_send 
+61f4 6808807f fetcht 1 ,mem_lmo_tid2 
+61f5 6800804c fetch 1 ,mem_state_map 
+61f6 793ffe01 set0 smap_lmptid ,pdata 
+61f7 9841fe00 ior temp ,pdata 
+61f8 6000804c store 1 ,mem_state_map 
+61f9 70007c00 jam 0 ,mem_lmo_opcode2 
+61fa 20600000 rtn 
+
+special_tid_store:
+61fb 79200025 set1 mark_ext_patch ,mark 
+61fc 44f2c03c bpatch patch3c_5 ,mem_patch3c 
+61fd 6800804c fetch 1 ,mem_state_map 
+61fe 1fe22600 copy pdata ,regc 
+61ff e8408000 ifetch 1 ,temp 
+6200 20405d12 call pop_tid_follow 
+6201 204061c4 call send_lmp_follow 
+6202 1a627e00 copy regc ,pdata 
+6203 6000804c store 1 ,mem_state_map 
+6204 20600000 rtn 
+
+tid_reply:
+6205 6808804c fetcht 1 ,mem_state_map 
+6206 793f8400 set0 smap_lmptidinit ,temp 
+6207 6008804c storet 1 ,mem_state_map 
+6208 20600000 rtn 
+
+tid_initiate:
+6209 6808804c fetcht 1 ,mem_state_map 
+620a 79200400 set1 smap_lmptidinit ,temp 
+620b 6008804c storet 1 ,mem_state_map 
+620c 20600000 rtn 
+
+tid_check:
+620d 7d34fe01 nsetflag master ,smap_lmptid ,pdata 
+620e 6808804c fetcht 1 ,mem_state_map 
+620f 9842fe00 ixor temp ,pdata 
+6210 2feffe01 isolate1 smap_lmptid ,pdata 
+6211 20600000 rtn 
+
+tid_set_reply:
+6212 6800804c fetch 1 ,mem_state_map 
+6213 7934fe01 setflag master ,smap_lmptid ,pdata 
+6214 6000804c store 1 ,mem_state_map 
+6215 20600000 rtn 
+
+check_localsm:
+6216 680087e0 fetch 1 ,mem_sp_localsm 
+6217 2fe0fe01 compare local_statemachine ,pdata ,0x7f 
+6218 20600000 rtn 
+
+setlocalsm_master:
+6219 680087e0 fetch 1 ,mem_sp_localsm 
+621a 79207e07 set1 7 ,pdata 
+621b 600087e0 store 1 ,mem_sp_localsm 
+621c 20600000 rtn 
+
+setlocalsm_slave:
+621d 680087e0 fetch 1 ,mem_sp_localsm 
+621e 793ffe07 set0 7 ,pdata 
+621f 600087e0 store 1 ,mem_sp_localsm 
+6220 20600000 rtn 
+
+check_localsm_master:
+6221 680087e0 fetch 1 ,mem_sp_localsm 
+6222 2feffe07 isolate1 7 ,pdata 
+6223 600087e0 store 1 ,mem_sp_localsm 
+6224 20600000 rtn 
+
+generate_random_number:
+6225 d8a004ef arg mem_random_number ,contw 
+
+generate_random:
+6226 18007210 force 16 ,loopcnt 
+
+generate_random_another:
+
+generate_random_loop:
+6227 180a7e00 random pdata 
+6228 e0a08000 istore 1 ,contw 
+6229 c2006227 loop generate_random_another 
+622a 20600000 rtn 
+
+generate_linkkey:
+622b 2040736e call function_e21 
+622c da204262 arg mem_link_key ,rega 
+622d da40051f arg mem_input_store ,regb 
+622e ea240000 ifetch 8 ,rega 
+622f 68088030 fetcht 1 ,mem_state 
+6230 7d3a0406 nsetflag blank ,state_combkey ,temp 
+6231 60088030 storet 1 ,mem_state 
+6232 1a220a00 copy rega ,contw 
+6233 20407467 call xor16 
+6234 20203229 branch generate_linkkey_continue 
+
+process_conn_sm:
+6235 79200025 set1 mark_ext_patch ,mark 
+6236 44f3403c bpatch patch3c_6 ,mem_patch3c 
+6237 6800807c fetch 1 ,mem_lmo_opcode2 
+6238 203a623c branch process_conn_sm_continue ,blank 
+6239 204061d9 call lmo_fifo_process 
+623a 6800807c fetch 1 ,mem_lmo_opcode2 
+623b 247a0000 nrtn blank 
+
+process_conn_sm_continue:
+623c 68008055 fetch 1 ,mem_conn_sm 
+623d 207a0000 rtn blank 
+623e c002628d beq conn_sm_send_conn_req ,host_create_conn_send_conn_req 
+623f c002e292 beq conn_sm_wait_conn_accept ,host_create_conn_wait_accept 
+6240 c0016284 beq conn_sm_send_features ,host_create_conn_send_features 
+6241 c001e29a beq conn_sm_wait_features_res ,host_create_conn_waiting 
+6242 c0076287 beq conn_sm_send_switch ,host_create_conn_send_switch 
+6243 c00362b6 beq conn_sm_auth_pair ,host_create_conn_auth_pair 
+6244 c003e2ce beq conn_sm_auth_pair_wait ,host_create_conn_auth_pair_wait 
+6245 c004e2cf beq conn_sm_encrypt ,host_create_conn_encrypt 
+6246 c00562d8 beq conn_sm_encrypt_wait ,host_create_conn_encrypt_wait 
+6247 c005e2dc beq conn_sm_encrypt_wait_clear ,host_create_conn_encrypt_wait_clear 
+6248 c00662a4 beq conn_sm_send_setup_complete ,host_create_conn_send_setup_complete 
+6249 c006e2a7 beq conn_sm_wait_setup_complete ,host_create_conn_wait_setup_complete 
+624a c007e2ad beq conn_sm_detach_delay ,host_create_conn_master_detach 
+624b c0096277 beq conn_sm_send_version ,host_create_conn_send_version 
+624c c009e29a beq conn_sm_wait_version ,host_create_conn_waiting 
+624d c008627a beq conn_sm_wait_switch_after_host_connection ,host_creat_conn_wait_switch 
+624e c00a6274 beq conn_sm_send_features_ext ,host_creat_conn_send_feat_ext 
+624f c00ae29a beq conn_sm_wait_features_ext ,host_create_conn_waiting 
+6250 c00b626e beq conn_sm_pairing ,host_create_conn_pairing 
+6251 c00c6273 beq conn_sm_pairing_wait ,host_create_conn_pairing_wait 
+6252 c00be267 beq conn_sm_auth ,host_create_conn_auth 
+6253 c00ce26d beq conn_sm_auth_wait ,host_create_conn_auth_wait 
+6254 c00d6258 beq conn_sm_done ,host_create_conn_done 
+6255 c00de262 beq conn_sm_wait_done ,host_create_conn_done_wait 
+6256 70005500 jam conn_sm_standby ,mem_conn_sm 
+6257 20600000 rtn 
+
+host_create_conn_done:
+6258 6800844d fetch 1 ,mem_lmp_conn_state 
+6259 c4010000 rtnbit0 received_setup_complete 
+625a c4018000 rtnbit0 sent_setup_complete 
+625b 70005500 jam conn_sm_standby ,mem_conn_sm 
+625c 2040625e call host_conn_judge_encrypt 
+625d 20206e41 branch scheduler_start_upper_sm 
+
+host_conn_judge_encrypt:
+625e 68008177 fetch 1 ,mem_connection_options 
+625f c4008000 rtnbit0 connection_encrypt 
+6260 7000550a jam conn_sm_encrypt_wait ,mem_conn_sm 
+6261 20600000 rtn 
+
+host_create_conn_done_wait:
+6262 d8e0000b arg enpt_delay_timer ,queue 
+6263 20407e53 call timer_check 
+6264 247a0000 nrtn blank 
+6265 7000551a jam conn_sm_done ,mem_conn_sm 
+6266 20600000 rtn 
+
+host_create_conn_auth:
+6267 68008177 fetch 1 ,mem_connection_options 
+6268 793ffe00 set0 connection_auth ,pdata 
+6269 60008177 store 1 ,mem_connection_options 
+626a 70005519 jam conn_sm_auth_wait ,mem_conn_sm 
+626b 70007c0b jam lmp_au_rand ,mem_lmo_opcode2 
+626c 20600000 rtn 
+
+host_create_conn_auth_wait:
+626d 20600000 rtn 
+
+host_create_conn_pairing:
+626e 68008450 fetch 1 ,mem_pincode_state 
+626f c1810000 rtnne pincode_state_pincode_ready 
+6270 204062de call host_auth 
+6271 70005518 jam conn_sm_pairing_wait ,mem_conn_sm 
+6272 20600000 rtn 
+
+host_create_conn_pairing_wait:
+6273 20600000 rtn 
+
+host_creat_conn_send_feat_ext:
+6274 70005515 jam conn_sm_wait_features_ext ,mem_conn_sm 
+6275 70007c83 jam lmp_ext_features_req ,mem_lmo_opcode2 
+6276 20600000 rtn 
+
+host_create_conn_send_version:
+6277 70005513 jam conn_sm_wait_version ,mem_conn_sm 
+6278 70007c25 jam lmp_version_req ,mem_lmo_opcode2 
+6279 20600000 rtn 
+
+host_creat_conn_wait_switch:
+627a 6800c748 fetch 1 ,mem_switch_flag 
+627b c1000000 rtneq switch_flag_init 
+627c c000e282 beq switch_flag_accept ,host_create_conn_switch_accept 
+627d d8e0000a arg switch_wait_timer ,queue 
+627e 20407e53 call timer_check 
+627f 247a0000 nrtn blank 
+6280 70474800 jam switch_flag_init ,mem_switch_flag 
+6281 2020629b branch host_create_conn_switch 
+
+host_create_conn_switch_accept:
+6282 20748000 rtn master 
+6283 202062b6 branch host_create_conn_auth_pair 
+
+host_create_conn_send_features:
+6284 70005503 jam conn_sm_wait_features_res ,mem_conn_sm 
+6285 70007c27 jam lmp_features_req ,mem_lmo_opcode2 
+6286 20600000 rtn 
+
+host_create_conn_send_switch:
+6287 70007c13 jam lmp_switch_req ,mem_lmo_opcode2 
+6288 79200003 set1 mark_switch_initiated ,mark 
+6289 70005505 jam conn_sm_wait_conn_accept ,mem_conn_sm 
+628a 580001ff setarg 0x1ff 
+628b 6001044e store 2 ,mem_soft_timer 
+628c 20600000 rtn 
+
+host_create_conn_send_conn_req:
+628d 70005505 jam conn_sm_wait_conn_accept ,mem_conn_sm 
+628e 70044eff jam 0xff ,mem_soft_timer 
+628f 793f8022 set0 mark_reconn_recieve_switch ,mark 
+6290 70007c33 jam lmp_host_connection_req ,mem_lmo_opcode2 
+6291 20205b6f branch init_lmp_reinit 
+
+host_create_conn_wait_accept:
+6292 c6110000 rtnmark1 mark_reconn_recieve_switch 
+6293 6801044e fetch 2 ,mem_soft_timer 
+6294 1fe67e01 sub pdata ,1 ,pdata 
+6295 2022e298 branch host_create_conn_resend ,zero 
+6296 6001044e store 2 ,mem_soft_timer 
+6297 20600000 rtn 
+
+host_create_conn_resend:
+6298 7000550e jam conn_sm_send_switch ,mem_conn_sm 
+6299 20600000 rtn 
+
+host_create_conn_waiting:
+629a 20600000 rtn 
+
+host_create_conn_switch:
+629b 6800844d fetch 1 ,mem_lmp_conn_state 
+629c c4018000 rtnbit0 sent_setup_complete 
+629d c4010000 rtnbit0 received_setup_complete 
+629e 68008177 fetch 1 ,mem_connection_options 
+629f 793ffe02 set0 connection_switch ,pdata 
+62a0 60008177 store 1 ,mem_connection_options 
+62a1 70007c13 jam lmp_switch_req ,mem_lmo_opcode2 
+62a2 70005510 jam conn_sm_wait_switch_after_host_connection ,mem_conn_sm 
+62a3 20600000 rtn 
+
+host_create_conn_send_setup_complete:
+62a4 7000550d jam conn_sm_wait_setup_complete ,mem_conn_sm 
+62a5 70007c31 jam lmp_setup_complete ,mem_lmo_opcode2 
+62a6 20600000 rtn 
+
+host_create_conn_wait_setup_complete:
+62a7 6800844d fetch 1 ,mem_lmp_conn_state 
+62a8 c4010000 rtnbit0 received_setup_complete 
+62a9 70005500 jam conn_sm_standby ,mem_conn_sm 
+62aa 20600000 rtn 
+
+host_create_conn_wait_setup_complete_rtn:
+62ab 70005506 jam conn_sm_auth_pair ,mem_conn_sm 
+62ac 20600000 rtn 
+
+host_create_conn_master_detach:
+62ad 6800844e fetch 1 ,mem_soft_timer 
+62ae 1fe0ffff increase -1 ,pdata 
+62af 203a62b2 branch host_create_conn_send_detach ,blank 
+62b0 6000844e store 1 ,mem_soft_timer 
+62b1 20600000 rtn 
+
+host_create_conn_send_detach:
+62b2 70007c07 jam lmp_detach ,mem_lmo_opcode2 
+62b3 70044616 jam local_host ,mem_disconn_reason_send 
+62b4 70005500 jam 0 ,mem_conn_sm 
+62b5 20600000 rtn 
+
+host_create_conn_auth_pair:
+62b6 68008177 fetch 1 ,mem_connection_options 
+62b7 c281629b bbit1 connection_switch ,host_create_conn_switch 
+62b8 c28062bb bbit1 connection_auth ,host_create_conn_auth_pair_true 
+
+host_create_conn_sm_done:
+62b9 7000551a jam conn_sm_done ,mem_conn_sm 
+62ba 20600000 rtn 
+
+host_create_conn_auth_pair_true:
+62bb 6800c25e fetch 1 ,mem_link_key_exists 
+62bc 203a62c7 branch host_create_conn_auth_pair_nokey ,blank 
+62bd 6800844d fetch 1 ,mem_lmp_conn_state 
+62be c4018000 rtnbit0 sent_setup_complete 
+62bf c4010000 rtnbit0 received_setup_complete 
+62c0 68020465 fetch 4 ,mem_aurand_send_delay_time 
+62c1 d8400064 arg 100 ,temp 
+62c2 98408400 iadd temp ,temp 
+62c3 1c427e00 copy clkn_bt ,pdata 
+62c4 98467c00 isub temp ,null 
+62c5 24610000 nrtn positive 
+62c6 20206267 branch host_create_conn_auth 
+
+host_create_conn_auth_pair_nokey:
+62c7 70005516 jam conn_sm_pairing ,mem_conn_sm 
+62c8 70054f04 jam 4 ,mem_pin_length 
+62c9 58003030 setarg 0x3030 
+62ca 60010550 store 2 ,mem_pin 
+62cb e0a10000 istore 2 ,contw 
+62cc 70045002 jam pincode_state_pincode_ready ,mem_pincode_state 
+62cd 2020626e branch host_create_conn_pairing 
+
+host_create_conn_auth_pair_wait:
+62ce 20600000 rtn 
+
+host_create_conn_encrypt:
+62cf 68008177 fetch 1 ,mem_connection_options 
+62d0 c280e2d3 bbit1 connection_encrypt ,host_create_conn_encrypt_start 
+62d1 7000551a jam conn_sm_done ,mem_conn_sm 
+62d2 20600000 rtn 
+
+host_create_conn_encrypt_start:
+62d3 68008177 fetch 1 ,mem_connection_options 
+62d4 793ffe01 set0 connection_encrypt ,pdata 
+62d5 60008177 store 1 ,mem_connection_options 
+62d6 70007c0f jam lmp_encryption_mode_req ,mem_lmo_opcode2 
+62d7 20600000 rtn 
+
+host_create_conn_encrypt_wait:
+62d8 68008454 fetch 1 ,mem_wait_encryption 
+62d9 207a0000 rtn blank 
+62da 70005500 jam conn_sm_standby ,mem_conn_sm 
+62db 202062d3 branch host_create_conn_encrypt_start 
+
+host_create_conn_encrypt_wait_clear:
+62dc 7000550c jam conn_sm_send_setup_complete ,mem_conn_sm 
+62dd 20600000 rtn 
+
+host_auth:
+62de 6800804b fetch 1 ,mem_op 
+62df c28162e3 bbit1 op_inrand_req ,remote_auth 
+62e0 20406209 call tid_initiate 
+62e1 70007c08 jam lmp_in_rand ,mem_lmo_opcode2 
+62e2 202049bc branch cmd_exit 
+
+remote_auth:
+62e3 6800804b fetch 1 ,mem_op 
+62e4 793ffe02 set0 op_inrand_req ,pdata 
+62e5 6000804b store 1 ,mem_op 
+62e6 20405ed0 call lmp_accept_inrand 
+62e7 20406212 call tid_set_reply 
+62e8 202049bc branch cmd_exit 
+
+pincode_reinit:
+62e9 58000004 setarg 4 
+62ea 6000854f store 1 ,mem_pin_length 
+62eb 58003030 setarg 0x3030 
+62ec e0a10000 istore 2 ,contw 
+62ed e0a10000 istore 2 ,contw 
+62ee 20600000 rtn 
+
+module_init:
+62ef 20758000 rtn wake 
+62f0 70481300 jam 0 ,mem_module_task 
+62f1 20406321 call module_gpio_init 
+62f2 20406438 call module_init_static_string 
+62f3 5800632e setarg module_process_idle 
+62f4 60014290 store 2 ,mem_cb_idle_process 
+62f5 5800632f setarg module_conn_process 
+62f6 6001428e store 2 ,mem_cb_bt_process 
+62f7 58006337 setarg module_process_bb_event 
+62f8 60014292 store 2 ,mem_cb_bb_event_process 
+62f9 580063b6 setarg module_le_rx 
+62fa 60014296 store 2 ,mem_cb_att_write 
+62fb 5800632f setarg module_conn_process 
+62fc 6001428c store 2 ,mem_cb_le_process 
+62fd 79200025 set1 mark_ext_patch ,mark 
+62fe 44c04030 bpatch patch30_0 ,mem_patch30 
+62ff 5800632a setarg module_lpm_lock 
+6300 60014286 store 2 ,mem_cb_check_wakelock 
+6301 580063be setarg module_le_tx_update_data 
+6302 60014298 store 2 ,mem_cb_update_notify_value 
+6303 58000000 setarg 0 
+6304 6002480a store 4 ,mem_last_uart_clock 
+6305 60014810 store 2 ,mem_module_prepare_tx_len 
+6306 2040630a call module_hardware_init 
+6307 20403fc5 call init_module_environment 
+6308 20403e2b call check_module_disabled 
+6309 2020691d branch eeprom_load_reconn_info 
+
+module_hardware_init:
+630a 20758000 rtn wake 
+630b 580001a0 setarg uart_baud_115200 
+630c 600142ac store uart_baud_len ,mem_baud 
+
+module_lpm_uart_init:
+630d 20406a0d call init_filter_ram 
+630e 58004a00 setarg mem_module_rx_buf 
+630f 60110054 hstore 2 ,core_uart_rsaddr 
+6310 58004fff setarg mem_module_rx_buf_end 
+6311 60110056 hstore 2 ,core_uart_readdr 
+6312 58001c00 setarg mem_module_tx_buf 
+6313 6011005a hstore 2 ,core_uart_tsaddr 
+6314 58001fff setarg mem_module_tx_buf_end 
+6315 6011005c hstore 2 ,core_uart_teaddr 
+6316 70808104 hjam 0x4 ,core_gpio_sel1 
+6317 70029fff jam 0xff ,mem_ucode_id_local 
+6318 70806200 hjam 0x0 ,core_uart_ctrl 
+6319 58001c00 setarg mem_module_tx_buf 
+631a 6011005e hstore 2 ,core_uart_twptr 
+631b 60110060 hstore 2 ,core_uart_trptrp 
+631c 58004a00 setarg mem_module_rx_buf 
+631d 60110058 hstore 2 ,core_uart_rrptr 
+631e 20204480 branch hci_init_common 
+
+module_lpm_init:
+631f 2040630d call module_lpm_uart_init 
+6320 20206321 branch module_gpio_init 
+
+module_gpio_init:
+6321 20407bd9 call ui_led_init 
+6322 20403f94 call app_led_start_blink 
+6323 6808c803 fetcht 1 ,mem_module_connect_state_gpio 
+6324 204069da call gpio_config_output 
+6325 2040639e call module_set_conn_pin_low 
+6326 6808c801 fetcht 1 ,mem_module_wake_up_gpio 
+6327 204069d1 call gpio_config_input 
+6328 6808c800 fetcht 1 ,mem_at_gpio 
+6329 202069d2 branch gpio_config_input_without_wake 
+
+module_lpm_lock:
+632a 6808c801 fetcht 1 ,mem_module_wake_up_gpio 
+632b 204069e5 call gpio_get_bit 
+632c 2420bf5c nbranch app_put_lpm_wake_lock ,true 
+632d 20203f5a branch app_get_lpm_wake_lock 
+
+module_process_idle:
+632e 20206330 branch module_app_dispatch 
+
+module_conn_process:
+632f 20206330 branch module_app_dispatch 
+
+module_app_dispatch:
+6330 79200025 set1 mark_ext_patch ,mark 
+6331 44c0c030 bpatch patch30_1 ,mem_patch30 
+6332 2040641c call module_control_air_flow 
+6333 20406421 call module_uart_set 
+6334 2040527a call l2cap_malloc_is_fifo_full 
+6335 247a0000 nrtn blank 
+6336 202063a0 branch module_process 
+
+module_process_bb_event:
+6337 1a627e00 copy regc ,pdata 
+6338 c0056368 beq bt_evt_pincode_req ,module_process_evt_pincode_req 
+6339 c0026383 beq bt_evt_reconn_failed ,module_reconn_fail 
+633a c009e387 beq bt_evt_reconn_page_timeout ,module_page_time_out 
+633b c001634c beq bt_evt_bb_disconnected ,module_process_bb_event_disconned 
+633c c00ce36a beq bt_evt_switch_not_accept ,module_process_switch_not_accept 
+633d c010636f beq bt_evt_switch_accept ,module_process_switch_accept 
+633e c0116374 beq bt_evt_sniff_accept ,module_process_sniff_accept 
+633f c010e375 beq bt_evt_sniff_not_accept ,module_process_sniff_not_accept 
+6340 c011e376 beq bt_evt_unsniff_accept ,module_process_unsniff_accept 
+6341 c0126379 beq bt_evt_unsniff_not_accept ,module_process_unsniff_not_accept 
+6342 c00a637a beq bt_evt_le_connected ,module_process_le_conn 
+6343 c000e382 beq bt_evt_bb_connected ,module_process_bb_conn 
+6344 c00ae364 beq bt_evt_le_disconnected ,module_process_bb_even_le_disconn 
+6345 c002e35d beq bt_evt_setup_complete ,module_process_setup_complete 
+6346 c005e352 beq bt_evt_enter_sniff ,module_sniff_param_check 
+6347 c0063fa6 beq bt_evt_exit_sniff ,app_lpm_mult_disable 
+6348 1fe1040f and pdata ,0x0f ,temp 
+6349 1fe17ef0 and_into bt_evt_timer_mask ,pdata 
+634a c02863ec beq bt_evt_timer_init ,module_bb_event_timer 
+634b 20600000 rtn 
+
+module_process_bb_event_disconned:
+634c 2040638a call module_disconn_start 
+634d 680142a0 fetch app_disc_rsn_size ,mem_app_disconn_reason 
+634e c4020000 rtnbit0 app_disc_after_setup_done 
+634f df200003 arg 3 ,loopcnt 
+6350 d8c04849 arg mem_prarm_dis ,contr 
+6351 20207f71 branch send_mem_to_uart 
+
+module_sniff_param_check:
+6352 68014042 fetch 2 ,mem_context + coffset_tsniff 
+6353 1fe37e00 rshift pdata ,pdata 
+6354 68094280 fetcht 2 ,mem_sniff_param_interval 
+6355 98467c00 isub temp ,null 
+6356 2422e358 nbranch module_sniff_param_check_unsniff ,zero 
+6357 20203fa4 branch app_lpm_mult_enable 
+
+module_sniff_param_check_unsniff:
+6358 6800c813 fetch 1 ,mem_module_task 
+6359 c3800000 rtnbit1 at_task_unsinff 
+635a 68110112 hfetch 2 ,core_uart_rxitems 
+635b 245a640c ncall at_set_unsniff_task_flag ,blank 
+635c 20203f9c branch app_bt_sniff_exit 
+
+module_process_setup_complete:
+635d 20406395 call module_conn_start 
+635e 2040642e call module_check_cmode 
+635f 2022e361 branch module_uart_send_conn ,zero 
+6360 20203f77 branch app_bt_disconnect 
+
+module_uart_send_conn:
+6361 df200004 arg 4 ,loopcnt 
+6362 d8c0488e arg mem_prarm_conn ,contr 
+6363 20207f71 branch send_mem_to_uart 
+
+module_process_bb_even_le_disconn:
+6364 2040638a call module_disconn_start 
+6365 df200005 arg 5 ,loopcnt 
+6366 d8c04847 arg mem_prarm_bledis ,contr 
+6367 20207f71 branch send_mem_to_uart 
+
+module_process_evt_pincode_req:
+6368 20403fc1 call at_restore_pin_code 
+6369 20203f6a branch app_bt_set_pincode 
+
+module_process_switch_not_accept:
+636a 6800c813 fetch 1 ,mem_module_task 
+636b c4020000 rtnbit0 at_task_switch 
+636c 793ffe04 set0 at_task_switch ,pdata 
+636d 6000c813 store 1 ,mem_module_task 
+636e 2020427f branch at_error_rev_end 
+
+module_process_switch_accept:
+636f 6800c813 fetch 1 ,mem_module_task 
+6370 c4020000 rtnbit0 at_task_switch 
+6371 793ffe04 set0 at_task_switch ,pdata 
+6372 6000c813 store 1 ,mem_module_task 
+6373 20204286 branch at_nomal_rev_end 
+
+module_process_sniff_accept:
+6374 20600000 rtn 
+
+module_process_sniff_not_accept:
+6375 20600000 rtn 
+
+module_process_unsniff_accept:
+6376 6800c813 fetch 1 ,mem_module_task 
+6377 c3003f9e bbit0 at_task_unsinff ,app_bt_enter_sniff 
+6378 20206410 branch at_clear_unsniff_task_flag 
+
+module_process_unsniff_not_accept:
+6379 20600000 rtn 
+
+module_process_le_conn:
+637a 20406395 call module_conn_start 
+637b da4003d0 arg mem_le_plap ,regb 
+637c 2040642e call module_check_cmode 
+637d 2022e37f branch module_uart_send_leconn ,zero 
+637e 20203f90 branch app_ble_disconnect 
+
+module_uart_send_leconn:
+637f df200006 arg 6 ,loopcnt 
+6380 d8c0488c arg mem_prarm_bleconn ,contr 
+6381 20207f71 branch send_mem_to_uart 
+
+module_process_bb_conn:
+6382 20600000 rtn 
+
+module_reconn_fail:
+6383 df200007 arg 7 ,loopcnt 
+6384 d8c04899 arg mem_prarm_recfail ,contr 
+6385 20407f71 call send_mem_to_uart 
+6386 2020638a branch module_disconn_start 
+
+module_page_time_out:
+6387 df200007 arg 7 ,loopcnt 
+6388 d8c04892 arg mem_prarm_pageout ,contr 
+6389 20407f71 call send_mem_to_uart 
+
+module_disconn_start:
+638a 2040638c call module_start_adv_discovery 
+638b 20206393 branch module_set_conn_pin_high 
+
+module_start_adv_discovery:
+638c 6800c812 fetch 1 ,mem_module_state 
+638d 2feffe00 isolate1 at_state_set30 ,pdata 
+638e 2040bf7c call app_bt_start_discovery ,true 
+638f 6800c812 fetch 1 ,mem_module_state 
+6390 2feffe01 isolate1 at_state_set40 ,pdata 
+6391 2040bf88 call app_ble_start_adv ,true 
+6392 20600000 rtn 
+
+module_set_conn_pin_high:
+6393 6808c803 fetcht 1 ,mem_module_connect_state_gpio 
+6394 202069ef branch gpio_out_active 
+
+module_conn_start:
+6395 20406397 call module_stop_adv_discovery 
+6396 2020639e branch module_set_conn_pin_low 
+
+module_stop_adv_discovery:
+6397 6800c812 fetch 1 ,mem_module_state 
+6398 2feffe00 isolate1 at_state_set30 ,pdata 
+6399 2040bf7e call app_bt_stop_discovery ,true 
+639a 6800c812 fetch 1 ,mem_module_state 
+639b 2feffe01 isolate1 at_state_set40 ,pdata 
+639c 2040bf86 call app_ble_stop_adv ,true 
+639d 20600000 rtn 
+
+module_set_conn_pin_low:
+639e 6808c803 fetcht 1 ,mem_module_connect_state_gpio 
+639f 202069ed branch gpio_out_inactive 
+
+module_process:
+63a0 6800c132 fetch 1 ,mem_device_option 
+63a1 c1850000 rtnne dvc_op_module 
+63a2 68110112 hfetch 2 ,core_uart_rxitems 
+63a3 207a0000 rtn blank 
+63a4 6001480e store 2 ,mem_current_packet_length 
+63a5 204063a9 call spp_mode 
+63a6 2020bfef branch at_process ,true 
+63a7 20406400 call at_ckeck_send_buff 
+63a8 202063af branch module_tx_packet 
+
+spp_mode:
+63a9 6808c800 fetcht 1 ,mem_at_gpio 
+63aa 202069e5 branch gpio_get_bit 
+
+module_exit_sniff:
+63ab 6800c813 fetch 1 ,mem_module_task 
+63ac c3800000 rtnbit1 at_task_unsinff 
+63ad 2040640c call at_set_unsniff_task_flag 
+63ae 20203f9c branch app_bt_sniff_exit 
+
+module_tx_packet:
+63af 6800c040 fetch 1 ,mem_context 
+63b0 c300428c bbit0 state_inconn ,spp_send_end 
+63b1 6800c041 fetch 1 ,mem_context + coffset_mode 
+63b2 c28063d5 bbit1 mode_le ,modle_le_tx 
+63b3 20403f40 call app_check_sniff 
+63b4 2020e3ab branch module_exit_sniff ,true 
+63b5 20206d97 branch spp_tx_rfcomm_packet 
+
+module_le_rx:
+63b6 20405a88 call le_att_get_handle_ptr 
+63b7 e8c08000 ifetch 1 ,contr 
+63b8 18c22200 copy contr ,rega 
+63b9 20407f6e call get_uart_twptr 
+63ba 1a427200 copy regb ,loopcnt 
+63bb 1a220c00 copy rega ,contr 
+63bc 20404976 call uart_copy_tx_bytes 
+63bd 202068fa branch uartd_send 
+
+module_le_tx_update_data:
+63be 68014810 fetch 2 ,mem_module_prepare_tx_len 
+63bf 207a0000 rtn blank 
+63c0 d8400014 arg dm_le_buff_len ,temp 
+63c1 20407fb9 call not_greater_than 
+63c2 60010469 store 2 ,mem_module_temp_len 
+63c3 1fe20400 copy pdata ,temp 
+63c4 68014810 fetch 2 ,mem_module_prepare_tx_len 
+63c5 98467e00 isub temp ,pdata 
+63c6 60014810 store 2 ,mem_module_prepare_tx_len 
+63c7 24213bf1 nbranch assert ,positive 
+63c8 d8400014 arg prcp_tx_le ,temp 
+63c9 600944c2 storet 2 ,mem_le_notify_handle 
+63ca 20405a88 call le_att_get_handle_ptr 
+63cb 203a3bf1 branch assert ,blank 
+63cc 18c08a01 add contr ,1 ,contw 
+63cd 68010469 fetch 2 ,mem_module_temp_len 
+63ce 1fe27200 copy pdata ,loopcnt 
+63cf 20407f6b call get_uart_rrptr 
+63d0 2040497c call uart_copy_rx_bytes 
+63d1 68010469 fetch 2 ,mem_module_temp_len 
+63d2 6001480e store 2 ,mem_current_packet_length 
+63d3 6001041b store 2 ,mem_le_notify_len 
+63d4 2020428c branch spp_send_end 
+
+modle_le_tx:
+63d5 c6848000 rtnmark0 mark_context 
+63d6 204063d8 call modle_le_tx_once 
+63d7 204063d8 call modle_le_tx_once 
+
+modle_le_tx_once:
+63d8 2040561e call le_xtype_fifo_is_near_full 
+63d9 247a0000 nrtn blank 
+63da 68110112 hfetch 2 ,core_uart_rxitems 
+63db 207a0000 rtn blank 
+63dc 68094810 fetcht 2 ,mem_module_prepare_tx_len 
+63dd 98467e00 isub temp ,pdata 
+63de 24213bf1 nbranch assert ,positive 
+63df 6001480e store 2 ,mem_current_packet_length 
+63e0 207a0000 rtn blank 
+63e1 20406407 call at_ckeck_send_buff_le 
+63e2 68014810 fetch 2 ,mem_module_prepare_tx_len 
+63e3 6809480e fetcht 2 ,mem_current_packet_length 
+63e4 9840fe00 iadd temp ,pdata 
+63e5 60014810 store 2 ,mem_module_prepare_tx_len 
+63e6 68094810 fetcht 2 ,mem_module_prepare_tx_len 
+63e7 68110112 hfetch 2 ,core_uart_rxitems 
+63e8 98462200 isub temp ,rega 
+63e9 24213bf1 nbranch assert ,positive 
+63ea 700b7d1b jam attop_handle_value_notification ,mem_fifo_temp 
+63eb 20205620 branch le_xtype_fifo_in 
+
+module_bb_event_timer:
+63ec 60088259 storet 1 ,mem_app_evt_timer_count 
+
+module_bb_event_100ms_loop:
+63ed 68008259 fetch 1 ,mem_app_evt_timer_count 
+63ee 207a0000 rtn blank 
+63ef 1fe0ffff increase -1 ,pdata 
+63f0 60008259 store 1 ,mem_app_evt_timer_count 
+63f1 204063f3 call module_bb_event_hud_ms 
+63f2 202063ed branch module_bb_event_100ms_loop 
+
+module_bb_event_hud_ms:
+63f3 6801481a fetch 2 ,mem_at_scan_time 
+63f4 207a0000 rtn blank 
+63f5 1fe0ffff increase -1 ,pdata 
+63f6 6001481a store 2 ,mem_at_scan_time 
+63f7 247a0000 nrtn blank 
+63f8 6800c2a4 fetch 1 ,mem_at_using_flag 
+63f9 7042a400 jam 0 ,mem_at_using_flag 
+63fa c280e3fd bbit1 at_flag_leinq ,modue_le_inq 
+63fb c28063fe bbit1 at_flag_inq ,module_inq 
+63fc 20203bf1 branch assert 
+
+modue_le_inq:
+63fd 20203f8c branch app_ble_stop_scan 
+
+module_inq:
+63fe 70427202 jam hci_cmd_inquiry_cancel ,mem_hci_cmd 
+63ff 20600000 rtn 
+
+at_ckeck_send_buff:
+6400 6800c041 fetch 1 ,mem_context + coffset_mode 
+6401 c2806407 bbit1 mode_le ,at_ckeck_send_buff_le 
+6402 6801480e fetch 2 ,mem_current_packet_length 
+6403 d840006e arg dm_refcom_buff_len ,temp 
+6404 20407fb9 call not_greater_than 
+6405 6001480e store 2 ,mem_current_packet_length 
+6406 20600000 rtn 
+
+at_ckeck_send_buff_le:
+6407 6801480e fetch 2 ,mem_current_packet_length 
+6408 d8400014 arg dm_le_buff_len ,temp 
+6409 20407fb9 call not_greater_than 
+640a 6001480e store 2 ,mem_current_packet_length 
+640b 20600000 rtn 
+
+at_set_unsniff_task_flag:
+640c 6800c813 fetch 1 ,mem_module_task 
+640d 79207e00 set1 at_task_unsinff ,pdata 
+640e 6000c813 store 1 ,mem_module_task 
+640f 20600000 rtn 
+
+at_clear_unsniff_task_flag:
+6410 6800c813 fetch 1 ,mem_module_task 
+6411 793ffe00 set0 at_task_unsinff ,pdata 
+6412 6000c813 store 1 ,mem_module_task 
+6413 20600000 rtn 
+
+at_set_cmd_task_flag:
+6414 6800c813 fetch 1 ,mem_module_task 
+6415 79207e07 set1 at_task_cmd_flag ,pdata 
+6416 6000c813 store 1 ,mem_module_task 
+6417 20600000 rtn 
+
+at_clear_cmd_task_flag:
+6418 6800c813 fetch 1 ,mem_module_task 
+6419 793ffe07 set0 at_task_cmd_flag ,pdata 
+641a 6000c813 store 1 ,mem_module_task 
+641b 20600000 rtn 
+
+module_control_air_flow:
+641c 79200025 set1 mark_ext_patch ,mark 
+641d 44c14030 bpatch patch30_2 ,mem_patch30 
+641e 20407f8e call check_uart_tx_buff 
+641f 20213f66 branch app_l2cap_flow_control_enable ,positive 
+6420 20203f68 branch app_l2cap_flow_control_disable 
+
+module_uart_set:
+6421 204063a9 call spp_mode 
+6422 2020e428 branch module_set_baud_115200 ,true 
+6423 68190052 hfetcht uart_baud_len ,core_uart_baud 
+6424 680142ac fetch 2 ,mem_baud 
+6425 98467c00 isub temp ,null 
+6426 20628000 rtn zero 
+6427 20206909 branch uart_set_baud_by_mem 
+
+module_set_baud_115200:
+6428 68190052 hfetcht uart_baud_len ,core_uart_baud 
+6429 580001a0 setarg at_baud_115200 
+642a 98467c00 isub temp ,null 
+642b 20628000 rtn zero 
+642c 60110052 hstore uart_baud_len ,core_uart_baud 
+642d 20600000 rtn 
+
+module_check_cmode:
+642e 79200025 set1 mark_ext_patch ,mark 
+642f 44c1c030 bpatch patch30_3 ,mem_patch30 
+6430 6800c812 fetch 1 ,mem_module_state 
+6431 2fec0002 isolate0 at_state_cmode ,pdata 
+6432 2020e436 branch module_check_cmode_close ,true 
+6433 da204814 arg mem_cmode_addr ,rega 
+6434 df200006 arg 6 ,loopcnt 
+6435 20207f25 branch string_compare 
+
+module_check_cmode_close:
+6436 18007c00 force 0 ,null 
+6437 20600000 rtn 
+
+module_init_static_string:
+6438 79200025 set1 mark_ext_patch ,mark 
+6439 44c24030 bpatch patch30_4 ,mem_patch30 
+643a d8a0481c arg mem_prarm_pswd ,contw 
+643b 38035350 setsect 0 ,0x35350 
+643c 38055115 setsect 1 ,0x15115 
+643d 38092415 setsect 2 ,0x12415 
+643e 380d0951 setsect 3 ,0x10951 
+643f e0a48000 istore 9 ,contw 
+6440 3802454c setsect 0 ,0x2454c 
+6441 38075053 setsect 1 ,0x35053 
+6442 38082454 setsect 2 ,0x2454 
+6443 380d1531 setsect 3 ,0x11531 
+6444 e0a48000 istore 9 ,contw 
+6445 38034441 setsect 0 ,0x34441 
+6446 380594d4 setsect 1 ,0x194d4 
+6447 38092455 setsect 2 ,0x12455 
+6448 380d0d4d setsect 3 ,0x10d4d 
+6449 e0a48000 istore 9 ,contw 
+644a 3803414c setsect 0 ,0x3414c 
+644b 3804d4d4 setsect 1 ,0xd4d4 
+644c 380924c4 setsect 2 ,0x124c4 
+644d 380d3119 setsect 3 ,0x13119 
+644e e0a48000 istore 9 ,contw 
+644f 38015247 setsect 0 ,0x15247 
+6450 3807d0d1 setsect 1 ,0x3d0d1 
+6451 3808e4e4 setsect 2 ,0xe4e4 
+6452 380d1531 setsect 3 ,0x11531 
+6453 e0a48000 istore 9 ,contw 
+6454 38034944 setsect 0 ,0x34944 
+6455 380514d4 setsect 1 ,0x114d4 
+6456 3808e535 setsect 2 ,0xe535 
+6457 380d5105 setsect 3 ,0x15105 
+6458 e0a48000 istore 9 ,contw 
+6459 38014c2b setsect 0 ,0x14c2b 
+645a 380514d2 setsect 1 ,0x114d2 
+645b 3808f525 setsect 2 ,0xf525 
+645c 380d1531 setsect 3 ,0x11531 
+645d e0a48000 istore 9 ,contw 
+645e 38014e53 setsect 0 ,0x14e53 
+645f 38059192 setsect 1 ,0x19192 
+6460 380844c4 setsect 2 ,0x44c4 
+6461 380d5915 setsect 3 ,0x15915 
+6462 e0a48000 istore 9 ,contw 
+6463 38035352 setsect 0 ,0x35352 
+6464 3804d254 setsect 1 ,0xd254 
+6465 38085444 setsect 2 ,0x5444 
+6466 380d0959 setsect 3 ,0x10959 
+6467 e0a48000 istore 9 ,contw 
+6468 3801454c setsect 0 ,0x1454c 
+6469 38045392 setsect 1 ,0x5392 
+646a 38083525 setsect 2 ,0x3525 
+646b 380d3d35 setsect 3 ,0x13d35 
+646c e0a48000 istore 9 ,contw 
+646d 38014544 setsect 0 ,0x14544 
+646e 380513d3 setsect 1 ,0x113d3 
+646f 38084454 setsect 2 ,0x4454 
+6470 380d4d35 setsect 3 ,0x14d35 
+6471 e0a48000 istore 9 ,contw 
+6472 38004154 setsect 0 ,0x4154 
+6473 38051155 setsect 1 ,0x11155 
+6474 38093494 setsect 2 ,0x13494 
+6475 380d3d0d setsect 3 ,0x13d0d 
+6476 e0a48000 istore 9 ,contw 
+6477 38004f56 setsect 0 ,0x4f56 
+6478 38071055 setsect 1 ,0x31055 
+6479 38083454 setsect 2 ,0x3454 
+647a 380d393d setsect 3 ,0x1393d 
+647b e0a48000 istore 9 ,contw 
+647c 3801504e setsect 0 ,0x1504e 
+647d 380551d0 setsect 1 ,0x151d0 
+647e 380954f4 setsect 2 ,0x154f4 
+647f 380d4951 setsect 3 ,0x14951 
+6480 e0a48000 istore 9 ,contw 
+6481 38024345 setsect 0 ,0x24345 
+6482 38065051 setsect 1 ,0x25051 
+6483 380804c4 setsect 2 ,0x4c4 
+6484 e0a30000 istore 6 ,contw 
+6485 20600000 rtn 
+
+mouse_init:
+6486 580065d7 setarg le_mouse 
+6487 6001428c store 2 ,mem_cb_le_process 
+6488 5800652e setarg mouse_send_process 
+6489 6001428e store 2 ,mem_cb_bt_process 
+648a 580064e3 setarg mouse_process_lpm_before 
+648b 6001428a store 2 ,mem_cb_before_lpm 
+648c 580065f3 setarg mouse_priority_bb_event 
+648d 60014292 store 2 ,mem_cb_bb_event_process 
+648e 580064a9 setarg mouse_idle 
+648f 60014290 store 2 ,mem_cb_idle_process 
+6490 58006561 setarg mouse_le_notify_update_data 
+6491 60014298 store 2 ,mem_cb_update_notify_value 
+6492 7007dc00 jam 0 ,mem_sp_flag 
+6493 7007dd00 jam 0 ,mem_master_sp_flag 
+6494 793f8025 set0 mark_ext_patch ,mark 
+6495 44e04018 bpatch patch18_0 ,mem_patch18 
+6496 204064c4 call mouse_init_common 
+6497 20758000 rtn wake 
+6498 2040649f call mouse_init_environment 
+6499 204064a7 call mouse_dpi_init 
+649a 580064e0 setarg mouse_before_hibernate 
+649b 60014288 store 2 ,mem_cb_before_hibernate 
+649c 680147f4 fetch 2 ,mem_ui_state_map 
+649d c2866697 bbit1 ui_state_btn_down ,mouse_start_discovery 
+649e 20206693 branch mouse_check_reconn_target 
+
+mouse_init_environment:
+649f 20403f4d call app_initflag_check 
+64a0 2022e4a4 branch mouse_load_eeprom_param ,zero 
+64a1 20406963 call eeprom_store_le_local_addr 
+64a2 204066ba call eeprom_store_mouse_dpi 
+64a3 20203f45 branch app_initflag_store 
+
+mouse_load_eeprom_param:
+64a4 2040691d call eeprom_load_reconn_info 
+64a5 20406967 call eeprom_load_le_loacal_addr 
+64a6 202066c0 branch eeprom_load_mouse_dpi 
+
+mouse_dpi_init:
+64a7 70481c01 jam dpi_button_state_up ,mem_mouse_dpi_button_state 
+64a8 202064bb branch mouse_modified_dpi 
+
+mouse_idle:
+64a9 20407cd7 call ui_check_paring_button 
+64aa 204064ac call mouse_check_dpi 
+64ab 202064f6 branch mouse_wheel_check 
+
+mouse_check_dpi:
+64ac 6808c825 fetcht 1 ,mem_dpi_button_gpio 
+64ad 204069e5 call gpio_get_bit 
+64ae 2420e4b3 nbranch mouse_dpi_up ,true 
+
+mouse_dpi_down:
+64af 6800c81c fetch 1 ,mem_mouse_dpi_button_state 
+64b0 c1000000 rtneq dpi_button_state_down 
+64b1 70481c00 jam dpi_button_state_down ,mem_mouse_dpi_button_state 
+64b2 20600000 rtn 
+
+mouse_dpi_up:
+64b3 6800c81c fetch 1 ,mem_mouse_dpi_button_state 
+64b4 c1008000 rtneq dpi_button_state_up 
+64b5 70481c01 jam dpi_button_state_up ,mem_mouse_dpi_button_state 
+64b6 6800c81b fetch 1 ,mem_mouse_dpi 
+64b7 1fe0fe01 increase 1 ,pdata 
+64b8 1fe17e03 and pdata ,0x03 ,pdata 
+64b9 6000c81b store 1 ,mem_mouse_dpi 
+64ba 202064bb branch mouse_modified_dpi 
+
+mouse_modified_dpi:
+64bb 58000006 setarg mouse_dpi_address 
+64bc 204066d8 call twspi_read 
+64bd 1fe104fc and pdata ,0xfc ,temp 
+64be 6800c81b fetch 1 ,mem_mouse_dpi 
+64bf 9840fe00 iadd temp ,pdata 
+64c0 1fed7e00 lshift8 pdata ,pdata 
+64c1 1fe0fe06 add pdata ,mouse_dpi_address ,pdata 
+64c2 204066d7 call twspi_write 
+64c3 202066ba branch eeprom_store_mouse_dpi 
+
+mouse_init_common:
+64c4 204065c5 call mouse_init_sunt 
+64c5 204064ca call mouse_gpio_init 
+64c6 68110050 hfetch 2 ,core_clkoff 
+64c7 793ffe0b set0 clock_off_qdecoder ,pdata 
+64c8 60110050 hstore 2 ,core_clkoff 
+64c9 20600000 rtn 
+
+mouse_gpio_init:
+64ca 20403e0b call lpm_disable_exen_output 
+64cb 6808c827 fetcht 1 ,mem_whee_a_data_gpio 
+64cc 204069d1 call gpio_config_input 
+64cd 6808c828 fetcht 1 ,mem_whee_b_data_gpio 
+64ce 204069d1 call gpio_config_input 
+64cf 6808c822 fetcht 1 ,mem_lbutton_gpio 
+64d0 204069d1 call gpio_config_input 
+64d1 6808c823 fetcht 1 ,mem_rbutton_gpio 
+64d2 204069d1 call gpio_config_input 
+64d3 6808c824 fetcht 1 ,mem_mbutton_gpio 
+64d4 204069d1 call gpio_config_input 
+64d5 6808c826 fetcht 1 ,mem_sensor_data_gpio 
+64d6 204069d1 call gpio_config_input 
+64d7 6808c825 fetcht 1 ,mem_dpi_button_gpio 
+64d8 204069d1 call gpio_config_input 
+64d9 6810807b hfetch 1 ,core_gpio_pu3 
+64da 1fe1fe18 or_into 0x18 ,pdata 
+64db 6010807b hstore 1 ,core_gpio_pu3 
+64dc 6810807f hfetch 1 ,core_gpio_pd2 + 1 
+64dd 1fe17ee7 and_into 0xe7 ,pdata 
+64de 6010807f hstore 1 ,core_gpio_pd2 + 1 
+64df 20600000 rtn 
+
+mouse_before_hibernate:
+64e0 5800bc05 setarg 0xbc05 
+64e1 204066d7 call twspi_write 
+64e2 7000a201 jam 1 ,mem_lpm_current_mult 
+
+mouse_process_lpm_before:
+64e3 204064f6 call mouse_wheel_check 
+64e4 d8400019 arg 25 ,temp 
+64e5 204069da call gpio_config_output 
+64e6 70808100 hjam 0 ,core_gpio_sel1 
+64e7 6808c827 fetcht 1 ,mem_whee_a_data_gpio 
+64e8 204069b4 call gpio_set_wake_by_current_state 
+64e9 6808c828 fetcht 1 ,mem_whee_b_data_gpio 
+64ea 204069b4 call gpio_set_wake_by_current_state 
+64eb 6808c822 fetcht 1 ,mem_lbutton_gpio 
+64ec 204069b4 call gpio_set_wake_by_current_state 
+64ed 6808c823 fetcht 1 ,mem_rbutton_gpio 
+64ee 204069b4 call gpio_set_wake_by_current_state 
+64ef 6808c824 fetcht 1 ,mem_mbutton_gpio 
+64f0 204069b4 call gpio_set_wake_by_current_state 
+64f1 6808c826 fetcht 1 ,mem_sensor_data_gpio 
+64f2 204069b9 call gpio_set_wake 
+64f3 680080a2 fetch 1 ,mem_lpm_current_mult 
+64f4 247a0000 nrtn blank 
+64f5 202069c4 branch gpio_clr_wake 
+
+mouse_wheel_check:
+64f6 793f8025 set0 mark_ext_patch ,mark 
+64f7 44e0c018 bpatch patch18_1 ,mem_patch18 
+64f8 da200000 arg 0 ,rega 
+64f9 6808c827 fetcht 1 ,mem_whee_a_data_gpio 
+64fa 204069e5 call gpio_get_bit 
+64fb 7920a200 setflag true ,0 ,rega 
+64fc 6808c828 fetcht 1 ,mem_whee_b_data_gpio 
+64fd 204069e5 call gpio_get_bit 
+64fe 7920a201 setflag true ,1 ,rega 
+64ff 1a227e00 copy rega ,pdata 
+6500 1fe17e03 and_into 0x3 ,pdata 
+6501 6808c808 fetcht 1 ,mem_mouse_z_now 
+6502 6000c808 store 1 ,mem_mouse_z_now 
+6503 98467c00 isub temp ,null 
+6504 2022e514 branch mouse_wheel_clear ,zero 
+6505 6800c807 fetch 1 ,mem_mouse_z_before 
+6506 6000c806 store 1 ,mem_mouse_z_last 
+6507 6008c807 storet 1 ,mem_mouse_z_before 
+6508 6800c808 fetch 1 ,mem_mouse_z_now 
+6509 1ff27e00 lshift4 pdata ,pdata 
+650a 6808c807 fetcht 1 ,mem_mouse_z_before 
+650b 184b8400 lshift2 temp ,temp 
+650c 9840fe00 iadd temp ,pdata 
+650d 6808c806 fetcht 1 ,mem_mouse_z_last 
+650e 9840fe00 iadd temp ,pdata 
+650f c01c6515 beq 0x38 ,mouse_wheel_forward 
+6510 c01a6519 beq 0x34 ,mouse_wheel_back 
+6511 c005e519 beq 0x0b ,mouse_wheel_back 
+6512 c003e515 beq 0x07 ,mouse_wheel_forward 
+6513 20600000 rtn 
+
+mouse_wheel_clear:
+6514 20600000 rtn 
+
+mouse_wheel_forward:
+6515 6800c809 fetch 1 ,mem_mouse_z_data 
+6516 1fe0fe01 increase 1 ,pdata 
+6517 6000c809 store 1 ,mem_mouse_z_data 
+6518 20600000 rtn 
+
+mouse_wheel_back:
+6519 6800c809 fetch 1 ,mem_mouse_z_data 
+651a 1fe0ffff increase -1 ,pdata 
+651b 6000c809 store 1 ,mem_mouse_z_data 
+651c 20600000 rtn 
+
+mouse_process_ble:
+651d 20600000 rtn 
+
+mouse_sleep_sensor:
+651e 5800b805 setarg 0xB805 
+651f 202066d7 branch twspi_write 
+
+mouse_bb_connected:
+6520 20600000 rtn 
+
+le_mouse_bb_event_write_request:
+6521 20403fa0 call app_ble_store_reconn_info 
+6522 70482002 jam mouse_mode_state_ble ,mem_mouse_mode_state 
+6523 20403fa4 call app_lpm_mult_enable 
+
+le_mouse_bb_event_enc_info:
+6524 20203f92 branch app_ble_start_write 
+
+le_hibernate_timer:
+6525 6801481e fetch 2 ,mem_le_hibernate_timer 
+6526 207a0000 rtn blank 
+6527 1fe0ffff increase -1 ,pdata 
+6528 6001481e store 2 ,mem_le_hibernate_timer 
+6529 247a0000 nrtn blank 
+652a 20203f9a branch app_enter_hibernate 
+
+mouse_hid_connected:
+652b 58000002 setarg hid_handshake_timeout 
+652c 6000c7f2 store 1 ,mem_hid_handshake_timer_count 
+652d 20600000 rtn 
+
+mouse_send_process:
+652e 6800c27f fetch 1 ,mem_app_handshake_flag 
+652f 207a0000 rtn blank 
+6530 2040527c call l2cap_malloc_is_fifo_nearly_full 
+6531 247a0000 nrtn blank 
+6532 20406578 call mouse_motion 
+6533 24740000 nrtn user 
+6534 2040655e call mouse_no_data_timer_init 
+6535 2040655a call mouse_send_blank_packet_timer_init 
+
+mouse_send_data:
+6536 da200008 arg 8 ,rega 
+6537 20404b2c call hid_malloc_tx_buff 
+6538 680142b7 fetch 2 ,mem_hid_int_remote_cid 
+6539 e0a10000 istore 2 ,contw 
+653a 580002a1 setarg 0x02a1 
+653b e0a10000 istore 2 ,contw 
+653c 6800c805 fetch 1 ,mem_mouse_key 
+653d e0a08000 istore 1 ,contw 
+653e 68014800 fetch 2 ,mem_mouse_x 
+653f d8400fff arg 0xfff ,temp 
+6540 98417e00 iand temp ,pdata 
+6541 68094802 fetcht 2 ,mem_mouse_y 
+6542 18520400 lshift4 temp ,temp 
+6543 184d0400 lshift8 temp ,temp 
+6544 9841fe00 ior temp ,pdata 
+6545 e0a18000 istore 3 ,contw 
+6546 6800c804 fetch 1 ,mem_mouse_z 
+6547 e0a08000 istore 1 ,contw 
+6548 58000000 setarg 0 
+6549 e0a08000 istore 1 ,contw 
+654a 7008a808 jam 8 ,mem_ui_data_txbuff_length 
+654b 20600000 rtn 
+
+mouse_send_blank_packet_timer:
+654c 793f8025 set0 mark_ext_patch ,mark 
+654d 44e14018 bpatch patch18_2 ,mem_patch18 
+654e 6800c81a fetch 1 ,mem_mouse_send_blank_timer 
+654f 207a0000 rtn blank 
+6550 1fe0ffff increase -1 ,pdata 
+6551 6000c81a store 1 ,mem_mouse_send_blank_timer 
+6552 247a0000 nrtn blank 
+6553 2040527e call l2cap_malloc_is_fifo_empty 
+6554 247a0000 nrtn blank 
+6555 58000000 setarg 0 
+6556 6002c800 store 5 ,mem_mouse_x 
+6557 20406536 call mouse_send_data 
+6558 70481a50 jam mouse_send_blank_timer ,mem_mouse_send_blank_timer 
+6559 20600000 rtn 
+
+mouse_send_blank_packet_timer_init:
+655a 68014810 fetch 2 ,mem_mouse_blank_data_timeout 
+655b 60014818 store 2 ,mem_mouse_blank_data_timer 
+655c 70481a50 jam mouse_send_blank_timer ,mem_mouse_send_blank_timer 
+655d 20600000 rtn 
+
+mouse_no_data_timer_init:
+655e 6801480e fetch 2 ,mem_mouse_no_data_timeout 
+655f 60014816 store 2 ,mem_mouse_no_data_timer 
+6560 20600000 rtn 
+
+mouse_le_notify_update_data:
+6561 680944c2 fetcht 2 ,mem_le_notify_handle 
+6562 20405a88 call le_att_get_handle_ptr 
+6563 e8c08000 ifetch 1 ,contr 
+6564 6000841b store 1 ,mem_le_notify_len 
+6565 20600000 rtn 
+
+mouse_fill_data_le:
+6566 793f8025 set0 mark_ext_patch ,mark 
+6567 44e1c018 bpatch patch18_3 ,mem_patch18 
+6568 680944c2 fetcht 2 ,mem_le_notify_handle 
+6569 20405a88 call le_att_get_handle_ptr 
+656a 18c08a01 add contr ,1 ,contw 
+
+mouse_fill_data:
+656b 6800c805 fetch 1 ,mem_mouse_key 
+656c e0a08000 istore 1 ,contw 
+656d 68014800 fetch 2 ,mem_mouse_x 
+656e d8400fff arg 0xfff ,temp 
+656f 98417e00 iand temp ,pdata 
+6570 68094802 fetcht 2 ,mem_mouse_y 
+6571 18520400 lshift4 temp ,temp 
+6572 184d0400 lshift8 temp ,temp 
+6573 9841fe00 ior temp ,pdata 
+6574 e0a18000 istore 3 ,contw 
+6575 6800c804 fetch 1 ,mem_mouse_z 
+6576 e0a08000 istore 1 ,contw 
+6577 20600000 rtn 
+
+mouse_motion:
+6578 793f8025 set0 mark_ext_patch ,mark 
+6579 44e24018 bpatch patch18_4 ,mem_patch18 
+657a 78547c00 disable user 
+657b 58000000 setarg 0 
+657c 6002c800 store 5 ,mem_mouse_x 
+657d 20406581 call p3204_motion 
+657e 204065b4 call p3204_sdio_low 
+657f 2040659c call mouse_zwheel 
+6580 202065a2 branch mouse_key 
+
+p3204_motion:
+6581 6800c821 fetch 1 ,mem_sensor_type 
+6582 c1810000 rtnne sensor_type_p3204 
+6583 6800c80a fetch 1 ,mem_mouse_move_flag 
+6584 205a65ba call p3204_clear_data ,blank 
+6585 70480a01 jam 1 ,mem_mouse_move_flag 
+6586 78547c00 disable user 
+6587 6808c826 fetcht 1 ,mem_sensor_data_gpio 
+6588 204069e5 call gpio_get_bit 
+6589 24608000 nrtn true 
+658a 58000000 setarg 0 
+658b 204066d8 call twspi_read 
+658c c09866c6 bne p3204_id ,twspi_reset 
+658d 58000002 setarg 2 
+658e 204066d8 call twspi_read 
+658f c4038000 rtnbit0 7 
+6590 58000003 setarg 3 
+6591 204066d8 call twspi_read 
+6592 204065d3 call extsign 
+6593 60014800 store 2 ,mem_mouse_x 
+6594 58000004 setarg 4 
+6595 204066d8 call twspi_read 
+6596 204065d3 call extsign 
+6597 1fe67e00 sub pdata ,0 ,pdata 
+6598 60014802 store 2 ,mem_mouse_y 
+6599 68024800 fetch 4 ,mem_mouse_x 
+659a 78347c00 enable user 
+659b 20600000 rtn 
+
+mouse_zwheel:
+659c 6800c809 fetch 1 ,mem_mouse_z_data 
+659d 207a0000 rtn blank 
+659e 6000c804 store 1 ,mem_mouse_z 
+659f 70480900 jam 0 ,mem_mouse_z_data 
+65a0 78347c00 enable user 
+65a1 20600000 rtn 
+
+mouse_key:
+65a2 da200000 arg 0 ,rega 
+65a3 6808c822 fetcht 1 ,mem_lbutton_gpio 
+65a4 204069e5 call gpio_get_bit 
+65a5 7920a200 setflag true ,0 ,rega 
+65a6 6808c823 fetcht 1 ,mem_rbutton_gpio 
+65a7 204069e5 call gpio_get_bit 
+65a8 7920a201 setflag true ,1 ,rega 
+65a9 6808c824 fetcht 1 ,mem_mbutton_gpio 
+65aa 204069e5 call gpio_get_bit 
+65ab 7920a202 setflag true ,2 ,rega 
+65ac 1a227e00 deposit rega 
+65ad 6808c805 fetcht 1 ,mem_mouse_key 
+65ae 6000c805 store 1 ,mem_mouse_key 
+65af 9842fe00 ixor temp ,pdata 
+65b0 1fe67c00 sub pdata ,0 ,null 
+65b1 20628000 rtn zero 
+65b2 78347c00 enable user 
+65b3 20600000 rtn 
+
+p3204_sdio_low:
+65b4 d840001a arg 26 ,temp 
+65b5 204069e5 call gpio_get_bit 
+65b6 20608000 rtn true 
+65b7 58000000 setarg 0 
+65b8 204066d8 call twspi_read 
+65b9 202065b4 branch p3204_sdio_low 
+
+p3204_clear_data:
+65ba df200000 arg 0 ,loopcnt 
+
+p3204_clear_data_loop:
+65bb 58000002 setarg 2 
+65bc 204066d8 call twspi_read 
+65bd 20000064 nop 100 
+65be 1f20f201 increase 1 ,loopcnt 
+65bf 6808c826 fetcht 1 ,mem_sensor_data_gpio 
+65c0 204069e5 call gpio_get_bit 
+65c1 2020e5bb branch p3204_clear_data_loop ,true 
+65c2 1f227e00 deposit loopcnt 
+65c3 6001046b store 2 ,mem_init_cnt 
+65c4 20600000 rtn 
+
+mouse_init_sunt:
+65c5 2040678e call spid_init 
+65c6 20758000 rtn wake 
+
+mouse_init_p3204:
+65c7 58000000 setarg 0 
+65c8 204066d8 call twspi_read 
+65c9 60008256 store 1 ,mem_sensor_id 
+65ca c01865ce beq p3204_id ,mouse_init_p3204_cont 
+65cb 204066c6 call twspi_reset 
+65cc 20002710 nop 10000 
+65cd 202065c7 branch mouse_init_p3204 
+
+mouse_init_p3204_cont:
+65ce 58008006 setarg 0x8006 
+65cf 204066d7 call twspi_write 
+65d0 200003e8 nop 1000 
+65d1 70482102 jam sensor_type_p3204 ,mem_sensor_type 
+65d2 20600000 rtn 
+
+extsign:
+65d3 c4038000 rtnbit0 7 
+65d4 d840ff00 arg 0xff00 ,temp 
+65d5 9841fe00 ior temp ,pdata 
+65d6 20600000 rtn 
+
+le_mouse:
+65d7 2040561e call le_xtype_fifo_is_near_full 
+65d8 247a0000 nrtn blank 
+65d9 680944c2 fetcht 2 ,mem_le_notify_handle 
+65da 20405866 call le_att_check_notification_enable 
+65db c4000000 rtnbit0 0 
+65dc 6800c6f8 fetch 1 ,mem_le_switch_send_data 
+65dd c4000000 rtnbit0 0 
+65de 20406578 call mouse_motion 
+65df 24740000 nrtn user 
+65e0 2040655e call mouse_no_data_timer_init 
+65e1 700b7d1b jam attop_handle_value_notification ,mem_fifo_temp 
+65e2 20405620 call le_xtype_fifo_in 
+65e3 20206566 branch mouse_fill_data_le 
+
+mouse_test:
+65e4 20740000 rtn user 
+65e5 6800c81d fetch 1 ,mem_mouse_test_cnt 
+65e6 1fe0fe01 increase 1 ,pdata 
+65e7 6000c81d store 1 ,mem_mouse_test_cnt 
+65e8 d8400001 arg 1 ,temp 
+65e9 c303e5eb bbit0 7 ,mouse_test_pos 
+65ea d840ffff arg 0xffff ,temp 
+
+mouse_test_pos:
+65eb 600ac800 storet 5 ,mem_mouse_x 
+65ec 78347c00 enable user 
+65ed 20600000 rtn 
+
+mouse_check_mode_state:
+65ee 78547c00 disable user 
+65ef 6800c820 fetch 1 ,mem_mouse_mode_state 
+65f0 c1010000 rtneq mouse_mode_state_ble 
+65f1 78347c00 enable user 
+65f2 20600000 rtn 
+
+mouse_priority_bb_event:
+65f3 1a627e00 copy regc ,pdata 
+65f4 c00a6606 beq bt_evt_le_connected ,le_mouse_bb_event_connected 
+65f5 c000e6a6 beq bt_evt_bb_connected ,mouse_stop_discovery 
+65f6 c00ae617 beq bt_evt_le_disconnected ,mouse_bb_disconnected 
+65f7 c0016617 beq bt_evt_bb_disconnected ,mouse_bb_disconnected 
+65f8 c002e616 beq bt_evt_setup_complete ,mouse_bt_event_setup_complete 
+65f9 c008666a beq bt_evt_button_long_pressed ,mouse_bb_event_discovery_btn 
+65fa c009668a beq bt_evt_hid_handshake ,mouse_bt_hid_handshake 
+65fb c0036614 beq bt_evt_hid_connected ,mouse_bt_hid_connected 
+65fc c0146521 beq bt_evt_le_write_request ,le_mouse_bb_event_write_request 
+65fd c014e524 beq bt_evt_le_enc_info ,le_mouse_bb_event_enc_info 
+65fe c0026611 beq bt_evt_reconn_failed ,mouse_bb_event_reconn_failed 
+65ff c009e611 beq bt_evt_reconn_page_timeout ,mouse_bb_event_reconn_failed 
+6600 c005660f beq bt_evt_pincode_req ,mouse_bb_event_pincode 
+6601 c0173f57 beq bt_evt_remote_unsniff ,app_start_auto_sniff 
+6602 1fe1040f and pdata ,0x0f ,temp 
+6603 1fe17ef0 and_into bt_evt_timer_mask ,pdata 
+6604 c0286634 beq bt_evt_timer_init ,mouse_bb_event_timer 
+6605 20600000 rtn 
+
+le_mouse_bb_event_connected:
+6606 680142a2 fetch app_disc_rsn_size ,mem_app_disconn_reason_flag 
+6607 793ffe00 set0 app_disc_by_button ,pdata 
+6608 600142a2 store app_disc_rsn_size ,mem_app_disconn_reason_flag 
+6609 58000000 setarg 0 
+660a 60014814 store 2 ,mem_mouse_direct_timer 
+660b 6800c829 fetch 1 ,mem_conn_cnt 
+660c 1fe0fe01 increase 1 ,pdata 
+660d 6000c829 store 1 ,mem_conn_cnt 
+660e 202066a6 branch mouse_stop_discovery 
+
+mouse_bb_event_pincode:
+660f 204062e9 call pincode_reinit 
+6610 20203f6a branch app_bt_set_pincode 
+
+mouse_bb_event_reconn_failed:
+6611 680147f4 fetch 2 ,mem_ui_state_map 
+6612 c2866697 bbit1 ui_state_btn_down ,mouse_start_discovery 
+6613 20203f10 branch app_bb_hibernate 
+
+mouse_bt_hid_connected:
+6614 2040652b call mouse_hid_connected 
+6615 20600000 rtn 
+
+mouse_bt_event_setup_complete:
+6616 20600000 rtn 
+
+mouse_bb_disconnected:
+6617 793f8025 set0 mark_ext_patch ,mark 
+6618 44e2c018 bpatch patch18_5 ,mem_patch18 
+6619 20406621 call mouse_bb_discon_clear_stack 
+661a 680142a0 fetch app_disc_rsn_size ,mem_app_disconn_reason 
+661b c283e630 bbit1 app_disc_ble ,mouse4_0_event_bb_disconn 
+661c c2803f12 bbit1 app_disc_by_button ,app_disconn_reason_clear 
+661d c280e62a bbit1 app_disc_after_pairing ,mouse_event_light_state_pairing 
+661e c281662d bbit1 app_disc_after_reconn ,mouse_event_light_state_hibernate 
+661f c281e62d bbit1 app_disc_after_sniff ,mouse_event_light_state_hibernate 
+6620 20206697 branch mouse_start_discovery 
+
+mouse_bb_discon_clear_stack:
+6621 58000000 setarg 0 
+6622 60024806 store 4 ,mem_mouse_z_last 
+6623 70481a00 jam 0 ,mem_mouse_send_blank_timer 
+6624 70480a00 jam 0 ,mem_mouse_move_flag 
+6625 70427f00 jam app_handshake_null ,mem_app_handshake_flag 
+6626 70448b00 jam 0 ,mem_ltk_exists 
+6627 70482000 jam 0 ,mem_mouse_mode_state 
+6628 70480b00 jam 0 ,mem_reconnect_timeout 
+6629 20600000 rtn 
+
+mouse_event_light_state_pairing:
+662a c282e62d bbit1 app_disc_after_handshake ,mouse_event_light_state_hibernate 
+662b c281e62d bbit1 app_disc_after_sniff ,mouse_event_light_state_hibernate 
+662c 20206697 branch mouse_start_discovery 
+
+mouse_event_light_state_hibernate:
+662d 680147f4 fetch 2 ,mem_ui_state_map 
+662e c2866697 bbit1 ui_state_btn_down ,mouse_start_discovery 
+662f 20203f10 branch app_bb_hibernate 
+
+mouse4_0_event_bb_disconn:
+6630 20405b30 call le_clean_att_list_handle_enable 
+6631 680142a0 fetch app_disc_rsn_size ,mem_app_disconn_reason 
+6632 c2803f12 bbit1 app_disc_by_button ,app_disconn_reason_clear 
+6633 20203f10 branch app_bb_hibernate 
+
+mouse_bb_event_timer:
+6634 793f8025 set0 mark_ext_patch ,mark 
+6635 44e34018 bpatch patch18_6 ,mem_patch18 
+6636 60088259 storet 1 ,mem_app_evt_timer_count 
+
+mouse_bb_event_100ms_loop:
+6637 68008259 fetch 1 ,mem_app_evt_timer_count 
+6638 207a0000 rtn blank 
+6639 1fe0ffff increase -1 ,pdata 
+663a 60008259 store 1 ,mem_app_evt_timer_count 
+663b 20406649 call mouse_check_hid_handshake_timer 
+663c 2040664f call mouse_check_discovery_timeout_timer 
+663d 20406656 call mouse_check_direct_timeout_timer 
+663e 20406664 call mouse_check_no_data_timeout_timer 
+663f 6800c820 fetch 1 ,mem_mouse_mode_state 
+6640 2fe1fe02 compare mouse_mode_state_ble ,pdata ,0xff 
+6641 2040e648 call mouse4_0_bb_event_100ms ,true 
+6642 6800c820 fetch 1 ,mem_mouse_mode_state 
+6643 2fe1fe01 compare mouse_mode_state_bt ,pdata ,0xff 
+6644 2040e646 call mouse3_0_bb_event_100ms ,true 
+6645 20206637 branch mouse_bb_event_100ms_loop 
+
+mouse3_0_bb_event_100ms:
+6646 2040665d call mouse_check_blank_data_timeout_timer 
+6647 2020654c branch mouse_send_blank_packet_timer 
+
+mouse4_0_bb_event_100ms:
+6648 20600000 rtn 
+
+mouse_check_hid_handshake_timer:
+6649 6800c7f2 fetch 1 ,mem_hid_handshake_timer_count 
+664a 207a0000 rtn blank 
+664b 1fe0ffff increase -1 ,pdata 
+664c 6000c7f2 store 1 ,mem_hid_handshake_timer_count 
+664d 247a0000 nrtn blank 
+664e 2020668a branch mouse_bt_hid_handshake 
+
+mouse_check_discovery_timeout_timer:
+664f 68014812 fetch 2 ,mem_mouse_discovery_timer 
+6650 207a0000 rtn blank 
+6651 1fe0ffff increase -1 ,pdata 
+6652 60014812 store 2 ,mem_mouse_discovery_timer 
+6653 247a0000 nrtn blank 
+6654 204066a6 call mouse_stop_discovery 
+6655 20203f9a branch app_enter_hibernate 
+
+mouse_check_direct_timeout_timer:
+6656 68014814 fetch 2 ,mem_mouse_direct_timer 
+6657 207a0000 rtn blank 
+6658 1fe0ffff increase -1 ,pdata 
+6659 60014814 store 2 ,mem_mouse_direct_timer 
+665a 247a0000 nrtn blank 
+665b 20403f84 call app_ble_stop_direct_adv 
+665c 20203f9a branch app_enter_hibernate 
+
+mouse_check_blank_data_timeout_timer:
+665d 68014818 fetch 2 ,mem_mouse_blank_data_timer 
+665e 207a0000 rtn blank 
+665f 1fe0ffff increase -1 ,pdata 
+6660 60014818 store 2 ,mem_mouse_blank_data_timer 
+6661 247a0000 nrtn blank 
+6662 70481a00 jam 0 ,mem_mouse_send_blank_timer 
+6663 20600000 rtn 
+
+mouse_check_no_data_timeout_timer:
+6664 68014816 fetch 2 ,mem_mouse_no_data_timer 
+6665 207a0000 rtn blank 
+6666 1fe0ffff increase -1 ,pdata 
+6667 60014816 store 2 ,mem_mouse_no_data_timer 
+6668 247a0000 nrtn blank 
+6669 202066b1 branch mouse_disconnect 
+
+mouse_bb_event_discovery_btn:
+666a 793f8025 set0 mark_ext_patch ,mark 
+666b 44e3c018 bpatch patch18_7 ,mem_patch18 
+666c 70481a00 jam 0 ,mem_mouse_send_blank_timer 
+666d 70480b01 jam 1 ,mem_reconnect_timeout 
+666e 58000000 setarg 0 
+666f 60014814 store 2 ,mem_mouse_direct_timer 
+6670 204066b1 call mouse_disconnect 
+6671 6800c132 fetch 1 ,mem_device_option 
+6672 2feffe01 isolate1 mode_4_mouse ,pdata 
+6673 2040e688 call mouse4_0_bb_event_discovery_btn ,true 
+6674 6800c132 fetch 1 ,mem_device_option 
+6675 2feffe00 isolate1 mode_3_mouse ,pdata 
+6676 2040e684 call mouse3_0_bb_event_discovery_btn ,true 
+6677 20403fa6 call app_lpm_mult_disable 
+6678 20206697 branch mouse_start_discovery 
+
+mouse3_0_check_reconn_target:
+6679 68034274 fetch 6 ,mem_hci_plap 
+667a 203a3f79 branch app_bt_start_discovery_short ,blank 
+667b 20203f6e branch app_bt_start_reconnect 
+
+mouse4_0_check_reconn_target:
+667c 68034274 fetch 6 ,mem_hci_plap 
+667d 203a6682 branch mouse4_0_no_reconn_target ,blank 
+667e 6801480c fetch 2 ,mem_mouse_direct_timeout 
+667f 60014814 store 2 ,mem_mouse_direct_timer 
+6680 20403fa4 call app_lpm_mult_enable 
+6681 20203f82 branch app_ble_start_direct_adv 
+
+mouse4_0_no_reconn_target:
+6682 20403f94 call app_led_start_blink 
+6683 20203f88 branch app_ble_start_adv 
+
+mouse3_0_bb_event_discovery_btn:
+6684 680147f4 fetch 2 ,mem_ui_state_map 
+6685 2feffe07 isolate1 ui_state_bt_reconnect ,pdata 
+6686 2040bf75 call app_bt_reconnect_cancel ,true 
+6687 20600000 rtn 
+
+mouse4_0_bb_event_discovery_btn:
+6688 20405b30 call le_clean_att_list_handle_enable 
+6689 20600000 rtn 
+
+mouse_bt_hid_handshake:
+668a 70427f01 jam app_handshake_done ,mem_app_handshake_flag 
+668b 20403fa4 call app_lpm_mult_enable 
+668c 20403fa2 call app_bt_store_reconn_info 
+668d 70482001 jam mouse_mode_state_bt ,mem_mouse_mode_state 
+668e 58000000 setarg 0 
+668f 600147f0 store 2 ,mem_discovery_timeout_timer_count 
+6690 6000c7f2 store 1 ,mem_hid_handshake_timer_count 
+6691 20403f9e call app_bt_enter_sniff 
+6692 2020655a branch mouse_send_blank_packet_timer_init 
+
+mouse_check_reconn_target:
+6693 6800c2a9 fetch 1 ,mem_xrecord_mode 
+6694 c019e679 beq rec_3_mode ,mouse3_0_check_reconn_target 
+6695 c01a667c beq rec_4_mode ,mouse4_0_check_reconn_target 
+6696 20206697 branch mouse_start_discovery 
+
+mouse_start_discovery:
+6697 793f8025 set0 mark_ext_patch ,mark 
+6698 44e44019 bpatch patch19_0 ,mem_patch19 
+6699 6800c4f9 fetch 1 ,mem_le_lap 
+669a 1fe0fe01 increase 1 ,pdata 
+669b 6000c4f9 store 1 ,mem_le_lap 
+669c 20403fa6 call app_lpm_mult_disable 
+669d 680147fe fetch 2 ,mem_discovery_timeout 
+669e 60014812 store 2 ,mem_mouse_discovery_timer 
+669f 6800c132 fetch 1 ,mem_device_option 
+66a0 2feffe01 isolate1 mode_4_mouse ,pdata 
+66a1 2040bf88 call app_ble_start_adv ,true 
+66a2 6800c132 fetch 1 ,mem_device_option 
+66a3 2feffe00 isolate1 mode_3_mouse ,pdata 
+66a4 2040bf7c call app_bt_start_discovery ,true 
+66a5 20203f94 branch app_led_start_blink 
+
+mouse_stop_discovery:
+66a6 793f8025 set0 mark_ext_patch ,mark 
+66a7 44e4c019 bpatch patch19_1 ,mem_patch19 
+66a8 58000000 setarg 0 
+66a9 60014812 store 2 ,mem_mouse_discovery_timer 
+66aa 6800c132 fetch 1 ,mem_device_option 
+66ab 2feffe01 isolate1 mode_4_mouse ,pdata 
+66ac 2040bf86 call app_ble_stop_adv ,true 
+66ad 6800c132 fetch 1 ,mem_device_option 
+66ae 2feffe00 isolate1 mode_3_mouse ,pdata 
+66af 2040bf7e call app_bt_stop_discovery ,true 
+66b0 20203f98 branch app_led_stop_blink 
+
+mouse_disconnect:
+66b1 793f8025 set0 mark_ext_patch ,mark 
+66b2 44e54019 bpatch patch19_2 ,mem_patch19 
+66b3 58000000 setarg 0 
+66b4 60014816 store 2 ,mem_mouse_no_data_timer 
+66b5 680147f4 fetch 2 ,mem_ui_state_map 
+66b6 c284bf90 bbit1 ui_state_ble_connected ,app_ble_disconnect 
+66b7 680147f4 fetch 2 ,mem_ui_state_map 
+66b8 c2803f77 bbit1 ui_state_bt_connected ,app_bt_disconnect 
+66b9 20600000 rtn 
+
+eeprom_store_mouse_dpi:
+66ba 793f8025 set0 mark_ext_patch ,mark 
+66bb 44e5c019 bpatch patch19_3 ,mem_patch19 
+66bc d8400001 arg 1 ,temp 
+66bd da20481b arg mem_mouse_dpi ,rega 
+66be da4000c6 arg mouse_dpi_eeprom_addr ,regb 
+66bf 2020683e branch iicd_write_eep_data 
+
+eeprom_load_mouse_dpi:
+66c0 793f8025 set0 mark_ext_patch ,mark 
+66c1 44e64019 bpatch patch19_4 ,mem_patch19 
+66c2 d8400001 arg 1 ,temp 
+66c3 da20481b arg mem_mouse_dpi ,rega 
+66c4 da4000c6 arg mouse_dpi_eeprom_addr ,regb 
+66c5 2020681d branch iicd_read_eep_data 
+
+twspi_reset:
+66c6 793f8025 set0 mark_ext_patch ,mark 
+66c7 44ff401f bpatch patch1f_6 ,mem_patch1f 
+66c8 68108073 hfetch 1 ,core_gpio_oe3 
+66c9 d8400006 arg 0x06 ,temp 
+66ca 9841fe00 ior temp ,pdata 
+66cb 60108073 hstore 1 ,core_gpio_oe3 
+66cc 68108077 hfetch 1 ,core_gpio_out3 
+66cd 9841fe00 ior temp ,pdata 
+66ce 60108077 hstore 1 ,core_gpio_out3 
+66cf 70808100 hjam 0 ,core_gpio_sel1 
+66d0 68108077 hfetch 1 ,core_gpio_out3 
+66d1 793ffe01 set0 1 ,pdata 
+66d2 793ffe02 set0 2 ,pdata 
+66d3 60108077 hstore 1 ,core_gpio_out3 
+66d4 2000001e nop 30 
+66d5 70808101 hjam 1 ,core_gpio_sel1 
+66d6 20600000 rtn 
+
+twspi_write:
+66d7 202067a1 branch spid_write_reg 
+
+twspi_read:
+66d8 202067a9 branch spid_read_reg 
+
+read_function_aes:
+66d9 243466dd nbranch read_function ,user 
+66da 68108085 hfetch 1 ,core_gpio_key2 
+66db 1fe1fe20 or_into 0x20 ,pdata 
+66dc 60108085 hstore 1 ,core_gpio_key2 
+
+read_function:
+66dd 18427c00 copy temp ,null 
+66de 2022e6e0 branch read_fuction_zero ,zero 
+66df 1a627a00 copy regc ,pc 
+
+read_fuction_zero:
+66e0 2fcc0000 isolate0 0 ,null 
+66e1 20206763 branch set_ucode_status 
+
+get_block_header:
+66e2 18000404 force 4 ,temp 
+
+get_block_header0:
+66e3 da20022c arg mem_ucode_buf ,rega 
+66e4 68108085 hfetch 1 ,core_gpio_key2 
+66e5 1fe17edf and_into 0xdf ,pdata 
+66e6 60108085 hstore 1 ,core_gpio_key2 
+66e7 204066dd call read_function 
+66e8 da2055aa arg 0x55aa ,rega 
+66e9 6801022c fetch 2 ,mem_ucode_buf 
+66ea e8c90000 ifetcht 2 ,contr 
+66eb 9a267c00 isub rega ,null 
+66ec 20600000 rtn 
+
+read_first_block:
+66ed d8400002 arg 2 ,temp 
+66ee da200232 arg mem_ucode_ptr ,rega 
+66ef 204066dd call read_function 
+66f0 68010232 fetch 2 ,mem_ucode_ptr 
+66f1 60010225 store 2 ,mem_addr_mi 
+66f2 205466f4 call get_iv ,user 
+66f3 20600000 rtn 
+
+get_iv:
+66f4 d8400010 arg 16 ,temp 
+66f5 da200234 arg mem_ucode_keybuf ,rega 
+66f6 68108085 hfetch 1 ,core_gpio_key2 
+66f7 1fe17edf and_into 0xdf ,pdata 
+66f8 60108085 hstore 1 ,core_gpio_key2 
+66f9 204066dd call read_function 
+66fa d8c00234 arg mem_ucode_keybuf ,contr 
+66fb df200010 arg 16 ,loopcnt 
+66fc 20407584 call aes_load_data 
+66fd 2040753d call aes_init 
+66fe 2040759d call aes_clear_data 
+66ff 20207534 branch do_aes_cbc 
+
+load_storage:
+6700 7856fc00 disable match 
+6701 204066e2 call get_block_header 
+6702 24628000 nrtn zero 
+6703 7836fc00 enable match 
+6704 70802380 hjam 0x80 ,core_ucode_ctrl 
+6705 70802200 hjam 0 ,core_ucode_hi 
+6706 70802400 hjam 0 ,core_ucode_low 
+6707 da208025 arg core_ucode_data ,rega 
+6708 204066d9 call read_function_aes 
+6709 70802300 hjam 0x0 ,core_ucode_ctrl 
+670a 204066e2 call get_block_header 
+670b 24628000 nrtn zero 
+670c 18007e00 force 0 ,pdata 
+670d 60110288 hstore 2 ,core_docd_paddr 
+670e da20828a arg core_docd_pdata ,rega 
+670f 204066d9 call read_function_aes 
+
+load_storage_loop:
+6710 d8400006 arg 6 ,temp 
+6711 204066e3 call get_block_header0 
+6712 24628000 nrtn zero 
+6713 e8c10000 ifetch 2 ,contr 
+6714 98002200 iforce rega 
+6715 204066dd call read_function 
+6716 20206710 branch load_storage_loop 
+
+reload_eeprom:
+6717 20407f36 call clean_mem 
+6718 58001000 setarg 0x1000 
+6719 60010225 store 2 ,mem_addr_mi 
+671a da606823 arg iicd_read_eep ,regc 
+671b df200002 arg 2 ,loopcnt 
+
+reload_eeprom_loop:
+671c 204066e2 call get_block_header 
+671d 24628000 nrtn zero 
+671e 68010225 fetch 2 ,mem_addr_mi 
+671f 1ff0fe00 byteswap pdata ,pdata 
+6720 9840fe00 iadd temp ,pdata 
+6721 1ff0fe00 byteswap pdata ,pdata 
+6722 60010225 store 2 ,mem_addr_mi 
+6723 c200671c loop reload_eeprom_loop 
+6724 20206710 branch load_storage_loop 
+
+loadcode:
+6725 70805025 hjam 0x25 ,core_clkoff 
+6726 70828005 hjam 5 ,core_docd_ctrl 
+6727 20407f36 call clean_mem 
+
+loadcode_lpm:
+6728 78547c00 disable user 
+6729 2040688a call otp_enable_chgpump 
+672a 58000000 setarg otp_ucode_flag 
+672b da200221 arg mem_otp_ucode_flag ,rega 
+672c d8400002 arg 2 ,temp 
+672d 204068d3 call otpd_read_data 
+672e 68010221 fetch 2 ,mem_otp_ucode_flag 
+672f c303e738 bbit0 otp_uflag_aes ,loadcode_otp 
+6730 580007f0 setarg otp_ucode_aeskey 
+6731 da200234 arg mem_ucode_keybuf ,rega 
+6732 d8400010 arg 16 ,temp 
+6733 204068d3 call otpd_read_data 
+6734 70800608 hjam lock_otp ,core_misc_ctrl 
+6735 d8c00234 arg mem_ucode_keybuf ,contr 
+6736 20407590 call load_key 
+6737 78347c00 enable user 
+
+loadcode_otp:
+6738 68010221 fetch 2 ,mem_otp_ucode_flag 
+6739 1ff0fe00 byteswap pdata ,pdata 
+673a d84007ff arg 0x7ff ,temp 
+673b 98417e00 iand temp ,pdata 
+673c 2022e744 branch loadcode_spi ,zero 
+673d 2040688f call otp_set_addr 
+673e da6068d8 arg otpd_read_code ,regc 
+673f 205466f4 call get_iv ,user 
+6740 20406700 call load_storage 
+6741 68008220 fetch 1 ,mem_ucode_status 
+6742 2fe00603 compare 3 ,pdata ,3 
+6743 2420e738 nbranch loadcode_otp ,true 
+
+loadcode_spi:
+6744 2040688d call otp_disable_chgpump 
+6745 68008221 fetch 1 ,mem_otp_ucode_flag 
+6746 c282e751 bbit1 otp_uflag_skip_flash ,loadcode_iic 
+6747 58000000 setarg 0x0 
+6748 60018224 store 3 ,mem_addr_hi 
+6749 204067b9 call spid_init_flash 
+674a da6067db arg spid_read_flash ,regc 
+674b 204066ed call read_first_block 
+674c 20406700 call load_storage 
+674d 2436e751 nbranch loadcode_iic ,match 
+674e 68008220 fetch 1 ,mem_ucode_status 
+674f 2fe00603 compare 3 ,pdata ,3 
+6750 2420e744 nbranch loadcode_spi ,true 
+
+loadcode_iic:
+6751 68008221 fetch 1 ,mem_otp_ucode_flag 
+6752 c283675d bbit1 otp_uflag_skip_eep ,loadcode_hci 
+6753 58000000 setarg 0x0 
+6754 60010225 store 2 ,mem_addr_mi 
+6755 da606823 arg iicd_read_eep ,regc 
+6756 20406805 call iicd_init_12m 
+6757 204066ed call read_first_block 
+6758 20406700 call load_storage 
+6759 2436e75d nbranch loadcode_hci ,match 
+675a 68008220 fetch 1 ,mem_ucode_status 
+675b 2fe00603 compare 3 ,pdata ,3 
+675c 2420e751 nbranch loadcode_iic ,true 
+
+loadcode_hci:
+675d 70805021 hjam 0x21 ,core_clkoff 
+675e 68008221 fetch 1 ,mem_otp_ucode_flag 
+675f c4020000 rtnbit0 otp_uflag_hci 
+6760 20404461 call hci_init 
+
+loadcode_hci_loop:
+6761 204044a3 call hci_rx_packet 
+6762 20206761 branch loadcode_hci_loop 
+
+set_ucode_status:
+6763 68008220 fetch 1 ,mem_ucode_status 
+6764 1fe3fe00 lshift pdata ,pdata 
+6765 7920fe00 setflag true ,0 ,pdata 
+6766 2a2c000f isolate0 15 ,rega 
+6767 20608000 rtn true 
+6768 60008220 store 1 ,mem_ucode_status 
+6769 20600000 rtn 
+
+decrypt_code:
+676a 68108085 hfetch 1 ,core_gpio_key2 
+676b c4028000 rtnbit0 5 
+676c 20206770 branch decrypt_code_skip 
+
+decrypt_code_loop:
+676d 6810812c hfetch 1 ,core_dma_status 
+676e afefffff qisolate1 pdata 
+676f 20608000 rtn true 
+
+decrypt_code_skip:
+6770 68108108 hfetch 1 ,core_misc_status 
+6771 c300e76d bbit0 1 ,decrypt_code_loop 
+6772 20407534 call do_aes_cbc 
+6773 2020676d branch decrypt_code_loop 
+
+save_ucode:
+6774 1f220400 copy loopcnt ,temp 
+6775 6009423c storet 2 ,mem_patch_len 
+6776 70802380 hjam 0x80 ,core_ucode_ctrl 
+6777 70802200 hjam 0 ,core_ucode_hi 
+6778 70802400 hjam 0 ,core_ucode_low 
+6779 6001423a store 2 ,mem_patch_ptr 
+677a 98000a00 iforce contw 
+677b 1f2bf200 lshift2 loopcnt ,loopcnt 
+
+save_ucode_loop:
+677c 68108025 hfetch 1 ,core_ucode_data 
+677d e0a08000 istore 1 ,contw 
+677e c200677c loop save_ucode_loop 
+677f 70802300 hjam 0x0 ,core_ucode_ctrl 
+6780 20600000 rtn 
+
+load_ucode:
+6781 6801423a fetch 2 ,mem_patch_ptr 
+6782 207a0000 rtn blank 
+6783 70802380 hjam 0x80 ,core_ucode_ctrl 
+6784 70802200 hjam 0 ,core_ucode_hi 
+6785 70802400 hjam 0 ,core_ucode_low 
+6786 6809423c fetcht 2 ,mem_patch_len 
+6787 184bf200 lshift2 temp ,loopcnt 
+6788 98000c00 iforce contr 
+
+load_ucode_loop:
+6789 e8c08000 ifetch 1 ,contr 
+678a 60108025 hstore 1 ,core_ucode_data 
+678b c2006789 loop load_ucode_loop 
+678c 70802300 hjam 0x0 ,core_ucode_ctrl 
+678d 20600000 rtn 
+
+spid_init:
+678e 793f8025 set0 mark_ext_patch ,mark 
+678f 44ffc01f bpatch patch1f_7 ,mem_patch1f 
+6790 70808675 hjam 0x75 ,core_spid_ctrl 
+6791 7080870a hjam 10 ,core_spid_delay 
+6792 58000223 setarg mem_spid_tbuf 
+6793 6011008a hstore 2 ,core_spid_txaddr 
+6794 58000228 setarg mem_spid_rbuf 
+6795 6011008c hstore 2 ,core_spid_rxaddr 
+6796 68108081 hfetch 1 ,core_gpio_sel1 
+6797 79207e00 set1 0 ,pdata 
+6798 793ffe01 set0 1 ,pdata 
+6799 60108081 hstore 1 ,core_gpio_sel1 
+679a 20600000 rtn 
+
+spid_reset:
+679b 68108086 hfetch 1 ,core_spid_ctrl 
+679c 79207e07 set1 7 ,pdata 
+679d 60108086 hstore 1 ,core_spid_ctrl 
+679e 793ffe07 set0 7 ,pdata 
+679f 60108086 hstore 1 ,core_spid_ctrl 
+67a0 20600000 rtn 
+
+spid_write_reg:
+67a1 79207e07 set1 7 ,pdata 
+67a2 60010223 store 2 ,mem_spid_tbuf 
+67a3 79200025 set1 mark_ext_patch ,mark 
+67a4 44804020 bpatch patch20_0 ,mem_patch20 
+67a5 70808802 hjam 2 ,core_spid_txlen 
+67a6 70808e00 hjam 0 ,core_spid_rxlen 
+67a7 70800602 hjam spid_start ,core_misc_ctrl 
+67a8 202067b3 branch wait_spid_done 
+
+spid_read_reg:
+67a9 18000401 force 1 ,temp 
+
+spid_read_regs:
+67aa 60008223 store 1 ,mem_spid_tbuf 
+67ab 79200025 set1 mark_ext_patch ,mark 
+67ac 4480c020 bpatch patch20_1 ,mem_patch20 
+67ad 70808801 hjam 1 ,core_spid_txlen 
+67ae 6019008e hstoret 2 ,core_spid_rxlen 
+67af 70800602 hjam spid_start ,core_misc_ctrl 
+67b0 204067b3 call wait_spid_done 
+67b1 68008228 fetch 1 ,mem_spid_rbuf 
+67b2 20600000 rtn 
+
+wait_spid_done:
+67b3 68014177 fetch 2 ,mem_afh_error_total 
+67b4 1fe0fe01 increase 1 ,pdata 
+67b5 60014177 store 2 ,mem_afh_error_total 
+67b6 6810812c hfetch 1 ,core_dma_status 
+67b7 c301e7b3 bbit0 spid_done ,wait_spid_done 
+67b8 20600000 rtn 
+
+spid_init_flash:
+67b9 70808640 hjam 0x40 ,core_spid_ctrl 
+67ba 70808700 hjam 0x0 ,core_spid_delay 
+67bb 68108081 hfetch 1 ,core_gpio_sel1 
+67bc 793ffe00 set0 0 ,pdata 
+67bd 79207e01 set1 1 ,pdata 
+67be 60108081 hstore 1 ,core_gpio_sel1 
+67bf 58000000 setarg 0 
+67c0 60020223 store 4 ,mem_spid_tbuf 
+67c1 20600000 rtn 
+
+spid_unlock_flash:
+67c2 58000000 setarg 0 
+67c3 6011008e hstore 2 ,core_spid_rxlen 
+67c4 58000001 setarg 1 
+67c5 60108088 hstore 1 ,core_spid_txlen 
+67c6 58000223 setarg mem_spid_tbuf 
+67c7 6011008a hstore 2 ,core_spid_txaddr 
+67c8 70022306 jam 6 ,mem_spid_tbuf 
+67c9 70800602 hjam spid_start ,core_misc_ctrl 
+67ca 202067b3 branch wait_spid_done 
+
+spid_write_flash:
+67cb 18408404 increase 4 ,temp 
+67cc 60190088 hstoret 2 ,core_spid_txlen 
+67cd 1a20a3fc increase -4 ,rega 
+67ce d8400002 arg 2 ,temp 
+67cf e2288000 istoret 1 ,rega 
+67d0 1ff10400 rshift16 pdata ,temp 
+67d1 e0a88000 istoret 1 ,contw 
+67d2 1fec8400 rshift8 pdata ,temp 
+67d3 e0a88000 istoret 1 ,contw 
+67d4 e0a08000 istore 1 ,contw 
+67d5 1a227e00 deposit rega 
+67d6 6011008a hstore 2 ,core_spid_txaddr 
+67d7 58000000 setarg 0 
+67d8 6011008e hstore 2 ,core_spid_rxlen 
+67d9 70800602 hjam spid_start ,core_misc_ctrl 
+67da 202067b3 branch wait_spid_done 
+
+spid_read_flash:
+67db 6019008e hstoret 2 ,core_spid_rxlen 
+67dc 58000004 setarg 4 
+67dd 60110088 hstore 2 ,core_spid_txlen 
+67de 70022303 jam 3 ,mem_spid_tbuf 
+67df 58000223 setarg mem_spid_tbuf 
+67e0 6011008a hstore 2 ,core_spid_txaddr 
+67e1 1a227e00 deposit rega 
+67e2 6011008c hstore 2 ,core_spid_rxaddr 
+67e3 68108086 hfetch 1 ,core_spid_ctrl 
+67e4 2a2c000f isolate0 15 ,rega 
+67e5 7920fe06 setflag true ,6 ,pdata 
+67e6 60108086 hstore 1 ,core_spid_ctrl 
+67e7 70800602 hjam spid_start ,core_misc_ctrl 
+
+spi_read_flash_wait:
+67e8 6810812c hfetch 1 ,core_dma_status 
+67e9 c283e7e8 bbit1 7 ,spi_read_flash_wait 
+67ea d8e00003 arg spid_done ,queue 
+67eb 2040676a call decrypt_code 
+67ec 204067b3 call wait_spid_done 
+67ed 2feffe02 isolate1 spid_crcok ,pdata 
+67ee 20406763 call set_ucode_status 
+67ef 68008224 fetch 1 ,mem_addr_hi 
+67f0 1ff02400 lshift16 pdata ,regb 
+67f1 68008225 fetch 1 ,mem_addr_mi 
+67f2 1fed7e00 lshift8 pdata ,pdata 
+67f3 9a41a400 ior regb ,regb 
+67f4 68008226 fetch 1 ,mem_addr_lo 
+67f5 9a41fe00 ior regb ,pdata 
+67f6 9840fe00 iadd temp ,pdata 
+67f7 60008226 store 1 ,mem_addr_lo 
+67f8 1fecfe00 rshift8 pdata ,pdata 
+67f9 60008225 store 1 ,mem_addr_mi 
+67fa 1fecfe00 rshift8 pdata ,pdata 
+67fb 60008224 store 1 ,mem_addr_hi 
+67fc 20600000 rtn 
+
+iicd_init_5m:
+67fd 7080420a hjam 0xa ,core_clksel 
+67fe 70809102 hjam 2 ,core_iicd_scl_low 
+67ff 70809203 hjam 3 ,core_iicd_scl_high 
+6800 70809303 hjam 3 ,core_iicd_start_setup 
+6801 70809403 hjam 3 ,core_iicd_start_hold 
+6802 70809503 hjam 3 ,core_iicd_stop_setup 
+6803 70809602 hjam 2 ,core_iicd_data_setup 
+6804 20600000 rtn 
+
+iicd_init_12m:
+6805 70809105 hjam 5 ,core_iicd_scl_low 
+6806 70809207 hjam 7 ,core_iicd_scl_high 
+6807 70809307 hjam 7 ,core_iicd_start_setup 
+6808 70809407 hjam 7 ,core_iicd_start_hold 
+6809 70809507 hjam 7 ,core_iicd_stop_setup 
+680a 70809605 hjam 5 ,core_iicd_data_setup 
+680b 20600000 rtn 
+
+wait_iicd_done:
+680c 6810812c hfetch 1 ,core_dma_status 
+680d c302e80c bbit0 iicd_done ,wait_iicd_done 
+680e 20600000 rtn 
+
+iicd_read_data:
+680f 60008224 store 1 ,mem_iicd_tbuf 
+6810 58000224 setarg mem_iicd_tbuf 
+6811 6011009a hstore 2 ,core_iicd_txaddr 
+6812 58000001 setarg 1 
+6813 60110098 hstore 2 ,core_iicd_txlen 
+6814 6019009e hstoret 2 ,core_iicd_rxlen 
+6815 1a227e00 deposit rega 
+6816 6011009c hstore 2 ,core_iicd_rxaddr 
+6817 70809001 hjam 1 ,core_iicd_ctrl 
+6818 70800604 hjam iicd_start ,core_misc_ctrl 
+6819 2020680c branch wait_iicd_done 
+
+byteswap_addr_mi:
+681a 1ff0fe00 byteswap pdata ,pdata 
+681b 60010225 store 2 ,mem_addr_mi 
+681c 20600000 rtn 
+
+iicd_read_eep_data:
+681d 79200025 set1 mark_ext_patch ,mark 
+681e 44814020 bpatch patch20_2 ,mem_patch20 
+681f 6801429b fetch 2 ,mem_eeprom_base 
+6820 9a40fe00 iadd regb ,pdata 
+
+iicd_read_eep_adr:
+6821 1ff0fe00 byteswap pdata ,pdata 
+6822 60010225 store 2 ,mem_addr_mi 
+
+iicd_read_eep:
+6823 79200025 set1 mark_ext_patch ,mark 
+6824 4481c020 bpatch patch20_3 ,mem_patch20 
+6825 58000004 setarg 4 
+6826 60110098 hstore 2 ,core_iicd_txlen 
+6827 700224a0 jam 0xa0 ,mem_iicd_tbuf 
+6828 700227a1 jam 0xa1 ,mem_iicd_tbuf + 3 
+6829 58000224 setarg mem_iicd_tbuf 
+682a 6011009a hstore 2 ,core_iicd_txaddr 
+682b 6019009e hstoret 2 ,core_iicd_rxlen 
+682c 1a227e00 deposit rega 
+682d 6011009c hstore 2 ,core_iicd_rxaddr 
+682e 58000002 setarg 2 
+682f 2a2c000f isolate0 15 ,rega 
+6830 7920fe00 setflag true ,0 ,pdata 
+6831 60108090 hstore 1 ,core_iicd_ctrl 
+6832 70800604 hjam iicd_start ,core_misc_ctrl 
+6833 d8e00005 arg iicd_done ,queue 
+6834 2040676a call decrypt_code 
+6835 2040680c call wait_iicd_done 
+6836 2feffe04 isolate1 iicd_crcok ,pdata 
+6837 20406763 call set_ucode_status 
+6838 68010225 fetch 2 ,mem_addr_mi 
+6839 1ff0fe00 byteswap pdata ,pdata 
+683a 9840fe00 iadd temp ,pdata 
+683b 1ff0fe00 byteswap pdata ,pdata 
+683c 60010225 store 2 ,mem_addr_mi 
+683d 20600000 rtn 
+
+iicd_write_eep_data:
+683e 79200025 set1 mark_ext_patch ,mark 
+683f 44824020 bpatch patch20_4 ,mem_patch20 
+6840 6801429b fetch 2 ,mem_eeprom_base 
+6841 9a40fe00 iadd regb ,pdata 
+
+iicd_write_ota_data:
+6842 60010161 store 2 ,mem_pdatatemp 
+6843 79200025 set1 mark_ext_patch ,mark 
+6844 4482c020 bpatch patch20_5 ,mem_patch20 
+6845 600902a0 storet 2 ,mem_temp 
+6846 1a227e00 copy rega ,pdata 
+6847 600102b7 store 2 ,mem_contr 
+
+iicd_write_eep_loop:
+6848 20406858 call iicd_eep_transparency 
+6849 680902b0 fetcht 2 ,mem_regb 
+684a 680102b7 fetch 2 ,mem_contr 
+684b 1fe22200 copy pdata ,rega 
+684c 68010161 fetch 2 ,mem_pdatatemp 
+684d 20406870 call iicd_write_eep 
+684e 680102b0 fetch 2 ,mem_regb 
+684f 680902b7 fetcht 2 ,mem_contr 
+6850 98408400 iadd temp ,temp 
+6851 600902b7 storet 2 ,mem_contr 
+6852 68090161 fetcht 2 ,mem_pdatatemp 
+6853 98408400 iadd temp ,temp 
+6854 60090161 storet 2 ,mem_pdatatemp 
+6855 680102a0 fetch 2 ,mem_temp 
+6856 243a6848 nbranch iicd_write_eep_loop ,blank 
+6857 20600000 rtn 
+
+iicd_eep_transparency:
+6858 79200025 set1 mark_ext_patch ,mark 
+6859 44834020 bpatch patch20_6 ,mem_patch20 
+685a 680142aa fetch 2 ,mem_eeprom_block_size 
+685b 1fe0ffff increase -1 ,pdata 
+685c 68090161 fetcht 2 ,mem_pdatatemp 
+685d 9841fe00 ior temp ,pdata 
+685e 1fe0fe01 increase 1 ,pdata 
+685f 600182b4 store 3 ,mem_regc 
+6860 680102a0 fetch 2 ,mem_temp 
+6861 9840fe00 iadd temp ,pdata 
+6862 680982b4 fetcht 3 ,mem_regc 
+6863 98467e00 isub temp ,pdata 
+6864 2421686b nbranch iicd_eep_deal_short_packet ,positive 
+6865 600102a0 store 2 ,mem_temp 
+6866 680182b4 fetch 3 ,mem_regc 
+6867 68090161 fetcht 2 ,mem_pdatatemp 
+6868 98467e00 isub temp ,pdata 
+6869 600102b0 store 2 ,mem_regb 
+686a 20600000 rtn 
+
+iicd_eep_deal_short_packet:
+686b 680102a0 fetch 2 ,mem_temp 
+686c 600102b0 store 2 ,mem_regb 
+686d 58000000 setarg 0 
+686e 600102a0 store 2 ,mem_temp 
+686f 20600000 rtn 
+
+iicd_write_eep:
+6870 1fe22400 copy pdata ,regb 
+6871 79200025 set1 mark_ext_patch ,mark 
+6872 4483c020 bpatch patch20_7 ,mem_patch20 
+6873 1a427e00 copy regb ,pdata 
+6874 18408403 increase 3 ,temp 
+6875 60190098 hstoret 2 ,core_iicd_txlen 
+6876 1a20a3fd increase -3 ,rega 
+6877 ea298000 ifetcht 3 ,rega 
+6878 18422400 copy temp ,regb 
+6879 d84000a0 arg 0xa0 ,temp 
+687a e2288000 istoret 1 ,rega 
+687b 1ff0fe00 byteswap pdata ,pdata 
+687c e0a10000 istore 2 ,contw 
+687d 1a227e00 deposit rega 
+687e 6011009a hstore 2 ,core_iicd_txaddr 
+687f 58000000 setarg 0 
+6880 6011009e hstore 2 ,core_iicd_rxlen 
+6881 70809001 hjam 1 ,core_iicd_ctrl 
+6882 70800604 hjam iicd_start ,core_misc_ctrl 
+6883 2040680c call wait_iicd_done 
+6884 1a427e00 copy regb ,pdata 
+6885 e2218000 istore 3 ,rega 
+6886 20002710 nop 10000 
+6887 20002710 nop 10000 
+6888 20002710 nop 10000 
+6889 20600000 rtn 
+
+otp_enable_chgpump:
+688a 70897370 hjam 0x70 ,rfen_chgpump 
+688b 20000bb8 nop param_chgpump_delay 
+688c 20600000 rtn 
+
+otp_disable_chgpump:
+688d 70897330 hjam 0x30 ,rfen_chgpump 
+688e 20600000 rtn 
+
+otp_set_addr:
+688f 1fe9fe00 lshift3 pdata ,pdata 
+6890 60110045 hstore 2 ,core_otp_addr 
+6891 70804b00 hjam 0 ,core_otpd_ctrl 
+6892 20600000 rtn 
+
+otp_write:
+6893 2040688f call otp_set_addr 
+6894 204068c0 call otp_ce 
+
+otp_program:
+6895 ea288000 ifetcht 1 ,rega 
+6896 1a20a201 increase 1 ,rega 
+6897 18000e00 force 0 ,queue 
+
+otp_program_bit:
+6898 a84c0000 qisolate0 temp 
+6899 2020e8b7 branch otp_skip_0 ,true 
+689a 68108046 hfetch 1 ,core_otp_din 
+689b 79207e06 set1 6 ,pdata 
+689c 79207e07 set1 7 ,pdata 
+689d 60108046 hstore 1 ,core_otp_din 
+689e 70804702 hjam 0x02 ,core_otp_ctrl 
+689f 70804782 hjam 0x82 ,core_otp_ctrl 
+68a0 793ffe07 set0 7 ,pdata 
+68a1 60108046 hstore 1 ,core_otp_din 
+68a2 7080478a hjam 0x8a ,core_otp_ctrl 
+68a3 2000000b nop 11 
+68a4 708047ca hjam 0xca ,core_otp_ctrl 
+68a5 20000021 nop 33 
+68a6 7080474a hjam 0x4a ,core_otp_ctrl 
+68a7 2000002c nop 44 
+68a8 708047ca hjam 0xca ,core_otp_ctrl 
+68a9 20000016 nop 22 
+68aa 7080478a hjam 0x8a ,core_otp_ctrl 
+68ab 20000021 nop 33 
+68ac 70804782 hjam 0x82 ,core_otp_ctrl 
+68ad 20000001 nop 1 
+68ae 70804792 hjam 0x92 ,core_otp_ctrl 
+68af 2000000a nop 10 
+68b0 708047b2 hjam 0xb2 ,core_otp_ctrl 
+68b1 68108007 hfetch 1 ,core_otp_rdata 
+68b2 70804792 hjam 0x92 ,core_otp_ctrl 
+68b3 20000001 nop 1 
+68b4 70804782 hjam 0x82 ,core_otp_ctrl 
+68b5 afec0000 qisolate0 pdata 
+68b6 2020e898 branch otp_program_bit ,true 
+
+otp_skip_0:
+68b7 68110045 hfetch 2 ,core_otp_addr 
+68b8 1fe0fe01 increase 1 ,pdata 
+68b9 60110045 hstore 2 ,core_otp_addr 
+68ba 18e08e01 increase 1 ,queue 
+68bb 28e01e08 compare 8 ,queue ,0xf 
+68bc 2420e898 nbranch otp_program_bit ,true 
+68bd c2006895 loop otp_program 
+68be 70804783 hjam 0x83 ,core_otp_ctrl 
+68bf 20600000 rtn 
+
+otp_ce:
+68c0 70804782 hjam 0x82 ,core_otp_ctrl 
+68c1 2000000c nop 12 
+68c2 70804780 hjam 0x80 ,core_otp_ctrl 
+68c3 70804782 hjam 0x82 ,core_otp_ctrl 
+68c4 20000096 nop 150 
+68c5 20600000 rtn 
+
+otpd_read_init:
+68c6 204068c0 call otp_ce 
+
+otpd_read_special:
+68c7 708047a2 hjam 0xa2 ,core_otp_ctrl 
+68c8 1a227e00 deposit rega 
+68c9 60110048 hstore 2 ,core_otpd_addr 
+68ca 7920040b set1 11 ,temp 
+68cb 2fec000f isolate0 15 ,pdata 
+68cc 7920840f setflag true ,15 ,temp 
+68cd 6019004a hstoret 2 ,core_otpd_len 
+68ce 70800601 hjam otpd_start ,core_misc_ctrl 
+68cf 20600000 rtn 
+
+otpd_wait_end:
+68d0 6810812c hfetch 1 ,core_dma_status 
+68d1 c300e8d0 bbit0 otpd_done ,otpd_wait_end 
+68d2 20600000 rtn 
+
+otpd_read_data:
+68d3 2040688f call otp_set_addr 
+68d4 204068c6 call otpd_read_init 
+68d5 204068d0 call otpd_wait_end 
+68d6 70804783 hjam 0x83 ,core_otp_ctrl 
+68d7 20600000 rtn 
+
+otpd_read_code:
+68d8 68110124 hfetch 2 ,core_current_otp_addr 
+68d9 60110045 hstore 2 ,core_otp_addr 
+68da 204068c6 call otpd_read_init 
+68db d8e00001 arg otpd_done ,queue 
+68dc 2040676a call decrypt_code 
+68dd 204068d0 call otpd_wait_end 
+68de 2feffe00 isolate1 otpd_crcok ,pdata 
+68df 20406763 call set_ucode_status 
+68e0 70804783 hjam 0x83 ,core_otp_ctrl 
+68e1 20600000 rtn 
+
+uartd_rx_cnt_got_first_byte:
+68e2 70427a01 jam 1 ,mem_uartd_rxitems_got_data 
+68e3 18000e0e force uart_rx_timer ,queue 
+68e4 6801427c fetch 2 ,mem_uartd_rx_timeout 
+68e5 20207e4c branch timer_init 
+
+uartd_rx_cnt_with_threshold:
+68e6 68110112 hfetch 2 ,core_uart_rxitems 
+68e7 207a0000 rtn blank 
+68e8 6808c27b fetcht 1 ,mem_uartd_rxitems_threshold 
+68e9 98467c00 isub temp ,null 
+68ea 202168f2 branch uartd_rx_cnt_rtn_value ,positive 
+68eb 6800c27a fetch 1 ,mem_uartd_rxitems_got_data 
+68ec 203a68e2 branch uartd_rx_cnt_got_first_byte ,blank 
+68ed d8e0000e arg uart_rx_timer ,queue 
+68ee 20407e53 call timer_check 
+68ef 203a68f2 branch uartd_rx_cnt_rtn_value ,blank 
+68f0 58000000 setarg 0 
+68f1 20600000 rtn 
+
+uartd_rx_cnt_rtn_value:
+68f2 18000e0e force uart_rx_timer ,queue 
+68f3 20407e4b call timer_stop 
+68f4 70427a00 jam 0 ,mem_uartd_rxitems_got_data 
+68f5 68110112 hfetch 2 ,core_uart_rxitems 
+68f6 20600000 rtn 
+
+uartd_prepare_tx:
+68f7 6811005e hfetch 2 ,core_uart_twptr 
+68f8 98001400 iforce contwu 
+68f9 20600000 rtn 
+
+uartd_send:
+68fa 19427e00 deposit contwu 
+68fb 6011005e hstore 2 ,core_uart_twptr 
+68fc 20600000 rtn 
+
+uartd_prepare_rx:
+68fd 68110112 hfetch 2 ,core_uart_rxitems 
+68fe 207a0000 rtn blank 
+68ff 98007200 iforce loopcnt 
+6900 68110058 hfetch 2 ,core_uart_rrptr 
+6901 98000600 iforce contru 
+6902 20600000 rtn 
+
+uartd_rxdone_by_len:
+6903 68110058 hfetch 2 ,core_uart_rrptr 
+6904 9840fe00 iadd temp ,pdata 
+6905 1fe20600 copy pdata ,contru 
+
+uartd_rxdone:
+6906 18627e00 deposit contru 
+6907 60110058 hstore 2 ,core_uart_rrptr 
+6908 20600000 rtn 
+
+uart_set_baud_by_mem:
+6909 680142ac fetch uart_baud_len ,mem_baud 
+690a 60110052 hstore uart_baud_len ,core_uart_baud 
+690b 20600000 rtn 
+
+eeprom_store_le_reconn_info:
+690c 680303d0 fetch 6 ,mem_le_plap 
+690d 600301b4 store 6 ,mem_temp_lap 
+690e 7001b334 jam rec_4_mode ,mem_record_bt_mode 
+690f 20206913 branch eeprom_store_reconn_info 
+
+eeprom_store_bd_reconn_info:
+6910 68030040 fetch 6 ,mem_plap 
+6911 600301b4 store 6 ,mem_temp_lap 
+6912 7001b333 jam rec_3_mode ,mem_record_bt_mode 
+
+eeprom_store_reconn_info:
+6913 79200025 set1 mark_ext_patch ,mark 
+6914 44844021 bpatch patch21_0 ,mem_patch21 
+6915 20406954 call eeprom_store_remote_bdaddr 
+6916 20406950 call eeprom_store_last_record_index 
+6917 680081b3 fetch 1 ,mem_record_bt_mode 
+6918 c01a691b beq rec_4_mode ,eeprom_store_rec_4_mode 
+6919 c019e97c beq rec_3_mode ,eeprom_store_link_key 
+691a 20600000 rtn 
+
+eeprom_store_rec_4_mode:
+691b 2040697a call eeprom_store_le_ltl 
+691c 20206963 branch eeprom_store_le_local_addr 
+
+eeprom_load_reconn_info:
+691d 79200025 set1 mark_ext_patch ,mark 
+691e 4484c021 bpatch patch21_1 ,mem_patch21 
+691f 20406929 call eeprom_load_reconn_bdaddr 
+6920 680081b2 fetch 1 ,mem_select_list_item 
+6921 c17f8000 rtneq 0xff 
+6922 680301b4 fetch 6 ,mem_temp_lap 
+6923 60034274 store 6 ,mem_hci_plap 
+6924 680081b3 fetch 1 ,mem_record_bt_mode 
+6925 6000c2a9 store 1 ,mem_xrecord_mode 
+6926 c019e92d beq rec_3_mode ,eeprom_load_rec_3_mode 
+6927 c01a692f beq rec_4_mode ,eeprom_load_rec_4_mode 
+6928 20600000 rtn 
+
+eeprom_load_reconn_bdaddr:
+6929 2040694c call eeprom_load_last_record_index 
+692a 680081b2 fetch 1 ,mem_select_list_item 
+692b c17f8000 rtneq 0xff 
+692c 2020696b branch eeprom_load_remote_bdaddr 
+
+eeprom_load_rec_3_mode:
+692d 20406983 call eeprom_load_link_key 
+692e 202069a2 branch check_link_key_load 
+
+eeprom_load_rec_4_mode:
+692f 20406981 call eeprom_load_ltk_key 
+6930 202069a8 branch check_ltk_load 
+
+eeprom_clear_bd_reconn_info:
+6931 20406988 call eeprom_load_bdaddr_list 
+6932 78547c00 disable user 
+6933 2040698c call find_addr_from_bd_list 
+6934 2434427f nbranch at_error_rev_end ,user 
+
+eeprom_clear_reconn_info_common:
+6935 680901ba fetcht 2 ,mem_list_item_ptr 
+6936 184085ff increase -1 ,temp 
+6937 58000000 setarg 0 
+6938 e0438000 istore 7 ,temp 
+6939 d840001c arg 28 ,temp 
+693a da200195 arg mem_bdaddr_list_buff + 7 ,rega 
+693b da400000 arg eeprom_bdaddr_list ,regb 
+693c 2020683e branch iicd_write_eep_data 
+
+eeprom_clear_all_reconn_info:
+693d 79200025 set1 mark_ext_patch ,mark 
+693e 44854021 bpatch patch21_2 ,mem_patch21 
+693f d8a0018e arg mem_bdaddr_list_buff ,contw 
+6940 18007204 force 4 ,loopcnt 
+6941 20407e3b call memset0 
+6942 d840001c arg 28 ,temp 
+6943 da20018e arg mem_bdaddr_list_buff ,rega 
+6944 da400000 arg eeprom_bdaddr_list ,regb 
+6945 2020683e branch iicd_write_eep_data 
+
+eeprom_erase_reconn_info:
+6946 79200025 set1 mark_ext_patch ,mark 
+6947 4485c021 bpatch patch21_3 ,mem_patch21 
+6948 58000000 setarg 0x0 
+6949 60018040 store 3 ,mem_plap 
+694a e0a18000 istore 3 ,contw 
+694b 20206954 branch eeprom_store_remote_bdaddr 
+
+eeprom_load_last_record_index:
+694c d8400001 arg 1 ,temp 
+694d da2001b2 arg mem_select_list_item ,rega 
+694e da40001c arg eeprom_last_record ,regb 
+694f 2020681d branch iicd_read_eep_data 
+
+eeprom_store_last_record_index:
+6950 d8400001 arg 1 ,temp 
+6951 da2001b2 arg mem_select_list_item ,rega 
+6952 da40001c arg eeprom_last_record ,regb 
+6953 2020683e branch iicd_write_eep_data 
+
+eeprom_store_remote_bdaddr:
+6954 79200025 set1 mark_ext_patch ,mark 
+6955 44864021 bpatch patch21_4 ,mem_patch21 
+6956 20406988 call eeprom_load_bdaddr_list 
+6957 78547c00 disable user 
+6958 2040698c call find_addr_from_bd_list 
+6959 20740000 rtn user 
+
+eeprom_store_remote_addr_unfind:
+695a 7001b200 jam 0 ,mem_select_list_item 
+695b 680301b4 fetch 6 ,mem_temp_lap 
+695c 6003018f store 6 ,mem_bdaddr_list_buff + 1 
+695d 680081b3 fetch 1 ,mem_record_bt_mode 
+695e 6000818e store 1 ,mem_bdaddr_list_buff 
+695f d840001c arg 28 ,temp 
+6960 da20018e arg mem_bdaddr_list_buff ,rega 
+6961 da400000 arg eeprom_bdaddr_list ,regb 
+6962 2020683e branch iicd_write_eep_data 
+
+eeprom_store_le_local_addr:
+6963 d8400006 arg 6 ,temp 
+6964 da2044f9 arg mem_le_lap ,rega 
+6965 da40001d arg eeprom_le_reconn_local_addr ,regb 
+6966 2020683e branch iicd_write_eep_data 
+
+eeprom_load_le_loacal_addr:
+6967 d8400006 arg 6 ,temp 
+6968 da2044f9 arg mem_le_lap ,rega 
+6969 da40001d arg eeprom_le_reconn_local_addr ,regb 
+696a 2020681d branch iicd_read_eep_data 
+
+eeprom_load_remote_bdaddr:
+696b 79200025 set1 mark_ext_patch ,mark 
+696c 4486c021 bpatch patch21_5 ,mem_patch21 
+696d d8400007 arg 7 ,temp 
+696e da2001b3 arg mem_temp_reconn_record ,rega 
+696f da400000 arg eeprom_bdaddr_list ,regb 
+6970 680081b2 fetch 1 ,mem_select_list_item 
+6971 1feffe07 mul32 pdata ,7 ,pdata 
+6972 9a40a400 iadd regb ,regb 
+6973 2020681d branch iicd_read_eep_data 
+
+eeprom_linkkey_addr:
+6974 d8400010 arg 0x10 ,temp 
+6975 da400023 arg eeprom_linkkey_list ,regb 
+6976 680081b2 fetch 1 ,mem_select_list_item 
+6977 1ff27e00 lshift4 pdata ,pdata 
+6978 9a40a400 iadd regb ,regb 
+6979 20600000 rtn 
+
+eeprom_store_le_ltl:
+697a da20447b arg mem_le_ltk ,rega 
+697b 2020697d branch eeprom_store_link_key_common 
+
+eeprom_store_link_key:
+697c da204262 arg mem_link_key ,rega 
+
+eeprom_store_link_key_common:
+697d 79200025 set1 mark_ext_patch ,mark 
+697e 44874021 bpatch patch21_6 ,mem_patch21 
+697f 20406974 call eeprom_linkkey_addr 
+6980 2020683e branch iicd_write_eep_data 
+
+eeprom_load_ltk_key:
+6981 da20447b arg mem_le_ltk ,rega 
+6982 20206984 branch eeprom_load_link_key_common 
+
+eeprom_load_link_key:
+6983 da204262 arg mem_link_key ,rega 
+
+eeprom_load_link_key_common:
+6984 79200025 set1 mark_ext_patch ,mark 
+6985 4487c021 bpatch patch21_7 ,mem_patch21 
+6986 20406974 call eeprom_linkkey_addr 
+6987 2020681d branch iicd_read_eep_data 
+
+eeprom_load_bdaddr_list:
+6988 d840001c arg 28 ,temp 
+6989 da200195 arg mem_bdaddr_list_buff + 7 ,rega 
+698a da400000 arg eeprom_bdaddr_list ,regb 
+698b 2020681d branch iicd_read_eep_data 
+
+find_addr_from_bd_list:
+698c 79200025 set1 mark_ext_patch ,mark 
+698d 44884022 bpatch patch22_0 ,mem_patch22 
+698e 58000195 setarg mem_bdaddr_list_buff + 7 
+698f 600101ba store 2 ,mem_list_item_ptr 
+6990 7001b200 jam 0 ,mem_select_list_item 
+6991 df200004 arg 4 ,loopcnt 
+
+find_addr_from_list:
+6992 1f227e00 copy loopcnt ,pdata 
+6993 60008161 store 1 ,mem_pdatatemp 
+6994 680101ba fetch 2 ,mem_list_item_ptr 
+6995 1fe22200 copy pdata ,rega 
+6996 204069ac call find_addr_from_list_compare 
+6997 20740000 rtn user 
+6998 680101ba fetch 2 ,mem_list_item_ptr 
+6999 1fe0fe07 increase 7 ,pdata 
+699a 600101ba store 2 ,mem_list_item_ptr 
+699b 680081b2 fetch 1 ,mem_select_list_item 
+699c 1fe0fe01 increase 1 ,pdata 
+699d 600081b2 store 1 ,mem_select_list_item 
+699e 68008161 fetch 1 ,mem_pdatatemp 
+699f 1fe27200 copy pdata ,loopcnt 
+69a0 c2006992 loop find_addr_from_list 
+69a1 20600000 rtn 
+
+check_link_key_load:
+69a2 68044262 fetch 8 ,mem_link_key 
+69a3 680c426a fetcht 8 ,mem_link_key + 8 
+69a4 9841fe00 ior temp ,pdata 
+69a5 207a0000 rtn blank 
+69a6 70425e01 jam 1 ,mem_link_key_exists 
+69a7 20600000 rtn 
+
+check_ltk_load:
+69a8 68034274 fetch 6 ,mem_hci_plap 
+69a9 207a0000 rtn blank 
+69aa 70448b01 jam 1 ,mem_ltk_exists 
+69ab 20600000 rtn 
+
+find_addr_from_list_compare:
+69ac da4001b3 arg mem_temp_reconn_record ,regb 
+69ad df200007 arg 7 ,loopcnt 
+69ae 20407f25 call string_compare 
+69af 2022e9b1 branch enable_usr ,zero 
+69b0 20600000 rtn 
+
+enable_usr:
+69b1 78347c00 enable user 
+69b2 20600000 rtn 
+
+le_eeprom_load_reconn_info:
+69b3 20203bf1 branch assert 
+
+gpio_set_wake_by_current_state:
+69b4 79200025 set1 mark_ext_patch ,mark 
+69b5 4488c022 bpatch patch22_1 ,mem_patch22 
+69b6 79200407 set1 7 ,temp 
+69b7 204069e5 call gpio_get_bit 
+69b8 7d208407 nsetflag true ,7 ,temp 
+
+gpio_set_wake:
+69b9 79200025 set1 mark_ext_patch ,mark 
+69ba 44894022 bpatch patch22_2 ,mem_patch22 
+69bb 284c0007 isolate0 7 ,temp 
+69bc 18410e1f and temp ,0x1f ,queue 
+69bd 680200a3 fetch 4 ,mem_gpio_wakeup_low 
+69be f920fe00 qsetflag true ,pdata 
+69bf 600200a3 store 4 ,mem_gpio_wakeup_low 
+69c0 680200a7 fetch 4 ,mem_gpio_wakeup_high 
+69c1 fd20fe00 nqsetflag true ,pdata 
+69c2 600200a7 store 4 ,mem_gpio_wakeup_high 
+69c3 20600000 rtn 
+
+gpio_clr_wake:
+69c4 79200025 set1 mark_ext_patch ,mark 
+69c5 4489c022 bpatch patch22_3 ,mem_patch22 
+69c6 284c0007 isolate0 7 ,temp 
+69c7 18410e1f and temp ,0x1f ,queue 
+69c8 680200a3 fetch 4 ,mem_gpio_wakeup_low 
+69c9 f93ffe00 qset0 pdata 
+69ca 600200a3 store 4 ,mem_gpio_wakeup_low 
+69cb 680200a7 fetch 4 ,mem_gpio_wakeup_high 
+69cc f93ffe00 qset0 pdata 
+69cd 600200a7 store 4 ,mem_gpio_wakeup_high 
+69ce 20600000 rtn 
+
+gpio_config_input_nowake:
+69cf 204069c4 call gpio_clr_wake 
+69d0 202069d2 branch gpio_config_input_without_wake 
+
+gpio_config_input:
+69d1 2455e9b9 ncall gpio_set_wake ,wake 
+
+gpio_config_input_without_wake:
+69d2 d8a0807c arg core_gpio_pd0 ,contw 
+69d3 204069f4 call gpio_set_bit 
+69d4 79400407 setflip gpio_active_bit ,temp 
+69d5 d8a08078 arg core_gpio_pu0 ,contw 
+69d6 204069f4 call gpio_set_bit 
+69d7 793f8407 set0 gpio_active_bit ,temp 
+69d8 d8a08070 arg core_gpio_oe0 ,contw 
+69d9 202069f4 branch gpio_set_bit 
+
+gpio_config_output:
+69da 79400407 setflip gpio_active_bit ,temp 
+69db 204069f3 call gpio_out 
+69dc 79200407 set1 gpio_active_bit ,temp 
+69dd d8a08070 arg core_gpio_oe0 ,contw 
+69de 202069f4 branch gpio_set_bit 
+
+gpio_common:
+69df 18410e07 and temp ,0x07 ,queue 
+69e0 18497e00 rshift3 temp ,pdata 
+69e1 1fe17e03 and_into 3 ,pdata 
+69e2 98a08a00 iadd contw ,contw 
+69e3 e8a08000 ifetch 1 ,contw 
+69e4 20600000 rtn 
+
+gpio_get_bit:
+69e5 d8a0811c arg core_gpio_in ,contw 
+69e6 204069df call gpio_common 
+69e7 284ffe07 isolate1 gpio_active_bit ,temp 
+69e8 2020e9eb branch gpio_get_bit_reverse ,true 
+69e9 afec0000 qisolate0 pdata 
+69ea 20600000 rtn 
+
+gpio_get_bit_reverse:
+69eb afefffff qisolate1 pdata 
+69ec 20600000 rtn 
+
+gpio_out_inactive:
+69ed 2fcffe07 isolate1 7 ,null 
+69ee 202069f0 branch gpio_out_flag 
+
+gpio_out_active:
+69ef 2fcc0007 isolate0 7 ,null 
+
+gpio_out_flag:
+69f0 58000000 setarg 0 
+69f1 7d20fe07 nsetflag true ,gpio_active_bit ,pdata 
+69f2 98428400 ixor temp ,temp 
+
+gpio_out:
+69f3 d8a08074 arg core_gpio_out0 ,contw 
+
+gpio_set_bit:
+69f4 204069df call gpio_common 
+69f5 284ffe07 isolate1 gpio_active_bit ,temp 
+69f6 f920fe00 qsetflag true ,pdata 
+69f7 e0a08000 istore 1 ,contw 
+69f8 20600000 rtn 
+
+gpio_test:
+69f9 6800c16e fetch 1 ,mem_seqi 
+69fa c13f8000 rtneq 0x7f 
+69fb 70807700 hjam 0 ,core_gpio_out3 
+69fc 2000001e nop 30 
+69fd 70807708 hjam 8 ,core_gpio_out3 
+69fe 20600000 rtn 
+
+set_pwm_blink:
+69ff 1fed7e00 lshift8 pdata ,pdata 
+6a00 1ff27e00 lshift4 pdata ,pdata 
+6a01 601100a2 hstore 2 ,core_pwm_ncnt0 
+6a02 601100a0 hstore 2 ,core_pwm_pcnt0 
+6a03 20600000 rtn 
+
+set_pwm_steadyon:
+6a04 58000000 setarg 0 
+6a05 601100a2 hstore 2 ,core_pwm_ncnt0 
+6a06 58000001 setarg 1 
+6a07 601100a0 hstore 2 ,core_pwm_pcnt0 
+6a08 20600000 rtn 
+
+set_pwm_off:
+6a09 58000000 setarg 0 
+6a0a 601100a2 hstore 2 ,core_pwm_ncnt0 
+6a0b 601100a0 hstore 2 ,core_pwm_pcnt0 
+6a0c 20600000 rtn 
+
+init_filter_ram:
+6a0d d8a08800 arg 0x8800 ,contw 
+6a0e df200020 arg 0x20 ,loopcnt 
+6a0f 20407e3b call memset0 
+6a10 580004f9 setarg 0x4f9 
+6a11 60110848 hstore 2 ,0x8848 
+6a12 6011084a hstore 2 ,0x884a 
+6a13 6011084c hstore 2 ,0x884c 
+6a14 6011086c hstore 2 ,0x886c 
+6a15 6011088c hstore 2 ,0x888c 
+6a16 601108ac hstore 2 ,0x88ac 
+6a17 58000204 setarg 0x204 
+6a18 601108ae hstore 2 ,0x88ae 
+6a19 58000506 setarg 0x0506 
+6a1a 601108b0 hstore 2 ,0x88b0 
+6a1b 58000504 setarg 0x0504 
+6a1c 601108b2 hstore 2 ,0x88b2 
+6a1d 58000200 setarg 0x0200 
+6a1e 601108b4 hstore 2 ,0x88b4 
+6a1f 5800fefb setarg 0xFEFB 
+6a20 601108b6 hstore 2 ,0x88b6 
+6a21 5800faf9 setarg 0xFAF9 
+6a22 601108b8 hstore 2 ,0x88b8 
+6a23 5800fafb setarg 0xFAFB 
+6a24 601108ba hstore 2 ,0x88ba 
+6a25 5800fd00 setarg 0xFD00 
+6a26 601108bc hstore 2 ,0x88bc 
+6a27 58000408 setarg 0x0408 
+6a28 601108be hstore 2 ,0x88be 
+6a29 58000a0c setarg 0x0A0C 
+6a2a 601108c0 hstore 2 ,0x88c0 
+6a2b 58000b09 setarg 0x0B09 
+6a2c 601108c2 hstore 2 ,0x88c2 
+6a2d 58000500 setarg 0x0500 
+6a2e 601108c4 hstore 2 ,0x88c4 
+6a2f 5800f8f1 setarg 0xF8F1 
+6a30 601108c6 hstore 2 ,0x88c6 
+6a31 5800ece8 setarg 0xECE8 
+6a32 601108c8 hstore 2 ,0x88c8 
+6a33 5800e9eb setarg 0xE9EB 
+6a34 601108ca hstore 2 ,0x88ca 
+6a35 5800f500 setarg 0xF500 
+6a36 601108cc hstore 2 ,0x88cc 
+6a37 58001223 setarg 0x1223 
+6a38 601108ce hstore 2 ,0x88ce 
+6a39 5800374b setarg 0x374B 
+6a3a 601108d0 hstore 2 ,0x88d0 
+6a3b 58005e71 setarg 0x5E71 
+6a3c 601108d2 hstore 2 ,0x88d2 
+6a3d 5800787f setarg 0x787F 
+6a3e 601108d4 hstore 2 ,0x88d4 
+6a3f 20600000 rtn 
+
+enable_pcm:
+6a40 79200025 set1 mark_ext_patch ,mark 
+6a41 448a4022 bpatch patch22_4 ,mem_patch22 
+6a42 68110050 hfetch 2 ,core_clkoff 
+6a43 793ffe0e set0 clock_off_codec ,pdata 
+6a44 60110050 hstore 2 ,core_clkoff 
+6a45 7080b011 hjam 0x11 ,core_enc_ctrl 
+6a46 7080b101 hjam 0x1 ,core_cvsd_ctrl 
+6a47 7080b201 hjam 0x1 ,core_codec_ctrl 
+6a48 7080b311 hjam 0x11 ,core_dec_ctrl 
+6a49 20600000 rtn 
+
+disable_pcm:
+6a4a 79200025 set1 mark_ext_patch ,mark 
+6a4b 448ac022 bpatch patch22_5 ,mem_patch22 
+6a4c 68110050 hfetch 2 ,core_clkoff 
+6a4d 79207e0e set1 clock_off_codec ,pdata 
+6a4e 60110050 hstore 2 ,core_clkoff 
+6a4f 7080b004 hjam 0x4 ,core_enc_ctrl 
+6a50 7080b304 hjam 0x4 ,core_dec_ctrl 
+6a51 7080b100 hjam 0x0 ,core_cvsd_ctrl 
+6a52 7080b200 hjam 0x0 ,core_codec_ctrl 
+6a53 20600000 rtn 
+
+get_sco_data:
+6a54 68008030 fetch 1 ,mem_state 
+6a55 c4010000 rtnbit0 state_insco 
+6a56 d8a000b5 arg mem_sco_obuf ,contw 
+6a57 df20001e arg 30 ,loopcnt 
+
+get_sco_data_loop:
+6a58 68108134 hfetch 1 ,core_pcminfifo 
+6a59 e0a08000 istore 1 ,contw 
+6a5a c2006a58 loop get_sco_data_loop 
+6a5b 20600000 rtn 
+
+process_sco_data:
+6a5c 68008030 fetch 1 ,mem_state 
+6a5d c4010000 rtnbit0 state_insco 
+6a5e d8c000d3 arg mem_sco_ibuf ,contr 
+6a5f 1800721e force 30 ,loopcnt 
+
+process_sco_loop:
+6a60 e8c08000 ifetch 1 ,contr 
+6a61 60108009 hstore 1 ,core_pcmoutfifo 
+6a62 c2006a60 loop process_sco_loop 
+6a63 20600000 rtn 
+
+init_sched:
+6a64 20600000 rtn 
+
+gpio_cfg_uart_tx_output:
+6a65 20406a87 call gpio_uart2gpio 
+6a66 d8400006 arg uart_wakeup_tx ,temp 
+6a67 202069da branch gpio_config_output 
+
+gpio_pu_uart_tx:
+6a68 20406a65 call gpio_cfg_uart_tx_output 
+6a69 d8400006 arg uart_wakeup_tx ,temp 
+6a6a 202069ed branch gpio_out_inactive 
+
+gpio_pd_uart_tx:
+6a6b 20406a65 call gpio_cfg_uart_tx_output 
+6a6c d8400006 arg uart_wakeup_tx ,temp 
+6a6d 202069ef branch gpio_out_active 
+
+gpio_cfg_uart_rx_output:
+6a6e 20406a87 call gpio_uart2gpio 
+6a6f d8400007 arg uart_wakeup_rx ,temp 
+6a70 202069da branch gpio_config_output 
+
+gpio_pu_uart_rx:
+6a71 20406a6e call gpio_cfg_uart_rx_output 
+6a72 d8400007 arg uart_wakeup_rx ,temp 
+6a73 202069ed branch gpio_out_inactive 
+
+gpio_pd_uart_rx:
+6a74 20406a6e call gpio_cfg_uart_rx_output 
+6a75 d8400007 arg uart_wakeup_rx ,temp 
+6a76 202069ef branch gpio_out_active 
+
+gpio_tx_config_input_with_pu:
+6a77 20406a87 call gpio_uart2gpio 
+6a78 68108078 hfetch 1 ,core_gpio_pu0 
+6a79 79207e06 set1 uart_wakeup_tx ,pdata 
+6a7a 60108078 hstore 1 ,core_gpio_pu0 
+6a7b d8400006 arg uart_wakeup_tx ,temp 
+6a7c 202069d1 branch gpio_config_input 
+
+gpio_rx_config_input_with_pu:
+6a7d 20406a87 call gpio_uart2gpio 
+6a7e 68108078 hfetch 1 ,core_gpio_pu0 
+6a7f 79207e07 set1 uart_wakeup_rx ,pdata 
+6a80 60108078 hstore 1 ,core_gpio_pu0 
+6a81 d8400007 arg uart_wakeup_rx ,temp 
+6a82 202069d1 branch gpio_config_input 
+
+gpio_gpio2uart:
+6a83 68108081 hfetch 1 ,core_gpio_sel1 
+6a84 1fe1fe04 or_into 0x04 ,pdata 
+6a85 60108081 hstore 1 ,core_gpio_sel1 
+6a86 20600000 rtn 
+
+gpio_uart2gpio:
+6a87 68108081 hfetch 1 ,core_gpio_sel1 
+6a88 1fe17efb and_into 0xfb ,pdata 
+6a89 60108081 hstore 1 ,core_gpio_sel1 
+6a8a 20600000 rtn 
+
+gpio_check_uart_state:
+6a8b 68108081 hfetch 1 ,core_gpio_sel1 
+6a8c 2feffe02 isolate1 2 ,pdata 
+6a8d 20600000 rtn 
+
+prcp_init:
+6a8e 58006a91 setarg prcp_process 
+6a8f 60014296 store 2 ,mem_cb_att_write 
+6a90 20600000 rtn 
+
+prcp_process:
+6a91 20406b14 call clear_prcp_sendbuff 
+6a92 68008481 fetch 1 ,mem_prcp 
+6a93 c000ea96 beq prcp_le ,le_prcp 
+6a94 c0016a9c beq prcp_ssp ,prcp 
+6a95 20203bf1 branch assert 
+
+le_prcp:
+6a96 d8400017 arg prcp_rx_le ,temp 
+6a97 600944c2 storet 2 ,mem_le_notify_handle 
+6a98 20405a88 call le_att_get_handle_ptr 
+6a99 e8c08000 ifetch 1 ,contr 
+6a9a 20406a9e call prcp_parse 
+6a9b 20205b42 branch prcp_le_tx 
+
+prcp:
+6a9c 20406a9e call prcp_parse 
+6a9d 20205b51 branch prcp_tx 
+
+prcp_parse:
+6a9e 18c22200 copy contr ,rega 
+6a9f 79200025 set1 mark_ext_patch ,mark 
+6aa0 4498c026 bpatch patch26_1 ,mem_patch26 
+6aa1 e8c08000 ifetch 1 ,contr 
+6aa2 c0006ab7 beq common_res ,prcp_parse_common_res 
+6aa3 c000eabc beq read_registers_req ,prcp_parse_read_registers_req 
+6aa4 c0016abd beq read_registers_res ,prcp_parse_read_registers_res 
+6aa5 c001eabe beq write_registers_req ,prcp_parse_write_registers_req 
+6aa6 c0026b50 beq i2c_config_req ,prcp_parse_i2c_config_req 
+6aa7 c002eaff beq i2c_read_req ,prcp_parse_i2c_read_req 
+6aa8 c0036b51 beq i2c_read_res ,prcp_parse_i2c_read_res 
+6aa9 c003eb52 beq i2c_write_req ,prcp_parse_i2c_write_req 
+6aaa c0046abf beq spi_config_req ,prcp_parse_spi_config_req 
+6aab c004eac0 beq spi_read_req ,prcp_parse_spi_read_req 
+6aac c0056ac1 beq spi_read_res ,prcp_parse_spi_read_res 
+6aad c005eac2 beq spi_write_req ,prcp_parse_spi_write_req 
+6aae c0066ac3 beq pwm_config_req ,prcp_parse_pwm_config_req 
+6aaf c006ead5 beq pwm_write_req ,prcp_parse_pwm_write_req 
+6ab0 c0076ae3 beq gpio_config_req ,prcp_parse_gpio_config_req 
+6ab1 c007eaf0 beq gpio_read_req ,prcp_parse_gpio_read_req 
+6ab2 c0086af1 beq gpio_read_res ,prcp_parse_gpio_read_res 
+6ab3 c008eaf8 beq gpio_write_req ,prcp_parse_gpio_write_req 
+6ab4 c0096b19 beq ota_write_req ,prcp_parse_ota_write_req 
+6ab5 c009eb45 beq ota_end_cmd ,prcp_parse_ota_end_cmd 
+6ab6 20600000 rtn 
+
+prcp_parse_common_res:
+6ab7 1a220c00 copy rega ,contr 
+6ab8 e8c08000 ifetch 1 ,contr 
+6ab9 1fed7e00 lshift8 pdata ,pdata 
+6aba 6001846d store 3 ,mem_prcp_data 
+6abb 20600000 rtn 
+
+prcp_parse_read_registers_req:
+6abc 20600000 rtn 
+
+prcp_parse_read_registers_res:
+6abd 20600000 rtn 
+
+prcp_parse_write_registers_req:
+6abe 20600000 rtn 
+
+prcp_parse_spi_config_req:
+6abf 20600000 rtn 
+
+prcp_parse_spi_read_req:
+6ac0 20600000 rtn 
+
+prcp_parse_spi_read_res:
+6ac1 20600000 rtn 
+
+prcp_parse_spi_write_req:
+6ac2 20600000 rtn 
+
+prcp_parse_pwm_config_req:
+6ac3 e8c20000 ifetch 4 ,contr 
+6ac4 60108082 hstore 1 ,core_gpio_sel2 
+6ac5 1fecfe00 rshift8 pdata ,pdata 
+6ac6 68188081 hfetcht 1 ,core_gpio_sel1 
+6ac7 1841047f and_into 0x7f ,temp 
+6ac8 98418400 ior temp ,temp 
+6ac9 60188081 hstoret 1 ,core_gpio_sel1 
+6aca 1fecfe00 rshift8 pdata ,pdata 
+6acb 68188051 hfetcht 1 ,core_clkoff + 1 
+6acc 184104df and_into 0xdf ,temp 
+6acd 98418400 ior temp ,temp 
+6ace 60188051 hstoret 1 ,core_clkoff + 1 
+6acf 1fecfe00 rshift8 pdata ,pdata 
+6ad0 68188042 hfetcht 1 ,core_clksel 
+6ad1 1841043f and_into 0x3f ,temp 
+6ad2 98418400 ior temp ,temp 
+6ad3 60188042 hstoret 1 ,core_clksel 
+6ad4 20206ab7 branch prcp_parse_common_res 
+
+prcp_parse_pwm_write_req:
+6ad5 e8c48000 ifetch 9 ,contr 
+6ad6 68188085 hfetcht 1 ,core_gpio_key2 
+6ad7 1841043f and_into 0x3f ,temp 
+6ad8 98418400 ior temp ,temp 
+6ad9 60188085 hstoret 1 ,core_gpio_key2 
+6ada 1fecfe00 rshift8 pdata ,pdata 
+6adb 601100a0 hstore 2 ,core_pwm_pcnt0 
+6adc 1ff17e00 rshift16 pdata ,pdata 
+6add 601100a2 hstore 2 ,core_pwm_ncnt0 
+6ade 1ff17e00 rshift16 pdata ,pdata 
+6adf 601100a4 hstore 2 ,core_pwm_pcnt1 
+6ae0 1ff17e00 rshift16 pdata ,pdata 
+6ae1 601100a6 hstore 2 ,core_pwm_ncnt1 
+6ae2 20206ab7 branch prcp_parse_common_res 
+
+prcp_parse_gpio_config_req:
+6ae3 e8c20000 ifetch 4 ,contr 
+6ae4 60120070 hstore 4 ,core_gpio_oe0 
+6ae5 e8c20000 ifetch 4 ,contr 
+6ae6 60120078 hstore 4 ,core_gpio_pu0 
+6ae7 e8c20000 ifetch 4 ,contr 
+6ae8 6012007c hstore 4 ,core_gpio_pd0 
+6ae9 e8c08000 ifetch 1 ,contr 
+6aea 60108080 hstore 1 ,core_gpio_sel 
+6aeb e8c08000 ifetch 1 ,contr 
+6aec 60108081 hstore 1 ,core_gpio_sel1 
+6aed e8c08000 ifetch 1 ,contr 
+6aee 60108082 hstore 1 ,core_gpio_sel2 
+6aef 20206ab7 branch prcp_parse_common_res 
+
+prcp_parse_gpio_read_req:
+6af0 20206af1 branch prcp_parse_gpio_read_res 
+
+prcp_parse_gpio_read_res:
+6af1 70046d10 jam 0x10 ,mem_prcp_data 
+6af2 d8a0046e arg mem_prcp_data + 1 ,contw 
+6af3 68120074 hfetch 4 ,core_gpio_out0 
+6af4 e0a20000 istore 4 ,contw 
+6af5 6812011c hfetch 4 ,core_gpio_in 
+6af6 e0a20000 istore 4 ,contw 
+6af7 20600000 rtn 
+
+prcp_parse_gpio_write_req:
+6af8 e8c88000 ifetcht 1 ,contr 
+6af9 e8c08000 ifetch 1 ,contr 
+6afa 1fe9fe00 lshift3 pdata ,pdata 
+6afb 1ff27e00 lshift4 pdata ,pdata 
+6afc 98418400 ior temp ,temp 
+6afd 204069f3 call gpio_out 
+6afe 20206ab7 branch prcp_parse_common_res 
+
+prcp_parse_i2c_read_req:
+6aff e8c88000 ifetcht 1 ,contr 
+6b00 60188301 hstoret 1 ,iic_slave_addr 
+6b01 e8c08000 ifetch 1 ,contr 
+6b02 2fe1fe01 compare 1 ,pdata ,0xff 
+6b03 e8c08000 ifetch 1 ,contr 
+6b04 60108307 hstore 1 ,iic_fifo 
+6b05 2020eb08 branch iic_read_data_len ,true 
+6b06 e8c08000 ifetch 1 ,contr 
+6b07 60108307 hstore 1 ,iic_fifo 
+
+iic_read_data_len:
+6b08 e8c08000 ifetch 1 ,contr 
+6b09 1fe27200 copy pdata ,loopcnt 
+6b0a 1fe0ffff increase -1 ,pdata 
+6b0b 1fe1fe90 or_into 0x90 ,pdata 
+6b0c 60108302 hstore 1 ,iic_ctr 
+6b0d 70830302 hjam 2 ,iic_cr 
+6b0e 20000001 nop 1 
+6b0f d8a0046d arg mem_prcp_data ,contw 
+
+iic_read_loop:
+6b10 68108307 hfetch 1 ,iic_fifo 
+6b11 e0a08000 istore 1 ,contw 
+6b12 c2006b10 loop iic_read_loop 
+6b13 20600000 rtn 
+
+clear_prcp_sendbuff:
+6b14 58000000 setarg 0 
+6b15 6002046d store 4 ,mem_prcp_data 
+6b16 e0a40000 istore 8 ,contw 
+6b17 e0a40000 istore 8 ,contw 
+6b18 20600000 rtn 
+
+prcp_parse_ota_write_req:
+6b19 1a227e00 copy rega ,pdata 
+6b1a 1fe0fe01 increase 1 ,pdata 
+6b1b 60010483 store 2 ,rx_buf_data_ptr 
+6b1c 68014749 fetch 2 ,mem_eeprom_ota_base_addr 
+6b1d c0006b28 beq 0x0000 ,prcp_parse_ota_start1 
+
+prcp_parse_ota_load:
+6b1e 68014749 fetch 2 ,mem_eeprom_ota_base_addr 
+6b1f 68090483 fetcht 2 ,rx_buf_data_ptr 
+6b20 e8490000 ifetcht 2 ,temp 
+6b21 9840fe00 iadd temp ,pdata 
+6b22 68090483 fetcht 2 ,rx_buf_data_ptr 
+6b23 18408402 increase 2 ,temp 
+6b24 18420c00 copy temp ,contr 
+6b25 e8c88000 ifetcht 1 ,contr 
+6b26 18c22200 copy contr ,rega 
+6b27 20206842 branch iicd_write_ota_data 
+
+prcp_parse_ota_start1:
+6b28 58000002 setarg 0x0002 
+6b29 1ff0fe00 byteswap pdata ,pdata 
+6b2a 60010225 store 2 ,mem_addr_mi 
+6b2b da606823 arg iicd_read_eep ,regc 
+6b2c df200002 arg 0x2 ,loopcnt 
+
+prcp_parse_ota_loop1:
+6b2d 204066e2 call get_block_header 
+6b2e 2422eb36 nbranch prcp_parse_ota_start2 ,zero 
+6b2f 68010225 fetch 2 ,mem_addr_mi 
+6b30 1ff0fe00 byteswap pdata ,pdata 
+6b31 9840fe00 iadd temp ,pdata 
+6b32 60014749 store 2 ,mem_eeprom_ota_base_addr 
+6b33 1ff0fe00 byteswap pdata ,pdata 
+6b34 60010225 store 2 ,mem_addr_mi 
+6b35 c2006b2d loop prcp_parse_ota_loop1 
+
+prcp_parse_ota_start2:
+6b36 68014749 fetch 2 ,mem_eeprom_ota_base_addr 
+6b37 1ff0fe00 byteswap pdata ,pdata 
+6b38 60010225 store 2 ,mem_addr_mi 
+6b39 da606823 arg iicd_read_eep ,regc 
+6b3a df20ffff arg 0xffff ,loopcnt 
+
+prcp_parse_ota_loop2:
+6b3b 204066e2 call get_block_header 
+6b3c 2422eb1e nbranch prcp_parse_ota_load ,zero 
+6b3d 68010225 fetch 2 ,mem_addr_mi 
+6b3e 1ff0fe00 byteswap pdata ,pdata 
+6b3f 9840fe00 iadd temp ,pdata 
+6b40 1fe0fe02 increase 2 ,pdata 
+6b41 60014749 store 2 ,mem_eeprom_ota_base_addr 
+6b42 1ff0fe00 byteswap pdata ,pdata 
+6b43 60010225 store 2 ,mem_addr_mi 
+6b44 c2006b3b loop prcp_parse_ota_loop2 
+
+prcp_parse_ota_end_cmd:
+6b45 68014749 fetch 2 ,mem_eeprom_ota_base_addr 
+6b46 1fe0fe02 increase 2 ,pdata 
+6b47 1ff0fe00 byteswap pdata ,pdata 
+6b48 60014749 store 2 ,mem_eeprom_ota_base_addr 
+6b49 da204749 arg mem_eeprom_ota_base_addr ,rega 
+6b4a d8400002 arg 0x02 ,temp 
+6b4b dfe00000 arg 0x0000 ,pdata 
+6b4c 20406842 call iicd_write_ota_data 
+6b4d 58000000 setarg 0x0000 
+6b4e 60014749 store 2 ,mem_eeprom_ota_base_addr 
+6b4f 20600000 rtn 
+
+prcp_parse_i2c_config_req:
+6b50 20600000 rtn 
+
+prcp_parse_i2c_read_res:
+6b51 20600000 rtn 
+
+prcp_parse_i2c_write_req:
+6b52 20600000 rtn 
+
+rfcomm_init:
+6b53 20758000 rtn wake 
+6b54 70475500 jam 0 ,mem_rfcomm_send_more_pkt 
+6b55 70048503 jam bits9600 ,memremoterpnbitrate 
+6b56 70048603 jam databits8 ,memremoteprndatabits 
+6b57 70048a11 jam 0x11 ,memremoteprnxon 
+6b58 70048b13 jam 0x13 ,memremoteprnxoff 
+6b59 58000000 setarg 0 
+6b5a 60018487 store 3 ,memremoteprnstopbit 
+6b5b 6000c2bd store 1 ,mem_spp_state 
+6b5c 7047f300 jam 0 ,memui_reconnect_mode 
+
+rfcomm_init_spp:
+6b5d 79200025 set1 mark_ext_patch ,mark 
+6b5e 44dfc037 bpatch patch37_7 ,mem_patch37 
+6b5f 58000000 setarg 0 
+6b60 6000c2bd store 1 ,mem_spp_state 
+6b61 6000c752 store 1 ,mem_remote_spp_channel 
+6b62 6000c74b store 1 ,mem_pn_dlci 
+6b63 70475750 jam 0x50 ,mem_credit_given 
+6b64 20600000 rtn 
+
+set_cr_bit:
+6b65 18418402 or_into 0x02 ,temp 
+6b66 20600000 rtn 
+
+rfcomm_calculate_fcs_sabm:
+6b67 18427e00 copy temp ,pdata 
+6b68 1fedfe00 reverse pdata ,pdata 
+6b69 6000c750 store 1 ,memfcstemp3 
+6b6a 18007e3f force ini_tx_sabm ,pdata 
+6b6b 1fedfe00 reverse pdata ,pdata 
+6b6c 6000c74f store 1 ,memfcstemp2 
+6b6d 18007e01 force 0x01 ,pdata 
+6b6e 1fedfe00 reverse pdata ,pdata 
+6b6f 6000c74e store 1 ,memfcstemp1 
+6b70 20406b9d call caculate_fcs 
+6b71 18427e00 copy temp ,pdata 
+6b72 20600000 rtn 
+
+rfcomm_calculate_fcs_ua:
+6b73 1fedfe00 reverse pdata ,pdata 
+6b74 6000c750 store 1 ,memfcstemp3 
+6b75 18007e73 force rsp_tx_ua ,pdata 
+6b76 1fedfe00 reverse pdata ,pdata 
+6b77 6000c74f store 1 ,memfcstemp2 
+6b78 18007e01 force 0x01 ,pdata 
+6b79 1fedfe00 reverse pdata ,pdata 
+6b7a 6000c74e store 1 ,memfcstemp1 
+6b7b 20206b9d branch caculate_fcs 
+
+rfcomm_calculate_fcs_dlci0:
+6b7c 6800c751 fetch 1 ,mem_rfcomm_initiator 
+6b7d 203a6b80 branch rfcomm_calculate_fcs_dlci0_res ,blank 
+6b7e 58000070 setarg 0x70 
+6b7f 20600000 rtn 
+
+rfcomm_calculate_fcs_dlci0_res:
+6b80 580000aa setarg 0xaa 
+6b81 20600000 rtn 
+
+rfcomm_save_fcs_uih:
+6b82 1fedfe00 reverse pdata ,pdata 
+6b83 6000c750 store 1 ,memfcstemp3 
+6b84 18007eef force rsp_rx_uih ,pdata 
+6b85 20406b91 call caculate_uihdata_fcs 
+6b86 6809048f fetcht 2 ,mem_contw_temp 
+6b87 18420a00 copy temp ,contw 
+6b88 e0a08000 istore 1 ,contw 
+6b89 18a20400 copy contw ,temp 
+6b8a 6009048f storet 2 ,mem_contw_temp 
+6b8b 18007eff force rsp_rx_uih_wdata ,pdata 
+6b8c 20406b91 call caculate_uihdata_fcs 
+6b8d 6809048f fetcht 2 ,mem_contw_temp 
+6b8e 18420a00 copy temp ,contw 
+6b8f e0a08000 istore 1 ,contw 
+6b90 20600000 rtn 
+
+caculate_uihdata_fcs:
+6b91 1fedfe00 reverse pdata ,pdata 
+6b92 6000c74f store 1 ,memfcstemp2 
+6b93 6801474f fetch 2 ,memfcstemp2 
+6b94 1fed7e00 lshift8 pdata ,pdata 
+6b95 6001848c store 3 ,mem_mod2div_temp 
+6b96 da200107 arg 0x107 ,rega 
+6b97 da40000f arg 0xf ,regb 
+6b98 20406baa call mod2div 
+6b99 1fe2fed7 xor_into 0xd7 ,pdata 
+6b9a 1fe47e00 invert pdata ,pdata 
+6b9b 1fedfe00 reverse pdata ,pdata 
+6b9c 20600000 rtn 
+
+caculate_fcs:
+6b9d 6801c74e fetch 3 ,memfcstemp1 
+6b9e 6001848c store 3 ,mem_mod2div_temp 
+6b9f da200107 arg 0x107 ,rega 
+6ba0 da40000f arg 0xf ,regb 
+6ba1 20406baa call mod2div 
+6ba2 1fed7e00 lshift8 pdata ,pdata 
+6ba3 da400007 arg 0x7 ,regb 
+6ba4 20406baa call mod2div 
+6ba5 1fe2fe2b xor_into 0x2b ,pdata 
+6ba6 1fe47e00 invert pdata ,pdata 
+6ba7 1fedfe00 reverse pdata ,pdata 
+6ba8 1fe20400 copy pdata ,temp 
+6ba9 20600000 rtn 
+
+mod2div:
+6baa da600000 arg 0 ,regc 
+6bab 1a427200 copy regb ,loopcnt 
+6bac 20407dfb call right_shift_n 
+6bad 1fe20400 icopy temp 
+
+mod2div_loop:
+6bae 18427e00 copy temp ,pdata 
+6baf 1a63a600 lshift regc ,regc 
+6bb0 c3046bb3 bbit0 8 ,mod2div_not_enough_reduction 
+6bb1 9a228400 ixor rega ,temp 
+6bb2 1a60a601 increase 1 ,regc 
+
+mod2div_not_enough_reduction:
+6bb3 18438400 lshift temp ,temp 
+6bb4 6801848c fetch 3 ,mem_mod2div_temp 
+6bb5 1a40a5ff increase -1 ,regb 
+6bb6 2a41feff compare 0xff ,regb ,0xff 
+6bb7 2020ebbd branch mod2div_end ,true 
+6bb8 1a427200 copy regb ,loopcnt 
+6bb9 20407dfb call right_shift_n 
+6bba 2feffe00 isolate1 0 ,pdata 
+6bbb 79208400 setflag true ,0 ,temp 
+6bbc 20206bae branch mod2div_loop 
+
+mod2div_end:
+6bbd 18437e00 rshift temp ,pdata 
+6bbe 20600000 rtn 
+
+get_rfcomm_snd_adss:
+6bbf 6808c74b fetcht 1 ,mem_pn_dlci 
+
+dlci_to_address_cmd:
+6bc0 184b8400 lshift2 temp ,temp 
+6bc1 79200400 set1 rfcomm_address_ext_len ,temp 
+6bc2 6800c751 fetch 1 ,mem_rfcomm_initiator 
+6bc3 245a6b65 ncall set_cr_bit ,blank 
+6bc4 600884a5 storet 1 ,mem_rfcomm_send_adss 
+6bc5 20600000 rtn 
+
+dlci_to_address_res:
+6bc6 184b8400 lshift2 temp ,temp 
+6bc7 79200400 set1 rfcomm_address_ext_len ,temp 
+6bc8 6800c751 fetch 1 ,mem_rfcomm_initiator 
+6bc9 205a6b65 call set_cr_bit ,blank 
+6bca 20600000 rtn 
+
+channel_to_dlci:
+6bcb 18438400 lshift temp ,temp 
+6bcc 6800c751 fetch 1 ,mem_rfcomm_initiator 
+6bcd 793a0400 setflag blank ,0 ,temp 
+6bce 20600000 rtn 
+
+rfcomm_rx_process_dlci0_sabm:
+6bcf 68088494 fetcht 1 ,mem_current_channel 
+6bd0 700496d7 jam 0xd7 ,mem_current_fcs 
+6bd1 20406cf6 call rfcomm_send_ua 
+6bd2 6800c2ba fetch 1 ,mem_rfcomm_state 
+6bd3 79207e06 set1 l2cap_channel_rfcomm_only_sabm ,pdata 
+6bd4 79207e07 set1 l2cap_channel_rfcomm_only_ua ,pdata 
+6bd5 6000c2ba store 1 ,mem_rfcomm_state 
+6bd6 70475100 jam 0 ,mem_rfcomm_initiator 
+6bd7 20206cd7 branch rfcomm_rx_process_end 
+
+rfcomm_rx_process_dlci0_ua:
+6bd8 6800c2ba fetch 1 ,mem_rfcomm_state 
+6bd9 79207e07 set1 l2cap_channel_rfcomm_only_ua ,pdata 
+6bda 6000c2ba store 1 ,mem_rfcomm_state 
+6bdb 20206cd7 branch rfcomm_rx_process_end 
+
+rfcomm_rx_process:
+6bdc 79200025 set1 mark_ext_patch ,mark 
+6bdd 44e04038 bpatch patch38_0 ,mem_patch38 
+6bde 6800c7f3 fetch 1 ,memui_reconnect_mode 
+6bdf c0006be1 beq no_reconnection ,rfcomm_rx_process_remote_page 
+6be0 20206c8b branch rfcomm_rx_process_reconn 
+
+rfcomm_rx_process_remote_page:
+6be1 680102cb fetch 2 ,mem_l2cap_payload_ptr 
+6be2 1fe20c00 copy pdata ,contr 
+6be3 20406c0f call get_rfcomm_head_struct 
+6be4 68008494 fetch 1 ,mem_current_channel 
+6be5 c0006be7 beq 0 ,parse_dlci0_rp 
+6be6 20206c57 branch parse_uih_rp 
+
+parse_dlci0_rp:
+6be7 79200025 set1 mark_ext_patch ,mark 
+6be8 44e0c038 bpatch patch38_1 ,mem_patch38 
+6be9 68008495 fetch 1 ,mem_current_frame_type 
+6bea c01febcf beq rfcomm_frame_type_sabm ,rfcomm_rx_process_dlci0_sabm 
+6beb c039ebd8 beq rfcomm_frame_type_ua ,rfcomm_rx_process_dlci0_ua 
+6bec c077ebef beq rfcomm_frame_type_uih ,parse_dlci0_rp_uih 
+6bed c1298000 rtneq rfcomm_frame_type_disconn 
+6bee 20203bf1 branch assert 
+
+parse_dlci0_rp_uih:
+6bef 68010499 fetch 2 ,mem_rfcomm_uih_payload_ptr 
+6bf0 1fe20c00 copy pdata ,contr 
+6bf1 20406c1a call get_rfcomm_uih_head_struct 
+6bf2 6800849b fetch 1 ,mem_uih_cmd_type 
+6bf3 c020ebf8 beq uih_param_neg_cmd ,parse_dlci0_rp_uih_pn_cmd 
+6bf4 c0206c04 beq uih_param_neg_res ,parse_dlci0_rp_uih_pn_res 
+6bf5 c038ec3f beq uih_modem_status_cmd ,parse_dlci0_rp_uih_ms_cmd 
+6bf6 c0386c4e beq uih_modem_status_res ,parse_dlci0_rp_uih_ms_res 
+6bf7 20206cd7 branch rfcomm_rx_process_end 
+
+parse_dlci0_rp_uih_pn_cmd:
+6bf8 20406c06 call parse_dlci0_rp_uih_pn_res_common 
+6bf9 6800c74b fetch 1 ,mem_pn_dlci 
+6bfa 1fe37e00 rshift pdata ,pdata 
+6bfb 1fe67c01 sub pdata ,spp_slave_channel ,null 
+6bfc 2022ebfe branch parse_dlci0_rp_uih_pn_cmd_spp ,zero 
+6bfd 20203bf1 branch assert 
+
+parse_dlci0_rp_uih_pn_cmd_spp:
+6bfe 6800c2bd fetch 1 ,mem_spp_state 
+6bff 79207e00 set1 rfcomm_channel_state_pn_cmd ,pdata 
+6c00 79207e01 set1 rfcomm_channel_state_pn_res ,pdata 
+6c01 6000c2bd store 1 ,mem_spp_state 
+6c02 20406d22 call rfcomm_send_param_neg_res 
+6c03 20206cd7 branch rfcomm_rx_process_end 
+
+parse_dlci0_rp_uih_pn_res:
+6c04 20406c06 call parse_dlci0_rp_uih_pn_res_common 
+6c05 20206cd7 branch rfcomm_rx_process_end 
+
+parse_dlci0_rp_uih_pn_res_common:
+6c06 20406c22 call get_param_payload_ptr 
+6c07 20206c30 branch get_rfcomm_prarmer_negotiation 
+
+get_rfcomm_param_modem_status:
+6c08 20406c22 call get_param_payload_ptr 
+6c09 e8c08000 ifetch 1 ,contr 
+6c0a 1fe97e00 rshift3 pdata ,pdata 
+6c0b 6000c758 store 1 ,mem_ms_channel 
+6c0c e8c08000 ifetch 1 ,contr 
+6c0d 600084a0 store 1 ,mem_ms_param 
+6c0e 20600000 rtn 
+
+get_rfcomm_head_struct:
+6c0f e8c08000 ifetch 1 ,contr 
+6c10 60008493 store 1 ,mem_current_adss 
+6c11 1fe97e00 rshift3 pdata ,pdata 
+6c12 60008494 store 1 ,mem_current_channel 
+6c13 e8c08000 ifetch 1 ,contr 
+6c14 60008495 store 1 ,mem_current_frame_type 
+
+get_rfcomm_current_length:
+6c15 20406c27 call get_rfcomm_length_common 
+6c16 60090497 storet 2 ,mem_current_length 
+6c17 18c27e00 copy contr ,pdata 
+6c18 60010499 store 2 ,mem_rfcomm_uih_payload_ptr 
+6c19 20600000 rtn 
+
+get_rfcomm_uih_head_struct:
+6c1a e8c08000 ifetch 1 ,contr 
+6c1b 1fe37e00 rshift pdata ,pdata 
+6c1c 6000849b store 1 ,mem_uih_cmd_type 
+6c1d 20406c27 call get_rfcomm_length_common 
+6c1e 6009049c storet 2 ,mem_uih_length 
+6c1f 18c27e00 copy contr ,pdata 
+6c20 6001049e store 2 ,mem_param_payload_ptr 
+6c21 20600000 rtn 
+
+get_param_payload_ptr:
+6c22 6801049e fetch 2 ,mem_param_payload_ptr 
+6c23 1fe20c00 copy pdata ,contr 
+6c24 20600000 rtn 
+
+get_rfcomm_param_length_common:
+6c25 6801049e fetch 2 ,mem_param_payload_ptr 
+6c26 1fe20c00 copy pdata ,contr 
+
+get_rfcomm_length_common:
+6c27 e8c08000 ifetch 1 ,contr 
+6c28 1fe20400 copy pdata ,temp 
+6c29 18430400 rshift temp ,temp 
+6c2a c3800000 rtnbit1 0 
+6c2b e8c08000 ifetch 1 ,contr 
+6c2c 1fe9fe00 lshift3 pdata ,pdata 
+6c2d 1ff27e00 lshift4 pdata ,pdata 
+6c2e 98408400 iadd temp ,temp 
+6c2f 20600000 rtn 
+
+get_rfcomm_prarmer_negotiation:
+6c30 e8c08000 ifetch 1 ,contr 
+6c31 6000c74b store 1 ,mem_pn_dlci 
+6c32 e8c08000 ifetch 1 ,contr 
+6c33 600084a1 store 1 ,mem_pn_credit_flow_type_info 
+6c34 e8c08000 ifetch 1 ,contr 
+6c35 600084a2 store 1 ,mem_pn_priority 
+6c36 e8c08000 ifetch 1 ,contr 
+6c37 600084a3 store 1 ,mem_pn_acknowledg_timer 
+6c38 e8c10000 ifetch 2 ,contr 
+6c39 6001474c store 2 ,mem_pn_max_frame_size 
+6c3a e8c08000 ifetch 1 ,contr 
+6c3b 600084a4 store 1 ,mem_pn_max_retrans 
+6c3c e8c08000 ifetch 1 ,contr 
+6c3d 6000c756 store 1 ,mem_remote_credits 
+6c3e 20600000 rtn 
+
+parse_dlci0_rp_uih_ms_cmd:
+6c3f 20406c08 call get_rfcomm_param_modem_status 
+6c40 6800c758 fetch 1 ,mem_ms_channel 
+6c41 1fe67c01 sub pdata ,1 ,null 
+6c42 2022ec44 branch parse_dlci0_rp_uih_ms_cmd_spp ,zero 
+6c43 20203bf1 branch assert 
+
+parse_dlci0_rp_uih_ms_cmd_spp:
+6c44 6800c2bd fetch 1 ,mem_spp_state 
+6c45 79207e05 set1 rfcomm_channel_state_rcv_ms_cmd ,pdata 
+6c46 79207e06 set1 rfcomm_channel_state_snd_ms_res ,pdata 
+6c47 6000c2bd store 1 ,mem_spp_state 
+6c48 6808c74b fetcht 1 ,mem_pn_dlci 
+6c49 184b8400 lshift2 temp ,temp 
+6c4a 18418403 or_into 3 ,temp 
+6c4b 20406d55 call rfcomm_send_modem_status_res 
+6c4c 70475503 jam more_pkt_msc_cmd_spp ,mem_rfcomm_send_more_pkt 
+6c4d 20206cd7 branch rfcomm_rx_process_end 
+
+parse_dlci0_rp_uih_ms_res:
+6c4e 20406c08 call get_rfcomm_param_modem_status 
+6c4f 6800c758 fetch 1 ,mem_ms_channel 
+6c50 1fe67c01 sub pdata ,1 ,null 
+6c51 2022ec53 branch parse_dlci0_rp_uih_ms_res_spp ,zero 
+6c52 20203bf1 branch assert 
+
+parse_dlci0_rp_uih_ms_res_spp:
+6c53 6800c2bd fetch 1 ,mem_spp_state 
+6c54 79207e07 set1 rfcomm_channel_state_rcv_ms_res ,pdata 
+6c55 6000c2bd store 1 ,mem_spp_state 
+6c56 20206cd7 branch rfcomm_rx_process_end 
+
+parse_uih_rp:
+6c57 68008494 fetch 1 ,mem_current_channel 
+6c58 1fe67c01 sub pdata ,spp_slave_channel ,null 
+6c59 2022ec5b branch parse_uih_rp_spp ,zero 
+6c5a 20203bf1 branch assert 
+
+parse_uih_rp_spp:
+6c5b 68008495 fetch 1 ,mem_current_frame_type 
+6c5c c039ec62 beq rfcomm_frame_type_ua ,parse_uih_rp_spp_ua 
+6c5d c01fec66 beq rfcomm_frame_type_sabm ,parse_uih_rp_spp_sabm 
+6c5e c077ec80 beq rfcomm_frame_type_uih ,parse_uih_spp_uih 
+6c5f c07fec78 beq rfcomm_frame_type_uih_credits ,parse_uih_spp_uih_credits 
+6c60 c029ec85 beq rfcomm_frame_type_disconn ,parse_uih_rp_spp_disconn 
+6c61 20203bf1 branch assert 
+
+parse_uih_rp_spp_ua:
+6c62 6800c2bd fetch 1 ,mem_spp_state 
+6c63 79207e03 set1 rfcomm_channel_state_ua ,pdata 
+6c64 6000c2bd store 1 ,mem_spp_state 
+6c65 20206cd7 branch rfcomm_rx_process_end 
+
+parse_uih_rp_spp_sabm:
+6c66 6800c2bd fetch 1 ,mem_spp_state 
+6c67 79207e03 set1 rfcomm_channel_state_ua ,pdata 
+6c68 79207e02 set1 rfcomm_channel_state_sabm ,pdata 
+6c69 6000c2bd store 1 ,mem_spp_state 
+6c6a 68008493 fetch 1 ,mem_current_adss 
+6c6b 20406b73 call rfcomm_calculate_fcs_ua 
+6c6c 60008496 store 1 ,mem_current_fcs 
+6c6d 20406cf6 call rfcomm_send_ua 
+6c6e 68008493 fetch 1 ,mem_current_adss 
+6c6f 1feb7e00 rshift2 pdata ,pdata 
+6c70 6000c74b store 1 ,mem_pn_dlci 
+6c71 1febfe00 lshift2 pdata ,pdata 
+6c72 793ffe01 set0 rfcomm_address_cr ,pdata 
+6c73 79207e00 set1 rfcomm_address_ext_len ,pdata 
+6c74 d8404753 arg mem_hiufcs_spp ,temp 
+6c75 6009048f storet 2 ,mem_contw_temp 
+6c76 20406b82 call rfcomm_save_fcs_uih 
+6c77 20206cd7 branch rfcomm_rx_process_end 
+
+parse_uih_spp_uih_credits:
+6c78 68010499 fetch 2 ,mem_rfcomm_uih_payload_ptr 
+6c79 1fe20c00 copy pdata ,contr 
+6c7a 1fe0fe01 increase 1 ,pdata 
+6c7b 60010499 store 2 ,mem_rfcomm_uih_payload_ptr 
+6c7c e8c08000 ifetch 1 ,contr 
+6c7d 6808c756 fetcht 1 ,mem_remote_credits 
+6c7e 9840fe00 iadd temp ,pdata 
+6c7f 6000c756 store 1 ,mem_remote_credits 
+
+parse_uih_spp_uih:
+6c80 20406d88 call rfcomm_increase_credit_given 
+
+parse_uih_spp_uih_cont:
+6c81 20406bbf call get_rfcomm_snd_adss 
+6c82 20406d6d call rfcomm_send_uih_without_payload 
+6c83 20406d8e call spp_process_rx_data 
+6c84 20206cd7 branch rfcomm_rx_process_end 
+
+parse_uih_rp_spp_disconn:
+6c85 20406b5d call rfcomm_init_spp 
+6c86 68008493 fetch 1 ,mem_current_adss 
+6c87 20406b73 call rfcomm_calculate_fcs_ua 
+6c88 60008496 store 1 ,mem_current_fcs 
+6c89 20406cf6 call rfcomm_send_ua 
+6c8a 20206cd7 branch rfcomm_rx_process_end 
+
+rfcomm_rx_process_reconn:
+6c8b 680102cb fetch 2 ,mem_l2cap_payload_ptr 
+6c8c 1fe20c00 copy pdata ,contr 
+6c8d 20406c0f call get_rfcomm_head_struct 
+6c8e 68008494 fetch 1 ,mem_current_channel 
+6c8f c0006c91 beq 0 ,parse_dlci0_reconn 
+6c90 20206cc6 branch parse_uih_reconn 
+
+parse_dlci0_reconn:
+6c91 79200025 set1 mark_ext_patch ,mark 
+6c92 44e14038 bpatch patch38_2 ,mem_patch38 
+6c93 68008495 fetch 1 ,mem_current_frame_type 
+6c94 c01febcf beq rfcomm_frame_type_sabm ,rfcomm_rx_process_dlci0_sabm 
+6c95 c039ebd8 beq rfcomm_frame_type_ua ,rfcomm_rx_process_dlci0_ua 
+6c96 c077ec98 beq rfcomm_frame_type_uih ,parse_dlci0_reconn_uih 
+6c97 20206cd7 branch rfcomm_rx_process_end 
+
+parse_dlci0_reconn_uih:
+6c98 68010499 fetch 2 ,mem_rfcomm_uih_payload_ptr 
+6c99 1fe20c00 copy pdata ,contr 
+6c9a 20406c1a call get_rfcomm_uih_head_struct 
+6c9b 6800849b fetch 1 ,mem_uih_cmd_type 
+6c9c c020eca1 beq uih_param_neg_cmd ,parse_dlci0_reconn_uih_pn_cmd 
+6c9d c0206ca1 beq uih_param_neg_res ,parse_dlci0_reconn_uih_pn_cmd 
+6c9e c038ecac beq uih_modem_status_cmd ,parse_dlci0_reconn_uih_ms_cmd 
+6c9f c0386cbc beq uih_modem_status_res ,parse_dlci0_reconn_uih_ms_res 
+6ca0 20206cd7 branch rfcomm_rx_process_end 
+
+parse_dlci0_reconn_uih_pn_cmd:
+6ca1 20406c06 call parse_dlci0_rp_uih_pn_res_common 
+6ca2 6800c74b fetch 1 ,mem_pn_dlci 
+6ca3 1fe37e00 rshift pdata ,pdata 
+6ca4 6808c752 fetcht 1 ,mem_remote_spp_channel 
+6ca5 98467c00 isub temp ,null 
+6ca6 2022eca8 branch parse_dlci0_reconn_uih_pn_cmd_spp ,zero 
+6ca7 20203bf1 branch assert 
+
+parse_dlci0_reconn_uih_pn_cmd_spp:
+6ca8 6800c2bd fetch 1 ,mem_spp_state 
+6ca9 79207e01 set1 rfcomm_channel_state_pn_res ,pdata 
+6caa 6000c2bd store 1 ,mem_spp_state 
+6cab 20206cd7 branch rfcomm_rx_process_end 
+
+parse_dlci0_reconn_uih_ms_cmd:
+6cac 20406c08 call get_rfcomm_param_modem_status 
+6cad 6800c758 fetch 1 ,mem_ms_channel 
+6cae 6808c752 fetcht 1 ,mem_remote_spp_channel 
+6caf 98467c00 isub temp ,null 
+6cb0 2022ecb3 branch parse_dlci0_reconn_uih_ms_cmd_spp ,zero 
+6cb1 20203bf1 branch assert 
+6cb2 20206cd7 branch rfcomm_rx_process_end 
+
+parse_dlci0_reconn_uih_ms_cmd_spp:
+6cb3 6800c2bd fetch 1 ,mem_spp_state 
+6cb4 79207e05 set1 rfcomm_channel_state_rcv_ms_cmd ,pdata 
+6cb5 79207e06 set1 rfcomm_channel_state_snd_ms_res ,pdata 
+6cb6 6000c2bd store 1 ,mem_spp_state 
+6cb7 6808c74b fetcht 1 ,mem_pn_dlci 
+6cb8 184b8400 lshift2 temp ,temp 
+6cb9 18418403 or_into 3 ,temp 
+6cba 20406d55 call rfcomm_send_modem_status_res 
+6cbb 20206cd7 branch rfcomm_rx_process_end 
+
+parse_dlci0_reconn_uih_ms_res:
+6cbc 20406c08 call get_rfcomm_param_modem_status 
+6cbd 6800c758 fetch 1 ,mem_ms_channel 
+6cbe 6808c752 fetcht 1 ,mem_remote_spp_channel 
+6cbf 98467c00 isub temp ,null 
+6cc0 2022ecc2 branch parse_dlci0_reconn_uih_ms_res_spp ,zero 
+6cc1 20203bf1 branch assert 
+
+parse_dlci0_reconn_uih_ms_res_spp:
+6cc2 6800c2bd fetch 1 ,mem_spp_state 
+6cc3 79207e07 set1 rfcomm_channel_state_rcv_ms_res ,pdata 
+6cc4 6000c2bd store 1 ,mem_spp_state 
+6cc5 20206cd7 branch rfcomm_rx_process_end 
+
+parse_uih_reconn:
+6cc6 68008494 fetch 1 ,mem_current_channel 
+6cc7 6808c752 fetcht 1 ,mem_remote_spp_channel 
+6cc8 98467c00 isub temp ,null 
+6cc9 2022eccc branch parse_uih_reconn_spp ,zero 
+6cca 20203bf1 branch assert 
+6ccb 20206cd7 branch rfcomm_rx_process_end 
+
+parse_uih_reconn_spp:
+6ccc 68008495 fetch 1 ,mem_current_frame_type 
+6ccd c039ecd1 beq rfcomm_frame_type_ua ,parse_uih_reconn_spp_ua 
+6cce c077ec80 beq rfcomm_frame_type_uih ,parse_uih_spp_uih 
+6ccf c07fec78 beq rfcomm_frame_type_uih_credits ,parse_uih_spp_uih_credits 
+6cd0 c029ecd6 beq rfcomm_frame_type_disconn ,parse_uih_reconn_spp_disconn 
+
+parse_uih_reconn_spp_ua:
+6cd1 6800c2bd fetch 1 ,mem_spp_state 
+6cd2 79207e03 set1 rfcomm_channel_state_ua ,pdata 
+6cd3 6000c2bd store 1 ,mem_spp_state 
+6cd4 20206cd7 branch rfcomm_rx_process_end 
+
+parse_uih_reconn_spp_sabm:
+6cd5 20206cd5 branch parse_uih_reconn_spp_sabm 
+
+parse_uih_reconn_spp_disconn:
+6cd6 20206c85 branch parse_uih_rp_spp_disconn 
+
+rfcomm_rx_process_end:
+6cd7 20600000 rtn 
+
+rfcomm_send_more_pkt:
+6cd8 6800c755 fetch 1 ,mem_rfcomm_send_more_pkt 
+6cd9 207a0000 rtn blank 
+6cda c001ecdc beq more_pkt_msc_cmd_spp ,rfcomm_send_more_pkt_msc_cmd_spp 
+6cdb 20203bf1 branch assert 
+
+rfcomm_send_more_pkt_msc_cmd_spp:
+6cdc 70475500 jam 0 ,mem_rfcomm_send_more_pkt 
+6cdd 204052e0 call l2cap_malloc_rfcomm_channel 
+6cde d8400001 arg spp_slave_channel ,temp 
+6cdf 18498400 lshift3 temp ,temp 
+
+rfcomm_send_more_pkt_msc_cmd_spp0:
+6ce0 18418403 or_into 0x03 ,temp 
+6ce1 da2000aa arg 0xaa ,rega 
+6ce2 20406d3f call rfcomm_send_modem_status_cmd 
+6ce3 204052ef call l2cap_get_rfcomm_tx_buff 
+6ce4 18a20c00 copy contw ,contr 
+6ce5 e8c10000 ifetch 2 ,contr 
+6ce6 203a3bf1 branch assert ,blank 
+6ce7 20600000 rtn 
+
+rfcomm_send_sabm:
+6ce8 79200025 set1 mark_ext_patch ,mark 
+6ce9 44e1c038 bpatch patch38_3 ,mem_patch38 
+6cea 204052ef call l2cap_get_rfcomm_tx_buff 
+6ceb 58000004 setarg 0x0004 
+6cec e0a10000 istore 2 ,contw 
+6ced 680142b3 fetch 2 ,mem_rfcomm_remote_cid 
+6cee e0a10000 istore 2 ,contw 
+6cef 68008493 fetch 1 ,mem_current_adss 
+6cf0 e0a08000 istore 1 ,contw 
+6cf1 5800013f setarg 0x013f 
+6cf2 e0a10000 istore 2 ,contw 
+6cf3 68008496 fetch 1 ,mem_current_fcs 
+6cf4 e0a08000 istore 1 ,contw 
+6cf5 20600000 rtn 
+
+rfcomm_send_ua:
+6cf6 79200025 set1 mark_ext_patch ,mark 
+6cf7 44e24038 bpatch patch38_4 ,mem_patch38 
+6cf8 204052e0 call l2cap_malloc_rfcomm_channel 
+6cf9 204052ef call l2cap_get_rfcomm_tx_buff 
+6cfa 58000004 setarg 0x0004 
+6cfb e0a10000 istore 2 ,contw 
+6cfc 680142b3 fetch 2 ,mem_rfcomm_remote_cid 
+6cfd e0a10000 istore 2 ,contw 
+6cfe 68008493 fetch 1 ,mem_current_adss 
+6cff e0a08000 istore 1 ,contw 
+6d00 58000173 setarg 0x0173 
+6d01 e0a10000 istore 2 ,contw 
+6d02 68008496 fetch 1 ,mem_current_fcs 
+6d03 e0a08000 istore 1 ,contw 
+6d04 20600000 rtn 
+
+rfcomm_send_param_neg_cmd:
+6d05 79200025 set1 mark_ext_patch ,mark 
+6d06 44e2c038 bpatch patch38_5 ,mem_patch38 
+6d07 204052ef call l2cap_get_rfcomm_tx_buff 
+6d08 5800000e setarg 0x000e 
+6d09 e0a10000 istore 2 ,contw 
+6d0a 680142b3 fetch 2 ,mem_rfcomm_remote_cid 
+6d0b e0a10000 istore 2 ,contw 
+6d0c 6800c751 fetch 1 ,mem_rfcomm_initiator 
+6d0d 1fe3fe00 lshift pdata ,pdata 
+6d0e 79207e00 set1 0 ,pdata 
+6d0f e0a08000 istore 1 ,contw 
+6d10 580015ef setarg 0x15ef 
+6d11 e0a10000 istore 2 ,contw 
+6d12 58001183 setarg 0x1183 
+6d13 e0a10000 istore 2 ,contw 
+6d14 18427e00 copy temp ,pdata 
+6d15 e0a08000 istore 1 ,contw 
+6d16 580000f0 setarg 0x0000f0 
+6d17 e0a18000 istore 3 ,contw 
+6d18 5800007f setarg rfcomm_max_frame_size 
+6d19 e0a10000 istore 2 ,contw 
+6d1a 58000000 setarg 0 
+6d1b e0a08000 istore 1 ,contw 
+6d1c 58000001 setarg 0x01 
+6d1d e0a08000 istore 1 ,contw 
+6d1e 20406b7c call rfcomm_calculate_fcs_dlci0 
+6d1f e0a08000 istore 1 ,contw 
+6d20 70475710 jam 0x10 ,mem_credit_given 
+6d21 20600000 rtn 
+
+rfcomm_send_param_neg_res:
+6d22 79200025 set1 mark_ext_patch ,mark 
+6d23 44e34038 bpatch patch38_6 ,mem_patch38 
+6d24 204052e0 call l2cap_malloc_rfcomm_channel 
+6d25 204052ef call l2cap_get_rfcomm_tx_buff 
+6d26 5800000e setarg 0x000e 
+6d27 e0a10000 istore 2 ,contw 
+6d28 680142b3 fetch 2 ,mem_rfcomm_remote_cid 
+6d29 e0a10000 istore 2 ,contw 
+6d2a 6800c751 fetch 1 ,mem_rfcomm_initiator 
+6d2b 1fe3fe00 lshift pdata ,pdata 
+6d2c 79207e00 set1 0 ,pdata 
+6d2d e0a08000 istore 1 ,contw 
+6d2e 580015ef setarg 0x15ef 
+6d2f e0a10000 istore 2 ,contw 
+6d30 58001181 setarg 0x1181 
+6d31 e0a10000 istore 2 ,contw 
+6d32 6800c74b fetch 1 ,mem_pn_dlci 
+6d33 e0a08000 istore 1 ,contw 
+6d34 580000e0 setarg 0x0000e0 
+6d35 e0a18000 istore 3 ,contw 
+6d36 5800007f setarg rfcomm_max_frame_size 
+6d37 e0a10000 istore 2 ,contw 
+6d38 58000000 setarg 0x00 
+6d39 e0a08000 istore 1 ,contw 
+6d3a 58000007 setarg 0x07 
+6d3b e0a08000 istore 1 ,contw 
+6d3c 20406b7c call rfcomm_calculate_fcs_dlci0 
+6d3d e0a08000 istore 1 ,contw 
+6d3e 20600000 rtn 
+
+rfcomm_send_modem_status_cmd:
+6d3f 79200025 set1 mark_ext_patch ,mark 
+6d40 44e3c038 bpatch patch38_7 ,mem_patch38 
+6d41 204052ef call l2cap_get_rfcomm_tx_buff 
+6d42 58000008 setarg 0x0008 
+6d43 e0a10000 istore 2 ,contw 
+6d44 680142b3 fetch 2 ,mem_rfcomm_remote_cid 
+6d45 e0a10000 istore 2 ,contw 
+6d46 6800c751 fetch 1 ,mem_rfcomm_initiator 
+6d47 1fe3fe00 lshift pdata ,pdata 
+6d48 79207e00 set1 0 ,pdata 
+6d49 e0a08000 istore 1 ,contw 
+6d4a 580009ef setarg 0x09ef 
+6d4b e0a10000 istore 2 ,contw 
+6d4c 580005e3 setarg 0x05e3 
+6d4d e0a10000 istore 2 ,contw 
+6d4e 18427e00 copy temp ,pdata 
+6d4f e0a08000 istore 1 ,contw 
+6d50 5800008d setarg 0x8d 
+6d51 e0a08000 istore 1 ,contw 
+6d52 20406b7c call rfcomm_calculate_fcs_dlci0 
+6d53 e0a08000 istore 1 ,contw 
+6d54 20600000 rtn 
+
+rfcomm_send_modem_status_res:
+6d55 79200025 set1 mark_ext_patch ,mark 
+6d56 44e44039 bpatch patch39_0 ,mem_patch39 
+6d57 204052e0 call l2cap_malloc_rfcomm_channel 
+6d58 204052ef call l2cap_get_rfcomm_tx_buff 
+6d59 58000008 setarg 0x0008 
+6d5a e0a10000 istore 2 ,contw 
+6d5b 680142b3 fetch 2 ,mem_rfcomm_remote_cid 
+6d5c e0a10000 istore 2 ,contw 
+6d5d 18421600 copy temp ,timeup 
+6d5e 6800c751 fetch 1 ,mem_rfcomm_initiator 
+6d5f 1fe3fe00 lshift pdata ,pdata 
+6d60 79207e00 set1 0 ,pdata 
+6d61 e0a08000 istore 1 ,contw 
+6d62 580009ef setarg 0x09ef 
+6d63 e0a10000 istore 2 ,contw 
+6d64 580005e1 setarg 0x05e1 
+6d65 e0a10000 istore 2 ,contw 
+6d66 19627e00 copy timeup ,pdata 
+6d67 e0a08000 istore 1 ,contw 
+6d68 5800008d setarg 0x8d 
+6d69 e0a08000 istore 1 ,contw 
+6d6a 20406b7c call rfcomm_calculate_fcs_dlci0 
+6d6b e0a08000 istore 1 ,contw 
+6d6c 20600000 rtn 
+
+rfcomm_send_uih_without_payload:
+6d6d 79200025 set1 mark_ext_patch ,mark 
+6d6e 44e4c039 bpatch patch39_1 ,mem_patch39 
+6d6f 6800c757 fetch 1 ,mem_credit_given 
+6d70 207a0000 rtn blank 
+6d71 68110112 hfetch 2 ,core_uart_rxitems 
+6d72 247a0000 nrtn blank 
+6d73 1a227e00 copy rega ,pdata 
+6d74 60008162 store 1 ,mem_pdatatemp + 1 
+6d75 60088161 storet 1 ,mem_pdatatemp 
+6d76 2040527a call l2cap_malloc_is_fifo_full 
+6d77 247a0000 nrtn blank 
+6d78 204052e0 call l2cap_malloc_rfcomm_channel 
+6d79 204052ef call l2cap_get_rfcomm_tx_buff 
+6d7a 58000005 setarg 0x05 
+6d7b e0a10000 istore 2 ,contw 
+6d7c 680142b3 fetch 2 ,mem_rfcomm_remote_cid 
+6d7d e0a10000 istore 2 ,contw 
+6d7e 680084a5 fetch 1 ,mem_rfcomm_send_adss 
+6d7f e0a08000 istore 1 ,contw 
+6d80 580001ff setarg 0x01ff 
+6d81 e0a10000 istore 2 ,contw 
+6d82 6800c757 fetch 1 ,mem_credit_given 
+6d83 e0a08000 istore 1 ,contw 
+6d84 6800c754 fetch 1 ,mem_hiufcs_spp_wcredits 
+6d85 e0a08000 istore 1 ,contw 
+6d86 70475700 jam 0 ,mem_credit_given 
+6d87 20600000 rtn 
+
+rfcomm_increase_credit_given:
+6d88 68010497 fetch 2 ,mem_current_length 
+6d89 207a0000 rtn blank 
+6d8a 6800c757 fetch 1 ,mem_credit_given 
+6d8b 1fe0fe01 increase 1 ,pdata 
+6d8c 6000c757 store 1 ,mem_credit_given 
+6d8d 20600000 rtn 
+
+spp_process_rx_data:
+6d8e 79200025 set1 mark_ext_patch ,mark 
+6d8f 44e54039 bpatch patch39_2 ,mem_patch39 
+6d90 68010497 fetch 2 ,mem_current_length 
+6d91 1fe27200 copy pdata ,loopcnt 
+6d92 204068f7 call uartd_prepare_tx 
+6d93 68010499 fetch 2 ,mem_rfcomm_uih_payload_ptr 
+6d94 1fe20c00 copy pdata ,contr 
+6d95 20404976 call uart_copy_tx_bytes 
+6d96 202068fa branch uartd_send 
+
+spp_tx_rfcomm_packet:
+6d97 79200025 set1 mark_ext_patch ,mark 
+6d98 44e5c039 bpatch patch39_3 ,mem_patch39 
+6d99 6800c756 fetch 1 ,mem_remote_credits 
+6d9a 207a0000 rtn blank 
+6d9b 1fe0ffff increase -1 ,pdata 
+6d9c 6000c756 store 1 ,mem_remote_credits 
+6d9d 6801474c fetch 2 ,mem_pn_max_frame_size 
+6d9e 6809480e fetcht 2 ,mem_current_packet_length 
+6d9f 98467c00 isub temp ,null 
+6da0 20216da2 branch spp_tx_rfcomm_from_uart ,positive 
+6da1 6001480e store 2 ,mem_current_packet_length 
+
+spp_tx_rfcomm_from_uart:
+6da2 6800c757 fetch 1 ,mem_credit_given 
+6da3 203a6daa branch spp_tx_rfcomm_from_uart_without_credit ,blank 
+6da4 7004a801 jam 1 ,mem_rfcomm_send_offset 
+6da5 6800c754 fetch 1 ,mem_hiufcs_spp_wcredits 
+6da6 600084a7 store 1 ,mem_rfcomm_send_fcs 
+6da7 580000ff setarg rsp_rx_uih_wdata 
+6da8 600084a6 store 1 ,mem_rfcomm_send_frame_type 
+6da9 20206daf branch spp_tx_rfcomm_from_uart_common 
+
+spp_tx_rfcomm_from_uart_without_credit:
+6daa 7004a800 jam 0 ,mem_rfcomm_send_offset 
+6dab 6800c753 fetch 1 ,mem_hiufcs_spp 
+6dac 600084a7 store 1 ,mem_rfcomm_send_fcs 
+6dad 580000ef setarg rsp_tx_uih 
+6dae 600084a6 store 1 ,mem_rfcomm_send_frame_type 
+
+spp_tx_rfcomm_from_uart_common:
+6daf 79200025 set1 mark_ext_patch ,mark 
+6db0 44e64039 bpatch patch39_4 ,mem_patch39 
+6db1 6800c80e fetch 1 ,mem_current_packet_length 
+6db2 1fe67c7f sub pdata ,127 ,null 
+6db3 20216db7 branch spp_tx_rfcomm_from_uart_common0 ,positive 
+6db4 680084a8 fetch 1 ,mem_rfcomm_send_offset 
+6db5 1fe0fe01 increase 1 ,pdata 
+6db6 600084a8 store 1 ,mem_rfcomm_send_offset 
+
+spp_tx_rfcomm_from_uart_common0:
+6db7 20406bbf call get_rfcomm_snd_adss 
+6db8 6801480e fetch 2 ,mem_current_packet_length 
+6db9 1fe0fe08 increase 8 ,pdata 
+6dba 680884a8 fetcht 1 ,mem_rfcomm_send_offset 
+6dbb 9840a200 iadd temp ,rega 
+6dbc 20405248 call l2cap_malloc 
+6dbd 600102de store 2 ,mem_rfcomm_tx_buff_ptr 
+6dbe 1fe0fe04 increase 4 ,pdata 
+6dbf 600102e0 store 2 ,mem_rfcomm_tx_payload_ptr 
+6dc0 1fe20a00 copy pdata ,contw 
+6dc1 680084a5 fetch 1 ,mem_rfcomm_send_adss 
+6dc2 e0a08000 istore 1 ,contw 
+6dc3 680084a6 fetch 1 ,mem_rfcomm_send_frame_type 
+6dc4 e0a08000 istore 1 ,contw 
+6dc5 20406dd8 call spp_tx_write_length 
+6dc6 20406de8 call spp_tx_write_given_credit 
+6dc7 20407f6b call get_uart_rrptr 
+6dc8 6800c80e fetch 1 ,mem_current_packet_length 
+6dc9 1fe27200 copy pdata ,loopcnt 
+6dca 2040497c call uart_copy_rx_bytes 
+6dcb 680084a7 fetch 1 ,mem_rfcomm_send_fcs 
+6dcc e0a08000 istore 1 ,contw 
+6dcd 680102de fetch 2 ,mem_rfcomm_tx_buff_ptr 
+6dce 1fe20a00 copy pdata ,contw 
+6dcf 6801480e fetch 2 ,mem_current_packet_length 
+6dd0 680884a8 fetcht 1 ,mem_rfcomm_send_offset 
+6dd1 9840fe00 iadd temp ,pdata 
+6dd2 1fe0fe04 increase 4 ,pdata 
+6dd3 e0a10000 istore 2 ,contw 
+6dd4 680142b3 fetch 2 ,mem_rfcomm_remote_cid 
+6dd5 e0a10000 istore 2 ,contw 
+6dd6 70475700 jam 0 ,mem_credit_given 
+6dd7 2020428c branch spp_send_end 
+
+spp_tx_write_length:
+6dd8 6801480e fetch 2 ,mem_current_packet_length 
+6dd9 1fe67c7f sub pdata ,0x7f ,null 
+6dda 24216ddf nbranch spp_tx_write_long_packet ,positive 
+6ddb 1fe3fe00 lshift pdata ,pdata 
+6ddc 79207e00 set1 0 ,pdata 
+6ddd e0a08000 istore 1 ,contw 
+6dde 20600000 rtn 
+
+spp_tx_write_long_packet:
+6ddf 6801480e fetch 2 ,mem_current_packet_length 
+6de0 1fe97e00 rshift3 pdata ,pdata 
+6de1 1ff18400 rshift4 pdata ,temp 
+6de2 1fe17e7f and_into 0x7f ,pdata 
+6de3 1fe3fe00 lshift pdata ,pdata 
+6de4 793ffe00 set0 0 ,pdata 
+6de5 e0a08000 istore 1 ,contw 
+6de6 e0a88000 istoret 1 ,contw 
+6de7 20600000 rtn 
+
+spp_tx_write_given_credit:
+6de8 6800c757 fetch 1 ,mem_credit_given 
+6de9 207a0000 rtn blank 
+6dea e0a08000 istore 1 ,contw 
+6deb 20600000 rtn 
+
+scheduler_process:
+6dec 79200025 set1 mark_ext_patch ,mark 
+6ded 44cec033 bpatch patch33_5 ,mem_patch33 
+6dee 20407c45 call check_51cmd 
+6def 20403e73 call app_process_bb_event 
+6df0 20406235 call process_conn_sm 
+6df1 79200025 set1 mark_ext_patch ,mark 
+6df2 44cf4033 bpatch patch33_6 ,mem_patch33 
+6df3 20407813 call sp_calc_sequence 
+6df4 204077ee call simple_pairing_sequence 
+6df5 204077fe call master_simple_paring_sequence 
+6df6 79200025 set1 mark_ext_patch ,mark 
+6df7 44cfc033 bpatch patch33_7 ,mem_patch33 
+6df8 6800c132 fetch 1 ,mem_device_option 
+6df9 c1008000 rtneq dvc_op_hci 
+6dfa 2040527a call l2cap_malloc_is_fifo_full 
+6dfb 247a0000 nrtn blank 
+6dfc 20404dcd call l2cap_call_proc_sigal_pending 
+
+scheduler_process1:
+6dfd 2040527a call l2cap_malloc_is_fifo_full 
+6dfe 247a0000 nrtn blank 
+6dff 79200025 set1 mark_ext_patch ,mark 
+6e00 44d04034 bpatch patch34_0 ,mem_patch34 
+6e01 20406e47 call process_upper_sm 
+6e02 20404f6e call l2cap_send_config_req 
+6e03 20406cd8 call rfcomm_send_more_pkt 
+
+scheduler_process0:
+6e04 20406e0a call scheduler_tx_disconnect_hid 
+6e05 79200025 set1 mark_ext_patch ,mark 
+6e06 44d0c034 bpatch patch34_1 ,mem_patch34 
+6e07 2040527a call l2cap_malloc_is_fifo_full 
+6e08 247a0000 nrtn blank 
+6e09 20203e6f branch app_process_bt 
+
+scheduler_tx_disconnect_hid:
+6e0a 79200025 set1 mark_ext_patch ,mark 
+6e0b 44d14034 bpatch patch34_2 ,mem_patch34 
+6e0c 680082e6 fetch 1 ,mem_control_tasks 
+6e0d c280508f bbit1 l2cap_disconnect_interrupt ,l2cap_disconnect_interrupt_req 
+6e0e c283d099 bbit1 l2cap_disconnect_control ,l2cap_disconnect_control_req 
+6e0f 20600000 rtn 
+
+scheduler_tx_l2cap_pkt:
+6e10 79200025 set1 mark_ext_patch ,mark 
+6e11 44d1c034 bpatch patch34_3 ,mem_patch34 
+6e12 2040527e call l2cap_malloc_is_fifo_empty 
+6e13 207a0000 rtn blank 
+6e14 6800804b fetch 1 ,mem_op 
+6e15 c3830000 rtnbit1 op_txl2cap 
+6e16 20405261 call l2cap_malloc_fifo_out 
+6e17 60010179 store 2 ,mem_txptr 
+6e18 1fe20c00 copy pdata ,contr 
+6e19 e8c10000 ifetch 2 ,contr 
+6e1a 1fe0fe04 increase 4 ,pdata 
+6e1b 60010091 store 2 ,mem_tx_len 
+6e1c 70009006 jam 6 ,mem_tx_lch 
+6e1d 79200025 set1 mark_ext_patch ,mark 
+6e1e 44d24034 bpatch patch34_4 ,mem_patch34 
+6e1f 680142af fetch 2 ,mem_l2cap_tx_multi_offset 
+6e20 203a6e2d branch scheduler_tx_l2cap_start_pkt ,blank 
+6e21 6800804b fetch 1 ,mem_op 
+6e22 c4038000 rtnbit0 op_pkt_comp 
+6e23 793ffe07 set0 op_pkt_comp ,pdata 
+6e24 6000804b store 1 ,mem_op 
+6e25 70009005 jam 5 ,mem_tx_lch 
+6e26 680942af fetcht 2 ,mem_l2cap_tx_multi_offset 
+6e27 68010179 fetch 2 ,mem_txptr 
+6e28 9840fe00 iadd temp ,pdata 
+6e29 60010179 store 2 ,mem_txptr 
+6e2a 68010091 fetch 2 ,mem_tx_len 
+6e2b 98467e00 isub temp ,pdata 
+6e2c 60010091 store 2 ,mem_tx_len 
+
+scheduler_tx_l2cap_start_pkt:
+6e2d 79200025 set1 mark_ext_patch ,mark 
+6e2e 44d2c034 bpatch patch34_5 ,mem_patch34 
+6e2f 68010091 fetch 2 ,mem_tx_len 
+6e30 203a3bf1 branch assert ,blank 
+6e31 d8400104 arg l2cap_max_pkt_len ,temp 
+6e32 98467e00 isub temp ,pdata 
+6e33 24216e3b nbranch scheduler_tx_l2cap_last_pkt ,positive 
+6e34 79200025 set1 mark_ext_patch ,mark 
+6e35 44d34034 bpatch patch34_6 ,mem_patch34 
+6e36 60090091 storet 2 ,mem_tx_len 
+6e37 680142af fetch 2 ,mem_l2cap_tx_multi_offset 
+6e38 9840fe00 iadd temp ,pdata 
+6e39 600142af store 2 ,mem_l2cap_tx_multi_offset 
+6e3a 20206e3d branch scheduler_tx_l2cap_pkt_end 
+
+scheduler_tx_l2cap_last_pkt:
+6e3b 58000000 setarg 0 
+6e3c 600142af store 2 ,mem_l2cap_tx_multi_offset 
+
+scheduler_tx_l2cap_pkt_end:
+6e3d 6800804b fetch 1 ,mem_op 
+6e3e 79207e06 set1 op_txl2cap ,pdata 
+6e3f 6000804b store 1 ,mem_op 
+6e40 20600000 rtn 
+
+scheduler_start_upper_sm:
+6e41 6800c7f6 fetch 1 ,mem_ui_profile_supported 
+6e42 c2806e45 bbit1 support_hid ,scheduler_start_upper_sm_hid 
+6e43 7002ee01 jam uppersm_reconn_sdp_conn ,mem_upper_sm_reconn 
+6e44 20600000 rtn 
+
+scheduler_start_upper_sm_hid:
+6e45 7002ee0f jam uppersm_reconn_hid_ctrl_conn ,mem_upper_sm_reconn 
+6e46 20600000 rtn 
+
+process_upper_sm:
+6e47 6800c7f3 fetch 1 ,memui_reconnect_mode 
+6e48 243a6e4d nbranch process_upper_sm_reconn ,blank 
+
+process_upper_sm_remote_page:
+6e49 680082ed fetch 1 ,mem_upper_sm_remote_page 
+6e4a 207a0000 rtn blank 
+6e4b 7002ed00 jam 0 ,mem_upper_sm_remote_page 
+
+process_upper_sm_rp_wait:
+6e4c 20600000 rtn 
+
+process_upper_sm_reconn:
+6e4d 79200025 set1 mark_ext_patch ,mark 
+6e4e 44d3c034 bpatch patch34_7 ,mem_patch34 
+6e4f 680082ee fetch 1 ,mem_upper_sm_reconn 
+6e50 207a0000 rtn blank 
+6e51 c000ee6e beq uppersm_reconn_sdp_conn ,process_upper_sm_reconn_sdp_conn 
+6e52 c0016ec7 beq uppersm_reconn_sdp_conn_wait ,process_upper_sm_reconn_sdp_conn_wait 
+6e53 c001ee74 beq uppersm_reconn_sdp_cfg ,process_upper_sm_reconn_sdp_cfg 
+6e54 c0026ecb beq uppersm_reconn_sdp_cfg_wait ,process_upper_sm_reconn_sdp_cfg_wait 
+6e55 c01dee7e beq uppersm_reconn_ss_spp ,process_upper_sm_reconn_ss_spp 
+6e56 c01e6ece beq uppersm_reconn_ss_spp_wait ,process_upper_sm_reconn_ss_spp_wait 
+6e57 c006ee83 beq uppersm_reconn_sdp_disconn ,process_upper_sm_reconn_sdp_disconn 
+6e58 c0076ed3 beq uppersm_reconn_sdp_disconn_wait ,process_upper_sm_reconn_sdp_disconn_wait 
+6e59 c007ee86 beq uppersm_reconn_hid_ctrl_conn ,process_upper_sm_reconn_hid_ctrl_conn 
+6e5a c0086ed9 beq uppersm_reconn_hid_ctrl_conn_wait ,process_upper_sm_reconn_hid_ctrl_conn_wait 
+6e5b c008ee8c beq uppersm_reconn_hid_ctrl_cfg ,process_upper_sm_reconn_hid_ctrl_cfg 
+6e5c c0096edd beq uppersm_reconn_hid_ctrl_cfg_wait ,process_upper_sm_reconn_hid_ctrl_cfg_wait 
+6e5d c009ee92 beq uppersm_reconn_hid_int_conn ,process_upper_sm_reconn_hid_int_conn 
+6e5e c00a6ee1 beq uppersm_reconn_hid_int_conn_wait ,process_upper_sm_reconn_hid_int_conn_wait 
+6e5f c00aee98 beq uppersm_reconn_hid_int_cfg ,process_upper_sm_reconn_hid_int_cfg 
+6e60 c00b6ee5 beq uppersm_reconn_hid_int_cfg_wait ,process_upper_sm_reconn_hid_int_cfg_wait 
+6e61 c00bee9e beq uppersm_reconn_rfcomm_conn ,process_upper_sm_reconn_rfcomm_conn 
+6e62 c00c6eea beq uppersm_reconn_rfcomm_conn_wait ,process_upper_sm_reconn_rfcomm_conn_wait 
+6e63 c00ceea4 beq uppersm_reconn_rfcomm_cfg ,process_upper_sm_reconn_rfcomm_cfg 
+6e64 c00d6eee beq uppersm_reconn_rfcomm_cfg_wait ,process_upper_sm_reconn_rfcomm_cfg_wait 
+6e65 c00deeaa beq uppersm_reconn_rfcomm_sabm ,process_upper_sm_reconn_rfcomm_sabm 
+6e66 c00e6ef2 beq uppersm_reconn_rfcomm_sabm_wait ,process_upper_sm_reconn_rfcomm_sabm_wait 
+6e67 c00eeeb0 beq uppersm_reconn_spp_cmd_pn ,process_upper_sm_reconn_spp_cmd_pn 
+6e68 c00f6ef7 beq uppersm_reconn_spp_cmd_pn_wait ,process_upper_sm_reconn_spp_cmd_pn_wait 
+6e69 c00feeb6 beq uppersm_reconn_spp_sabm ,process_upper_sm_reconn_spp_sabm 
+6e6a c0106efb beq uppersm_reconn_spp_sabm_wait ,process_upper_sm_reconn_spp_sabm_wait 
+6e6b c010eec1 beq uppersm_reconn_spp_cmd_ms ,process_upper_sm_reconn_spp_cmd_ms 
+6e6c c0116eff beq uppersm_reconn_spp_cmd_ms_wait ,process_upper_sm_reconn_spp_cmd_ms_wait 
+
+process_upper_sm_reconn_wait:
+6e6d 20600000 rtn 
+
+process_upper_sm_reconn_sdp_conn:
+6e6e 20406f0a call upper_sm_send_sdp_conn 
+6e6f 7002ee02 jam uppersm_reconn_sdp_conn_wait ,mem_upper_sm_reconn 
+6e70 6800c2b9 fetch 1 ,mem_sdp_state 
+6e71 79207e00 set1 l2cap_channel_state_conn_req ,pdata 
+6e72 6000c2b9 store 1 ,mem_sdp_state 
+6e73 20600000 rtn 
+
+process_upper_sm_reconn_sdp_cfg:
+6e74 7002ee04 jam uppersm_reconn_sdp_cfg_wait ,mem_upper_sm_reconn 
+6e75 6800c2b9 fetch 1 ,mem_sdp_state 
+6e76 c3810000 rtnbit1 l2cap_channel_state_snd_cfg_req 
+6e77 7002ee03 jam uppersm_reconn_sdp_cfg ,mem_upper_sm_reconn 
+6e78 20406f12 call upper_sm_send_sdp_cfg 
+6e79 7002ee04 jam uppersm_reconn_sdp_cfg_wait ,mem_upper_sm_reconn 
+6e7a 6800c2b9 fetch 1 ,mem_sdp_state 
+6e7b 79207e02 set1 l2cap_channel_state_snd_cfg_req ,pdata 
+6e7c 6000c2b9 store 1 ,mem_sdp_state 
+6e7d 20600000 rtn 
+
+process_upper_sm_reconn_ss_spp:
+6e7e 2040527e call l2cap_malloc_is_fifo_empty 
+6e7f 247a0000 nrtn blank 
+6e80 20406f23 call upper_sm_send_ss_spp 
+6e81 7002ee3c jam uppersm_reconn_ss_spp_wait ,mem_upper_sm_reconn 
+6e82 20600000 rtn 
+
+process_upper_sm_reconn_sdp_disconn:
+6e83 20406f18 call upper_sm_send_sdp_disconn 
+6e84 7002ee0e jam uppersm_reconn_sdp_disconn_wait ,mem_upper_sm_reconn 
+6e85 20600000 rtn 
+
+process_upper_sm_reconn_hid_ctrl_conn:
+6e86 20406f36 call upper_sm_send_hid_ctrl_conn 
+6e87 7002ee10 jam uppersm_reconn_hid_ctrl_conn_wait ,mem_upper_sm_reconn 
+6e88 6800c2bb fetch 1 ,mem_hid_control_state 
+6e89 79207e00 set1 l2cap_channel_state_conn_req ,pdata 
+6e8a 6000c2bb store 1 ,mem_hid_control_state 
+6e8b 20600000 rtn 
+
+process_upper_sm_reconn_hid_ctrl_cfg:
+6e8c 20406f3e call upper_sm_send_hid_ctrl_cfg 
+6e8d 7002ee12 jam uppersm_reconn_hid_ctrl_cfg_wait ,mem_upper_sm_reconn 
+6e8e 6800c2bb fetch 1 ,mem_hid_control_state 
+6e8f 79207e02 set1 l2cap_channel_state_snd_cfg_req ,pdata 
+6e90 6000c2bb store 1 ,mem_hid_control_state 
+6e91 20600000 rtn 
+
+process_upper_sm_reconn_hid_int_conn:
+6e92 20406f44 call upper_sm_send_hid_int_conn 
+6e93 7002ee14 jam uppersm_reconn_hid_int_conn_wait ,mem_upper_sm_reconn 
+6e94 6800c2bc fetch 1 ,mem_hid_interrupt_state 
+6e95 79207e00 set1 l2cap_channel_state_conn_req ,pdata 
+6e96 6000c2bc store 1 ,mem_hid_interrupt_state 
+6e97 20600000 rtn 
+
+process_upper_sm_reconn_hid_int_cfg:
+6e98 20406f4c call upper_sm_send_hid_int_cfg 
+6e99 7002ee16 jam uppersm_reconn_hid_int_cfg_wait ,mem_upper_sm_reconn 
+6e9a 6800c2bc fetch 1 ,mem_hid_interrupt_state 
+6e9b 79207e02 set1 l2cap_channel_state_snd_cfg_req ,pdata 
+6e9c 6000c2bc store 1 ,mem_hid_interrupt_state 
+6e9d 20600000 rtn 
+
+process_upper_sm_reconn_rfcomm_conn:
+6e9e 20406f28 call upper_sm_send_rfcomm_conn 
+6e9f 7002ee18 jam uppersm_reconn_rfcomm_conn_wait ,mem_upper_sm_reconn 
+6ea0 6800c2ba fetch 1 ,mem_rfcomm_state 
+6ea1 79207e00 set1 l2cap_channel_state_conn_req ,pdata 
+6ea2 6000c2ba store 1 ,mem_rfcomm_state 
+6ea3 20600000 rtn 
+
+process_upper_sm_reconn_rfcomm_cfg:
+6ea4 20406f30 call upper_sm_send_rfcomm_cfg 
+6ea5 7002ee1a jam uppersm_reconn_rfcomm_cfg_wait ,mem_upper_sm_reconn 
+6ea6 6800c2ba fetch 1 ,mem_rfcomm_state 
+6ea7 79207e02 set1 l2cap_channel_state_snd_cfg_req ,pdata 
+6ea8 6000c2ba store 1 ,mem_rfcomm_state 
+6ea9 20600000 rtn 
+
+process_upper_sm_reconn_rfcomm_sabm:
+6eaa 20406f52 call upper_sm_send_rfcomm_sabm 
+6eab 7002ee1c jam uppersm_reconn_rfcomm_sabm_wait ,mem_upper_sm_reconn 
+6eac 6800c2ba fetch 1 ,mem_rfcomm_state 
+6ead 79207e06 set1 l2cap_channel_rfcomm_only_sabm ,pdata 
+6eae 6000c2ba store 1 ,mem_rfcomm_state 
+6eaf 20600000 rtn 
+
+process_upper_sm_reconn_spp_cmd_pn:
+6eb0 20406f5a call upper_sm_send_spp_cmd_pn 
+6eb1 6800c2bd fetch 1 ,mem_spp_state 
+6eb2 79207e00 set1 rfcomm_channel_state_pn_cmd 
+6eb3 6000c2bd store 1 ,mem_spp_state 
+6eb4 7002ee1e jam uppersm_reconn_spp_cmd_pn_wait ,mem_upper_sm_reconn 
+6eb5 20600000 rtn 
+
+process_upper_sm_reconn_spp_sabm:
+6eb6 20406f61 call upper_sm_send_spp_sabm 
+6eb7 6800c2bd fetch 1 ,mem_spp_state 
+6eb8 79207e02 set1 rfcomm_channel_state_sabm 
+6eb9 6000c2bd store 1 ,mem_spp_state 
+6eba 7002ee20 jam uppersm_reconn_spp_sabm_wait ,mem_upper_sm_reconn 
+6ebb 6800c752 fetch 1 ,mem_remote_spp_channel 
+6ebc 1fe9fe00 lshift3 pdata ,pdata 
+6ebd 1fe1fe03 or_into 3 ,pdata 
+6ebe d8404753 arg mem_hiufcs_spp ,temp 
+6ebf 6009048f storet 2 ,mem_contw_temp 
+6ec0 20206b82 branch rfcomm_save_fcs_uih 
+
+process_upper_sm_reconn_spp_cmd_ms:
+6ec1 20406f6c call upper_sm_send_spp_cmd_ms 
+6ec2 6800c2bd fetch 1 ,mem_spp_state 
+6ec3 79207e04 set1 rfcomm_channel_state_snd_ms_cmd 
+6ec4 6000c2bd store 1 ,mem_spp_state 
+6ec5 7002ee22 jam uppersm_reconn_spp_cmd_ms_wait ,mem_upper_sm_reconn 
+6ec6 20600000 rtn 
+
+process_upper_sm_reconn_sdp_conn_wait:
+6ec7 6800c2b9 fetch 1 ,mem_sdp_state 
+6ec8 c4008000 rtnbit0 l2cap_channel_state_conn_res 
+6ec9 7002ee03 jam uppersm_reconn_sdp_cfg ,mem_upper_sm_reconn 
+6eca 20206e4d branch process_upper_sm_reconn 
+
+process_upper_sm_reconn_sdp_cfg_wait:
+6ecb 6800c2b9 fetch 1 ,mem_sdp_state 
+6ecc c19f8000 rtnne l2cap_channel_setup_complete 
+6ecd 7002ee3b jam uppersm_reconn_ss_spp ,mem_upper_sm_reconn 
+
+process_upper_sm_reconn_ss_spp_wait:
+6ece 680082ec fetch 1 ,mem_message_to_uppersm 
+6ecf c18b8000 rtnne recieve_ss_reasult_hf 
+6ed0 7002ec00 jam 0 ,mem_message_to_uppersm 
+6ed1 7002ee0d jam uppersm_reconn_sdp_disconn ,mem_upper_sm_reconn 
+6ed2 20206e4d branch process_upper_sm_reconn 
+
+process_upper_sm_reconn_sdp_disconn_wait:
+6ed3 6800c2b9 fetch 1 ,mem_sdp_state 
+6ed4 247a0000 nrtn blank 
+6ed5 6800c7f6 fetch 1 ,mem_ui_profile_supported 
+6ed6 c2806f02 bbit1 support_hid ,process_upper_sm_reconn_setup_hid 
+6ed7 c2836f04 bbit1 support_spp ,process_upper_sm_reconn_setup_rfcomm 
+6ed8 20206f08 branch process_upper_sm_reconn_termination 
+
+process_upper_sm_reconn_hid_ctrl_conn_wait:
+6ed9 6800c2bb fetch 1 ,mem_hid_control_state 
+6eda c4008000 rtnbit0 l2cap_channel_state_conn_res 
+6edb 7002ee11 jam uppersm_reconn_hid_ctrl_cfg ,mem_upper_sm_reconn 
+6edc 20206e4d branch process_upper_sm_reconn 
+
+process_upper_sm_reconn_hid_ctrl_cfg_wait:
+6edd 6800c2bb fetch 1 ,mem_hid_control_state 
+6ede c19f8000 rtnne l2cap_channel_setup_complete 
+6edf 7002ee13 jam uppersm_reconn_hid_int_conn ,mem_upper_sm_reconn 
+6ee0 20206e4d branch process_upper_sm_reconn 
+
+process_upper_sm_reconn_hid_int_conn_wait:
+6ee1 6800c2bc fetch 1 ,mem_hid_interrupt_state 
+6ee2 c4008000 rtnbit0 l2cap_channel_state_conn_res 
+6ee3 7002ee15 jam uppersm_reconn_hid_int_cfg ,mem_upper_sm_reconn 
+6ee4 20206e4d branch process_upper_sm_reconn 
+
+process_upper_sm_reconn_hid_int_cfg_wait:
+6ee5 6800c2bc fetch 1 ,mem_hid_interrupt_state 
+6ee6 c19f8000 rtnne l2cap_channel_setup_complete 
+6ee7 6800c7f6 fetch 1 ,mem_ui_profile_supported 
+6ee8 c2836f04 bbit1 support_spp ,process_upper_sm_reconn_setup_rfcomm 
+6ee9 20206f08 branch process_upper_sm_reconn_termination 
+
+process_upper_sm_reconn_rfcomm_conn_wait:
+6eea 6800c2ba fetch 1 ,mem_rfcomm_state 
+6eeb c4008000 rtnbit0 l2cap_channel_state_conn_res 
+6eec 7002ee19 jam uppersm_reconn_rfcomm_cfg ,mem_upper_sm_reconn 
+6eed 20206e4d branch process_upper_sm_reconn 
+
+process_upper_sm_reconn_rfcomm_cfg_wait:
+6eee 6800c2ba fetch 1 ,mem_rfcomm_state 
+6eef c19f8000 rtnne l2cap_channel_setup_complete 
+6ef0 7002ee1b jam uppersm_reconn_rfcomm_sabm ,mem_upper_sm_reconn 
+6ef1 20206e4d branch process_upper_sm_reconn 
+
+process_upper_sm_reconn_rfcomm_sabm_wait:
+6ef2 6800c2ba fetch 1 ,mem_rfcomm_state 
+6ef3 c1ff8000 rtnne l2cap_channel_rfcomm_dlci0_opened 
+6ef4 6800c7f6 fetch 1 ,mem_ui_profile_supported 
+6ef5 c2836f06 bbit1 support_spp ,process_upper_sm_reconn_setup_spp 
+6ef6 20206f08 branch process_upper_sm_reconn_termination 
+
+process_upper_sm_reconn_spp_cmd_pn_wait:
+6ef7 6800c2bd fetch 1 ,mem_spp_state 
+6ef8 c4008000 rtnbit0 rfcomm_channel_state_pn_res 
+6ef9 7002ee1f jam uppersm_reconn_spp_sabm ,mem_upper_sm_reconn 
+6efa 20206e4d branch process_upper_sm_reconn 
+
+process_upper_sm_reconn_spp_sabm_wait:
+6efb 6800c2bd fetch 1 ,mem_spp_state 
+6efc c4018000 rtnbit0 rfcomm_channel_state_ua 
+6efd 7002ee21 jam uppersm_reconn_spp_cmd_ms ,mem_upper_sm_reconn 
+6efe 20206e4d branch process_upper_sm_reconn 
+
+process_upper_sm_reconn_spp_cmd_ms_wait:
+6eff 6800c2bd fetch 1 ,mem_spp_state 
+6f00 c1ff8000 rtnne rfcomm_channel_setup_complete 
+6f01 20206f08 branch process_upper_sm_reconn_termination 
+
+process_upper_sm_reconn_setup_hid:
+6f02 7002ee0f jam uppersm_reconn_hid_ctrl_conn ,mem_upper_sm_reconn 
+6f03 20206e4d branch process_upper_sm_reconn 
+
+process_upper_sm_reconn_setup_rfcomm:
+6f04 7002ee17 jam uppersm_reconn_rfcomm_conn ,mem_upper_sm_reconn 
+6f05 20206e4d branch process_upper_sm_reconn 
+
+process_upper_sm_reconn_setup_spp:
+6f06 7002ee1d jam uppersm_reconn_spp_cmd_pn ,mem_upper_sm_reconn 
+6f07 20206e4d branch process_upper_sm_reconn 
+
+process_upper_sm_reconn_termination:
+6f08 7002ee00 jam 0 ,mem_upper_sm_reconn 
+6f09 20600000 rtn 
+
+upper_sm_send_sdp_conn:
+6f0a 79200025 set1 mark_ext_patch ,mark 
+6f0b 44d44035 bpatch patch35_0 ,mem_patch35 
+6f0c 204052c4 call l2cap_malloc_signal_channel 
+6f0d 58000001 setarg psm_sdp 
+6f0e 1fe20400 copy pdata ,temp 
+6f0f 58000050 setarg l2cap_sdp_channel 
+6f10 1fe21600 copy pdata ,timeup 
+6f11 202050b0 branch ml2cap_send_signal_connect_req 
+
+upper_sm_send_sdp_cfg:
+6f12 79200025 set1 mark_ext_patch ,mark 
+6f13 44d4c035 bpatch patch35_1 ,mem_patch35 
+6f14 204052c4 call l2cap_malloc_signal_channel 
+6f15 680142b1 fetch 2 ,mem_sdp_remote_cid 
+6f16 1fe20400 copy pdata ,temp 
+6f17 202050c0 branch ml2cap_send_signal_config_req 
+
+upper_sm_send_sdp_disconn:
+6f18 79200025 set1 mark_ext_patch ,mark 
+6f19 44d54035 bpatch patch35_2 ,mem_patch35 
+6f1a 204052c4 call l2cap_malloc_signal_channel 
+6f1b 680142b1 fetch 2 ,mem_sdp_remote_cid 
+6f1c 1fe20400 copy pdata ,temp 
+6f1d d9600050 arg l2cap_sdp_channel ,timeup 
+6f1e 204050d6 call ml2cap_send_signal_disconn_req 
+6f1f 6800c2b9 fetch 1 ,mem_sdp_state 
+6f20 793ffe05 set0 l2cap_channel_state_rcv_cfg_res ,pdata 
+6f21 6000c2b9 store 1 ,mem_sdp_state 
+6f22 20600000 rtn 
+
+upper_sm_send_ss_spp:
+6f23 79200025 set1 mark_ext_patch ,mark 
+6f24 44d5c035 bpatch patch35_3 ,mem_patch35 
+6f25 204052d2 call l2cap_malloc_sdp_channel 
+6f26 204071b0 call sdp_send_spp_request 
+6f27 202050f2 branch msdp_send_req_done 
+
+upper_sm_send_rfcomm_conn:
+6f28 79200025 set1 mark_ext_patch ,mark 
+6f29 44d64035 bpatch patch35_4 ,mem_patch35 
+6f2a 204052c4 call l2cap_malloc_signal_channel 
+6f2b 58000003 setarg psm_rfcomm 
+6f2c 1fe20400 copy pdata ,temp 
+6f2d 58000051 setarg l2cap_rfcomm_channel 
+6f2e 1fe21600 copy pdata ,timeup 
+6f2f 202050b0 branch ml2cap_send_signal_connect_req 
+
+upper_sm_send_rfcomm_cfg:
+6f30 79200025 set1 mark_ext_patch ,mark 
+6f31 44d6c035 bpatch patch35_5 ,mem_patch35 
+6f32 204052c4 call l2cap_malloc_signal_channel 
+6f33 680142b3 fetch 2 ,mem_rfcomm_remote_cid 
+6f34 1fe20400 copy pdata ,temp 
+6f35 202050c0 branch ml2cap_send_signal_config_req 
+
+upper_sm_send_hid_ctrl_conn:
+6f36 79200025 set1 mark_ext_patch ,mark 
+6f37 44d74035 bpatch patch35_6 ,mem_patch35 
+6f38 204052c4 call l2cap_malloc_signal_channel 
+6f39 58000011 setarg psm_hid_control 
+6f3a 1fe20400 copy pdata ,temp 
+6f3b 58000052 setarg l2cap_hid_control_channel 
+6f3c 1fe21600 copy pdata ,timeup 
+6f3d 202050b0 branch ml2cap_send_signal_connect_req 
+
+upper_sm_send_hid_ctrl_cfg:
+6f3e 79200025 set1 mark_ext_patch ,mark 
+6f3f 44d7c035 bpatch patch35_7 ,mem_patch35 
+6f40 204052c4 call l2cap_malloc_signal_channel 
+6f41 680142b5 fetch 2 ,mem_hid_ctrl_remote_cid 
+6f42 1fe20400 copy pdata ,temp 
+6f43 202050c0 branch ml2cap_send_signal_config_req 
+
+upper_sm_send_hid_int_conn:
+6f44 79200025 set1 mark_ext_patch ,mark 
+6f45 44d84036 bpatch patch36_0 ,mem_patch36 
+6f46 204052c4 call l2cap_malloc_signal_channel 
+6f47 58000013 setarg psm_hid_interrupt 
+6f48 1fe20400 copy pdata ,temp 
+6f49 58000053 setarg l2cap_hid_interrupt_channel 
+6f4a 1fe21600 copy pdata ,timeup 
+6f4b 202050b0 branch ml2cap_send_signal_connect_req 
+
+upper_sm_send_hid_int_cfg:
+6f4c 79200025 set1 mark_ext_patch ,mark 
+6f4d 44d8c036 bpatch patch36_1 ,mem_patch36 
+6f4e 204052c4 call l2cap_malloc_signal_channel 
+6f4f 680142b7 fetch 2 ,mem_hid_int_remote_cid 
+6f50 1fe20400 copy pdata ,temp 
+6f51 202050c0 branch ml2cap_send_signal_config_req 
+
+upper_sm_send_rfcomm_sabm:
+6f52 79200025 set1 mark_ext_patch ,mark 
+6f53 44d94036 bpatch patch36_2 ,mem_patch36 
+6f54 204052e0 call l2cap_malloc_rfcomm_channel 
+6f55 70049303 jam 3 ,mem_current_adss 
+6f56 7004961c jam 0x1c ,mem_current_fcs 
+6f57 20406ce8 call rfcomm_send_sabm 
+6f58 70475101 jam 1 ,mem_rfcomm_initiator 
+6f59 20600000 rtn 
+
+upper_sm_send_spp_cmd_pn:
+6f5a 79200025 set1 mark_ext_patch ,mark 
+6f5b 44d9c036 bpatch patch36_3 ,mem_patch36 
+6f5c 204052e0 call l2cap_malloc_rfcomm_channel 
+6f5d 6808c752 fetcht 1 ,mem_remote_spp_channel 
+6f5e 20406bcb call channel_to_dlci 
+6f5f 6008c74b storet 1 ,mem_pn_dlci 
+6f60 20206d05 branch rfcomm_send_param_neg_cmd 
+
+upper_sm_send_spp_sabm:
+6f61 79200025 set1 mark_ext_patch ,mark 
+6f62 44da4036 bpatch patch36_4 ,mem_patch36 
+6f63 204052e0 call l2cap_malloc_rfcomm_channel 
+6f64 6808c74b fetcht 1 ,mem_pn_dlci 
+6f65 20406bc0 call dlci_to_address_cmd 
+6f66 20406b67 call rfcomm_calculate_fcs_sabm 
+6f67 60008496 store 1 ,mem_current_fcs 
+6f68 6808c74b fetcht 1 ,mem_pn_dlci 
+6f69 20406bc0 call dlci_to_address_cmd 
+6f6a 60088493 storet 1 ,mem_current_adss 
+6f6b 20206ce8 branch rfcomm_send_sabm 
+
+upper_sm_send_spp_cmd_ms:
+6f6c 79200025 set1 mark_ext_patch ,mark 
+6f6d 44dac036 bpatch patch36_5 ,mem_patch36 
+6f6e 204052e0 call l2cap_malloc_rfcomm_channel 
+6f6f 6808c74b fetcht 1 ,mem_pn_dlci 
+6f70 20406bc0 call dlci_to_address_cmd 
+6f71 20206d3f branch rfcomm_send_modem_status_cmd 
+
+sdp_process:
+6f72 79200025 set1 mark_ext_patch ,mark 
+6f73 44f3c03c bpatch patch3c_7 ,mem_patch3c 
+6f74 680102cb fetch 2 ,mem_l2cap_payload_ptr 
+6f75 98000c00 iforce contr 
+6f76 e8c08000 ifetch 1 ,contr 
+6f77 1fe22400 copy pdata ,regb 
+6f78 600084af store 1 ,mem_sdp_pduid 
+6f79 e8c10000 ifetch 2 ,contr 
+6f7a 600104b0 store 2 ,mem_sdp_transactionid 
+6f7b e8c08000 ifetch 1 ,contr 
+6f7c 1fed1600 lshift8 pdata ,timeup 
+6f7d e8c08000 ifetch 1 ,contr 
+6f7e 99609600 iadd timeup ,timeup 
+6f7f 79200025 set1 mark_ext_patch ,mark 
+6f80 44f4403d bpatch patch3d_0 ,mem_patch3d 
+6f81 1a427e00 deposit regb 
+6f82 c0016f87 beq sdp_service_search_request ,servicesearch_req 
+6f83 c0026fb0 beq sdp_service_attribute_request ,serviceattribute_req 
+6f84 c003708b beq sdp_service_search_attribute_request ,servicesearchattribute_req 
+6f85 c003f1c7 beq sdp_service_search_attribute_response ,servicesearchattribute_res 
+6f86 2020723e branch sdp_insufficient_resource 
+
+servicesearch_req:
+6f87 2040724d call ask_serviceclassid 
+6f88 2841fe01 compare 1 ,temp ,0xff 
+6f89 2020f2bb branch empth_sa_rsp ,true 
+6f8a 2841feff compare 0xff ,temp ,0xff 
+6f8b 2020f241 branch sdp_invalid_reqest_syntax ,true 
+6f8c e8c10000 ifetch 2 ,contr 
+6f8d 600104b4 store 2 ,mem_sdp_record_maxcnt 
+6f8e 196097fe increase -2 ,timeup 
+6f8f 196097ff increase -1 ,timeup 
+6f90 2422f23b nbranch sdp_invalid_pdu_size ,zero 
+6f91 d96004a9 arg mem_uuid_search_pat ,timeup 
+6f92 e9610000 ifetch 2 ,timeup 
+6f93 207a0000 rtn blank 
+6f94 19609602 increase 2 ,timeup 
+6f95 20407307 call search_uuid 
+6f96 204052de call l2cap_get_sdp_tx_payload 
+6f97 18007e03 force 3 ,pdata 
+6f98 e0a08000 istore 1 ,contw 
+6f99 680104b0 fetch 2 ,mem_sdp_transactionid 
+6f9a e0a10000 istore 2 ,contw 
+6f9b 18ebfe00 lshift2 queue ,pdata 
+6f9c 1fe0fe05 add pdata ,5 ,pdata 
+6f9d 1fe0a605 add pdata ,5 ,regc 
+6f9e 1ff0fe00 byteswap pdata ,pdata 
+6f9f e0a10000 istore 2 ,contw 
+6fa0 18e27e00 deposit queue 
+6fa1 1ff0fe00 byteswap pdata ,pdata 
+6fa2 e0a10000 istore 2 ,contw 
+6fa3 e0a10000 istore 2 ,contw 
+6fa4 d8c004c5 arg mem_handle_list ,contr 
+6fa5 18e27200 copy queue ,loopcnt 
+6fa6 2022efaa branch servicesearch_req_blank ,zero 
+
+servicesearch_req_loop:
+6fa7 e8c20000 ifetch 4 ,contr 
+6fa8 e0a20000 istore 4 ,contw 
+6fa9 c2006fa7 loop servicesearch_req_loop 
+
+servicesearch_req_blank:
+6faa 18007e00 force 0 ,pdata 
+6fab e0a08000 istore 1 ,contw 
+6fac 1a627e00 deposit regc 
+6fad 600082dc store 1 ,mem_sdp_tx_pkt_length 
+6fae 203a3bf1 branch assert ,blank 
+6faf 20600000 rtn 
+
+serviceattribute_req:
+6fb0 e8c20000 ifetch 4 ,contr 
+6fb1 600204be store 4 ,mem_sdp_record_handle 
+6fb2 196097fc increase -4 ,timeup 
+6fb3 98000400 iforce temp 
+6fb4 e8c10000 ifetch 2 ,contr 
+6fb5 1ff0fe00 byteswap pdata ,pdata 
+6fb6 1fe0ffee increase -18 ,pdata 
+6fb7 600104b2 store 2 ,mem_sdp_attribute_maxbyte 
+6fb8 196097fe increase -2 ,timeup 
+6fb9 204072a4 call dataelementtype6 
+6fba 2022f241 branch sdp_invalid_reqest_syntax ,zero 
+6fbb 2a21fe05 compare 5 ,rega ,0xff 
+6fbc 2020efc0 branch serviceattribute_judge_wholerangle ,true 
+
+serviceattribute_isnot_wholerangle:
+6fbd d8a00491 arg mem_attrib_list ,contw 
+6fbe 18000e00 force 0 ,queue 
+6fbf 20206fd0 branch serviceattribute_req_loop 
+
+serviceattribute_judge_wholerangle:
+6fc0 e8c08000 ifetch 1 ,contr 
+6fc1 c0857241 bne 0xa ,sdp_invalid_reqest_syntax 
+6fc2 e8c10000 ifetch 2 ,contr 
+6fc3 243a6fce nbranch serviceattribute_judge_wholerangle_false1 ,blank 
+6fc4 e8c08000 ifetch 1 ,contr 
+6fc5 c0ffefcc bne 0xff ,serviceattribute_judge_wholerangle_false2 
+6fc6 e8c08000 ifetch 1 ,contr 
+6fc7 c0ffefca bne 0xff ,serviceattribute_judge_wholerangle_false3 
+6fc8 18c08dfb increase -5 ,contr 
+6fc9 20207022 branch serviceattribute_req_all 
+
+serviceattribute_judge_wholerangle_false3:
+6fca 18c08dfb increase -5 ,contr 
+6fcb 20206fbd branch serviceattribute_isnot_wholerangle 
+
+serviceattribute_judge_wholerangle_false2:
+6fcc 18c08dfc increase -4 ,contr 
+6fcd 20206fbd branch serviceattribute_isnot_wholerangle 
+
+serviceattribute_judge_wholerangle_false1:
+6fce 18c08dfd increase -3 ,contr 
+6fcf 20206fbd branch serviceattribute_isnot_wholerangle 
+
+serviceattribute_req_loop:
+6fd0 e8c08000 ifetch 1 ,contr 
+6fd1 c004efe5 beq 0x09 ,serviceattribute_req_one_id 
+6fd2 c0056fd3 beq 0x0a ,serviceattribute_req_range_id 
+
+serviceattribute_req_range_id:
+6fd3 e8c10000 ifetch 2 ,contr 
+6fd4 e0a10000 istore 2 ,contw 
+6fd5 18e08e01 increase 1 ,queue 
+6fd6 1ff0a400 byteswap pdata ,regb 
+6fd7 e8c10000 ifetch 2 ,contr 
+6fd8 1ff0fe00 byteswap pdata ,pdata 
+
+serviceattribute_req_range_id_increase:
+6fd9 1a40a401 increase 1 ,regb 
+6fda 9a467c00 isub regb ,null 
+6fdb 24216fe2 nbranch serviceattribute_req_range_id_finish ,positive 
+6fdc 1fe22600 copy pdata ,regc 
+6fdd 1a50fe00 byteswap regb ,pdata 
+6fde e0a10000 istore 2 ,contw 
+6fdf 18e08e01 increase 1 ,queue 
+6fe0 1a627e00 copy regc ,pdata 
+6fe1 20206fd9 branch serviceattribute_req_range_id_increase 
+
+serviceattribute_req_range_id_finish:
+6fe2 196097fb increase -5 ,timeup 
+6fe3 1a20a3fb increase -5 ,rega 
+6fe4 20206fea branch serviceattribute_req_check_next_id 
+
+serviceattribute_req_one_id:
+6fe5 e8c10000 ifetch 2 ,contr 
+6fe6 e0a10000 istore 2 ,contw 
+6fe7 18e08e01 increase 1 ,queue 
+6fe8 196097fd increase -3 ,timeup 
+6fe9 1a20a3fd increase -3 ,rega 
+
+serviceattribute_req_check_next_id:
+6fea 24217241 nbranch sdp_invalid_reqest_syntax ,positive 
+6feb 2422efd0 nbranch serviceattribute_req_loop ,zero 
+6fec 196097ff increase -1 ,timeup 
+6fed 2422f241 nbranch sdp_invalid_reqest_syntax ,zero 
+6fee 204052de call l2cap_get_sdp_tx_payload 
+6fef 18a08a0a increase 10 ,contw 
+6ff0 da200491 arg mem_attrib_list ,rega 
+
+answer_handle_attributelist_next:
+6ff1 18e27e00 copy queue ,pdata 
+6ff2 203a7004 branch answer_handle_attributelist_end ,blank 
+6ff3 ea210000 ifetch 2 ,rega 
+6ff4 203a7004 branch answer_handle_attributelist_end ,blank 
+6ff5 98002400 iforce regb 
+6ff6 680204be fetch 4 ,mem_sdp_record_handle 
+6ff7 98000400 iforce temp 
+6ff8 2040734e call search_handle_attrib 
+6ff9 203a7001 branch answer_handle_attributelist_notfound ,blank 
+6ffa 18c08dfd increase -3 ,contr 
+6ffb e8c18000 ifetch 3 ,contr 
+6ffc e0a18000 istore 3 ,contw 
+6ffd 20407199 call sdp_data_len_obs 
+6ffe 203a7001 branch answer_handle_attributelist_notfound ,blank 
+6fff 98007200 iforce loopcnt 
+7000 20407e45 call memcpy 
+
+answer_handle_attributelist_notfound:
+7001 1a20a202 increase 2 ,rega 
+7002 18e08fff increase -1 ,queue 
+7003 20206ff1 branch answer_handle_attributelist_next 
+
+answer_handle_attributelist_end:
+7004 18007e00 force 0 ,pdata 
+7005 e0a08000 istore 1 ,contw 
+7006 18a08bff increase -1 ,contw 
+7007 680902da fetcht 2 ,mem_sdp_tx_payload_ptr 
+7008 1840fe0a add temp ,10 ,pdata 
+7009 98a67e00 isub contw ,pdata 
+700a 1fe62200 sub pdata ,0 ,rega 
+700b 1a30fe00 byteswap rega ,pdata 
+700c 1840a408 add temp ,8 ,regb 
+700d e2410000 istore 2 ,regb 
+700e 1a20a203 increase 3 ,rega 
+700f 1a30fe00 byteswap rega ,pdata 
+7010 1840a405 add temp ,5 ,regb 
+7011 e2410000 istore 2 ,regb 
+7012 1a20a203 increase 3 ,rega 
+7013 1a30fe00 byteswap rega ,pdata 
+7014 1840a403 add temp ,3 ,regb 
+7015 e2410000 istore 2 ,regb 
+7016 1a20a205 increase 5 ,rega 
+7017 1a227e00 copy rega ,pdata 
+7018 600102dc store 2 ,mem_sdp_tx_pkt_length 
+7019 58000036 setarg 0x36 
+701a 1840a407 add temp ,7 ,regb 
+701b e2408000 istore 1 ,regb 
+701c 58000005 setarg 5 
+701d e0408000 istore 1 ,temp 
+701e 680104b0 fetch 2 ,mem_sdp_transactionid 
+701f 1840a401 add temp ,1 ,regb 
+7020 e2410000 istore 2 ,regb 
+7021 20600000 rtn 
+
+serviceattribute_req_all:
+7022 e8c08000 ifetch 1 ,contr 
+7023 c0857241 bne 0xa ,sdp_invalid_reqest_syntax 
+7024 e8c10000 ifetch 2 ,contr 
+7025 243a7241 nbranch sdp_invalid_reqest_syntax ,blank 
+7026 e8c08000 ifetch 1 ,contr 
+7027 c0fff241 bne 0xff ,sdp_invalid_reqest_syntax 
+7028 e8c08000 ifetch 1 ,contr 
+7029 c0fff241 bne 0xff ,sdp_invalid_reqest_syntax 
+702a 196097fb increase -5 ,timeup 
+702b e8c08000 ifetch 1 ,contr 
+702c c000702f beq 0 ,continue_zero 
+702d c000f032 beq 1 ,continue_one_byte 
+702e c0017036 beq 2 ,continue_two_byte 
+
+continue_zero:
+702f 600104ad store 2 ,mem_sdp_continue_byte 
+7030 196097ff increase -1 ,timeup 
+7031 2020703a branch continue_end 
+
+continue_one_byte:
+7032 e8c08000 ifetch 1 ,contr 
+7033 600104ad store 2 ,mem_sdp_continue_byte 
+7034 196097fe increase -2 ,timeup 
+7035 2020703a branch continue_end 
+
+continue_two_byte:
+7036 e8c10000 ifetch 2 ,contr 
+7037 1ff0fe00 byteswap pdata ,pdata 
+7038 600104ad store 2 ,mem_sdp_continue_byte 
+7039 196097fd increase -3 ,timeup 
+
+continue_end:
+703a 2422f23b nbranch sdp_invalid_pdu_size ,zero 
+703b 2040731e call search_handle 
+703c 2422f238 nbranch sdp_invalid_service_record_handle ,zero 
+703d 18c22200 copy contr ,rega 
+703e 204052de call l2cap_get_sdp_tx_payload 
+703f 1a220c00 copy rega ,contr 
+7040 18a08a03 increase 3 ,contw 
+7041 18c21600 copy contr ,timeup 
+7042 204072e8 call sdp_get_data 
+7043 1fe22200 copy pdata ,rega 
+7044 680104ad fetch 2 ,mem_sdp_continue_byte 
+7045 1fe22400 copy pdata ,regb 
+7046 1a227e00 copy rega ,pdata 
+7047 9a462400 isub regb ,regb 
+7048 680104b2 fetch 2 ,mem_sdp_attribute_maxbyte 
+7049 9a467c00 isub regb ,null 
+704a 24217066 nbranch fragment_sdp ,positive 
+704b 78547c00 disable user 
+704c 680104ad fetch 2 ,mem_sdp_continue_byte 
+704d 203a7059 branch fisrt_fragment ,blank 
+704e 99608c00 iadd timeup ,contr 
+704f 1a40a403 increase 3 ,regb 
+7050 1a427200 copy regb ,loopcnt 
+7051 1f227e00 copy loopcnt ,pdata 
+7052 1fe0fe03 increase 3 ,pdata 
+7053 1ff0fe00 byteswap pdata ,pdata 
+7054 e0a10000 istore 2 ,contw 
+7055 1f227e00 copy loopcnt ,pdata 
+7056 1ff0fe00 byteswap pdata ,pdata 
+7057 e0a10000 istore 2 ,contw 
+7058 20207074 branch answer_attributelist_full_loop 
+
+fisrt_fragment:
+7059 1a20f206 add rega ,6 ,loopcnt 
+705a 2034705d branch parlength_continue_byte ,user 
+705b 1f30fe00 byteswap loopcnt ,pdata 
+705c 20207060 branch parlength_continue_byte_end 
+
+parlength_continue_byte:
+705d 1f227e00 copy loopcnt ,pdata 
+705e 1fe0fe02 increase 2 ,pdata 
+705f 1ff0fe00 byteswap pdata ,pdata 
+
+parlength_continue_byte_end:
+7060 e0a10000 istore 2 ,contw 
+7061 1f20f3fd increase -3 ,loopcnt 
+7062 1f30fe00 byteswap loopcnt ,pdata 
+7063 e0a10000 istore 2 ,contw 
+7064 19620c00 copy timeup ,contr 
+7065 20207074 branch answer_attributelist_full_loop 
+
+fragment_sdp:
+7066 78347c00 enable user 
+7067 680104b2 fetch 2 ,mem_sdp_attribute_maxbyte 
+7068 1fe22200 copy pdata ,rega 
+7069 1fe27200 copy pdata ,loopcnt 
+706a 680104ad fetch 2 ,mem_sdp_continue_byte 
+706b 203a7059 branch fisrt_fragment ,blank 
+706c 99608c00 iadd timeup ,contr 
+706d 1a227e00 copy rega ,pdata 
+706e 1fe0fe05 increase 5 ,pdata 
+706f 1ff0fe00 byteswap pdata ,pdata 
+7070 e0a10000 istore 2 ,contw 
+7071 1a227e00 copy rega ,pdata 
+7072 1ff0fe00 byteswap pdata ,pdata 
+7073 e0a10000 istore 2 ,contw 
+
+answer_attributelist_full_loop:
+7074 e8c08000 ifetch 1 ,contr 
+7075 e0a08000 istore 1 ,contw 
+7076 c2007074 loop answer_attributelist_full_loop 
+7077 2434707f nbranch last_frag_continue ,user 
+7078 18007e02 force 2 ,pdata 
+7079 e0a08000 istore 1 ,contw 
+707a 18c27e00 copy contr ,pdata 
+707b 99667e00 isub timeup ,pdata 
+707c 1ff0fe00 byteswap pdata ,pdata 
+707d e0a10000 istore 2 ,contw 
+707e 20207081 branch sdp_frag_end 
+
+last_frag_continue:
+707f 18007e00 force 0 ,pdata 
+7080 e0a08000 istore 1 ,contw 
+
+sdp_frag_end:
+7081 680102da fetch 2 ,mem_sdp_tx_payload_ptr 
+7082 98a67e00 isub contw ,pdata 
+7083 1fe67e00 sub pdata ,0 ,pdata 
+7084 600102dc store 2 ,mem_sdp_tx_pkt_length 
+7085 204052de call l2cap_get_sdp_tx_payload 
+7086 58000005 setarg 5 
+7087 e0a08000 istore 1 ,contw 
+7088 680104b0 fetch 2 ,mem_sdp_transactionid 
+7089 e0a10000 istore 2 ,contw 
+708a 20600000 rtn 
+
+servicesearchattribute_req:
+708b 2040724d call ask_serviceclassid 
+708c 2841feff compare 0xff ,temp ,0xff 
+708d 2020f0b4 branch servicesearchattribute_req_all ,true 
+708e e8c10000 ifetch 2 ,contr 
+708f 600104b2 store 2 ,mem_sdp_attribute_maxbyte 
+7090 196097fe increase -2 ,timeup 
+7091 204072a4 call dataelementtype6 
+7092 d8a00491 arg mem_attrib_list ,contw 
+7093 18000e00 force 0 ,queue 
+
+servicesearchattribute_req_loop:
+7094 e8c18000 ifetch 3 ,contr 
+7095 c084f0b4 bne 0x09 ,servicesearchattribute_req_all 
+
+servicesearchattribute_req_uuid:
+7096 1fecfe00 rshift8 pdata ,pdata 
+7097 e0a10000 istore 2 ,contw 
+7098 18e08e01 increase 1 ,queue 
+7099 196097fd increase -3 ,timeup 
+709a 1a20a3fd increase -3 ,rega 
+709b 24217241 nbranch sdp_invalid_reqest_syntax ,positive 
+709c 2422f094 nbranch servicesearchattribute_req_loop ,zero 
+709d 196097ff increase -1 ,timeup 
+709e 2422f241 nbranch sdp_invalid_reqest_syntax ,zero 
+
+servicesearchattribute_req_search:
+709f 204052de call l2cap_get_sdp_tx_payload 
+70a0 18a08a0d increase 13 ,contw 
+70a1 680104a9 fetch 2 ,mem_uuid_search_pat 
+70a2 98002600 iforce regc 
+70a3 da200491 arg mem_attrib_list ,rega 
+
+answer_attributelist_next:
+70a4 ea220000 ifetch 4 ,rega 
+70a5 203a70c4 branch answer_attributelist_end ,blank 
+70a6 ea210000 ifetch 2 ,rega 
+70a7 98002400 iforce regb 
+70a8 2040732a call search_attrib 
+70a9 203a70b2 branch answer_attributelist_notfound ,blank 
+70aa 18c08dfd increase -3 ,contr 
+70ab e8c18000 ifetch 3 ,contr 
+70ac e0a18000 istore 3 ,contw 
+70ad 20407199 call sdp_data_len_obs 
+70ae 98007200 iforce loopcnt 
+
+answer_attributelist_attrib_loop:
+70af e8c08000 ifetch 1 ,contr 
+70b0 e0a08000 istore 1 ,contw 
+70b1 c20070af loop answer_attributelist_attrib_loop 
+
+answer_attributelist_notfound:
+70b2 1a20a202 increase 2 ,rega 
+70b3 202070a4 branch answer_attributelist_next 
+
+servicesearchattribute_req_all:
+70b4 e8c08000 ifetch 1 ,contr 
+70b5 e8c08000 ifetch 1 ,contr 
+70b6 196097fb increase -5 ,timeup 
+70b7 1a20a3fb increase -5 ,rega 
+70b8 24217241 nbranch sdp_invalid_reqest_syntax ,positive 
+70b9 d96004a9 arg mem_uuid_search_pat ,timeup 
+70ba e9610000 ifetch 2 ,timeup 
+70bb 19609602 increase 2 ,timeup 
+70bc 20407307 call search_uuid 
+70bd 18e27e00 deposit queue 
+70be 600084dd store 1 ,mem_handle_humber 
+70bf 203a72be branch empty_ssa_rsp ,blank 
+70c0 d8e00000 arg 0 ,queue 
+70c1 204052de call l2cap_get_sdp_tx_payload 
+70c2 18a08a0a increase 10 ,contw 
+70c3 20207108 branch servicesearchattribute_req_next_handle 
+
+answer_attributelist_end:
+70c4 18007e00 force 0 ,pdata 
+70c5 e0a08000 istore 1 ,contw 
+70c6 18a08bff increase -1 ,contw 
+70c7 680902da fetcht 2 ,mem_sdp_tx_payload_ptr 
+70c8 1840fe0d add temp ,13 ,pdata 
+70c9 98a67e00 isub contw ,pdata 
+70ca 2022f0e8 branch no_attribute_return ,zero 
+70cb 1fe67e00 sub pdata ,0 ,pdata 
+70cc 1840a40c add temp ,12 ,regb 
+70cd e2408000 istore 1 ,regb 
+70ce 1fe0fe03 increase 3 ,pdata 
+70cf 1840a409 add temp ,9 ,regb 
+70d0 e2408000 istore 1 ,regb 
+70d1 1fe0fe03 increase 3 ,pdata 
+70d2 1ff0fe00 byteswap pdata ,pdata 
+70d3 1840a405 add temp ,5 ,regb 
+70d4 e2410000 istore 2 ,regb 
+70d5 1fecfe00 rshift8 pdata ,pdata 
+70d6 1fe0fe03 increase 3 ,pdata 
+70d7 1ff0fe00 byteswap pdata ,pdata 
+70d8 1840a403 add temp ,3 ,regb 
+70d9 e2410000 istore 2 ,regb 
+70da 1fecfe00 rshift8 pdata ,pdata 
+70db 1fe0fe05 increase 5 ,pdata 
+70dc 600082dc store 1 ,mem_sdp_tx_pkt_length 
+70dd 680104b0 fetch 2 ,mem_sdp_transactionid 
+70de 1840a401 add temp ,1 ,regb 
+70df e2410000 istore 2 ,regb 
+70e0 58000007 setarg 7 
+70e1 e0408000 istore 1 ,temp 
+70e2 58000036 setarg 0x0036 
+70e3 1840a407 add temp ,7 ,regb 
+70e4 e2410000 istore 2 ,regb 
+70e5 1840a40a add temp ,10 ,regb 
+70e6 e2410000 istore 2 ,regb 
+70e7 20600000 rtn 
+
+no_attribute_return:
+70e8 7002dc0a jam 10 ,mem_sdp_tx_pkt_length 
+70e9 204052de call l2cap_get_sdp_tx_payload 
+70ea 58000007 setarg 7 
+70eb e0a08000 istore 1 ,contw 
+70ec 680104b0 fetch 2 ,mem_sdp_transactionid 
+70ed e0a10000 istore 2 ,contw 
+70ee 58000500 setarg 0x0500 
+70ef e0a10000 istore 2 ,contw 
+70f0 58000200 setarg 0x0200 
+70f1 e0a10000 istore 2 ,contw 
+70f2 58000035 setarg 0x000035 
+70f3 e0a18000 istore 3 ,contw 
+70f4 20600000 rtn 
+
+servicesearchattribute_req_attributelist_loop:
+70f5 e8c08000 ifetch 1 ,contr 
+70f6 e0a08000 istore 1 ,contw 
+70f7 1a40a401 increase 1 ,regb 
+70f8 1a20a3ff increase -1 ,rega 
+70f9 2022f0fb branch servicesearchattribute_req_check_next_ctn ,zero 
+70fa c20070f5 loop servicesearchattribute_req_attributelist_loop 
+
+servicesearchattribute_req_check_next_ctn:
+70fb 18a21600 copy contw ,timeup 
+70fc 1a427e00 copy regb ,pdata 
+70fd 600104ad store 2 ,mem_sdp_continue_byte 
+70fe 1a227e00 copy rega ,pdata 
+70ff 600104b2 store 2 ,mem_sdp_attribute_maxbyte 
+7100 203a7117 branch answer_attributelist_with_ctn_bytes ,blank 
+7101 20347152 branch answer_attributelist_with_ctn_end ,user 
+7102 19620a00 copy timeup ,contw 
+
+servicesearchattribute_req_check_handle:
+7103 18e08e01 increase 1 ,queue 
+7104 680084dd fetch 1 ,mem_handle_humber 
+7105 98e67c00 isub queue ,null 
+7106 2422f108 nbranch servicesearchattribute_req_next_handle ,zero 
+7107 20207171 branch answer_attributelist_end_long 
+
+servicesearchattribute_req_next_handle:
+7108 d8c004c5 arg mem_handle_list ,contr 
+7109 18ebfe00 lshift2 queue ,pdata 
+710a 98c08c00 iadd contr ,contr 
+710b e8c20000 ifetch 4 ,contr 
+710c 98000400 iforce temp 
+710d 2040731e call search_handle 
+710e 18c21600 copy contr ,timeup 
+710f 204072e8 call sdp_get_data 
+7110 1fe0f203 add pdata ,3 ,loopcnt 
+7111 680104b2 fetch 2 ,mem_sdp_attribute_maxbyte 
+7112 1fe22200 copy pdata ,rega 
+7113 680104ad fetch 2 ,mem_sdp_continue_byte 
+7114 1fe22400 copy pdata ,regb 
+7115 19620c00 copy timeup ,contr 
+7116 202070f5 branch servicesearchattribute_req_attributelist_loop 
+
+answer_attributelist_with_ctn_bytes:
+7117 d8e00000 arg 0 ,queue 
+7118 da400000 arg 0 ,regb 
+
+answer_attributelist_calc_attribute_length:
+7119 d8c004c5 arg mem_handle_list ,contr 
+711a 18ebfe00 lshift2 queue ,pdata 
+711b 98c08c00 iadd contr ,contr 
+711c e8c20000 ifetch 4 ,contr 
+711d 98000400 iforce temp 
+711e 2040731e call search_handle 
+711f 204072e8 call sdp_get_data 
+7120 1fe0fe03 add pdata ,3 ,pdata 
+7121 9a40a400 iadd regb ,regb 
+7122 18e08e01 increase 1 ,queue 
+7123 680084dd fetch 1 ,mem_handle_humber 
+7124 98e67c00 isub queue ,null 
+7125 2422f119 nbranch answer_attributelist_calc_attribute_length ,zero 
+7126 19620a00 copy timeup ,contw 
+7127 18007e02 force 2 ,pdata 
+7128 e0a08000 istore 1 ,contw 
+7129 680104ad fetch 2 ,mem_sdp_continue_byte 
+712a 1ff0fe00 byteswap pdata ,pdata 
+712b e0a10000 istore 2 ,contw 
+712c 18a08bfd increase -3 ,contw 
+712d 680902da fetcht 2 ,mem_sdp_tx_payload_ptr 
+712e 1840fe0a add temp ,10 ,pdata 
+712f 98a67e00 isub contw ,pdata 
+7130 1fe67e00 sub pdata ,0 ,pdata 
+7131 98002200 iforce rega 
+7132 1a427e00 deposit regb 
+7133 1840a409 add temp ,9 ,regb 
+7134 e2408000 istore 1 ,regb 
+7135 1fecfe00 rshift8 pdata ,pdata 
+7136 1840a408 add temp ,8 ,regb 
+7137 e2408000 istore 1 ,regb 
+7138 1a20a203 increase 3 ,rega 
+7139 1a227e00 deposit rega 
+713a 1840a406 add temp ,6 ,regb 
+713b e2408000 istore 1 ,regb 
+713c 1fecfe00 rshift8 pdata ,pdata 
+713d 1840a405 add temp ,5 ,regb 
+713e e2408000 istore 1 ,regb 
+713f 1a20a205 increase 5 ,rega 
+7140 1a227e00 deposit rega 
+7141 1840a404 add temp ,4 ,regb 
+7142 e2408000 istore 1 ,regb 
+7143 1fecfe00 rshift8 pdata ,pdata 
+7144 1840a403 add temp ,3 ,regb 
+7145 e2408000 istore 1 ,regb 
+7146 1a20a205 increase 5 ,rega 
+7147 1a227e00 deposit rega 
+7148 600102dc store 2 ,mem_sdp_tx_pkt_length 
+7149 58000007 setarg 7 
+714a e0408000 istore 1 ,temp 
+714b 58000036 setarg 0x36 
+714c 1840a407 add temp ,7 ,regb 
+714d e2408000 istore 1 ,regb 
+714e 1840a401 add temp ,1 ,regb 
+714f 680104b0 fetch 2 ,mem_sdp_transactionid 
+7150 e2410000 istore 2 ,regb 
+7151 20600000 rtn 
+
+answer_attributelist_with_ctn_end:
+7152 19620a00 copy timeup ,contw 
+7153 18007e00 force 0 ,pdata 
+7154 e0a08000 istore 1 ,contw 
+7155 18a08bff increase -1 ,contw 
+7156 680902da fetcht 2 ,mem_sdp_tx_payload_ptr 
+7157 1840fe07 add temp ,7 ,pdata 
+7158 98a67e00 isub contw ,pdata 
+7159 1fe67e00 sub pdata ,0 ,pdata 
+715a 98002200 iforce rega 
+715b 1a227e00 deposit rega 
+715c 1840a406 add temp ,6 ,regb 
+715d e2408000 istore 1 ,regb 
+715e 1fecfe00 rshift8 pdata ,pdata 
+715f 1840a405 add temp ,5 ,regb 
+7160 e2408000 istore 1 ,regb 
+7161 1a20a203 increase 3 ,rega 
+7162 1a227e00 deposit rega 
+7163 1840a404 add temp ,4 ,regb 
+7164 e2408000 istore 1 ,regb 
+7165 1fecfe00 rshift8 pdata ,pdata 
+7166 1840a403 add temp ,3 ,regb 
+7167 e2408000 istore 1 ,regb 
+7168 1a20a205 increase 5 ,rega 
+7169 1a227e00 deposit rega 
+716a 600102dc store 2 ,mem_sdp_tx_pkt_length 
+716b 58000007 setarg 7 
+716c e0408000 istore 1 ,temp 
+716d 680104b0 fetch 2 ,mem_sdp_transactionid 
+716e 1840a401 add temp ,1 ,regb 
+716f e2410000 istore 2 ,regb 
+7170 20600000 rtn 
+
+answer_attributelist_end_long:
+7171 18007e00 force 0 ,pdata 
+7172 e0a08000 istore 1 ,contw 
+7173 18a08bff increase -1 ,contw 
+7174 680902da fetcht 2 ,mem_sdp_tx_payload_ptr 
+7175 1840fe0a add temp ,10 ,pdata 
+7176 98a67e00 isub contw ,pdata 
+7177 1fe67e00 sub pdata ,0 ,pdata 
+7178 98002200 iforce rega 
+7179 1a227e00 deposit rega 
+717a 1840a409 add temp ,9 ,regb 
+717b e2408000 istore 1 ,regb 
+717c 1fecfe00 rshift8 pdata ,pdata 
+717d 1840a408 add temp ,8 ,regb 
+717e e2408000 istore 1 ,regb 
+717f 1a20a203 increase 3 ,rega 
+7180 1a227e00 deposit rega 
+7181 1840a406 add temp ,6 ,regb 
+7182 e2408000 istore 1 ,regb 
+7183 1fecfe00 rshift8 pdata ,pdata 
+7184 1840a405 add temp ,5 ,regb 
+7185 e2408000 istore 1 ,regb 
+7186 1a20a203 increase 3 ,rega 
+7187 1a227e00 deposit rega 
+7188 1840a404 add temp ,4 ,regb 
+7189 e2408000 istore 1 ,regb 
+718a 1fecfe00 rshift8 pdata ,pdata 
+718b 1840a403 add temp ,3 ,regb 
+718c e2408000 istore 1 ,regb 
+718d 1a20a205 increase 5 ,rega 
+718e 1a227e00 deposit rega 
+718f 600102dc store 2 ,mem_sdp_tx_pkt_length 
+7190 58000036 setarg 0x36 
+7191 1840a407 add temp ,7 ,regb 
+7192 e2408000 istore 1 ,regb 
+7193 58000007 setarg 7 
+7194 e0408000 istore 1 ,temp 
+7195 680104b0 fetch 2 ,mem_sdp_transactionid 
+7196 1840a401 add temp ,1 ,regb 
+7197 e2410000 istore 2 ,regb 
+7198 20600000 rtn 
+
+sdp_data_len_obs:
+7199 18c21600 copy contr ,timeup 
+719a e8c08000 ifetch 1 ,contr 
+719b 1fe17207 and pdata ,0x07 ,loopcnt 
+719c 1fe97e00 rshift3 pdata ,pdata 
+719d c00371a2 beq 6 ,sdp_data_len_6_obs 
+719e c000f2e0 beq 1 ,sdp_data_len_1 
+719f c00272e5 beq 4 ,sdp_data_len_6 
+71a0 c002f2e3 beq 5 ,sdp_data_len_5 
+71a1 202072de branch sdp_data_len_rtn 
+
+sdp_data_len_6_obs:
+71a2 204071a4 call sdp_get_data_6_obs 
+71a3 202072de branch sdp_data_len_rtn 
+
+sdp_get_data_6_obs:
+71a4 1f227e00 deposit loopcnt 
+71a5 c002f1a9 beq 5 ,sdp_get_data_6_8bit_obs 
+71a6 c00371ac beq 6 ,sdp_get_data_6_16bit_obs 
+71a7 18007203 force 3 ,loopcnt 
+71a8 202072ef branch sdp_get_data_1 
+
+sdp_get_data_6_8bit_obs:
+71a9 e8c08000 ifetch 1 ,contr 
+71aa 1fe0fe02 increase 2 ,pdata 
+71ab 20600000 rtn 
+
+sdp_get_data_6_16bit_obs:
+71ac e8c10000 ifetch 2 ,contr 
+71ad 1ff0fe00 byteswap pdata ,pdata 
+71ae 1fe0fe03 increase 3 ,pdata 
+71af 20600000 rtn 
+
+sdp_send_spp_request:
+71b0 204052de call l2cap_get_sdp_tx_payload 
+71b1 1fe20a00 copy pdata ,contw 
+71b2 58000006 setarg 6 
+71b3 e0a08000 istore 1 ,contw 
+71b4 5800006e setarg sdp_tid_spp 
+71b5 e0a10000 istore 2 ,contw 
+71b6 58000f00 setarg 0x0f00 
+71b7 e0a10000 istore 2 ,contw 
+71b8 581a0535 setarg 0x1a0535 
+71b9 e0a18000 istore 3 ,contw 
+71ba 58000111 setarg 0x0111 
+71bb 1ff07e00 lshift16 pdata ,pdata 
+71bc e0a20000 istore 4 ,contw 
+71bd 58002600 setarg 0x2600 
+71be e0a10000 istore 2 ,contw 
+71bf 58000335 setarg 0x0335 
+71c0 e0a10000 istore 2 ,contw 
+71c1 58000009 setarg 0x0009 
+71c2 e0a10000 istore 2 ,contw 
+71c3 58000004 setarg 0x0004 
+71c4 e0a10000 istore 2 ,contw 
+71c5 7002dc14 jam 0x14 ,mem_sdp_tx_pkt_length 
+71c6 20600000 rtn 
+
+servicesearchattribute_res:
+71c7 18c20400 copy contr ,temp 
+71c8 680104b0 fetch 2 ,mem_sdp_transactionid 
+71c9 c03771cb beq sdp_tid_spp ,servicesearchattribute_res_spp 
+71ca 202071d4 branch srchfail 
+
+servicesearchattribute_res_spp:
+71cb 18420c00 copy temp ,contr 
+71cc 196097fd increase -3 ,timeup 
+71cd 19627e00 copy timeup ,pdata 
+71ce c00171d4 beq 2 ,srchfail 
+71cf 204071d5 call find_rfcomm_channel_number 
+71d0 20740000 rtn user 
+71d1 6000c752 store 1 ,mem_remote_spp_channel 
+71d2 7002ec17 jam recieve_ss_reasult_hf ,mem_message_to_uppersm 
+71d3 20600000 rtn 
+
+srchfail:
+71d4 20600000 rtn 
+
+find_rfcomm_channel_number:
+71d5 78347c00 enable user 
+71d6 1fe27200 copy pdata ,loopcnt 
+71d7 d8400400 arg 0x0400 ,temp 
+
+find_rfcomm_channel_number_loop:
+71d8 e8c10000 ifetch 2 ,contr 
+71d9 98467c00 isub temp ,null 
+71da 2022f1de branch find_rfcomm_channel_number_find_adl ,zero 
+71db 18c08dff increase -1 ,contr 
+71dc c20071d8 loop find_rfcomm_channel_number_loop 
+71dd 20600000 rtn 
+
+find_rfcomm_channel_number_find_adl:
+71de d8400300 arg 0x0300 ,temp 
+
+find_rfcomm_channel_number_loop2:
+71df e8c10000 ifetch 2 ,contr 
+71e0 98467c00 isub temp ,null 
+71e1 2022f1e5 branch find_rfcomm_channel_number_find_rfcomm ,zero 
+71e2 18c08dff increase -1 ,contr 
+71e3 c20071df loop find_rfcomm_channel_number_loop2 
+71e4 20600000 rtn 
+
+find_rfcomm_channel_number_find_rfcomm:
+71e5 e8c08000 ifetch 1 ,contr 
+71e6 e8c08000 ifetch 1 ,contr 
+71e7 78547c00 disable user 
+71e8 20600000 rtn 
+
+attribute_reading:
+71e9 204072a4 call dataelementtype6 
+71ea 2022f236 branch rdnortn ,zero 
+71eb 18002400 force 0 ,regb 
+71ec e8c08000 ifetch 1 ,contr 
+71ed 1a20a3ff increase -1 ,rega 
+71ee 196097ff increase -1 ,timeup 
+71ef 2fe1f018 compare 0x18 ,pdata ,0xf8 
+71f0 2420f230 nbranch rduuid3 ,true 
+71f1 2fe00e04 compare 0x04 ,pdata ,0x07 
+71f2 2420f1f8 nbranch is032 ,true 
+71f3 18002401 force 1 ,regb 
+
+skp2bytes:
+71f4 18c08c02 increase 2 ,contr 
+71f5 1a20a3fe increase -2 ,rega 
+71f6 196097fe increase -2 ,timeup 
+71f7 202071fd branch rduuid1 
+
+is032:
+71f8 2fe00e02 compare 0x02 ,pdata ,0x07 
+71f9 2420f1fb nbranch is016 ,true 
+71fa 202071f4 branch skp2bytes 
+
+is016:
+71fb 2fe00e01 compare 0x01 ,pdata ,0x07 
+71fc 2420f230 nbranch rduuid3 ,true 
+
+rduuid1:
+71fd e8c08000 ifetch 1 ,contr 
+71fe 1a20a3ff increase -1 ,rega 
+71ff 196097ff increase -1 ,timeup 
+7200 c080f207 bne 0x01 ,rduuid2 
+7201 e8c08000 ifetch 1 ,contr 
+7202 1a20a3ff increase -1 ,rega 
+7203 196097ff increase -1 ,timeup 
+7204 c0807230 bne 0x00 ,rduuid3 
+7205 7004c3ff jam 0xff ,mem_sdp_lacap_found 
+7206 20207230 branch rduuid3 
+
+rduuid2:
+7207 c0807230 bne 0x00 ,rduuid3 
+7208 e8c08000 ifetch 1 ,contr 
+7209 1a20a3ff increase -1 ,rega 
+720a 196097ff increase -1 ,timeup 
+720b c081f230 bne 0x03 ,rduuid3 
+720c 1a427c00 copy regb ,null 
+720d 2022f210 branch not16by ,zero 
+720e 18c08df4 increase -12 ,contr 
+720f 196097f4 increase -12 ,timeup 
+
+not16by:
+7210 18007eff force 0xff ,pdata 
+7211 600084c4 store 1 ,mem_sdp_rfcomm_found 
+7212 e8c08000 ifetch 1 ,contr 
+7213 1a20a3ff increase -1 ,rega 
+7214 196097ff increase -1 ,timeup 
+7215 2fe1f008 compare 0x08 ,pdata ,0xf8 
+7216 2420f230 nbranch rduuid3 ,true 
+7217 2fe00e00 compare 0x00 ,pdata ,0x07 
+7218 2020f22d branch unsign1 ,true 
+7219 2fe00e01 compare 0x01 ,pdata ,0x07 
+721a 2020f22a branch unsign2 ,true 
+721b 2fe00e02 compare 0x02 ,pdata ,0x07 
+721c 2020f227 branch unsign4 ,true 
+721d 2fe00e03 compare 0x03 ,pdata ,0x07 
+721e 2020f224 branch unsign8 ,true 
+721f 2fe00e04 compare 0x04 ,pdata ,0x07 
+7220 2420f230 nbranch rduuid3 ,true 
+7221 18c08c08 increase 8 ,contr 
+7222 1a20a3f8 increase -8 ,rega 
+7223 196097f8 increase -8 ,timeup 
+
+unsign8:
+7224 18c08c04 increase 4 ,contr 
+7225 1a20a3fc increase -4 ,rega 
+7226 196097fc increase -4 ,timeup 
+
+unsign4:
+7227 18c08c02 increase 2 ,contr 
+7228 1a20a3fe increase -2 ,rega 
+7229 196097fe increase -2 ,timeup 
+
+unsign2:
+722a 18c08c01 increase 1 ,contr 
+722b 1a20a3ff increase -1 ,rega 
+722c 196097ff increase -1 ,timeup 
+
+unsign1:
+722d e8c08000 ifetch 1 ,contr 
+722e 1a20a3ff increase -1 ,rega 
+722f 196097ff increase -1 ,timeup 
+
+rduuid3:
+7230 196097ff increase -1 ,timeup 
+7231 1a20a3ff increase -1 ,rega 
+7232 20217230 branch rduuid3 ,positive 
+7233 19609601 increase 1 ,timeup 
+7234 18007e01 force 0x01 ,pdata 
+7235 20600000 rtn ,
+
+rdnortn:
+7236 18007e00 force 0x00 ,pdata 
+7237 20600000 rtn ,
+
+sdp_invalid_service_record_handle:
+7238 58000200 setarg 0x0200 
+7239 600104b6 store 2 ,mem_sdp_error_code 
+723a 20207243 branch sdp_error_rsp 
+
+sdp_invalid_pdu_size:
+723b 58000400 setarg 0x0400 
+723c 600104b6 store 2 ,mem_sdp_error_code 
+723d 20207243 branch sdp_error_rsp 
+
+sdp_insufficient_resource:
+723e 58000600 setarg 0x0600 
+723f 600104b6 store 2 ,mem_sdp_error_code 
+7240 20207243 branch sdp_error_rsp 
+
+sdp_invalid_reqest_syntax:
+7241 58000300 setarg 0x0300 
+7242 600104b6 store 2 ,mem_sdp_error_code 
+
+sdp_error_rsp:
+7243 204052de call l2cap_get_sdp_tx_payload 
+7244 e0a08000 istore 1 ,contw 
+7245 680104b0 fetch 2 ,mem_sdp_transactionid 
+7246 e0a10000 istore 2 ,contw 
+7247 58000200 setarg 0x0200 
+7248 e0a10000 istore 2 ,contw 
+7249 680104b6 fetch 2 ,mem_sdp_error_code 
+724a e0a10000 istore 2 ,contw 
+724b 7002dc07 jam 7 ,mem_sdp_tx_pkt_length 
+724c 20600000 rtn 
+
+ask_serviceclassid:
+724d 18000400 force 0 ,temp 
+724e d8a004a9 arg mem_uuid_search_pat ,contw 
+724f 204072a4 call dataelementtype6 
+7250 2022f2a2 branch asksrv_error ,zero 
+
+classidloop:
+7251 e8c08000 ifetch 1 ,contr 
+7252 1a20a3ff increase -1 ,rega 
+7253 196097ff increase -1 ,timeup 
+7254 2fe1f018 compare 0x18 ,pdata ,0xf8 
+7255 2420f2a2 nbranch asksrv_error ,true 
+7256 2fe00e04 compare 0x04 ,pdata ,0x07 
+7257 2420f26e nbranch cmp032 ,true 
+7258 18000401 force 1 ,temp 
+
+skip2bytes:
+7259 e8c08000 ifetch 1 ,contr 
+725a 1a20a3ff increase -1 ,rega 
+725b 196097ff increase -1 ,timeup 
+725c c0807262 bne 0x00 ,frstbwrong 
+725d e8c08000 ifetch 1 ,contr 
+725e 1a20a3ff increase -1 ,rega 
+725f 196097ff increase -1 ,timeup 
+7260 c0007273 beq 0x00 ,cmpuuid 
+7261 20207265 branch scndbwrong 
+
+frstbwrong:
+7262 18c08c01 increase 1 ,contr 
+7263 1a20a3ff increase -1 ,rega 
+7264 196097ff increase -1 ,timeup 
+
+scndbwrong:
+7265 18c08c02 increase 2 ,contr 
+7266 1a20a3fe increase -2 ,rega 
+7267 196097fe increase -2 ,timeup 
+7268 2841fe00 compare 0x00 ,temp ,0xff 
+7269 2020f29d branch loopornot ,true 
+726a 18c08c0c increase 12 ,contr 
+726b 1a20a3f4 increase -12 ,rega 
+726c 196097f4 increase -12 ,timeup 
+726d 2020729d branch loopornot 
+
+cmp032:
+726e 2fe00e02 compare 0x02 ,pdata ,0x07 
+726f 2420f271 nbranch cmp016 ,true 
+7270 20207259 branch skip2bytes 
+
+cmp016:
+7271 2fe00e01 compare 0x01 ,pdata ,0x07 
+7272 2420f2a2 nbranch asksrv_error ,true 
+
+cmpuuid:
+7273 e8c10000 ifetch 2 ,contr 
+7274 1a20a3fe increase -2 ,rega 
+7275 196097fe increase -2 ,timeup 
+7276 e0a10000 istore 2 ,contw 
+
+uuidsize:
+7277 2841fe00 compare 0x00 ,temp ,0xff 
+7278 2020f29d branch loopornot ,true 
+7279 18c20400 copy contr ,temp 
+727a e8c08000 ifetch 1 ,contr 
+727b c0807292 bne 0x00 ,wrong12b 
+727c e8c08000 ifetch 1 ,contr 
+727d c0807292 bne 0x00 ,wrong12b 
+727e e8c08000 ifetch 1 ,contr 
+727f c0887292 bne 0x10 ,wrong12b 
+7280 e8c08000 ifetch 1 ,contr 
+7281 c0807292 bne 0x00 ,wrong12b 
+7282 e8c08000 ifetch 1 ,contr 
+7283 c0c07292 bne 0x80 ,wrong12b 
+7284 e8c08000 ifetch 1 ,contr 
+7285 c0807292 bne 0x00 ,wrong12b 
+7286 e8c08000 ifetch 1 ,contr 
+7287 c0807292 bne 0x00 ,wrong12b 
+7288 e8c08000 ifetch 1 ,contr 
+7289 c0c07292 bne 0x80 ,wrong12b 
+728a e8c08000 ifetch 1 ,contr 
+728b c0aff292 bne 0x5f ,wrong12b 
+728c e8c08000 ifetch 1 ,contr 
+728d c0cdf292 bne 0x9b ,wrong12b 
+728e e8c08000 ifetch 1 ,contr 
+728f c09a7292 bne 0x34 ,wrong12b 
+7290 e8c08000 ifetch 1 ,contr 
+7291 c07df29b beq 0xfb ,chck12dn 
+
+wrong12b:
+7292 18420c00 copy temp ,contr 
+
+wrong12b1:
+7293 18c08c0c increase 12 ,contr 
+7294 18000e00 force 0x00 ,queue 
+7295 18000400 force 0x00 ,temp 
+7296 2020729b branch chck12dn 
+
+noclass:
+7297 e8c08000 ifetch 1 ,contr 
+7298 1a20a3ff increase -1 ,rega 
+7299 196097ff increase -1 ,timeup 
+729a 20207277 branch uuidsize 
+
+chck12dn:
+729b 196097f4 increase -12 ,timeup 
+729c 1a20a3f4 increase -12 ,rega 
+
+loopornot:
+729d 2a21fe00 compare 0x00 ,rega ,0xff 
+729e 2420f251 nbranch classidloop ,true 
+729f 18007e00 force 0 ,pdata 
+72a0 e0a10000 istore 2 ,contw 
+72a1 20600000 rtn ,
+
+asksrv_error:
+72a2 d84000ff arg 0xff ,temp 
+72a3 20600000 rtn 
+
+dataelementtype6:
+72a4 e8c08000 ifetch 1 ,contr 
+72a5 196097ff increase -1 ,timeup 
+72a6 2fe1f030 compare 0x30 ,pdata ,0xf8 
+72a7 2420f2b9 nbranch dsize_error ,true 
+72a8 2fe00e07 compare 0x07 ,pdata ,0x07 
+72a9 2020f2b2 branch dsize32 ,true 
+72aa 2fe00e06 compare 0x06 ,pdata ,0x07 
+72ab 2020f2b4 branch dsize16 ,true 
+72ac 2fe00e05 compare 0x05 ,pdata ,0x07 
+72ad 2420f2b9 nbranch dsize_error ,true 
+72ae e8c08000 ifetch 1 ,contr 
+72af 1fe22200 copy pdata ,rega 
+72b0 196097ff increase -1 ,timeup 
+72b1 202072b7 branch dsize 
+
+dsize32:
+72b2 18c08c02 increase 2 ,contr 
+72b3 196097fe increase -2 ,timeup 
+
+dsize16:
+72b4 e8c10000 ifetch 2 ,contr 
+72b5 1ff0a200 byteswap pdata ,rega 
+72b6 196097fe increase -2 ,timeup 
+
+set_nblank:
+
+dsize:
+72b7 18007e01 force 0x01 ,pdata 
+72b8 20600000 rtn 
+
+set_blank:
+
+dsize_error:
+72b9 18007e00 force 0x00 ,pdata 
+72ba 20600000 rtn 
+
+empth_sa_rsp:
+72bb 58000003 setarg 0x03 
+72bc 600084af store 1 ,mem_sdp_pduid 
+72bd 202072c0 branch empty_response 
+
+empty_ssa_rsp:
+72be 58000007 setarg 0x07 
+72bf 600084af store 1 ,mem_sdp_pduid 
+
+empty_response:
+72c0 204052de call l2cap_get_sdp_tx_payload 
+72c1 680084af fetch 1 ,mem_sdp_pduid 
+72c2 e0a08000 istore 1 ,contw 
+72c3 1fe22400 copy pdata ,regb 
+72c4 680104b0 fetch 2 ,mem_sdp_transactionid 
+72c5 e0a10000 istore 2 ,contw 
+72c6 58000500 setarg 0x0500 
+72c7 e0a10000 istore 2 ,contw 
+72c8 2a41fe05 compare 0x05 ,regb ,0xff 
+72c9 2020f2d0 branch fullsearch ,true 
+72ca 2a41fe07 compare 0x07 ,regb ,0xff 
+72cb 2020f2d0 branch fullsearch ,true 
+72cc 58000000 setarg 0x000000 
+72cd e0a18000 istore 3 ,contw 
+72ce e0a10000 istore 2 ,contw 
+72cf 202072d4 branch outempty 
+
+fullsearch:
+72d0 58350200 setarg 0x350200 
+72d1 e0a18000 istore 3 ,contw 
+72d2 58000000 setarg 0 
+72d3 e0a10000 istore 2 ,contw 
+
+outempty:
+72d4 7002dc0a jam 10 ,mem_sdp_tx_pkt_length 
+72d5 20600000 rtn 
+
+sdp_data_len:
+72d6 18c21600 copy contr ,timeup 
+72d7 e8c08000 ifetch 1 ,contr 
+72d8 1fe17207 and pdata ,0x7 ,loopcnt 
+72d9 1fe97e00 rshift3 pdata ,pdata 
+72da c00372e5 beq 6 ,sdp_data_len_6 
+72db c000f2e0 beq 1 ,sdp_data_len_1 
+72dc c00272e5 beq 4 ,sdp_data_len_6 
+72dd c002f2e3 beq 5 ,sdp_data_len_5 
+
+sdp_data_len_rtn:
+72de 19620c00 copy timeup ,contr 
+72df 20600000 rtn 
+
+sdp_data_len_1:
+72e0 20407301 call sdp_data_size 
+72e1 1fe0fe01 increase 1 ,pdata 
+72e2 202072de branch sdp_data_len_rtn 
+
+sdp_data_len_5:
+72e3 18007e02 force 2 ,pdata 
+72e4 202072de branch sdp_data_len_rtn 
+
+sdp_data_len_6:
+72e5 204072f7 call sdp_get_data_6 
+72e6 1fe0fe02 increase 2 ,pdata 
+72e7 202072de branch sdp_data_len_rtn 
+
+sdp_get_data:
+72e8 e8c08000 ifetch 1 ,contr 
+72e9 1fe17207 and pdata ,0x7 ,loopcnt 
+72ea 1fe97e00 rshift3 pdata ,pdata 
+72eb c00372f7 beq 6 ,sdp_get_data_6 
+72ec c000f2ef beq 1 ,sdp_get_data_1 
+72ed c002f2fc beq 5 ,sdp_get_data_6_8bit 
+72ee 20600000 rtn 
+
+sdp_get_data_1:
+72ef 20407301 call sdp_data_size 
+72f0 98007200 iforce loopcnt 
+72f1 18000400 force 0 ,temp 
+
+sdp_get_data_1_loop:
+72f2 184d0400 lshift8 temp ,temp 
+72f3 e8c08000 ifetch 1 ,contr 
+72f4 98418400 ior temp ,temp 
+72f5 c20072f2 loop sdp_get_data_1_loop 
+72f6 20600000 rtn 
+
+sdp_get_data_6:
+72f7 1f227e00 deposit loopcnt 
+72f8 c002f2fc beq 5 ,sdp_get_data_6_8bit 
+72f9 c00372fe beq 6 ,sdp_get_data_6_16bit 
+72fa 18007203 force 3 ,loopcnt 
+72fb 202072ef branch sdp_get_data_1 
+
+sdp_get_data_6_8bit:
+72fc e8c08000 ifetch 1 ,contr 
+72fd 20600000 rtn 
+
+sdp_get_data_6_16bit:
+72fe e8c10000 ifetch 2 ,contr 
+72ff 1ff0fe00 byteswap pdata ,pdata 
+7300 20600000 rtn 
+
+sdp_data_size:
+7301 18007e01 force 1 ,pdata 
+7302 1f227c00 copy loopcnt ,null 
+7303 20628000 rtn zero 
+
+sdp_data_size_loop:
+7304 1fe3fe00 lshift pdata ,pdata 
+7305 c2007304 loop sdp_data_size_loop 
+7306 20600000 rtn 
+
+search_uuid:
+7307 98002600 iforce regc 
+7308 79200025 set1 mark_ext_patch ,mark 
+7309 44f4c03d bpatch patch3d_1 ,mem_patch3d 
+730a 18000e00 force 0 ,queue 
+730b 68014759 fetch 2 ,memui_uuid_table 
+730c 98000c00 iforce contr 
+730d d8a004c5 arg mem_handle_list ,contw 
+
+search_uuid_next:
+730e 78547c00 disable user 
+730f e8c08000 ifetch 1 ,contr 
+7310 207a0000 rtn blank 
+7311 98007200 iforce loopcnt 
+
+search_uuid_loop:
+7312 e8c10000 ifetch 2 ,contr 
+7313 9a667c00 isub regc ,null 
+7314 2422f316 nbranch search_uuid_not_found ,zero 
+7315 78347c00 enable user 
+
+search_uuid_not_found:
+7316 c2007312 loop search_uuid_loop 
+7317 e8c20000 ifetch 4 ,contr 
+7318 2434731b nbranch search_uuid_nomatch ,user 
+7319 e0a20000 istore 4 ,contw 
+731a 18e08e01 increase 1 ,queue 
+
+search_uuid_nomatch:
+731b 204072e8 call sdp_get_data 
+731c 98c08c00 iadd contr ,contr 
+731d 2020730e branch search_uuid_next 
+
+search_handle:
+731e 68014759 fetch 2 ,memui_uuid_table 
+731f 98000c00 iforce contr 
+
+search_handle_loop:
+7320 e8c08000 ifetch 1 ,contr 
+7321 207a0000 rtn blank 
+7322 1fe3fe00 lshift pdata ,pdata 
+7323 98c08c00 iadd contr ,contr 
+7324 e8c20000 ifetch 4 ,contr 
+7325 98467c00 isub temp ,null 
+7326 20628000 rtn zero 
+7327 204072e8 call sdp_get_data 
+7328 98c08c00 iadd contr ,contr 
+7329 20207320 branch search_handle_loop 
+
+search_attrib:
+732a 79200025 set1 mark_ext_patch ,mark 
+732b 44f5403d bpatch patch3d_2 ,mem_patch3d 
+732c 68014759 fetch 2 ,memui_uuid_table 
+732d 98000c00 iforce contr 
+
+search_attrib_next:
+732e e8c08000 ifetch 1 ,contr 
+732f 203a734b branch search_attrib_end ,blank 
+7330 98007200 iforce loopcnt 
+
+search_attrib_loop:
+7331 e8c10000 ifetch 2 ,contr 
+7332 9a667c00 isub regc ,null 
+7333 2022f339 branch search_attrib_found_uuid ,zero 
+7334 c2007331 loop search_attrib_loop 
+7335 18c08c04 increase 4 ,contr 
+7336 204072e8 call sdp_get_data 
+7337 98c08c00 iadd contr ,contr 
+7338 2020732e branch search_attrib_next 
+
+search_attrib_found_uuid:
+7339 1f20f3ff increase -1 ,loopcnt 
+733a 1f23fe00 lshift loopcnt ,pdata 
+733b 98c08c00 iadd contr ,contr 
+733c 18c08c04 increase 4 ,contr 
+733d 204072e8 call sdp_get_data 
+733e 98c08400 iadd contr ,temp 
+
+search_attrib_loop_attribs:
+733f 18c08c01 increase 1 ,contr 
+7340 e8c10000 ifetch 2 ,contr 
+7341 9a461600 isub regb ,timeup 
+7342 7922fe00 setflag zero ,0 ,pdata 
+7343 19621600 copy timeup ,timeup 
+7344 20628000 rtn zero 
+7345 204072d6 call sdp_data_len 
+7346 98c08c00 iadd contr ,contr 
+7347 18427e00 deposit temp 
+7348 98c67c00 isub contr ,null 
+7349 2022f34b branch search_attrib_end ,zero 
+734a 2020733f branch search_attrib_loop_attribs 
+
+search_attrib_end:
+734b 18000c00 force 0 ,contr 
+734c 18007e00 force 0 ,pdata 
+734d 20600000 rtn 
+
+search_handle_attrib:
+734e 79200025 set1 mark_ext_patch ,mark 
+734f 44f5c03d bpatch patch3d_3 ,mem_patch3d 
+7350 68014759 fetch 2 ,memui_uuid_table 
+7351 98000c00 iforce contr 
+
+search_handle_attrib_next:
+7352 e8c08000 ifetch 1 ,contr 
+7353 203a7368 branch search_handle_attrib_end ,blank 
+7354 1fe3fe00 lshift pdata ,pdata 
+7355 98c08c00 iadd contr ,contr 
+7356 e8c20000 ifetch 4 ,contr 
+7357 98467c00 isub temp ,null 
+7358 2022f35c branch search_handl_attrib_found_handle ,zero 
+7359 204072e8 call sdp_get_data 
+735a 98c08c00 iadd contr ,contr 
+735b 20207352 branch search_handle_attrib_next 
+
+search_handl_attrib_found_handle:
+735c 204072e8 call sdp_get_data 
+735d 98c08400 iadd contr ,temp 
+
+search_handle_attrib_loop_attribs:
+735e 18c08c01 increase 1 ,contr 
+735f e8c10000 ifetch 2 ,contr 
+7360 9a467c00 isub regb ,null 
+7361 20628000 rtn zero 
+7362 204072d6 call sdp_data_len 
+7363 98c08c00 iadd contr ,contr 
+7364 18427e00 deposit temp 
+7365 98c67c00 isub contr ,null 
+7366 2022f368 branch search_handle_attrib_end ,zero 
+7367 2020735e branch search_handle_attrib_loop_attribs 
+
+search_handle_attrib_end:
+7368 18000c00 force 0 ,contr 
+7369 20600000 rtn 
+
+generate_kinit:
+736a 2040737d call function_e22 
+736b d8c0051f arg mem_input_store ,contr 
+736c d8a0050f arg mem_kinit ,contw 
+736d 20207e35 branch memcpy16 
+
+function_e21:
+736e 78547c00 disable user 
+736f 20407474 call function_expand 
+7370 d8c004ef arg mem_random_number ,contr 
+7371 d8a0052f arg mem_x ,contw 
+7372 1800720f force 15 ,loopcnt 
+7373 20407e45 call memcpy 
+7374 e8c08000 ifetch 1 ,contr 
+7375 1fe2fe06 xor_into 6 ,pdata 
+7376 e0a08000 istore 1 ,contw 
+7377 5800053f setarg mem_y 
+7378 60010574 store 2 ,memp_ar_input 
+7379 5800052f setarg mem_x 
+737a 60010572 store 2 ,memp_ar_key 
+737b 79200012 set1 mark_ar2 ,mark 
+737c 202073bd branch function_ar 
+
+function_e22:
+737d 6808854f fetcht 1 ,mem_pin_length 
+737e 18002410 force 16 ,regb 
+737f 1840a606 add temp ,6 ,regc 
+7380 1a667c10 sub regc ,16 ,null 
+7381 20217383 branch function_e22_pin_init ,positive 
+7382 18002610 force 16 ,regc 
+
+function_e22_pin_init:
+7383 d8a0052f arg mem_x ,contw 
+
+function_e22_genx_pin:
+7384 d8c00550 arg mem_pin ,contr 
+7385 18427200 copy temp ,loopcnt 
+7386 78547c00 disable user 
+
+function_e22_genx_loop:
+7387 e8c08000 ifetch 1 ,contr 
+7388 e0a08000 istore 1 ,contw 
+7389 1a40a5ff increase -1 ,regb 
+738a 2022f391 branch function_e22_genx_end ,zero 
+738b c2007387 loop function_e22_genx_loop 
+738c 20347384 branch function_e22_genx_pin ,user 
+738d 78347c00 enable user 
+738e 18007206 force 6 ,loopcnt 
+738f 1a220c00 copy rega ,contr 
+7390 20207387 branch function_e22_genx_loop 
+
+function_e22_genx_end:
+7391 d8c004ef arg mem_random_number ,contr 
+7392 d8a0053f arg mem_y ,contw 
+7393 20407e35 call memcpy16 
+7394 6800854e fetch 1 ,mem_y15 
+7395 9a62fe00 ixor regc ,pdata 
+7396 6000854e store 1 ,mem_y15 
+7397 5800053f setarg mem_y 
+7398 60010574 store 2 ,memp_ar_input 
+7399 5800052f setarg mem_x 
+739a 60010572 store 2 ,memp_ar_key 
+739b 79200012 set1 mark_ar2 ,mark 
+739c 202073bd branch function_ar 
+
+function_e1:
+739d 78547c00 disable user 
+739e 20407474 call function_expand 
+739f 202073a7 branch function_hash 
+
+function_e3:
+73a0 da200056 arg mem_aco ,rega 
+73a1 78347c00 enable user 
+73a2 20407474 call function_expand 
+73a3 204073a7 call function_hash 
+73a4 d8c0051f arg mem_input_store ,contr 
+73a5 d8a00062 arg mem_kc ,contw 
+73a6 20207e35 branch memcpy16 
+
+function_hash:
+73a7 580004ef setarg mem_random_number 
+73a8 60010574 store 2 ,memp_ar_input 
+73a9 58004262 setarg mem_link_key 
+73aa 60010572 store 2 ,memp_ar_key 
+73ab 793f8012 set0 mark_ar2 ,mark 
+73ac 204073bd call function_ar 
+73ad da20051f arg mem_input_store ,rega 
+73ae da4004ef arg mem_random_number ,regb 
+73af d8a0052f arg mem_x ,contw 
+73b0 20407467 call xor16 
+73b1 da20052f arg mem_x ,rega 
+73b2 da40053f arg mem_y ,regb 
+73b3 1a420a00 copy regb ,contw 
+73b4 78347c00 enable user 
+73b5 20407465 call add16 
+73b6 2040747f call key_offset 
+73b7 5800053f setarg mem_y 
+73b8 60010574 store 2 ,memp_ar_input 
+73b9 5800052f setarg mem_x 
+73ba 60010572 store 2 ,memp_ar_key 
+73bb 79200012 set1 mark_ar2 ,mark 
+73bc 202073bd branch function_ar 
+
+function_ar:
+73bd 70057600 jam 0 ,mem_ar_hround 
+73be 68010572 fetch 2 ,memp_ar_key 
+73bf 98000c00 iforce contr 
+73c0 d8a00560 arg mem_key_store ,contw 
+73c1 20407e35 call memcpy16 
+73c2 68010574 fetch 2 ,memp_ar_input 
+73c3 98000c00 iforce contr 
+73c4 d8a0051f arg mem_input_store ,contw 
+73c5 20407e35 call memcpy16 
+
+function_ar_loop:
+73c6 204073e4 call key_scheduling 
+73c7 78547c00 disable user 
+73c8 c58973ce bmark0 mark_ar2 ,function_ar_original 
+73c9 68008576 fetch 1 ,mem_ar_hround 
+73ca c08273ce bne 4 ,function_ar_original 
+73cb 68010574 fetch 2 ,memp_ar_input 
+73cc 98002400 iforce regb 
+73cd 20407416 call xor_mod32_ar2 
+
+function_ar_original:
+73ce 20407415 call xor_mod32 
+73cf 20407428 call el_boxes 
+73d0 68008576 fetch 1 ,mem_ar_hround 
+73d1 1fe0fe01 increase 1 ,pdata 
+73d2 60008576 store 1 ,mem_ar_hround 
+73d3 204073e4 call key_scheduling 
+73d4 78347c00 enable user 
+73d5 20407415 call xor_mod32 
+73d6 20407437 call pht 
+73d7 20407446 call permute 
+73d8 20407437 call pht 
+73d9 20407446 call permute 
+73da 20407437 call pht 
+73db 20407446 call permute 
+73dc 20407437 call pht 
+73dd 68008576 fetch 1 ,mem_ar_hround 
+73de 1fe0fe01 increase 1 ,pdata 
+73df 60008576 store 1 ,mem_ar_hround 
+73e0 c08873c6 bne 16 ,function_ar_loop 
+73e1 204073e4 call key_scheduling 
+73e2 78547c00 disable user 
+73e3 20207415 branch xor_mod32 
+
+key_scheduling:
+73e4 68008576 fetch 1 ,mem_ar_hround 
+73e5 d8c00560 arg mem_key_store ,contr 
+73e6 203a740b branch key_sched_zero ,blank 
+73e7 98002400 iforce regb 
+73e8 18007211 force 17 ,loopcnt 
+73e9 18c20a00 copy contr ,contw 
+
+key_rotateloop:
+73ea e8c08000 ifetch 1 ,contr 
+73eb 1fe98400 lshift3 pdata ,temp 
+73ec 1feb7e00 rshift2 pdata ,pdata 
+73ed 1fe97e00 rshift3 pdata ,pdata 
+73ee 9841fe00 ior temp ,pdata 
+73ef e0a08000 istore 1 ,contw 
+73f0 c20073ea loop key_rotateloop 
+73f1 58000560 setarg mem_key_store 
+73f2 9a408c00 iadd regb ,contr 
+73f3 18007210 force 16 ,loopcnt 
+73f4 d8a004ff arg mem_round_key ,contw 
+
+key_select_octet_loop:
+73f5 e8c08000 ifetch 1 ,contr 
+73f6 e0a08000 istore 1 ,contw 
+73f7 28c1ff71 compare mem_key_store_end ,contr ,0xff 
+73f8 2420f3fa nbranch key_select_octet_nwrap ,true 
+73f9 18c08def increase -17 ,contr 
+
+key_select_octet_nwrap:
+73fa c20073f5 loop key_select_octet_loop 
+73fb 18002200 force 0 ,rega 
+73fc 1a40a7ff add regb ,-1 ,regc 
+73fd 1a6ba600 lshift2 regc ,regc 
+73fe 1a6ba600 lshift2 regc ,regc 
+73ff 204075c5 call enable_authrom 
+7400 58008400 setarg mem_b_box 
+7401 9a60a600 iadd regc ,regc 
+7402 d8a004ff arg mem_round_key ,contw 
+7403 18007210 force 16 ,loopcnt 
+
+bias_round_key_loop:
+7404 ea688000 ifetcht 1 ,regc 
+7405 e8a08000 ifetch 1 ,contw 
+7406 9840fe00 iadd temp ,pdata 
+7407 e0a08000 istore 1 ,contw 
+7408 1a60a601 increase 1 ,regc 
+7409 c2007404 loop bias_round_key_loop 
+740a 202075c9 branch disable_authrom 
+
+key_sched_zero:
+740b 18007210 force 16 ,loopcnt 
+740c 18000400 force 0 ,temp 
+
+create_byte_16_loop:
+740d e8c08000 ifetch 1 ,contr 
+740e 98428400 ixor temp ,temp 
+740f c200740d loop create_byte_16_loop 
+7410 18427e00 deposit temp 
+7411 e0c08000 istore 1 ,contr 
+7412 d8c00560 arg mem_key_store ,contr 
+7413 d8a004ff arg mem_round_key ,contw 
+7414 20207e35 branch memcpy16 
+
+xor_mod32:
+7415 da4004ff arg mem_round_key ,regb 
+
+xor_mod32_ar2:
+7416 18007210 force 16 ,loopcnt 
+7417 da20051f arg mem_input_store ,rega 
+7418 1a220a00 copy rega ,contw 
+
+xor_mod32_loop:
+7419 ea288000 ifetcht 1 ,rega 
+741a ea408000 ifetch 1 ,regb 
+741b 9842e000 ixor temp ,alarm 
+741c 1f212603 and loopcnt ,3 ,regc 
+741d 2434741f nbranch xor_mod32_invert ,user 
+741e 1a62a603 xor_into 3 ,regc 
+
+xor_mod32_invert:
+741f 1a662601 sub regc ,1 ,regc 
+7420 20217422 branch xor_even ,positive 
+7421 9840e000 iadd temp ,alarm 
+
+xor_even:
+7422 1e027e00 deposit alarm 
+7423 e0a08000 istore 1 ,contw 
+7424 1a20a201 increase 1 ,rega 
+7425 1a40a401 increase 1 ,regb 
+7426 c2007419 loop xor_mod32_loop 
+7427 20600000 rtn 
+
+el_boxes:
+7428 204075c5 call enable_authrom 
+7429 18007210 force 16 ,loopcnt 
+742a da20051f arg mem_input_store ,rega 
+
+el_box_loop:
+742b ea208000 ifetch 1 ,rega 
+742c d8c08500 arg mem_e_box ,contr 
+742d 1f212603 and loopcnt ,3 ,regc 
+742e 1a667c01 sub regc ,1 ,null 
+742f 20217431 branch e_boxes ,positive 
+7430 d8c08600 arg mem_l_box ,contr 
+
+e_boxes:
+7431 98c08c00 iadd contr ,contr 
+7432 e8c08000 ifetch 1 ,contr 
+7433 e2208000 istore 1 ,rega 
+7434 1a20a201 increase 1 ,rega 
+7435 c200742b loop el_box_loop 
+7436 202075c9 branch disable_authrom 
+
+pht:
+7437 18007208 force 8 ,loopcnt 
+7438 d8c0051f arg mem_input_store ,contr 
+7439 18c20a00 copy contr ,contw 
+
+pht_loop:
+743a e8c08000 ifetch 1 ,contr 
+743b 98002200 iforce rega 
+743c e8c08000 ifetch 1 ,contr 
+743d 98002400 iforce regb 
+743e 1a23fe00 lshift rega ,pdata 
+743f 9a40fe00 iadd regb ,pdata 
+7440 e0a08000 istore 1 ,contw 
+7441 1a227e00 deposit rega 
+7442 9a40fe00 iadd regb ,pdata 
+7443 e0a08000 istore 1 ,contw 
+7444 c200743a loop pht_loop 
+7445 20600000 rtn 
+
+permute:
+7446 588ae42c setarg 0x8ae42c 
+7447 98000400 iforce temp 
+7448 18007207 force 7 ,loopcnt 
+7449 20407455 call permute_exchange 
+744a 580d751b setarg 0xd751b 
+744b 98000400 iforce temp 
+744c 18007205 force 5 ,loopcnt 
+744d 20407455 call permute_exchange 
+744e 6800852e fetch 1 ,mem_input_store + 15 
+744f 98002200 iforce rega 
+7450 68008522 fetch 1 ,mem_input_store + 3 
+7451 6000852e store 1 ,mem_input_store + 15 
+7452 1a227e00 deposit rega 
+7453 60008522 store 1 ,mem_input_store + 3 
+7454 20600000 rtn 
+
+permute_exchange:
+7455 1841240f and temp ,0xf ,regb 
+
+permute_loop:
+7456 18417e0f and temp ,0xf ,pdata 
+7457 d8a0051f arg mem_input_store ,contw 
+7458 98a08a00 iadd contw ,contw 
+7459 e8a08000 ifetch 1 ,contw 
+745a 98002600 iforce regc 
+745b 1a227e00 deposit rega 
+745c e0a08000 istore 1 ,contw 
+745d 1a622200 copy regc ,rega 
+745e 18518400 rshift4 temp ,temp 
+745f c2007456 loop permute_loop 
+7460 5800051f setarg mem_input_store 
+7461 9a408a00 iadd regb ,contw 
+7462 1a227e00 deposit rega 
+7463 e0a08000 istore 1 ,contw 
+7464 20600000 rtn 
+
+add16:
+7465 78347c00 enable user 
+7466 20207468 branch xor_add16 
+
+xor16:
+7467 78547c00 disable user 
+
+xor_add16:
+7468 18007210 force 16 ,loopcnt 
+
+xoradd_loop:
+7469 ea288000 ifetcht 1 ,rega 
+746a ea408000 ifetch 1 ,regb 
+746b 2034746e branch xoradd_add ,user 
+746c 9842fe00 ixor temp ,pdata 
+746d 2020746f branch xoradd_store 
+
+xoradd_add:
+746e 9840fe00 iadd temp ,pdata 
+
+xoradd_store:
+746f e0a08000 istore 1 ,contw 
+7470 1a20a201 increase 1 ,rega 
+7471 1a40a401 increase 1 ,regb 
+7472 c2007469 loop xoradd_loop 
+7473 20600000 rtn 
+
+function_expand:
+7474 d8a0053f arg mem_y ,contw 
+7475 ea230000 ifetch 6 ,rega 
+7476 e0a30000 istore 6 ,contw 
+7477 2034747a branch expand_12 ,user 
+7478 ea230000 ifetch 6 ,rega 
+7479 2020747b branch expand_cont 
+
+expand_12:
+747a e8c30000 ifetch 6 ,contr 
+
+expand_cont:
+747b e0a30000 istore 6 ,contw 
+747c ea220000 ifetch 4 ,rega 
+747d e0a20000 istore 4 ,contw 
+747e 20600000 rtn 
+
+key_offset:
+747f d8c04262 arg mem_link_key ,contr 
+7480 d8a0052f arg mem_x ,contw 
+7481 d8400000 arg 0 ,temp 
+7482 588395a7 setarg 0x8395a7 
+7483 204074a0 call concatenate_temp24 
+7484 58b3c1df setarg 0xb3c1df 
+7485 204074a0 call concatenate_temp24 
+7486 5800e5e9 setarg 0xe5e9 
+7487 204074a1 call concatenate_temp16 
+7488 18422800 copy temp ,regab 
+7489 78547c00 disable user 
+748a 2040748e call key_addxor 
+748b 1a820400 copy regab ,temp 
+748c 78347c00 enable user 
+748d 2020748e branch key_addxor 
+
+key_addxor:
+748e 18007208 force 8 ,loopcnt 
+
+key_addxor_loop:
+748f e8c08000 ifetch 1 ,contr 
+7490 2f200201 compare 1 ,loopcnt ,1 
+7491 20347495 branch key_high ,user 
+7492 2020f496 branch key_xor ,true 
+
+key_add:
+7493 9840fe00 iadd temp ,pdata 
+7494 20207497 branch key_store 
+
+key_high:
+7495 2020f493 branch key_add ,true 
+
+key_xor:
+7496 9842fe00 ixor temp ,pdata 
+
+key_store:
+7497 e0a08000 istore 1 ,contw 
+7498 184c8400 rshift8 temp ,temp 
+7499 c200748f loop key_addxor_loop 
+749a 20600000 rtn 
+
+copy_aco:
+749b 68030523 fetch 6 ,mem_input_store + 4 
+749c 60030056 store 6 ,mem_aco 
+749d e8c30000 ifetch 6 ,contr 
+749e e0a30000 istore 6 ,contw 
+749f 20600000 rtn 
+
+concatenate_temp24:
+74a0 184d0400 lshift8 temp ,temp 
+
+concatenate_temp16:
+74a1 18500400 lshift16 temp ,temp 
+74a2 98418400 ior temp ,temp 
+74a3 20600000 rtn 
+
+loop1:
+74a4 202074a4 branch loop1 
+
+generate_stk:
+74a5 20407540 call function_s1 
+74a6 d8a0447b arg mem_le_ltk ,contw 
+74a7 202075a3 branch store_aes_result 
+
+authenticate_rconfirm:
+74a8 d8a0449c arg mem_le_srand ,contw 
+74a9 2034f4ab branch authenticate_mconfirm ,master 
+74aa d8a003b0 arg mem_le_mrand ,contw 
+
+authenticate_mconfirm:
+74ab 18c22200 copy contr ,rega 
+74ac 20407e35 call memcpy16 
+74ad 20407551 call function_c1 
+74ae d8c0448c arg mem_le_rconfirm ,contr 
+74af 202075bc branch compare_res 
+
+generate_confirm:
+74b0 da2003b0 arg mem_le_mrand ,rega 
+74b1 2034f4b3 branch generate_mrand ,master 
+74b2 da20449c arg mem_le_srand ,rega 
+
+generate_mrand:
+74b3 1a220a00 copy rega ,contw 
+74b4 20406226 call generate_random 
+74b5 20207551 branch function_c1 
+
+generate_sk:
+74b6 d8c00380 arg mem_le_skdm ,contr 
+74b7 20407592 call load_data128 
+74b8 d8c0447b arg mem_le_ltk ,contr 
+74b9 20407593 call load_regext 
+74ba 18006c38 force 0x38 ,aes_ctrl 
+74bb 18006c00 force 0x0 ,aes_ctrl 
+74bc 2040752f call wait_aes 
+74bd d8a003fd arg mem_le_sk ,contw 
+74be 202075a3 branch store_aes_result 
+
+first_block_counter:
+74bf 18007e49 force 0x49 ,pdata 
+74c0 202074c2 branch first_block 
+
+first_block_data:
+74c1 18007e01 force 1 ,pdata 
+
+first_block:
+74c2 18007000 force regidx_data ,regext_index 
+74c3 184d5e00 lshift8 temp ,regext 
+74c4 9de1de00 ior regext ,regext 
+74c5 1f00f001 increase 1 ,regext_index 
+74c6 184cde00 rshift8 temp ,regext 
+74c7 1df15e00 rshift16 regext ,regext 
+74c8 68014473 fetch 2 ,mem_le_ivm 
+74c9 1ff07e00 lshift16 ,pdata ,pdata 
+74ca 9de1de00 ior regext ,regext 
+74cb 1f00f001 increase 1 ,regext_index 
+74cc e8c20000 ifetch 4 ,contr 
+74cd 98005e00 iforce regext 
+74ce 1f00f001 increase 1 ,regext_index 
+74cf e8c10000 ifetch 2 ,contr 
+74d0 1a30de00 byteswap rega ,regext 
+74d1 1df05e00 lshift16 regext ,regext 
+74d2 9de1de00 ior regext ,regext 
+74d3 1f00f001 increase 1 ,regext_index 
+74d4 20600000 rtn 
+
+generate_mic:
+74d5 1a608c01 add regc ,1 ,contr 
+74d6 e8c08000 ifetch 1 ,contr 
+74d7 98002200 iforce rega 
+74d8 204074bf call first_block_counter 
+74d9 20407531 call do_aes_ocb 
+74da 18007000 force regidx_data ,regext_index 
+74db ea608000 ifetch 1 ,regc 
+74dc 1fe17e03 and_into 0x3 ,pdata 
+74dd 1ff05e00 lshift16 pdata ,regext 
+74de 79205e08 set1 8 ,regext 
+74df 2040759b call clear_hidata 
+74e0 20407534 call do_aes_cbc 
+74e1 1a227200 copy rega ,loopcnt 
+74e2 1a608c02 add regc ,2 ,contr 
+74e3 2040757a call padding_data 
+
+generate_mic_loop:
+74e4 20407584 call aes_load_data 
+74e5 20407534 call do_aes_cbc 
+74e6 1f227e00 deposit loopcnt 
+74e7 203a74e9 branch generate_mic_end ,blank 
+74e8 202074e4 branch generate_mic_loop 
+
+generate_mic_end:
+74e9 1800700c force regidx_result ,regext_index 
+74ea 1de27e00 deposit regext 
+74eb 60020378 store 4 ,mem_le_mic 
+74ec 20600000 rtn 
+
+aes_crypt_data:
+74ed 1a20a201 increase 1 ,rega 
+74ee 204074c1 call first_block_data 
+74ef 1a620c00 copy regc ,contr 
+74f0 2040758e call aes_load_xor 
+74f1 20407537 call do_aes_ctr 
+74f2 204075aa call store_enc_data 
+74f3 1a60a610 increase 16 ,regc 
+74f4 1a40a5f0 increase -16 ,regb 
+74f5 202174ed branch aes_crypt_data ,positive 
+74f6 20600000 rtn 
+
+le_encrypt:
+74f7 da60443e arg mem_le_txheader ,regc 
+74f8 680ac465 fetcht 5 ,mem_le_pcnt_tx 
+74f9 204074d5 call generate_mic 
+74fa 18007008 force regidx_xor ,regext_index 
+74fb 98005e00 iforce regext 
+74fc 18002200 force 0 ,rega 
+74fd 204074c1 call first_block_data 
+74fe 20407537 call do_aes_ctr 
+74ff da604440 arg mem_le_txpayload ,regc 
+7500 6800c43f fetch 1 ,mem_le_txlen 
+7501 1fe0a5ff add pdata ,-1 ,regb 
+7502 9a608a00 iadd regc ,contw 
+7503 1800700c force regidx_result ,regext_index 
+7504 1de27e00 deposit regext 
+7505 e0a20000 istore 4 ,contw 
+7506 204074ed call aes_crypt_data 
+7507 6800c43f fetch 1 ,mem_le_txlen 
+7508 1fe0fe04 increase 4 ,pdata 
+7509 6000c43f store 1 ,mem_le_txlen 
+750a 680ac465 fetcht 5 ,mem_le_pcnt_tx 
+750b 18408401 increase 1 ,temp 
+750c 600ac465 storet 5 ,mem_le_pcnt_tx 
+750d 20600000 rtn 
+
+le_decrypt:
+750e 68008341 fetch 1 ,mem_le_rxbuf + 1 
+750f 1fe67c14 sub pdata ,20 ,null 
+7510 20217511 branch le_dec_cont ,positive 
+
+le_dec_cont:
+7511 da600342 arg mem_le_rxbuf + 2 ,regc 
+7512 1fe0a5ff add pdata ,-1 ,regb 
+7513 1fe0fffc increase -4 ,pdata 
+7514 60008341 store 1 ,mem_le_rxbuf + 1 
+7515 9a608c00 iadd regc ,contr 
+7516 e8c20000 ifetch 4 ,contr 
+7517 18007008 force regidx_xor ,regext_index 
+7518 98005e00 iforce regext 
+7519 18002200 force 0 ,rega 
+751a 680ac46a fetcht 5 ,mem_le_pcnt_rx 
+751b 204074c1 call first_block_data 
+751c 20407537 call do_aes_ctr 
+751d 1800700c force regidx_result ,regext_index 
+751e 1de27e00 deposit regext 
+751f 6002037c store 4 ,mem_le_peer_mic 
+7520 204074ed call aes_crypt_data 
+7521 da600340 arg mem_le_rxbuf ,regc 
+7522 204074d5 call generate_mic 
+7523 680a037c fetcht 4 ,mem_le_peer_mic 
+7524 98467e00 isub temp ,pdata 
+7525 247a0000 nrtn blank 
+7526 6802446f fetch 4 ,mem_le_last_mic 
+7527 98467e00 isub temp ,pdata 
+7528 207a0000 rtn blank 
+7529 600a446f storet 4 ,mem_le_last_mic 
+752a 6802c46a fetch 5 ,mem_le_pcnt_rx 
+752b 1fe0fe01 increase 1 ,pdata 
+752c 6002c46a store 5 ,mem_le_pcnt_rx 
+752d 18007e00 force 0 ,pdata 
+752e 20600000 rtn 
+
+wait_aes:
+752f 243bf52f nbranch wait_aes ,aes_ready 
+7530 20600000 rtn 
+
+do_aes_ocb:
+7531 18006c30 force 0x30 ,aes_ctrl 
+7532 18006c00 force 0x0 ,aes_ctrl 
+7533 2020752f branch wait_aes 
+
+do_aes_cbc:
+7534 18006c32 force 0x32 ,aes_ctrl 
+7535 18006c02 force 0x2 ,aes_ctrl 
+7536 2020752f branch wait_aes 
+
+do_aes_ctr:
+7537 18006c34 force 0x34 ,aes_ctrl 
+7538 18006c04 force 0x4 ,aes_ctrl 
+7539 2020752f branch wait_aes 
+
+do_aes_cfb:
+753a 18006c36 force 0x36 ,aes_ctrl 
+753b 18006c06 force 0x6 ,aes_ctrl 
+753c 2020752f branch wait_aes 
+
+aes_init:
+753d 18006c01 force 1 ,aes_ctrl 
+753e 18006c00 force 0 ,aes_ctrl 
+753f 20600000 rtn 
+
+function_s1:
+7540 18007000 force regidx_data ,regext_index 
+7541 680203b0 fetch 4 ,mem_le_mrand 
+7542 98005e00 iforce regext 
+7543 1f00f001 increase 1 ,regext_index 
+7544 e8c20000 ifetch 4 ,contr 
+7545 98005e00 iforce regext 
+7546 1f00f001 increase 1 ,regext_index 
+7547 6802449c fetch 4 ,mem_le_srand 
+7548 98005e00 iforce regext 
+7549 1f00f001 increase 1 ,regext_index 
+754a e8c20000 ifetch 4 ,contr 
+754b 98005e00 iforce regext 
+754c 1f00f001 increase 1 ,regext_index 
+754d 2040759e call aes_clear 
+754e 18006c38 force 0x38 ,aes_ctrl 
+754f 18006c08 force 0x8 ,aes_ctrl 
+7550 2020752f branch wait_aes 
+
+function_c1:
+7551 680344f9 fetch 6 ,mem_le_lap 
+7552 680b03d0 fetcht 6 ,mem_le_plap 
+7553 2034f556 branch function_c1_master ,master 
+7554 680303d0 fetch 6 ,mem_le_plap 
+7555 680b44f9 fetcht 6 ,mem_le_lap 
+
+function_c1_master:
+7556 18007008 force regidx_xor ,regext_index 
+7557 18425e00 copy temp ,regext 
+7558 1f00f001 increase 1 ,regext_index 
+7559 184f5e00 rshift32 temp ,regext 
+755a 1ff07e00 lshift16 pdata ,pdata 
+755b 9de1de00 ior regext ,regext 
+755c 1f00f001 increase 1 ,regext_index 
+755d 1fef5e00 rshift32 pdata ,regext 
+755e 1f00f001 increase 1 ,regext_index 
+755f 18005e00 force 0 ,regext 
+7560 18007e00 force 0 ,pdata 
+7561 6800c4e6 fetch 1 ,mem_le_conn_peer_addr_type 
+7562 6808c4dc fetcht 1 ,mem_le_adv_own_addr_type 
+7563 2434f566 nbranch function_c1_irat ,master 
+7564 6800c4ed fetch 1 ,mem_le_conn_own_addr_type 
+7565 6808c4e6 fetcht 1 ,mem_le_conn_peer_addr_type 
+
+function_c1_irat:
+7566 6000c4ac store 1 ,mem_le_iat 
+7567 6008c4ad storet 1 ,mem_le_rat 
+7568 18007000 force regidx_data ,regext_index 
+7569 da4044ac arg mem_le_iat ,regb 
+756a 18007204 force 4 ,loopcnt 
+
+function_c1_loop1:
+756b ea220000 ifetch 4 ,rega 
+756c ea4a0000 ifetcht 4 ,regb 
+756d 9842de00 ixor temp ,regext 
+756e 1f00f001 increase 1 ,regext_index 
+756f 1a20a204 increase 4 ,rega 
+7570 1a40a404 increase 4 ,regb 
+7571 c200756b loop function_c1_loop1 
+7572 2040759e call aes_clear 
+7573 18006c38 force 0x38 ,aes_ctrl 
+7574 18006c0c force 0xc ,aes_ctrl 
+7575 2040752f call wait_aes 
+7576 2040759d call aes_clear_data 
+7577 18006c3a force 0x3a ,aes_ctrl 
+7578 18006c08 force 0x8 ,aes_ctrl 
+7579 2020752f branch wait_aes 
+
+padding_data:
+757a 2f200600 compare 0 ,loopcnt ,3 
+757b 20608000 rtn true 
+757c 18c27e00 deposit contr 
+757d 9f208a00 iadd loopcnt ,contw 
+757e 18007e00 force 0 ,pdata 
+
+padding_loop:
+757f e0a08000 istore 1 ,contw 
+7580 1f20f201 increase 1 ,loopcnt 
+7581 2f200600 compare 0 ,loopcnt ,3 
+7582 20608000 rtn true 
+7583 2020757f branch padding_loop 
+
+aes_load_data:
+7584 18007000 force regidx_data ,regext_index 
+
+load_data_loop:
+7585 1f227e00 deposit loopcnt 
+7586 203a7589 branch load_data_padding ,blank 
+7587 e8c20000 ifetch 4 ,contr 
+7588 1f20f3fc increase -4 ,loopcnt 
+
+load_data_padding:
+7589 98005e00 iforce regext 
+758a 1f00f001 increase 1 ,regext_index 
+758b 2f001e04 compare regidx_key ,regext_index ,0xf 
+758c 20608000 rtn true 
+758d 20207585 branch load_data_loop 
+
+aes_load_xor:
+758e 18007008 force regidx_xor ,regext_index 
+758f 20207593 branch load_regext 
+
+load_key:
+7590 18007004 force regidx_key ,regext_index 
+7591 20207593 branch load_regext 
+
+load_data128:
+7592 18007000 force regidx_data ,regext_index 
+
+load_regext:
+7593 18007204 force 4 ,loopcnt 
+
+load_regext_loop:
+7594 e8c20000 ifetch 4 ,contr 
+7595 98005e00 iforce regext 
+7596 1f00f001 increase 1 ,regext_index 
+7597 c2007594 loop load_regext_loop 
+7598 20600000 rtn 
+
+load_sk:
+7599 d8c003fd arg mem_le_sk ,contr 
+759a 20207590 branch load_key 
+
+clear_hidata:
+759b 18007204 force 4 ,loopcnt 
+759c 202075a0 branch clear_data_rest 
+
+aes_clear_data:
+759d 18007000 force regidx_data ,regext_index 
+
+aes_clear:
+759e 18007204 force 4 ,loopcnt 
+
+clear_loop:
+759f 18005e00 force 0 ,regext 
+
+clear_data_rest:
+75a0 1f00f001 increase 1 ,regext_index 
+75a1 c200759f loop clear_loop 
+75a2 20600000 rtn 
+
+store_aes_result:
+75a3 1800700c force regidx_result ,regext_index 
+75a4 18007204 force 4 ,loopcnt 
+
+send_aes_result_loop:
+75a5 1de27e00 deposit regext 
+75a6 e0a20000 istore 4 ,contw 
+75a7 1f00f001 increase 1 ,regext_index 
+75a8 c20075a5 loop send_aes_result_loop 
+75a9 20600000 rtn 
+
+store_enc_data:
+75aa 1800700c force regidx_result ,regext_index 
+75ab 1a620a00 copy regc ,contw 
+75ac 1a40f201 add regb ,1 ,loopcnt 
+75ad 1f267c0f sub loopcnt ,15 ,null 
+75ae 202175b0 branch store_enc_loop ,positive 
+75af 18007210 force 16 ,loopcnt 
+
+store_enc_loop:
+75b0 1de27e00 deposit regext 
+75b1 1f267c03 sub loopcnt ,3 ,null 
+75b2 202175b8 branch store_enc_byte ,positive 
+75b3 e0a20000 istore 4 ,contw 
+75b4 1f20f3fc increase -4 ,loopcnt 
+75b5 20628000 rtn zero 
+75b6 1f00f001 increase 1 ,regext_index 
+75b7 202075b0 branch store_enc_loop 
+
+store_enc_byte:
+75b8 e0a08000 istore 1 ,contw 
+75b9 1fecfe00 rshift8 pdata ,pdata 
+75ba c20075b8 loop store_enc_byte 
+75bb 20600000 rtn 
+
+compare_res:
+75bc 1800700c force regidx_result ,regext_index 
+75bd 18007204 force 4 ,loopcnt 
+
+compare_res_loop:
+75be e8c20000 ifetch 4 ,contr 
+75bf 9de67c00 isub regext ,null 
+75c0 24628000 nrtn zero 
+75c1 1f00f001 increase 1 ,regext_index 
+75c2 c20075be loop compare_res_loop 
+75c3 18007c00 force 0 ,null 
+75c4 20600000 rtn 
+
+enable_authrom:
+75c5 68108050 hfetch 1 ,core_clkoff 
+75c6 793ffe00 set0 clock_off_auth_rom ,pdata 
+75c7 60108050 hstore 1 ,core_clkoff 
+75c8 20600000 rtn 
+
+disable_authrom:
+75c9 68108050 hfetch 1 ,core_clkoff 
+75ca 79207e00 set1 clock_off_auth_rom ,pdata 
+75cb 60108050 hstore 1 ,core_clkoff 
+75cc 20600000 rtn 
+
+init_memp:
+75cd d8a00742 arg mem_p ,contw 
+75ce 3803ffff setsect 0 ,0x3ffff 
+75cf 3807ffff setsect 1 ,0x3ffff 
+75d0 380bffff setsect 2 ,0x3ffff 
+75d1 380ffbff setsect 3 ,0x3fbff 
+75d2 e0a48000 istore 9 ,contw 
+75d3 3803ffff setsect 0 ,0x3ffff 
+75d4 3807ffff setsect 1 ,0x3ffff 
+75d5 380bffff setsect 2 ,0x3ffff 
+75d6 380fffff setsect 3 ,0x3ffff 
+75d7 e0a48000 istore 9 ,contw 
+75d8 3803ffff setsect 0 ,0x3ffff 
+75d9 3807ffff setsect 1 ,0x3ffff 
+75da 380bcfff setsect 2 ,0x3cfff 
+75db 380fffff setsect 3 ,0x3ffff 
+75dc e0a48000 istore 9 ,contw 
+75dd 3803ffff setsect 0 ,0x3ffff 
+75de 3807ffff setsect 1 ,0x3ffff 
+75df 380bffef setsect 2 ,0x3ffef 
+75e0 380fffff setsect 3 ,0x3ffff 
+75e1 e0a48000 istore 9 ,contw 
+75e2 3803ffff setsect 0 ,0x3ffff 
+75e3 3807ffff setsect 1 ,0x3ffff 
+75e4 380bffff setsect 2 ,0x3ffff 
+75e5 380fffff setsect 3 ,0x3ffff 
+75e6 e0a48000 istore 9 ,contw 
+75e7 3803ffff setsect 0 ,0x3ffff 
+75e8 38066c7f setsect 1 ,0x26c7f 
+75e9 3808146b setsect 2 ,0x146b 
+75ea 380f7bb3 setsect 3 ,0x37bb3 
+75eb e0a48000 istore 9 ,contw 
+75ec 3801feb8 setsect 0 ,0x1feb8 
+75ed 38050c12 setsect 1 ,0x10c12 
+75ee 380ab722 setsect 2 ,0x2b722 
+75ef 380e9fa6 setsect 3 ,0x29fa6 
+75f0 e0a48000 istore 9 ,contw 
+75f1 3800e70f setsect 0 ,0xe70f 
+75f2 38056720 setsect 1 ,0x16720 
+75f3 3808519e setsect 2 ,0x519e 
+75f4 380d9084 setsect 3 ,0x19084 
+75f5 e0a48000 istore 9 ,contw 
+75f6 38031012 setsect 0 ,0x31012 
+75f7 380760bf setsect 1 ,0x360bf 
+75f8 380bf0af setsect 2 ,0x3f0af 
+75f9 380c03d3 setsect 3 ,0x3d3 
+75fa e0a48000 istore 9 ,contw 
+75fb 3803a188 setsect 0 ,0x3a188 
+75fc 38043ad0 setsect 1 ,0x3ad0 
+75fd 380bcbf2 setsect 2 ,0x3cbf2 
+75fe 380e43d9 setsect 3 ,0x243d9 
+75ff e0a48000 istore 9 ,contw 
+7600 3802b030 setsect 0 ,0x2b030 
+7601 38076a03 setsect 1 ,0x36a03 
+7602 38091188 setsect 2 ,0x11188 
+7603 380de520 setsect 3 ,0x1e520 
+7604 e0a48000 istore 9 ,contw 
+7605 3803a11e setsect 0 ,0x3a11e 
+7606 3804fe5d setsect 1 ,0xfe5d 
+7607 3808dd57 setsect 2 ,0xdd57 
+7608 380dac93 setsect 3 ,0x1ac93 
+7609 e0a48000 istore 9 ,contw 
+760a 380011ed setsect 0 ,0x11ed 
+760b 380618c4 setsect 1 ,0x218c4 
+760c 38088da7 setsect 2 ,0x8da7 
+760d 380e57ff setsect 3 ,0x257ff 
+760e e0a48000 istore 9 ,contw 
+760f 3803192b setsect 0 ,0x3192b 
+7610 38074641 setsect 1 ,0x34641 
+7611 3809be0c setsect 2 ,0x1be0c 
+7612 380f66ad setsect 3 ,0x366ad 
+7613 e0a48000 istore 9 ,contw 
+7614 38001f83 setsect 0 ,0x1f83 
+7615 38055a23 setsect 1 ,0x15a23 
+7616 380bf9b0 setsect 2 ,0x3f9b0 
+7617 380c3949 setsect 3 ,0x3949 
+7618 e0a48000 istore 9 ,contw 
+7619 38013a51 setsect 0 ,0x13a51 
+761a 380553fd setsect 1 ,0x153fd 
+761b 380b372a setsect 2 ,0x3372a 
+761c 380cf1bb setsect 3 ,0xf1bb 
+761d e0a48000 istore 9 ,contw 
+761e 3803ae85 setsect 0 ,0x3ae85 
+761f 3805eed9 setsect 1 ,0x1eed9 
+7620 38089e66 setsect 2 ,0x9e66 
+7621 380c01a8 setsect 3 ,0x1a8 
+7622 e0a40000 istore 8 ,contw 
+7623 20600000 rtn 
+
+shutter_init:
+7624 5800764c setarg shutter_send_process 
+7625 6001428e store 2 ,mem_cb_bt_process 
+7626 5800770f setarg shutter_process_idle 
+7627 60014290 store 2 ,mem_cb_idle_process 
+7628 580076ac setarg shutter_process_bb_event 
+7629 60014292 store 2 ,mem_cb_bb_event_process 
+762a 58007710 setarg shutter_process_lpm_before 
+762b 6001428a store 2 ,mem_cb_before_lpm 
+762c 58007718 setarg shutter_discovery_timeout_sleep 
+762d 60014294 store 2 ,mem_cb_discovry_timeout 
+762e 79200025 set1 mark_ext_patch ,mark 
+762f 44fcc03f bpatch patch3f_1 ,mem_patch3f 
+7630 20758000 rtn wake 
+7631 70808100 hjam 0x00 ,core_gpio_sel1 
+7632 2040763f call shutter_key_and_wake_gpio_setup 
+7633 58007717 setarg shutter_before_hibernate 
+7634 60014288 store 2 ,mem_cb_before_hibernate 
+7635 70480e00 jam flag_shutter_1key_send_null ,mem_shutter_1key_send_sm 
+7636 70480a00 jam 0 ,mem_shutter_key 
+7637 70480b00 jam flag_shutter_default ,mem_shutter_flag 
+7638 58000000 setarg 0 
+7639 60024800 store 4 ,mem_shutter_send_data 
+763a 20403f23 call app_check_reconn_target 
+763b 203a3f79 branch app_bt_start_discovery_short ,blank 
+763c 20403f96 call app_led_on 
+763d 20403f7e call app_bt_stop_discovery 
+763e 20203f6e branch app_bt_start_reconnect 
+
+shutter_key_and_wake_gpio_setup:
+763f 6808c80f fetcht 1 ,mem_shutter_iphonekey_gpio 
+7640 204069d1 call gpio_config_input 
+7641 6808c810 fetcht 1 ,mem_shutter_androidkey_gpio 
+7642 202069d1 branch gpio_config_input 
+
+shutter_cancel_key_shake:
+7643 79200025 set1 mark_ext_patch ,mark 
+7644 44fd403f bpatch patch3f_2 ,mem_patch3f 
+7645 680a4806 fetcht 4 ,mem_shutter_clkn_bt_last 
+7646 1c427e00 deposit clkn_bt 
+7647 60024806 store 4 ,mem_shutter_clkn_bt_last 
+7648 98467e00 isub temp ,pdata 
+7649 24610000 nrtn positive 
+764a 1fe67ec8 sub pdata ,200 ,pdata 
+764b 20600000 rtn 
+
+shutter_send_process:
+764c 6800c2bc fetch 1 ,mem_hid_interrupt_state 
+764d c19f8000 rtnne 0x3f 
+
+shutter_scan_key_start:
+764e 79200025 set1 mark_ext_patch ,mark 
+764f 44fdc03f bpatch patch3f_3 ,mem_patch3f 
+7650 6800c132 fetch 1 ,mem_device_option 
+7651 c1848000 rtnne dvc_op_shutter 
+7652 78547c00 disable user 
+7653 2040769b call shutter_scan_key 
+7654 24740000 nrtn user 
+7655 78547c00 disable user 
+7656 6800c133 fetch 1 ,mem_scan_mode 
+7657 c001f706 beq 0x03 ,shutter_reconnect_scan_2 
+7658 6800c80b fetch 1 ,mem_shutter_flag 
+7659 c000f663 beq flag_shutter_iphonekey_send ,shutter_iphonekey_release 
+765a c001767d beq flag_shutter_androidkey_send ,shutter_androidkey_release 
+765b 20407643 call shutter_cancel_key_shake 
+765c 20217660 branch shutter_send_process_end ,positive 
+765d 6800c80a fetch 1 ,mem_shutter_key 
+765e c2807674 bbit1 flag_shutter_iphonekey_press ,shutter_iphonekey_press 
+765f c280f682 bbit1 flag_shutter_androidkey_press ,shutter_androidkey_press 
+
+shutter_send_process_end:
+7660 70480a00 jam 0 ,mem_shutter_key 
+7661 70480b00 jam flag_shutter_default ,mem_shutter_flag 
+7662 20600000 rtn 
+
+shutter_iphonekey_release:
+7663 70480b00 jam flag_shutter_default ,mem_shutter_flag 
+7664 20407bde call ui_led_blink_stop 
+7665 6800c811 fetch 1 ,mem_shutter_key_number 
+7666 c000f66a beq flag_shutter_1key ,shutter_1key_iphonekey_release 
+
+shutter_2key_iphonekey_release:
+
+shutter_iphonekey_release_package:
+7667 70480505 jam 0x05 ,mem_shutter_send_length 
+7668 70480003 jam 0x03 ,mem_shutter_send_data 
+7669 20207688 branch shutter_send_keydata 
+
+shutter_1key_iphonekey_release:
+766a 70480e00 jam flag_shutter_1key_send_null ,mem_shutter_1key_send_sm 
+766b 2020766c branch shutter_1key_send_step1 
+
+shutter_1key_send_step1:
+766c 70480e02 jam flag_shutter_1key_send_step2 ,mem_shutter_1key_send_sm 
+766d 20207684 branch shutter_androidkey_press_package 
+
+shutter_1key_send_step2:
+766e 70480e03 jam flag_shutter_1key_send_step3 ,mem_shutter_1key_send_sm 
+766f 2020767f branch shutter_androidkey_release_package 
+
+shutter_1key_send_step3:
+7670 70480e04 jam flag_shutter_1key_send_step4 ,mem_shutter_1key_send_sm 
+7671 20207678 branch shutter_iphonekey_press_package 
+
+shutter_1key_send_step4:
+7672 70480e00 jam flag_shutter_1key_send_null ,mem_shutter_1key_send_sm 
+7673 20207667 branch shutter_iphonekey_release_package 
+
+shutter_iphonekey_press:
+7674 70480b01 jam flag_shutter_iphonekey_send ,mem_shutter_flag 
+7675 20407be7 call ui_led_on 
+7676 6800c811 fetch 1 ,mem_shutter_key_number 
+7677 c000f67c beq flag_shutter_1key ,shutter_1key_iphonekey_press 
+
+shutter_2key_iphonekey_press:
+
+shutter_iphonekey_press_package:
+7678 70480505 jam 0x05 ,mem_shutter_send_length 
+7679 58020003 setarg 0x20003 
+767a 6001c800 store 3 ,mem_shutter_send_data 
+767b 20207688 branch shutter_send_keydata 
+
+shutter_1key_iphonekey_press:
+767c 20600000 rtn 
+
+shutter_androidkey_release:
+767d 70480b00 jam flag_shutter_default ,mem_shutter_flag 
+767e 20407bde call ui_led_blink_stop 
+
+shutter_androidkey_release_package:
+767f 7048050a jam 0x0a ,mem_shutter_send_length 
+7680 70480001 jam 0x01 ,mem_shutter_send_data 
+7681 20207688 branch shutter_send_keydata 
+
+shutter_androidkey_press:
+7682 70480b02 jam flag_shutter_androidkey_send ,mem_shutter_flag 
+7683 20407be7 call ui_led_on 
+
+shutter_androidkey_press_package:
+7684 7048050a jam 0x0a ,mem_shutter_send_length 
+7685 70480001 jam 0x01 ,mem_shutter_send_data 
+7686 58280000 setarg 0x280000 
+7687 6001c801 store 3 ,mem_shutter_send_data + 1 
+
+shutter_send_keydata:
+7688 79200025 set1 mark_ext_patch ,mark 
+7689 44fe403f bpatch patch3f_4 ,mem_patch3f 
+768a 6800c805 fetch 1 ,mem_shutter_send_length 
+768b 1fe22200 copy pdata ,rega 
+768c 20404b2c call hid_malloc_tx_buff 
+768d 680142b7 fetch 2 ,mem_hid_int_remote_cid 
+768e e0a10000 istore 2 ,contw 
+768f 580000a1 setarg 0xa1 
+7690 e0a08000 istore 1 ,contw 
+7691 680a4800 fetcht 4 ,mem_shutter_send_data 
+7692 e0ac0000 istoret 8 ,contw 
+7693 58000000 setarg 0 
+7694 e0a08000 istore 1 ,contw 
+7695 60024800 store 4 ,mem_shutter_send_data 
+7696 6800c80e fetch 1 ,mem_shutter_1key_send_sm 
+7697 c001766e beq flag_shutter_1key_send_step2 ,shutter_1key_send_step2 
+7698 c001f670 beq flag_shutter_1key_send_step3 ,shutter_1key_send_step3 
+7699 c0027672 beq flag_shutter_1key_send_step4 ,shutter_1key_send_step4 
+769a 20600000 rtn 
+
+shutter_scan_key:
+769b 6808c80f fetcht 1 ,mem_shutter_iphonekey_gpio 
+769c 204069e5 call gpio_get_bit 
+769d 58000000 setarg 0 
+769e 7920fe00 setflag true ,flag_shutter_iphonekey_press ,pdata 
+769f 6000c804 store 1 ,mem_shutter_key_temp 
+76a0 6808c810 fetcht 1 ,mem_shutter_androidkey_gpio 
+76a1 204069e5 call gpio_get_bit 
+76a2 58000000 setarg 0 
+76a3 7920fe01 setflag true ,flag_shutter_androidkey_press ,pdata 
+76a4 6808c804 fetcht 1 ,mem_shutter_key_temp 
+76a5 9841fe00 ior temp ,pdata 
+76a6 6808c80a fetcht 1 ,mem_shutter_key 
+76a7 6000c80a store 1 ,mem_shutter_key 
+76a8 9842fc00 ixor temp ,null 
+76a9 20628000 rtn zero 
+76aa 78347c00 enable user 
+76ab 20600000 rtn 
+
+shutter_process_bb_event:
+76ac 1a627e00 copy regc ,pdata 
+76ad c002f6d8 beq bt_evt_setup_complete ,shutter_bb_event_setup_complete 
+76ae c00376da beq bt_evt_hid_connected ,shutter_bb_event_hid_connected 
+76af c003f6dd beq bt_evt_hid_disconnected ,shutter_bb_event_hid_disconn 
+76b0 c013f6e1 beq bt_evt_virtual_cable_unplug ,shutter_bb_event_unplug 
+76b1 c00176c9 beq bt_evt_bb_disconnected ,shutter_bb_event_bb_disconn 
+76b2 c00276d0 beq bt_evt_reconn_failed ,shutter_bb_event_reconn_failed 
+76b3 c009f6d0 beq bt_evt_reconn_page_timeout ,shutter_bb_event_reconn_failed 
+76b4 c000f6c6 beq bt_evt_bb_connected ,shutter_process_bb_conn 
+76b5 c00976c0 beq bt_evt_hid_handshake ,shutter_event_hid_handshake 
+76b6 c0173f57 beq bt_evt_remote_unsniff ,app_start_auto_sniff 
+76b7 1fe1040f and pdata ,0x0f ,temp 
+76b8 1fe17ef0 and_into bt_evt_timer_mask ,pdata 
+76b9 c02876e4 beq bt_evt_timer_init ,shutter_bb_event_timer 
+76ba 20600000 rtn 
+
+shutter_hid_handshake_timer:
+76bb 6800c7f2 fetch 1 ,mem_hid_handshake_timer_count 
+76bc 207a0000 rtn blank 
+76bd 1fe0ffff increase -1 ,pdata 
+76be 6000c7f2 store 1 ,mem_hid_handshake_timer_count 
+76bf 247a0000 nrtn blank 
+
+shutter_event_hid_handshake:
+76c0 70427f01 jam app_handshake_done ,mem_app_handshake_flag 
+76c1 20403fa4 call app_lpm_mult_enable 
+76c2 20403fa2 call app_bt_store_reconn_info 
+76c3 20403f7e call app_bt_stop_discovery 
+76c4 20403f98 call app_led_off 
+76c5 20203f9e branch app_bt_enter_sniff 
+
+shutter_process_bb_conn:
+76c6 70480d00 jam 0 ,mem_shutter_hid_disconn_count 
+76c7 70480c00 jam 0 ,mem_shutter_cable_unplug_conut 
+76c8 20600000 rtn 
+
+shutter_bb_event_bb_disconn:
+76c9 79200025 set1 mark_ext_patch ,mark 
+76ca 44fec03f bpatch patch3f_5 ,mem_patch3f 
+76cb 70429d00 jam 0 ,mem_unsniff2sniff_timer_count 
+76cc 70480c00 jam 0 ,mem_shutter_cable_unplug_conut 
+76cd 70480d00 jam 0 ,mem_shutter_hid_disconn_count 
+76ce 680142a0 fetch app_disc_rsn_size ,mem_app_disconn_reason 
+76cf c301f6d4 bbit0 app_disc_after_sniff ,shutter_check_pairing 
+
+shutter_bb_event_reconn_failed:
+76d0 680147fe fetch 2 ,mem_discovery_timeout 
+76d1 600147f0 store 2 ,mem_discovery_timeout_timer_count 
+
+shutter_discovery_on_not_renew_timer:
+76d2 20403f12 call app_disconn_reason_clear 
+76d3 20203f7b branch app_bt_start_discovery_led_blink 
+
+shutter_check_pairing:
+76d4 c300f6d6 bbit0 app_disc_after_pairing ,shutter_check_reconn 
+76d5 202076d0 branch shutter_bb_event_reconn_failed 
+
+shutter_check_reconn:
+76d6 c30176d2 bbit0 app_disc_after_reconn ,shutter_discovery_on_not_renew_timer 
+76d7 202076d0 branch shutter_bb_event_reconn_failed 
+
+shutter_bb_event_setup_complete:
+76d8 20403f7e call app_bt_stop_discovery 
+76d9 20203f98 branch app_led_stop_blink 
+
+shutter_bb_event_hid_connected:
+76da 58000002 setarg hid_handshake_timeout 
+76db 6000c7f2 store 1 ,mem_hid_handshake_timer_count 
+76dc 20600000 rtn 
+
+shutter_bb_event_hid_disconn:
+76dd 70480c00 jam 0 ,mem_shutter_cable_unplug_conut 
+76de 58000001 setarg flag_shutter_hid_disconn_timeout 
+76df 6000c80d store 1 ,mem_shutter_hid_disconn_count 
+76e0 20600000 rtn 
+
+shutter_bb_event_unplug:
+76e1 58000005 setarg flag_shutter_cable_unplug_timeout 
+76e2 6000c80c store 1 ,mem_shutter_cable_unplug_conut 
+76e3 20600000 rtn 
+
+shutter_bb_event_timer:
+76e4 79200025 set1 mark_ext_patch ,mark 
+76e5 44ff403f bpatch patch3f_6 ,mem_patch3f 
+76e6 60088259 storet 1 ,mem_app_evt_timer_count 
+
+shutter_bb_event_100ms_loop:
+76e7 68008259 fetch 1 ,mem_app_evt_timer_count 
+76e8 207a0000 rtn blank 
+76e9 1fe0ffff increase -1 ,pdata 
+76ea 60008259 store 1 ,mem_app_evt_timer_count 
+76eb 204076ef call shutter_check_unplug_timer 
+76ec 204076bb call shutter_hid_handshake_timer 
+76ed 204076fa call shutter_check_hid_disconn_timer 
+76ee 202076e7 branch shutter_bb_event_100ms_loop 
+
+shutter_check_unplug_timer:
+76ef 6800c80c fetch 1 ,mem_shutter_cable_unplug_conut 
+76f0 207a0000 rtn blank 
+76f1 6800c80c fetch 1 ,mem_shutter_cable_unplug_conut 
+76f2 1fe0ffff increase -1 ,pdata 
+76f3 6000c80c store 1 ,mem_shutter_cable_unplug_conut 
+76f4 247a0000 nrtn blank 
+76f5 680082e6 fetch 1 ,mem_control_tasks 
+76f6 79207e00 set1 l2cap_disconnect_interrupt ,pdata 
+76f7 79207e07 set1 l2cap_disconnect_control ,pdata 
+76f8 600082e6 store 1 ,mem_control_tasks 
+76f9 20600000 rtn 
+
+shutter_check_hid_disconn_timer:
+76fa 6800c80d fetch 1 ,mem_shutter_hid_disconn_count 
+76fb 207a0000 rtn blank 
+76fc 6800c80d fetch 1 ,mem_shutter_hid_disconn_count 
+76fd 1fe0ffff increase -1 ,pdata 
+76fe 6000c80d store 1 ,mem_shutter_hid_disconn_count 
+76ff 247a0000 nrtn blank 
+7700 20203f77 branch app_bt_disconnect 
+
+shutter_reconnect_scan:
+7701 79200025 set1 mark_ext_patch ,mark 
+7702 44ffc03f bpatch patch3f_7 ,mem_patch3f 
+7703 6800c133 fetch 1 ,mem_scan_mode 
+7704 c1818000 rtnne 0x03 
+7705 2020764e branch shutter_scan_key_start 
+
+shutter_reconnect_scan_2:
+7706 20407643 call shutter_cancel_key_shake 
+7707 20610000 rtn positive 
+7708 6800c80a fetch 1 ,mem_shutter_key 
+7709 207a0000 rtn blank 
+770a 20403f23 call app_check_reconn_target 
+770b 203a3f79 branch app_bt_start_discovery_short ,blank 
+770c 20403f96 call app_led_on 
+770d 20403f7e call app_bt_stop_discovery 
+770e 20203f6e branch app_bt_start_reconnect 
+
+shutter_process_idle:
+770f 20207701 branch shutter_reconnect_scan 
+
+shutter_process_lpm_before:
+7710 6808c80f fetcht 1 ,mem_shutter_iphonekey_gpio 
+7711 204069b4 call gpio_set_wake_by_current_state 
+7712 6800c811 fetch 1 ,mem_shutter_key_number 
+7713 c080f715 bne flag_shutter_1key ,shutter_process_lpm_before_key2 
+7714 20600000 rtn 
+
+shutter_process_lpm_before_key2:
+7715 6808c810 fetcht 1 ,mem_shutter_androidkey_gpio 
+7716 202069b4 branch gpio_set_wake_by_current_state 
+
+shutter_before_hibernate:
+7717 2020763f branch shutter_key_and_wake_gpio_setup 
+
+shutter_discovery_timeout_sleep:
+7718 20203f9a branch app_enter_hibernate 
+
+sp_initialize:
+7719 79200025 set1 mark_ext_patch ,mark 
+771a 44f9403e bpatch patch3e_2 ,mem_patch3e 
+771b 6800c7dc fetch 1 ,mem_ssp_enable 
+771c 203a6009 branch ssp_disable ,blank 
+771d 20406003 call ssp_enable 
+771e 58000000 setarg 0 
+771f 600407da store 8 ,mem_sp_state_start 
+7720 600207e2 store 4 ,mem_sp_flag_start 
+7721 d8a007e9 arg mem_sp_iocap_remote ,contw 
+7722 e0a38000 istore 7 ,contw 
+7723 7007e000 jam default_statemachine ,mem_sp_localsm 
+7724 202077a4 branch sp_pubkey_calc 
+
+sp_generate_local_key:
+7725 7007dc01 jam sp_flag_commit ,mem_sp_flag 
+7726 2020772a branch sp_generate_local_key0 
+
+sp_master_generate_local_key:
+7727 6800c793 fetch 1 ,mem_sp_local_key_invalid 
+7728 c000f7c2 beq sp_key_valid ,sp_dhkey_calc 
+7729 20203bf1 branch assert 
+
+sp_generate_local_key0:
+772a 6800c793 fetch 1 ,mem_sp_local_key_invalid 
+772b c000f72d beq sp_key_valid ,sp_start_send_pubkey 
+772c 202077a4 branch sp_pubkey_calc 
+
+sp_start_send_pubkey:
+772d 204077c2 call sp_dhkey_calc 
+772e 680087db fetch 1 ,mem_master_sp_state 
+772f 247a0000 nrtn blank 
+7730 7007da03 jam sp_stat_key_send ,mem_sp_state 
+7731 20600000 rtn 
+
+sp_calculate_commitment:
+7732 680087de fetch 1 ,mem_sp_calc 
+7733 c0807750 bne sp_calc_standby ,sp_calculate_commitment_wait_dhkey_calc 
+7734 2040774d call sp_local_random_key_generator 
+7735 d8a00898 arg mem_sp_prarm_stack ,contw 
+7736 58000848 setarg mem_sp_random_local_end 
+7737 e0a10000 istore 2 ,contw 
+7738 580047c4 setarg mem_sp_pubkey_local_x_end 
+7739 e0a10000 istore 2 ,contw 
+773a 58000808 setarg mem_sp_pubkey_remote_x_end 
+773b e0a10000 istore 2 ,contw 
+773c 20207744 branch sp_calculate_commitment0 
+
+master_sp_calculate_commitment:
+773d d8a00898 arg mem_sp_prarm_stack ,contw 
+773e 58000858 setarg mem_sp_random_remote_end 
+773f e0a10000 istore 2 ,contw 
+7740 58000808 setarg mem_sp_pubkey_remote_x_end 
+7741 e0a10000 istore 2 ,contw 
+7742 580047c4 setarg mem_sp_pubkey_local_x_end 
+7743 e0a10000 istore 2 ,contw 
+
+sp_calculate_commitment0:
+7744 20407ad2 call function_f1 
+7745 680087db fetch 1 ,mem_master_sp_state 
+7746 c002774a beq sp_stat_commit_calc ,master_sp_calculate_commitment0 
+7747 7007dc01 jam sp_flag_commit ,mem_sp_flag 
+7748 7007da05 jam sp_stat_commit_send ,mem_sp_state 
+7749 20600000 rtn 
+
+master_sp_calculate_commitment0:
+774a 7007db14 jam sp_stat_commitment_compare ,mem_master_sp_state 
+774b 20407727 call sp_master_generate_local_key 
+774c 2020780f branch master_set_mem_master_sp_flag 
+
+sp_local_random_key_generator:
+774d d8a00838 arg mem_sp_random_local ,contw 
+774e 18000e08 force 8 ,queue 
+774f 202077db branch random_generator 
+
+sp_calculate_commitment_wait_dhkey_calc:
+7750 7007dc01 jam sp_flag_commit ,mem_sp_flag 
+7751 20600000 rtn 
+
+sp_confirm_check:
+7752 d8a006c3 arg mem_addr_value ,contw 
+7753 68034140 fetch 6 ,mem_lap 
+7754 e0a30000 istore 6 ,contw 
+7755 68030040 fetch 6 ,mem_plap 
+7756 e0a30000 istore 6 ,contw 
+7757 680187e9 fetch 3 ,mem_sp_iocap_remote 
+7758 e0a18000 istore 3 ,contw 
+7759 20407b3c call function_f3a 
+775a da200868 arg mem_sp_calc_result_high ,rega 
+775b da400878 arg mem_sp_check_result ,regb 
+775c 18000e04 force 4 ,queue 
+775d 204077e0 call compare4 
+775e 2420f768 nbranch sp_confirm_check_failed ,true 
+
+sp_confirm_check_success:
+775f 680087db fetch 1 ,mem_master_sp_state 
+7760 c004f765 beq sp_stat_confirm_check ,sp_confirm_check_success_master 
+7761 7007da0a jam sp_stat_confirm_calc ,mem_sp_state 
+7762 7007dc01 jam sp_flag_commit ,mem_sp_flag 
+7763 70007c03 jam lmp_accepted ,mem_lmo_opcode2 
+7764 20600000 rtn 
+
+sp_confirm_check_success_master:
+7765 70007c03 jam lmp_accepted ,mem_lmo_opcode2 
+7766 7007db15 jam sp_state_end ,mem_master_sp_state 
+7767 2020780f branch master_set_mem_master_sp_flag 
+
+sp_confirm_check_failed:
+7768 680087db fetch 1 ,mem_master_sp_state 
+7769 c004f76e beq sp_stat_confirm_check ,sp_confirm_check_failed_master 
+776a 7007da00 jam sp_stat_null ,mem_sp_state 
+776b 70007c04 jam lmp_not_accepted ,mem_lmo_opcode2 
+776c 70007e05 jam authentication_failure_error ,mem_lmo_reason2 
+776d 20600000 rtn 
+
+sp_confirm_check_failed_master:
+776e 70007c04 jam lmp_not_accepted ,mem_lmo_opcode2 
+776f 7007db00 jam sp_stat_null ,mem_master_sp_state 
+7770 20600000 rtn 
+
+sp_confirm_calc:
+7771 680087df fetch 1 ,mem_sp_dh_ready 
+7772 c000f775 beq sp_flag_commit ,sp_confirm_calc_ready 
+7773 7007db0a jam sp_stat_confirm_calc ,mem_master_sp_state 
+7774 2020780f branch master_set_mem_master_sp_flag 
+
+sp_confirm_calc_ready:
+7775 d8a006c3 arg mem_addr_value ,contw 
+7776 68030040 fetch 6 ,mem_plap 
+7777 e0a30000 istore 6 ,contw 
+7778 68034140 fetch 6 ,mem_lap 
+7779 e0a30000 istore 6 ,contw 
+777a 680187e6 fetch 3 ,mem_sp_iocap_local 
+777b e0a18000 istore 3 ,contw 
+777c 20407b4a call function_f3b 
+777d 680087db fetch 1 ,mem_master_sp_state 
+777e c0057782 beq sp_stat_confirm_calc ,sp_confirm_calc_master 
+777f 7007da0b jam sp_stat_confirm_send ,mem_sp_state 
+7780 7007dc01 jam sp_flag_commit ,mem_sp_flag 
+7781 20600000 rtn 
+
+sp_confirm_calc_master:
+7782 7007db0b jam sp_stat_confirm_send ,mem_master_sp_state 
+7783 7007dd01 jam sp_flag_commit ,mem_master_sp_flag 
+7784 20600000 rtn 
+
+sp_master_key_prarm_push:
+7785 d8a00898 arg mem_sp_prarm_stack ,contw 
+7786 68030040 fetch 6 ,mem_plap 
+7787 e0a30000 istore 6 ,contw 
+7788 68034140 fetch 6 ,mem_lap 
+7789 e0a30000 istore 6 ,contw 
+778a 58000848 setarg mem_sp_random_local_end 
+778b e0a10000 istore 2 ,contw 
+778c 58000858 setarg mem_sp_random_remote_end 
+778d e0a10000 istore 2 ,contw 
+778e 20207799 branch sp_link_key_calc 
+
+sp_link_key_prarm_push:
+778f 7007da0f jam sp_stat_done ,mem_sp_state 
+7790 d8a00898 arg mem_sp_prarm_stack ,contw 
+7791 68034140 fetch 6 ,mem_lap 
+7792 e0a30000 istore 6 ,contw 
+7793 68030040 fetch 6 ,mem_plap 
+7794 e0a30000 istore 6 ,contw 
+7795 58000858 setarg mem_sp_random_remote_end 
+7796 e0a10000 istore 2 ,contw 
+7797 58000848 setarg mem_sp_random_local_end 
+7798 e0a10000 istore 2 ,contw 
+
+sp_link_key_calc:
+7799 d8a006c3 arg mem_addr_value ,contw 
+779a 68030898 fetch 6 ,mem_sp_prarm_stack 
+779b e0a30000 istore 6 ,contw 
+779c 6803089e fetch 6 ,mem_sp_prarm_stack + 6 
+779d e0a30000 istore 6 ,contw 
+779e 20407b06 call function_f2 
+779f 70425e01 jam 1 ,mem_link_key_exists 
+77a0 d8a04262 arg mem_link_key ,contw 
+77a1 d8c00868 arg mem_sp_calc_result_high ,contr 
+77a2 20407e35 call memcpy16 
+77a3 20203229 branch generate_linkkey_continue 
+
+sp_pubkey_calc:
+77a4 79200025 set1 mark_ext_patch ,mark 
+77a5 44f9c03e bpatch patch3e_3 ,mem_patch3e 
+77a6 6800c793 fetch 1 ,mem_sp_local_key_invalid 
+77a7 c1800000 rtnne sp_key_invalid 
+77a8 680087de fetch 1 ,mem_sp_calc 
+77a9 c1800000 rtnne sp_calc_standby 
+77aa d8a04794 arg mem_sp_private_key ,contw 
+77ab 18000e0b force 11 ,queue 
+77ac 204077db call random_generator 
+77ad 180a7e00 random pdata 
+77ae 1fe37e00 rshift pdata ,pdata 
+77af e0a10000 istore 2 ,contw 
+77b0 d8a0065a arg mem_k ,contw 
+77b1 d8c04794 arg mem_sp_private_key ,contr 
+77b2 20407e33 call memcpy24 
+77b3 d8a00582 arg mem_ax ,contw 
+77b4 d8c0078a arg mem_gx ,contr 
+77b5 20407e2d call memcpy48 
+77b6 d8a005b2 arg mem_az ,contw 
+77b7 20407e3a call bn_zero 
+77b8 7005b201 jam 1 ,mem_az 
+77b9 20407b7f call eckp_calc_init 
+77ba 7007de01 jam sp_calc_pubkey ,mem_sp_calc 
+77bb 20600000 rtn 
+
+sp_pubkey_generated:
+77bc d8a047ac arg mem_sp_pubkey_local ,contw 
+77bd d8c005ca arg mem_bx ,contr 
+77be 20407e2d call memcpy48 
+77bf 70479301 jam sp_key_valid ,mem_sp_local_key_invalid 
+77c0 7007de00 jam sp_calc_standby ,mem_sp_calc 
+77c1 20600000 rtn 
+
+sp_dhkey_calc:
+77c2 79200025 set1 mark_ext_patch ,mark 
+77c3 44fa403e bpatch patch3e_4 ,mem_patch3e 
+77c4 680087e5 fetch 1 ,mem_sp_dhkey_invalid 
+77c5 c1800000 rtnne sp_key_invalid 
+77c6 680087de fetch 1 ,mem_sp_calc 
+77c7 c1800000 rtnne sp_calc_standby 
+77c8 d8a0065a arg mem_k ,contw 
+77c9 d8c04794 arg mem_sp_private_key ,contr 
+77ca 20407e33 call memcpy24 
+77cb d8a00582 arg mem_ax ,contw 
+77cc d8c007f0 arg mem_sp_pubkey_remote ,contr 
+77cd 20407e2d call memcpy48 
+77ce d8a005b2 arg mem_az ,contw 
+77cf 20407e3a call bn_zero 
+77d0 7005b201 jam 1 ,mem_az 
+77d1 20407b7f call eckp_calc_init 
+77d2 7007de02 jam sp_calc_dhkey ,mem_sp_calc 
+77d3 20600000 rtn 
+
+sp_dhkey_generated:
+77d4 7007df01 jam sp_flag_commit ,mem_sp_dh_ready 
+77d5 d8a00820 arg mem_sp_dhkey ,contw 
+77d6 d8c005ca arg mem_bx ,contr 
+77d7 20407e33 call memcpy24 
+77d8 7007e501 jam sp_key_valid ,mem_sp_dhkey_invalid 
+77d9 7007de00 jam sp_calc_standby ,mem_sp_calc 
+77da 20600000 rtn 
+
+random_generator:
+77db 18e08fff increase -1 ,queue 
+77dc 24610000 nrtn positive 
+77dd 180a7e00 random pdata 
+77de e0a10000 istore 2 ,contw 
+77df 202077db branch random_generator 
+
+compare4:
+77e0 18e08fff increase -1 ,queue 
+77e1 242177ec nbranch compare4_success ,positive 
+77e2 ea220000 ifetch 4 ,rega 
+77e3 1fe20400 copy pdata ,temp 
+77e4 ea420000 ifetch 4 ,regb 
+77e5 9842fe00 iflip temp ,pdata 
+77e6 2422f7ea nbranch compare4_failed ,zero 
+77e7 1a20a204 increase 4 ,rega 
+77e8 1a40a404 increase 4 ,regb 
+77e9 202077e0 branch compare4 
+
+compare4_failed:
+77ea 7840fc00 disable true 
+77eb 20600000 rtn 
+
+compare4_success:
+77ec 7820fc00 enable true 
+77ed 20600000 rtn 
+
+simple_pairing_sequence:
+77ee 79200025 set1 mark_ext_patch ,mark 
+77ef 44fac03e bpatch patch3e_5 ,mem_patch3e 
+77f0 680087dc fetch 1 ,mem_sp_flag 
+77f1 207a0000 rtn blank 
+77f2 7007dc00 jam sp_flag_standby ,mem_sp_flag 
+77f3 680087da fetch 1 ,mem_sp_state 
+77f4 c001e117 beq sp_stat_key_send ,sp_send_lmp_encapsulated_header 
+77f5 c002e134 beq sp_stat_commit_send ,sp_send_lmp_simple_pairing_comfirm 
+77f6 c003e13f beq sp_stat_random_send ,sp_send_lmp_simple_pairing_number 
+77f7 c005e155 beq sp_stat_confirm_send ,sp_send_lmp_dhkey_check 
+77f8 c0017725 beq sp_stat_key_generate ,sp_generate_local_key 
+77f9 c0027732 beq sp_stat_commit_calc ,sp_calculate_commitment 
+77fa c004f752 beq sp_stat_confirm_check ,sp_confirm_check 
+77fb c0057771 beq sp_stat_confirm_calc ,sp_confirm_calc 
+77fc c006778f beq sp_stat_link_key_calc ,sp_link_key_prarm_push 
+77fd 20600000 rtn 
+
+master_simple_paring_sequence:
+77fe 79200025 set1 mark_ext_patch ,mark 
+77ff 44fb403e bpatch patch3e_6 ,mem_patch3e 
+7800 680087dd fetch 1 ,mem_master_sp_flag 
+7801 207a0000 rtn blank 
+7802 7007dd00 jam sp_flag_standby ,mem_master_sp_flag 
+7803 680087db fetch 1 ,mem_master_sp_state 
+7804 c00960f7 beq sp_master_stat_start_skip ,sp_master_send_io_cap_get 
+7805 c009e0ff beq sp_master_stat_start_done ,sp_master_send_io_cap_send 
+7806 c001e103 beq sp_stat_key_send ,sp_master_send_lmp_encapsulated_header 
+7807 c002773d beq sp_stat_commit_calc ,master_sp_calculate_commitment 
+7808 c00a6107 beq sp_stat_commitment_compare ,sp_master_commitment_compare 
+7809 c003e115 beq sp_stat_random_send ,sp_master_send_lmp_simple_pairing_number 
+780a c0057771 beq sp_stat_confirm_calc ,sp_confirm_calc 
+780b c005e154 beq sp_stat_confirm_send ,master_sp_send_lmp_dhkey_check 
+780c c004f752 beq sp_stat_confirm_check ,sp_confirm_check 
+780d c00ae14e beq sp_state_end ,master_sp_sm_end 
+780e 20600000 rtn 
+
+master_set_mem_master_sp_flag:
+780f 7007dd01 jam sp_flag_commit ,mem_master_sp_flag 
+7810 20600000 rtn 
+
+master_clear_mem_master_sp_flag:
+7811 7007dd00 jam sp_flag_standby ,mem_master_sp_flag 
+7812 20600000 rtn 
+
+sp_calc_sequence:
+7813 79200025 set1 mark_ext_patch ,mark 
+7814 44fbc03e bpatch patch3e_7 ,mem_patch3e 
+7815 680087de fetch 1 ,mem_sp_calc 
+7816 207a0000 rtn blank 
+7817 1fe0fe80 increase 0x80 ,pdata 
+7818 600087de store 1 ,mem_sp_calc 
+7819 c3838000 rtnbit1 7 
+781a 68008581 fetch 1 ,mem_ec_loopc 
+781b 203a781d branch sp_calc_sequence_done ,blank 
+781c 20207b8a branch eckp_calc 
+
+sp_calc_sequence_done:
+781d 20407a0c call ecunmapz 
+781e 680087de fetch 1 ,mem_sp_calc 
+781f c000f7bc beq sp_calc_pubkey ,sp_pubkey_generated 
+7820 c00177d4 beq sp_calc_dhkey ,sp_dhkey_generated 
+7821 20600000 rtn 
+
+bn_testbit:
+7822 1fe10e07 and pdata ,7 ,queue 
+7823 1fe97e00 rshift3 pdata ,pdata 
+7824 98c08c00 iadd contr ,contr 
+7825 e8c08000 ifetch 1 ,contr 
+7826 afec0000 qisolate0 pdata 
+7827 20600000 rtn 
+
+ec_copy:
+7828 20407e33 call memcpy24 
+7829 20407e33 call memcpy24 
+782a 20207e33 branch memcpy24 
+
+bn_eq_zero:
+782b e8c40000 ifetch 8 ,contr 
+782c 247a0000 nrtn blank 
+782d e8c40000 ifetch 8 ,contr 
+782e 247a0000 nrtn blank 
+782f e8c40000 ifetch 8 ,contr 
+7830 20600000 rtn 
+
+bn_eq:
+7831 18007206 force 6 ,loopcnt 
+
+bn_eq_0:
+7832 ea220000 ifetch 4 ,rega 
+7833 98000400 iforce temp 
+7834 ea420000 ifetch 4 ,regb 
+7835 98467c00 isub temp ,null 
+7836 24628000 nrtn zero 
+7837 1a20a204 increase 4 ,rega 
+7838 1a40a404 increase 4 ,regb 
+7839 c2007832 loop bn_eq_0 
+783a 20600000 rtn 
+
+bn_bigeq:
+783b 18007206 force 6 ,loopcnt 
+783c 1a20a214 increase 20 ,rega 
+783d 1a40a414 increase 20 ,regb 
+
+bn_bigeq_0:
+783e ea420000 ifetch 4 ,regb 
+783f 98000400 iforce temp 
+7840 ea220000 ifetch 4 ,rega 
+7841 98467e00 isub temp ,pdata 
+7842 24610000 nrtn positive 
+7843 247a0000 nrtn blank 
+7844 1a20a3fc increase -4 ,rega 
+7845 1a40a5fc increase -4 ,regb 
+7846 c200783e loop bn_bigeq_0 
+7847 20600000 rtn 
+
+bn_add:
+7848 18007206 force 6 ,loopcnt 
+7849 18002600 force 0 ,regc 
+
+bn_add_0:
+784a ea220000 ifetch 4 ,rega 
+784b 98000400 iforce temp 
+784c ea420000 ifetch 4 ,regb 
+784d 9840fe00 iadd temp ,pdata 
+784e 9a60fe00 iadd regc ,pdata 
+784f e0a20000 istore 4 ,contw 
+7850 2feffe20 isolate1 32 ,pdata 
+7851 7920a600 setflag true ,0 ,regc 
+7852 1a20a204 increase 4 ,rega 
+7853 1a40a404 increase 4 ,regb 
+7854 c200784a loop bn_add_0 
+7855 20600000 rtn 
+
+bn_sub:
+7856 18007206 force 6 ,loopcnt 
+7857 18002600 force 0 ,regc 
+
+bn_sub_0:
+7858 ea420000 ifetch 4 ,regb 
+7859 98000400 iforce temp 
+785a ea220000 ifetch 4 ,rega 
+785b 98467e00 isub temp ,pdata 
+785c 9a667e00 isub regc ,pdata 
+785d e0a20000 istore 4 ,contw 
+785e 2feffe20 isolate1 32 ,pdata 
+785f 7920a600 setflag true ,0 ,regc 
+7860 1a20a204 increase 4 ,rega 
+7861 1a40a404 increase 4 ,regb 
+7862 c2007858 loop bn_sub_0 
+7863 20600000 rtn 
+
+bn_rshift6:
+7864 18007206 force 6 ,loopcnt 
+7865 1a20a214 increase 20 ,rega 
+
+bn_rshift:
+7866 18002600 force 0 ,regc 
+
+bn_rshift_0:
+7867 ea220000 ifetch 4 ,rega 
+7868 2feffe00 isolate1 0 ,pdata 
+7869 7920a601 setflag true ,1 ,regc 
+786a 1fe37e00 rshift pdata ,pdata 
+786b 2a6ffe00 isolate1 0 ,regc 
+786c 7920fe1f setflag true ,31 ,pdata 
+786d e2220000 istore 4 ,rega 
+786e 1a20a3fc increase -4 ,rega 
+786f 1a632600 rshift regc ,regc 
+7870 c2007867 loop bn_rshift_0 
+7871 20600000 rtn 
+
+bn_lshift:
+7872 18007206 force 6 ,loopcnt 
+7873 18002600 force 0 ,regc 
+
+bn_lshift_0:
+7874 ea220000 ifetch 4 ,rega 
+7875 2feffe1f isolate1 31 ,pdata 
+7876 7920a601 setflag true ,1 ,regc 
+7877 1fe3fe00 lshift pdata ,pdata 
+7878 2a6ffe00 isolate1 0 ,regc 
+7879 7920fe00 setflag true ,0 ,pdata 
+787a e2220000 istore 4 ,rega 
+787b 1a20a204 increase 4 ,rega 
+787c 1a632600 rshift regc ,regc 
+787d c2007874 loop bn_lshift_0 
+787e 20600000 rtn 
+
+bn_lshiftmod:
+787f 20407872 call bn_lshift 
+
+bn_lshiftmod_ismod:
+7880 2a6ffe00 isolate1 0 ,regc 
+7881 2020f888 branch bn_lshiftmod_0 ,true 
+7882 da400742 arg mem_p ,regb 
+7883 1a222600 copy rega ,regc 
+7884 1a20a3e8 increase -24 ,rega 
+7885 2040783b call bn_bigeq 
+7886 24610000 nrtn positive 
+7887 1a622200 copy regc ,rega 
+
+bn_lshiftmod_0:
+7888 1a20a3e8 increase -24 ,rega 
+7889 da400742 arg mem_p ,regb 
+788a 1a220a00 copy rega ,contw 
+788b 20207856 branch bn_sub 
+
+bn_addmod:
+788c 20407848 call bn_add 
+788d 18a22200 copy contw ,rega 
+788e 20207880 branch bn_lshiftmod_ismod 
+
+bn_submod:
+788f 20407856 call bn_sub 
+7890 2a6c0000 isolate0 0 ,regc 
+7891 20608000 rtn true 
+7892 da400742 arg mem_p ,regb 
+7893 18a0a3e8 add contw ,-24 ,rega 
+7894 1a220a00 copy rega ,contw 
+7895 20207848 branch bn_add 
+
+bn_p192mod:
+7896 18a21600 copy contw ,timeup 
+7897 1a226000 copy rega ,alarm 
+7898 da4006b2 arg mem_tmp2 ,regb 
+7899 1a420a00 copy regb ,contw 
+789a 1a208c18 add rega ,24 ,contr 
+789b e8c40000 ifetch 8 ,contr 
+789c e0a40000 istore 8 ,contw 
+789d e0a40000 istore 8 ,contw 
+789e 18007e00 force 0 ,pdata 
+789f e0a40000 istore 8 ,contw 
+78a0 19620a00 copy timeup ,contw 
+78a1 2040788c call bn_addmod 
+78a2 da4006b2 arg mem_tmp2 ,regb 
+78a3 1a420a00 copy regb ,contw 
+78a4 18007e00 force 0 ,pdata 
+78a5 e0a40000 istore 8 ,contw 
+78a6 1e008c20 add alarm ,32 ,contr 
+78a7 e8c40000 ifetch 8 ,contr 
+78a8 e0a40000 istore 8 ,contw 
+78a9 e0a40000 istore 8 ,contw 
+78aa 19622200 copy timeup ,rega 
+78ab 1a220a00 copy rega ,contw 
+78ac 2040788c call bn_addmod 
+78ad da4006b2 arg mem_tmp2 ,regb 
+78ae 1a420a00 copy regb ,contw 
+78af 1e008c28 add alarm ,40 ,contr 
+78b0 e8c40000 ifetch 8 ,contr 
+78b1 e0a40000 istore 8 ,contw 
+78b2 e0a40000 istore 8 ,contw 
+78b3 e0a40000 istore 8 ,contw 
+78b4 19622200 copy timeup ,rega 
+78b5 1a220a00 copy rega ,contw 
+78b6 2020788c branch bn_addmod 
+
+bn_load:
+78b7 18007206 force 6 ,loopcnt 
+
+bn_load_0:
+78b8 e8c20000 ifetch 4 ,contr 
+78b9 98005e00 iforce regext 
+78ba 1f00f001 increase 1 ,regext_index 
+78bb c20078b8 loop bn_load_0 
+78bc 20600000 rtn 
+
+bn_mulmod:
+78bd 18a21600 copy contw ,timeup 
+78be d8a00682 arg mem_tmp1 ,contw 
+78bf 20407e3a call bn_zero 
+78c0 d8a00682 arg mem_tmp1 ,contw 
+78c1 1a220c00 copy rega ,contr 
+78c2 18007000 force 0 ,regext_index 
+78c3 204078b7 call bn_load 
+78c4 1a420c00 copy regb ,contr 
+78c5 204078b7 call bn_load 
+78c6 18002400 force 0 ,regb 
+
+bn_mulmod_1:
+78c7 18000400 force 0 ,temp 
+78c8 18002606 force 6 ,regc 
+
+bn_mulmod_0:
+78c9 e8a20000 ifetch 4 ,contw 
+78ca 98002200 iforce rega 
+78cb 1a427000 copy regb ,regext_index 
+78cc 1de27e00 deposit regext 
+78cd 1a627000 copy regc ,regext_index 
+78ce 9deffe00 imul32 regext ,pdata 
+78cf 9a20fe00 iadd rega ,pdata 
+78d0 9840fe00 iadd temp ,pdata 
+78d1 e0a20000 istore 4 ,contw 
+78d2 1fef0400 rshift32 pdata ,temp 
+78d3 1a60a601 increase 1 ,regc 
+78d4 2a61fe0c compare 12 ,regc ,0xff 
+78d5 2420f8c9 nbranch bn_mulmod_0 ,true 
+78d6 18427e00 deposit temp 
+78d7 e0a20000 istore 4 ,contw 
+78d8 18a08be8 increase -24 ,contw 
+78d9 1a40a401 increase 1 ,regb 
+78da 2a41fe06 compare 6 ,regb ,0xff 
+78db 2420f8c7 nbranch bn_mulmod_1 ,true 
+78dc da200682 arg mem_tmp1 ,rega 
+78dd 19620a00 copy timeup ,contw 
+78de 20207896 branch bn_p192mod 
+
+bn_sqrmod:
+78df 1a222400 copy rega ,regb 
+78e0 202078bd branch bn_mulmod 
+
+bn_rshifteven:
+78e1 1a226000 copy rega ,alarm 
+
+bn_rshifteven_1:
+78e2 1e022200 copy alarm ,rega 
+78e3 ea208000 ifetch 1 ,rega 
+78e4 2feffe00 isolate1 0 ,pdata 
+78e5 20608000 rtn true 
+78e6 20407864 call bn_rshift6 
+78e7 ea408000 ifetch 1 ,regb 
+78e8 2fec0000 isolate0 0 ,pdata 
+78e9 2020f8f1 branch bn_rshifteven_0 ,true 
+78ea da200742 arg mem_p ,rega 
+78eb 1a420a00 copy regb ,contw 
+78ec 20407848 call bn_add 
+78ed ea408000 ifetch 1 ,regb 
+78ee 9a60fe00 iadd regc ,pdata 
+78ef e2408000 istore 1 ,regb 
+78f0 1a40a5e8 increase -24 ,regb 
+
+bn_rshifteven_0:
+78f1 1a40a218 add regb ,24 ,rega 
+78f2 18007207 force 7 ,loopcnt 
+78f3 20407866 call bn_rshift 
+78f4 202078e2 branch bn_rshifteven_1 
+
+bn_invmod:
+78f5 18a21600 copy contw ,timeup 
+78f6 d8a006e2 arg mem_tmp0 ,contw 
+78f7 20407e3a call bn_zero 
+78f8 18007e00 force 0 ,pdata 
+78f9 6002069a store 4 ,mem_tmp5 
+78fa 600206fa store 4 ,mem_t2 
+78fb 7006e201 jam 1 ,mem_tmp0 
+78fc d8a00682 arg mem_tmp1 ,contw 
+78fd 20407e3a call bn_zero 
+78fe d8c00742 arg mem_p ,contr 
+78ff d8a006b2 arg mem_tmp2 ,contw 
+7900 20407e33 call memcpy24 
+7901 1a220c00 copy rega ,contr 
+7902 d8a006ca arg mem_tmp3 ,contw 
+7903 20407e33 call memcpy24 
+
+bn_invmod_2:
+7904 d8c006ca arg mem_tmp3 ,contr 
+7905 2040782b call bn_eq_zero 
+7906 203a792d branch bn_invmod_0 ,blank 
+7907 da2006ca arg mem_tmp3 ,rega 
+7908 da4006e2 arg mem_tmp0 ,regb 
+7909 204078e1 call bn_rshifteven 
+790a da2006b2 arg mem_tmp2 ,rega 
+790b da400682 arg mem_tmp1 ,regb 
+790c 204078e1 call bn_rshifteven 
+790d da2006ca arg mem_tmp3 ,rega 
+790e da4006b2 arg mem_tmp2 ,regb 
+790f 2040783b call bn_bigeq 
+7910 2021791f branch bn_invmod_1 ,positive 
+7911 da2006b2 arg mem_tmp2 ,rega 
+7912 da4006ca arg mem_tmp3 ,regb 
+7913 1a220a00 copy rega ,contw 
+7914 20407856 call bn_sub 
+7915 da2006e2 arg mem_tmp0 ,rega 
+7916 da400682 arg mem_tmp1 ,regb 
+7917 1a420a00 copy regb ,contw 
+7918 20407848 call bn_add 
+7919 ea208000 ifetch 1 ,rega 
+791a 9a60a600 iadd regc ,regc 
+791b ea408000 ifetch 1 ,regb 
+791c 9a60fe00 iadd regc ,pdata 
+791d e2408000 istore 1 ,regb 
+791e 20207904 branch bn_invmod_2 
+
+bn_invmod_1:
+791f da2006ca arg mem_tmp3 ,rega 
+7920 da4006b2 arg mem_tmp2 ,regb 
+7921 1a220a00 copy rega ,contw 
+7922 20407856 call bn_sub 
+7923 da200682 arg mem_tmp1 ,rega 
+7924 da4006e2 arg mem_tmp0 ,regb 
+7925 1a420a00 copy regb ,contw 
+7926 20407848 call bn_add 
+7927 ea208000 ifetch 1 ,rega 
+7928 9a60a600 iadd regc ,regc 
+7929 ea408000 ifetch 1 ,regb 
+792a 9a60fe00 iadd regc ,pdata 
+792b e2408000 istore 1 ,regb 
+792c 20207904 branch bn_invmod_2 
+
+bn_invmod_0:
+792d d8a006e2 arg mem_tmp0 ,contw 
+792e 20407e3a call bn_zero 
+792f 6800869a fetch 1 ,mem_tmp5 
+7930 600086e2 store 1 ,mem_tmp0 
+7931 600086ea store 1 ,mem_tmp0a 
+7932 da2006e2 arg mem_tmp0 ,rega 
+7933 da400682 arg mem_tmp1 ,regb 
+7934 1a420a00 copy regb ,contw 
+7935 2040788c call bn_addmod 
+7936 da200742 arg mem_p ,rega 
+7937 da400682 arg mem_tmp1 ,regb 
+7938 19620a00 copy timeup ,contw 
+7939 2020788f branch bn_submod 
+
+ecdbl:
+793a da200642 arg mem_cz ,rega 
+793b d8a006fa arg mem_t2 ,contw 
+793c 204078df call bn_sqrmod 
+793d da2006fa arg mem_t2 ,rega 
+793e d8a00712 arg mem_t3 ,contw 
+793f 204078df call bn_sqrmod 
+7940 da20075a arg mem_a ,rega 
+7941 da400712 arg mem_t3 ,regb 
+7942 d8a00712 arg mem_t3 ,contw 
+7943 204078bd call bn_mulmod 
+7944 da200612 arg mem_cx ,rega 
+7945 d8a006fa arg mem_t2 ,contw 
+7946 204078df call bn_sqrmod 
+7947 d8c006fa arg mem_t2 ,contr 
+7948 d8a006ca arg mem_t1 ,contw 
+7949 20407e33 call memcpy24 
+794a da2006ca arg mem_t1 ,rega 
+794b 2040787f call bn_lshiftmod 
+794c da2006fa arg mem_t2 ,rega 
+794d da4006ca arg mem_t1 ,regb 
+794e d8a006fa arg mem_t2 ,contw 
+794f 2040788c call bn_addmod 
+7950 da2006fa arg mem_t2 ,rega 
+7951 da400712 arg mem_t3 ,regb 
+7952 d8a006fa arg mem_t2 ,contw 
+7953 2040788c call bn_addmod 
+7954 d8c00612 arg mem_cx ,contr 
+7955 d8a006ca arg mem_t1 ,contw 
+7956 20407e33 call memcpy24 
+7957 da20062a arg mem_cy ,rega 
+7958 d8a00712 arg mem_t3 ,contw 
+7959 204078df call bn_sqrmod 
+795a da2006ca arg mem_t1 ,rega 
+795b 2040787f call bn_lshiftmod 
+795c da2006ca arg mem_t1 ,rega 
+795d 2040787f call bn_lshiftmod 
+795e da2006ca arg mem_t1 ,rega 
+795f da400712 arg mem_t3 ,regb 
+7960 d8a006ca arg mem_t1 ,contw 
+7961 204078bd call bn_mulmod 
+7962 da200712 arg mem_t3 ,rega 
+7963 d8a006e2 arg mem_t0 ,contw 
+7964 204078df call bn_sqrmod 
+7965 da2006e2 arg mem_t0 ,rega 
+7966 2040787f call bn_lshiftmod 
+7967 da2006e2 arg mem_t0 ,rega 
+7968 2040787f call bn_lshiftmod 
+7969 da2006e2 arg mem_t0 ,rega 
+796a 2040787f call bn_lshiftmod 
+796b d8c0062a arg mem_cy ,contr 
+796c d8a00712 arg mem_t3 ,contw 
+796d 20407e33 call memcpy24 
+796e da200712 arg mem_t3 ,rega 
+796f 2040787f call bn_lshiftmod 
+7970 da200712 arg mem_t3 ,rega 
+7971 da400642 arg mem_cz ,regb 
+7972 d8a00642 arg mem_cz ,contw 
+7973 204078bd call bn_mulmod 
+7974 da2006fa arg mem_t2 ,rega 
+7975 d8a00712 arg mem_t3 ,contw 
+7976 204078df call bn_sqrmod 
+7977 da200712 arg mem_t3 ,rega 
+7978 da4006ca arg mem_t1 ,regb 
+7979 d8a00712 arg mem_t3 ,contw 
+797a 2040788f call bn_submod 
+797b da200712 arg mem_t3 ,rega 
+797c da4006ca arg mem_t1 ,regb 
+797d d8a00612 arg mem_cx ,contw 
+797e 2040788f call bn_submod 
+797f da2006ca arg mem_t1 ,rega 
+7980 da400612 arg mem_cx ,regb 
+7981 d8a00712 arg mem_t3 ,contw 
+7982 2040788f call bn_submod 
+7983 da200712 arg mem_t3 ,rega 
+7984 da4006fa arg mem_t2 ,regb 
+7985 d8a00712 arg mem_t3 ,contw 
+7986 204078bd call bn_mulmod 
+7987 da200712 arg mem_t3 ,rega 
+7988 da4006e2 arg mem_t0 ,regb 
+7989 d8a0062a arg mem_cy ,contw 
+798a 2020788f branch bn_submod 
+
+ecadd:
+798b da2005b2 arg mem_az ,rega 
+798c d8a0072a arg mem_t7 ,contw 
+798d 204078df call bn_sqrmod 
+798e da200612 arg mem_cx ,rega 
+798f da40072a arg mem_t7 ,regb 
+7990 d8a006e2 arg mem_t0 ,contw 
+7991 204078bd call bn_mulmod 
+7992 da2005b2 arg mem_az ,rega 
+7993 da40072a arg mem_t7 ,regb 
+7994 d8a0072a arg mem_t7 ,contw 
+7995 204078bd call bn_mulmod 
+7996 da20062a arg mem_cy ,rega 
+7997 da40072a arg mem_t7 ,regb 
+7998 d8a006ca arg mem_t1 ,contw 
+7999 204078bd call bn_mulmod 
+799a da200642 arg mem_cz ,rega 
+799b d8a0072a arg mem_t7 ,contw 
+799c 204078df call bn_sqrmod 
+799d da200582 arg mem_ax ,rega 
+799e da40072a arg mem_t7 ,regb 
+799f d8a006fa arg mem_t2 ,contw 
+79a0 204078bd call bn_mulmod 
+79a1 da200642 arg mem_cz ,rega 
+79a2 da40072a arg mem_t7 ,regb 
+79a3 d8a0072a arg mem_t7 ,contw 
+79a4 204078bd call bn_mulmod 
+79a5 da20059a arg mem_ay ,rega 
+79a6 da40072a arg mem_t7 ,regb 
+79a7 d8a00712 arg mem_t3 ,contw 
+79a8 204078bd call bn_mulmod 
+79a9 da2006e2 arg mem_t0 ,rega 
+79aa da4006fa arg mem_t2 ,regb 
+79ab d8a0072a arg mem_t7 ,contw 
+79ac 2040788f call bn_submod 
+79ad da2006e2 arg mem_t0 ,rega 
+79ae da4006fa arg mem_t2 ,regb 
+79af d8a006e2 arg mem_t0 ,contw 
+79b0 2040788c call bn_addmod 
+79b1 da2006ca arg mem_t1 ,rega 
+79b2 da400712 arg mem_t3 ,regb 
+79b3 d8a006fa arg mem_t2 ,contw 
+79b4 2040788f call bn_submod 
+79b5 da2006ca arg mem_t1 ,rega 
+79b6 da400712 arg mem_t3 ,regb 
+79b7 d8a006ca arg mem_t1 ,contw 
+79b8 2040788c call bn_addmod 
+79b9 da2006ca arg mem_t1 ,rega 
+79ba da40072a arg mem_t7 ,regb 
+79bb d8a006ca arg mem_t1 ,contw 
+79bc 204078bd call bn_mulmod 
+79bd da200642 arg mem_cz ,rega 
+79be da4005b2 arg mem_az ,regb 
+79bf d8a00712 arg mem_t3 ,contw 
+79c0 204078bd call bn_mulmod 
+79c1 da200712 arg mem_t3 ,rega 
+79c2 da40072a arg mem_t7 ,regb 
+79c3 d8a00642 arg mem_cz ,contw 
+79c4 204078bd call bn_mulmod 
+79c5 da20072a arg mem_t7 ,rega 
+79c6 d8a0072a arg mem_t7 ,contw 
+79c7 204078df call bn_sqrmod 
+79c8 da20072a arg mem_t7 ,rega 
+79c9 da4006e2 arg mem_t0 ,regb 
+79ca d8a00712 arg mem_t3 ,contw 
+79cb 204078bd call bn_mulmod 
+79cc da20072a arg mem_t7 ,rega 
+79cd da4006ca arg mem_t1 ,regb 
+79ce d8a006ca arg mem_t1 ,contw 
+79cf 204078bd call bn_mulmod 
+79d0 da2006fa arg mem_t2 ,rega 
+79d1 d8a00612 arg mem_cx ,contw 
+79d2 204078df call bn_sqrmod 
+79d3 da200612 arg mem_cx ,rega 
+79d4 da400712 arg mem_t3 ,regb 
+79d5 d8a00612 arg mem_cx ,contw 
+79d6 2040788f call bn_submod 
+79d7 d8c00612 arg mem_cx ,contr 
+79d8 d8a0072a arg mem_t7 ,contw 
+79d9 20407e33 call memcpy24 
+79da da20072a arg mem_t7 ,rega 
+79db 2040787f call bn_lshiftmod 
+79dc da200712 arg mem_t3 ,rega 
+79dd da40072a arg mem_t7 ,regb 
+79de d8a00712 arg mem_t3 ,contw 
+79df 2040788f call bn_submod 
+79e0 da200712 arg mem_t3 ,rega 
+79e1 da4006fa arg mem_t2 ,regb 
+79e2 d8a006fa arg mem_t2 ,contw 
+79e3 204078bd call bn_mulmod 
+79e4 da2006fa arg mem_t2 ,rega 
+79e5 da4006ca arg mem_t1 ,regb 
+79e6 d8a0062a arg mem_cy ,contw 
+79e7 2040788f call bn_submod 
+79e8 da20062a arg mem_cy ,rega 
+79e9 da400742 arg mem_p ,regb 
+79ea d8a0062a arg mem_cy ,contw 
+79eb 18002600 force 0 ,regc 
+79ec 6800862a fetch 1 ,mem_cy 
+79ed 2feffe00 isolate1 0 ,pdata 
+79ee 2040f848 call bn_add ,true 
+79ef 1a626000 copy regc ,alarm 
+79f0 da20062a arg mem_cy ,rega 
+79f1 20407864 call bn_rshift6 
+79f2 68008641 fetch 1 ,mem_cy5 
+79f3 2e0ffe00 isolate1 0 ,alarm 
+79f4 7920fe07 setflag true ,7 ,pdata 
+79f5 60008641 store 1 ,mem_cy5 
+79f6 20600000 rtn 
+
+eckp:
+79f7 700581c0 jam 192 ,mem_ec_loopc 
+79f8 70058001 jam 1 ,mem_ec_infinite 
+
+eckp_0:
+79f9 68008581 fetch 1 ,mem_ec_loopc 
+79fa 1fe0ffff increase -1 ,pdata 
+79fb 24610000 nrtn positive 
+79fc 60008581 store 1 ,mem_ec_loopc 
+79fd 68008580 fetch 1 ,mem_ec_infinite 
+79fe 205a793a call ecdbl ,blank 
+79ff 68008581 fetch 1 ,mem_ec_loopc 
+7a00 d8c0065a arg mem_k ,contr 
+7a01 20407822 call bn_testbit 
+7a02 2020f9f9 branch eckp_0 ,true 
+7a03 68008580 fetch 1 ,mem_ec_infinite 
+7a04 243a7a07 nbranch eckp_1 ,blank 
+7a05 2040798b call ecadd 
+7a06 202079f9 branch eckp_0 
+
+eckp_1:
+7a07 70058000 jam 0 ,mem_ec_infinite 
+7a08 d8c00582 arg mem_ax ,contr 
+7a09 d8a00612 arg mem_cx ,contw 
+7a0a 20407828 call ec_copy 
+7a0b 202079f9 branch eckp_0 
+
+ecunmapz:
+7a0c da200642 arg mem_cz ,rega 
+7a0d d8a00712 arg mem_t3 ,contw 
+7a0e 204078f5 call bn_invmod 
+7a0f da200712 arg mem_t3 ,rega 
+7a10 d8a006ca arg mem_t1 ,contw 
+7a11 204078df call bn_sqrmod 
+7a12 da200612 arg mem_cx ,rega 
+7a13 da4006ca arg mem_t1 ,regb 
+7a14 d8a005ca arg mem_bx ,contw 
+7a15 204078bd call bn_mulmod 
+7a16 da200712 arg mem_t3 ,rega 
+7a17 da4006ca arg mem_t1 ,regb 
+7a18 d8a006fa arg mem_t2 ,contw 
+7a19 204078bd call bn_mulmod 
+7a1a da20062a arg mem_cy ,rega 
+7a1b da4006fa arg mem_t2 ,regb 
+7a1c d8a005e2 arg mem_by ,contw 
+7a1d 202078bd branch bn_mulmod 
+
+sha_endian_swap:
+7a1e 18007210 force 16 ,loopcnt 
+
+sha_endian_swap2:
+7a1f e8c20000 ifetch 4 ,contr 
+7a20 18002204 force 4 ,rega 
+7a21 18a08a03 increase 3 ,contw 
+
+sha_endian_loop:
+7a22 e0a08000 istore 1 ,contw 
+7a23 1fecfe00 rshift8 pdata ,pdata 
+7a24 18a08bfe increase -2 ,contw 
+7a25 1a20a3ff increase -1 ,rega 
+7a26 2422fa22 nbranch sha_endian_loop ,zero 
+7a27 18a08a05 increase 5 ,contw 
+7a28 c2007a1f loop sha_endian_swap2 
+7a29 20600000 rtn 
+
+sha_getw:
+7a2a 18ebfe00 lshift2 queue ,pdata 
+7a2b 99608c00 iadd timeup ,contr 
+7a2c e8c20000 ifetch 4 ,contr 
+7a2d 20600000 rtn 
+
+sha_r:
+7a2e 18006010 force 16 ,alarm 
+7a2f d9600582 arg memdat ,timeup 
+
+sha_r_loop:
+7a30 1e008ff9 add alarm ,-7 ,queue 
+7a31 20407a2a call sha_getw 
+7a32 98000400 iforce temp 
+7a33 1e008ff0 add alarm ,-16 ,queue 
+7a34 20407a2a call sha_getw 
+7a35 98408400 iadd temp ,temp 
+7a36 1e008ffe add alarm ,-2 ,queue 
+7a37 20407a2a call sha_getw 
+7a38 1fee7e01 shasx pdata ,1 ,pdata 
+7a39 98408400 iadd temp ,temp 
+7a3a 1e008ff1 add alarm ,-15 ,queue 
+7a3b 20407a2a call sha_getw 
+7a3c 1fee7e00 shasx pdata ,0 ,pdata 
+7a3d 98408400 iadd temp ,temp 
+7a3e 1e0bfe00 lshift2 alarm ,pdata 
+7a3f 99608a00 iadd timeup ,contw 
+7a40 e0aa0000 istoret 4 ,contw 
+7a41 1e00e001 increase 1 ,alarm 
+7a42 2e01fe40 compare 64 ,alarm ,0xff 
+7a43 2420fa30 nbranch sha_r_loop ,true 
+7a44 20600000 rtn 
+
+sha_init:
+7a45 d8c007ba arg memh0 ,contr 
+7a46 18007007 force 7 ,regext_index 
+
+sha_init_0:
+7a47 e8c20000 ifetch 4 ,contr 
+7a48 98005e00 iforce regext 
+7a49 1f00f1ff increase -1 ,regext_index 
+7a4a 20217a47 branch sha_init_0 ,positive 
+7a4b 20600000 rtn 
+
+sha:
+7a4c 79200025 set1 mark_ext_patch ,mark 
+7a4d 44fc403f bpatch patch3f_0 ,mem_patch3f 
+7a4e 20407a2e call sha_r 
+7a4f d8a00682 arg memahbak ,contw 
+7a50 18007000 force 0 ,regext_index 
+
+sha_0:
+7a51 1de27e00 deposit regext 
+7a52 e0a20000 istore 4 ,contw 
+7a53 1f00f001 increase 1 ,regext_index 
+7a54 2f01fe08 compare 8 ,regext_index ,0xff 
+7a55 2420fa51 nbranch sha_0 ,true 
+7a56 204075c5 call enable_authrom 
+7a57 d9608700 arg memk ,timeup 
+7a58 de000582 arg memdat ,alarm 
+7a59 18007240 force 64 ,loopcnt 
+
+sha_loop:
+7a5a ee0a0000 ifetcht 4 ,alarm 
+7a5b e9620000 ifetch 4 ,timeup 
+7a5c 19609604 increase 4 ,timeup 
+7a5d 1e00e004 increase 4 ,alarm 
+7a5e 9840fe00 iadd temp ,pdata 
+7a5f 18007007 force 7 ,regext_index 
+7a60 9de08400 iadd regext ,temp 
+7a61 18007004 force 4 ,regext_index 
+7a62 1dee7e03 shasx regext ,3 ,pdata 
+7a63 98408400 iadd temp ,temp 
+7a64 18007005 force 5 ,regext_index 
+7a65 1de27e00 deposit regext 
+7a66 18007006 force 6 ,regext_index 
+7a67 9de2fe00 ixor regext ,pdata 
+7a68 18007004 force 4 ,regext_index 
+7a69 9de17e00 iand regext ,pdata 
+7a6a 18007006 force 6 ,regext_index 
+7a6b 9de2fe00 ixor regext ,pdata 
+7a6c 98408400 iadd temp ,temp 
+7a6d 18007007 force 7 ,regext_index 
+7a6e 18425e00 copy temp ,regext 
+7a6f 18007003 force 3 ,regext_index 
+7a70 1de27e00 deposit regext 
+7a71 9840de00 iadd temp ,regext 
+7a72 18007000 force 0 ,regext_index 
+7a73 1de27e00 deposit regext 
+7a74 18007001 force 1 ,regext_index 
+7a75 9de10400 iand regext ,temp 
+7a76 9de1fe00 ior regext ,pdata 
+7a77 18007002 force 2 ,regext_index 
+7a78 9de17e00 iand regext ,pdata 
+7a79 98418400 ior temp ,temp 
+7a7a 18007000 force 0 ,regext_index 
+7a7b 1dee7e02 shasx regext ,2 ,pdata 
+7a7c 9840fe00 iadd temp ,pdata 
+7a7d 18007007 force 7 ,regext_index 
+7a7e 9de0de00 iadd regext ,regext 
+7a7f 980efc00 regexrot 
+7a80 c2007a5a loop sha_loop 
+7a81 d8c00682 arg memahbak ,contr 
+7a82 18007000 force 0 ,regext_index 
+
+sha_1:
+7a83 e8c20000 ifetch 4 ,contr 
+7a84 9de0de00 iadd regext ,regext 
+7a85 1f00f001 increase 1 ,regext_index 
+7a86 2f01fe08 compare 8 ,regext_index ,0xff 
+7a87 2420fa83 nbranch sha_1 ,true 
+7a88 202075c9 branch disable_authrom 
+
+sha_result:
+7a89 d8a00858 arg memresult ,contw 
+7a8a 18007007 force 7 ,regext_index 
+
+sha_regext_save:
+7a8b 1de27e00 deposit regext 
+7a8c e0a20000 istore 4 ,contw 
+7a8d 1f00f1ff increase -1 ,regext_index 
+7a8e 20217a8b branch sha_regext_save ,positive 
+7a8f 20600000 rtn 
+
+pad_xor:
+7a90 d8a00582 arg memdat ,contw 
+7a91 18c08dfc increase -4 ,contr 
+7a92 1f262210 sub loopcnt ,16 ,rega 
+
+pad_xor_0:
+7a93 e8c20000 ifetch 4 ,contr 
+7a94 9842fe00 ixor temp ,pdata 
+7a95 e0a20000 istore 4 ,contw 
+7a96 18c08df8 increase -8 ,contr 
+7a97 c2007a93 loop pad_xor_0 
+7a98 1a227200 copy rega ,loopcnt 
+7a99 18427e00 deposit temp 
+
+pad_xor_1:
+7a9a e0a20000 istore 4 ,contw 
+7a9b c2007a9a loop pad_xor_1 
+7a9c 20600000 rtn 
+
+g_noninit:
+7a9d d8c00808 arg mem_sp_pubkey_remote_x_end ,contr 
+7a9e d8a00582 arg memdat ,contw 
+7a9f 18007206 force 6 ,loopcnt 
+7aa0 20407b97 call memcpy_dword_swap 
+7aa1 d8c047c4 arg mem_sp_pubkey_local_x_end ,contr 
+7aa2 18007206 force 6 ,loopcnt 
+7aa3 20407b97 call memcpy_dword_swap 
+7aa4 d8c00858 arg mem_sp_random_remote_end ,contr 
+7aa5 20407b96 call memcpy_dword_swap4 
+7aa6 20407a45 call sha_init 
+7aa7 20407a4c call sha 
+7aa8 d8c00848 arg mem_sp_random_local_end ,contr 
+7aa9 d8a00582 arg memdat ,contw 
+7aaa 20207ab8 branch g_common 
+
+g_init:
+7aab d8c047c4 arg mem_sp_pubkey_local_x_end ,contr 
+7aac d8a00582 arg memdat ,contw 
+7aad 18007206 force 6 ,loopcnt 
+7aae 20407b97 call memcpy_dword_swap 
+7aaf d8c00808 arg mem_sp_pubkey_remote_x_end ,contr 
+7ab0 18007206 force 6 ,loopcnt 
+7ab1 20407b97 call memcpy_dword_swap 
+7ab2 d8c00848 arg mem_sp_random_local_end ,contr 
+7ab3 20407b96 call memcpy_dword_swap4 
+7ab4 20407a45 call sha_init 
+7ab5 20407a4c call sha 
+7ab6 d8c00858 arg mem_sp_random_remote_end ,contr 
+7ab7 d8a00582 arg memdat ,contw 
+
+g_common:
+7ab8 20407b96 call memcpy_dword_swap4 
+7ab9 58800000 setarg 0x800000 
+7aba 1fed7e00 lshift8 pdata ,pdata 
+7abb e0a20000 istore 4 ,contw 
+7abc 18007205 force 5 ,loopcnt 
+7abd 20407e3b call memset0 
+7abe 58000280 setarg 640 
+7abf e0a20000 istore 4 ,contw 
+7ac0 20407a4c call sha 
+7ac1 68020858 fetch 4 ,memresult 
+7ac2 da2003e8 arg 1000 ,rega 
+7ac3 9a26fc00 idiv rega 
+7ac4 20407efd call wait_div_end 
+7ac5 18077e00 remainder pdata 
+7ac6 600207ec store 4 ,mem_sp_gkey 
+7ac7 1807fe00 quotient pdata 
+7ac8 da2003e8 arg 1000 ,rega 
+7ac9 9a26fc00 idiv rega 
+7aca 20407efd call wait_div_end 
+7acb 18077e00 remainder pdata 
+7acc da2003e8 arg 1000 ,rega 
+7acd 9a2ffe00 imul32 rega ,pdata 
+7ace 680a07ec fetcht 4 ,mem_sp_gkey 
+7acf 9840fe00 iadd temp ,pdata 
+7ad0 600207ec store 4 ,mem_sp_gkey 
+7ad1 20600000 rtn 
+
+function_f1:
+7ad2 58363636 setarg 0x363636 
+7ad3 1fed0400 lshift8 pdata ,temp 
+7ad4 18418436 or_into 0x36 ,temp 
+7ad5 68010898 fetch 2 ,mem_sp_prarm_stack 
+7ad6 1fe20c00 copy pdata ,contr 
+7ad7 18007204 force 4 ,loopcnt 
+7ad8 20407a90 call pad_xor 
+7ad9 20407a45 call sha_init 
+7ada 20407a4c call sha 
+7adb 6801089a fetch 2 ,mem_sp_prarm_stack + 2 
+7adc 1fe20c00 copy pdata ,contr 
+7add d8a00582 arg memdat ,contw 
+7ade 18007206 force 6 ,loopcnt 
+7adf 20407b97 call memcpy_dword_swap 
+7ae0 6801089c fetch 2 ,mem_sp_prarm_stack + 4 
+7ae1 1fe20c00 copy pdata ,contr 
+7ae2 18007206 force 6 ,loopcnt 
+7ae3 20407b97 call memcpy_dword_swap 
+7ae4 58800000 setarg 0x800000 
+7ae5 e0a18000 istore 3 ,contw 
+7ae6 18007e00 force 0 ,pdata 
+7ae7 e0a08000 istore 1 ,contw 
+7ae8 18007e00 force 0 ,pdata 
+7ae9 e0a40000 istore 8 ,contw 
+7aea 58000388 setarg 0x0388 
+7aeb e0a20000 istore 4 ,contw 
+7aec 20407a4c call sha 
+7aed 20407a89 call sha_result 
+7aee d8c00858 arg memresult ,contr 
+7aef d8a006a2 arg memahsave ,contw 
+7af0 20407e31 call memcpy32 
+7af1 585c5c5c setarg 0x5c5c5c 
+7af2 1fed0400 lshift8 pdata ,temp 
+7af3 1841845c or_into 0x5c ,temp 
+7af4 68010898 fetch 2 ,mem_sp_prarm_stack 
+7af5 1fe20c00 copy pdata ,contr 
+7af6 18007204 force 4 ,loopcnt 
+7af7 20407a90 call pad_xor 
+7af8 20407a45 call sha_init 
+7af9 20407a4c call sha 
+7afa d8c006c2 arg memahsave_end ,contr 
+7afb d8a00582 arg memdat ,contw 
+7afc 18007208 force 8 ,loopcnt 
+7afd 20407b97 call memcpy_dword_swap 
+7afe 58800000 setarg 0x800000 
+7aff 1fed7e00 lshift8 pdata ,pdata 
+7b00 e0a20000 istore 4 ,contw 
+7b01 20407e3a call bn_zero 
+7b02 58000300 setarg 0x0300 
+7b03 e0a20000 istore 4 ,contw 
+7b04 20407a4c call sha 
+7b05 20207a89 branch sha_result 
+
+function_f2:
+7b06 58363636 setarg 0x363636 
+7b07 1fed0400 lshift8 pdata ,temp 
+7b08 18418436 or_into 0x36 ,temp 
+7b09 d8c00838 arg mem_sp_dhkey_end ,contr 
+7b0a 18007206 force 6 ,loopcnt 
+7b0b 20407a90 call pad_xor 
+7b0c 20407a45 call sha_init 
+7b0d 20407a4c call sha 
+7b0e 680108a4 fetch 2 ,mem_sp_prarm_stack + 12 
+7b0f 1fe20c00 copy pdata ,contr 
+7b10 d8a00582 arg memdat ,contw 
+7b11 20407b96 call memcpy_dword_swap4 
+7b12 680108a6 fetch 2 ,mem_sp_prarm_stack + 14 
+7b13 1fe20c00 copy pdata ,contr 
+7b14 20407b96 call memcpy_dword_swap4 
+7b15 5862746c setarg 0x62746c 
+7b16 1fed7e00 lshift8 pdata ,pdata 
+7b17 1fe1fe6b or_into 0x6b ,pdata 
+7b18 e0a20000 istore 4 ,contw 
+7b19 d8c006cf arg mem_addr_value_end ,contr 
+7b1a 18007203 force 3 ,loopcnt 
+7b1b 20407b97 call memcpy_dword_swap 
+7b1c 58800000 setarg 0x800000 
+7b1d 1fed7e00 lshift8 pdata ,pdata 
+7b1e e0a20000 istore 4 ,contw 
+7b1f 18007e00 force 0 ,pdata 
+7b20 e0a40000 istore 8 ,contw 
+7b21 58000380 setarg 0x0380 
+7b22 e0a20000 istore 4 ,contw 
+7b23 20407a4c call sha 
+7b24 20407a89 call sha_result 
+7b25 d8c00858 arg memresult ,contr 
+7b26 d8a006a2 arg memahsave ,contw 
+7b27 20407e31 call memcpy32 
+7b28 585c5c5c setarg 0x5c5c5c 
+7b29 1fed0400 lshift8 pdata ,temp 
+7b2a 1841845c or_into 0x5c ,temp 
+7b2b d8c00838 arg mem_sp_dhkey_end ,contr 
+7b2c 18007206 force 6 ,loopcnt 
+7b2d 20407a90 call pad_xor 
+7b2e 20407a45 call sha_init 
+7b2f 20407a4c call sha 
+7b30 d8c006c2 arg memahsave_end ,contr 
+7b31 d8a00582 arg memdat ,contw 
+7b32 18007208 force 8 ,loopcnt 
+7b33 20407b97 call memcpy_dword_swap 
+7b34 58800000 setarg 0x800000 
+7b35 1fed7e00 lshift8 pdata ,pdata 
+7b36 e0a20000 istore 4 ,contw 
+7b37 20407e3a call bn_zero 
+7b38 58000300 setarg 0x0300 
+7b39 e0a20000 istore 4 ,contw 
+7b3a 20407a4c call sha 
+7b3b 20207a89 branch sha_result 
+
+function_f3a:
+7b3c 58363636 setarg 0x363636 
+7b3d 1fed0400 lshift8 pdata ,temp 
+7b3e 18418436 or_into 0x36 ,temp 
+7b3f d8c00838 arg mem_sp_dhkey_end ,contr 
+7b40 18007206 force 6 ,loopcnt 
+7b41 20407a90 call pad_xor 
+7b42 20407a45 call sha_init 
+7b43 20407a4c call sha 
+7b44 d8c00858 arg mem_sp_random_remote_end ,contr 
+7b45 d8a00582 arg memdat ,contw 
+7b46 20407b96 call memcpy_dword_swap4 
+7b47 d8c00848 arg mem_sp_random_local_end ,contr 
+7b48 20407b96 call memcpy_dword_swap4 
+7b49 20207b57 branch function_f3b_common 
+
+function_f3b:
+7b4a 58363636 setarg 0x363636 
+7b4b 1fed0400 lshift8 pdata ,temp 
+7b4c 18418436 or_into 0x36 ,temp 
+7b4d d8c00838 arg mem_sp_dhkey_end ,contr 
+7b4e 18007206 force 6 ,loopcnt 
+7b4f 20407a90 call pad_xor 
+7b50 20407a45 call sha_init 
+7b51 20407a4c call sha 
+7b52 d8c00848 arg mem_sp_random_local_end ,contr 
+7b53 d8a00582 arg memdat ,contw 
+7b54 20407b96 call memcpy_dword_swap4 
+7b55 d8c00858 arg mem_sp_random_remote_end ,contr 
+7b56 20407b96 call memcpy_dword_swap4 
+
+function_f3b_common:
+7b57 58000000 setarg 0x0 
+7b58 e0a40000 istore 8 ,contw 
+7b59 e0a40000 istore 8 ,contw 
+7b5a 18a20400 copy contw ,temp 
+7b5b 7006c280 jam 0x80 ,mem_addr_padding 
+7b5c 18420a00 copy temp ,contw 
+7b5d d8c006d2 arg mem_addr_iocap_end ,contr 
+7b5e 20407b96 call memcpy_dword_swap4 
+7b5f 20407a4c call sha 
+7b60 d8a00582 arg memdat ,contw 
+7b61 18007207 force 7 ,loopcnt 
+7b62 20407e3b call memset0 
+7b63 e0a20000 istore 4 ,contw 
+7b64 580003f8 setarg 0x03F8 
+7b65 e0a20000 istore 4 ,contw 
+7b66 20407a4c call sha 
+7b67 20407a89 call sha_result 
+7b68 d8c00858 arg memresult ,contr 
+7b69 d8a006a2 arg memahsave ,contw 
+7b6a 20407e31 call memcpy32 
+7b6b 585c5c5c setarg 0x5c5c5c 
+7b6c 1fed0400 lshift8 pdata ,temp 
+7b6d 1841845c or_into 0x5c ,temp 
+7b6e d8c00838 arg mem_sp_dhkey_end ,contr 
+7b6f 18007206 force 6 ,loopcnt 
+7b70 20407a90 call pad_xor 
+7b71 20407a45 call sha_init 
+7b72 20407a4c call sha 
+7b73 d8c006c2 arg memahsave_end ,contr 
+7b74 d8a00582 arg memdat ,contw 
+7b75 18007208 force 8 ,loopcnt 
+7b76 20407b97 call memcpy_dword_swap 
+7b77 58800000 setarg 0x800000 
+7b78 1fed7e00 lshift8 pdata ,pdata 
+7b79 e0a20000 istore 4 ,contw 
+7b7a 20407e3a call bn_zero 
+7b7b 58000300 setarg 0x0300 
+7b7c e0a20000 istore 4 ,contw 
+7b7d 20407a4c call sha 
+7b7e 20207a89 branch sha_result 
+
+eckp_calc_init:
+7b7f 700581c0 jam 192 ,mem_ec_loopc 
+
+eckp_calc_init_1:
+7b80 68008581 fetch 1 ,mem_ec_loopc 
+7b81 207a0000 rtn blank 
+7b82 1fe0ffff increase -1 ,pdata 
+7b83 60008581 store 1 ,mem_ec_loopc 
+7b84 d8c0065a arg mem_k ,contr 
+7b85 20407822 call bn_testbit 
+7b86 2020fb80 branch eckp_calc_init_1 ,true 
+7b87 d8c00582 arg mem_ax ,contr 
+7b88 d8a00612 arg mem_cx ,contw 
+7b89 20207828 branch ec_copy 
+
+eckp_calc:
+7b8a 2040793a call ecdbl 
+7b8b 68008581 fetch 1 ,mem_ec_loopc 
+7b8c 1fe0ffff increase -1 ,pdata 
+7b8d 60008581 store 1 ,mem_ec_loopc 
+7b8e d8c0065a arg mem_k ,contr 
+7b8f 20407822 call bn_testbit 
+7b90 20608000 rtn true 
+7b91 2020798b branch ecadd 
+
+eckp_cp_1:
+7b92 70058000 jam 0 ,mem_ec_infinite 
+7b93 d8c00582 arg mem_ax ,contr 
+7b94 d8a00612 arg mem_cx ,contw 
+7b95 20207828 branch ec_copy 
+
+memcpy_dword_swap4:
+7b96 18007204 force 4 ,loopcnt 
+
+memcpy_dword_swap:
+7b97 18c08dfc increase -4 ,contr 
+
+memcpy_dword_swap_loop:
+7b98 e8c20000 ifetch 4 ,contr 
+7b99 e0a20000 istore 4 ,contw 
+7b9a 18c08df8 increase -8 ,contr 
+7b9b c2007b98 loop memcpy_dword_swap_loop 
+7b9c 20600000 rtn 
+
+ui_init:
+7b9d 20758000 rtn wake 
+7b9e 20407ba5 call ui_button_init 
+7b9f 20407c13 call ui_timer_init 
+7ba0 20207bd9 branch ui_led_init 
+
+ui_dispatch:
+7ba1 6800c132 fetch 1 ,mem_device_option 
+7ba2 c1008000 rtneq dvc_op_hci 
+7ba3 20407bf2 call ui_led_blink_polling 
+7ba4 20207c04 branch ui_timer_check 
+
+ui_button_init:
+7ba5 6800c7fd fetch 1 ,mem_ui_button_gpio 
+7ba6 c17f8000 rtneq ui_button_gpio_disable 
+7ba7 98000400 iforce temp 
+7ba8 204069da call gpio_config_output 
+7ba9 6808c7fd fetcht 1 ,mem_ui_button_gpio 
+7baa 204069ed call gpio_out_inactive 
+7bab 20000064 nop 100 
+7bac 6808c7fd fetcht 1 ,mem_ui_button_gpio 
+7bad 204069d1 call gpio_config_input 
+7bae 20207bb1 branch ui_button_polling 
+
+ui_button_disable:
+7baf 7047fdff jam ui_button_gpio_disable ,mem_ui_button_gpio 
+7bb0 20600000 rtn 
+
+ui_button_polling:
+7bb1 79200025 set1 mark_ext_patch ,mark 
+7bb2 44c2c030 bpatch patch30_5 ,mem_patch30 
+7bb3 6800c7fd fetch 1 ,mem_ui_button_gpio 
+7bb4 c17f8000 rtneq ui_button_gpio_disable 
+7bb5 1fe20400 copy pdata ,temp 
+7bb6 204069e5 call gpio_get_bit 
+7bb7 2420fbc4 nbranch ui_button_up ,true 
+
+ui_button_down:
+7bb8 20407bce call ui_button_check_long_press 
+7bb9 680147f4 fetch 2 ,mem_ui_state_map 
+7bba 79207e0c set1 ui_state_btn_down 
+7bbb 600147f4 store 2 ,mem_ui_state_map 
+7bbc 6800c7eb fetch 1 ,mem_ui_button_last_state 
+7bbd c1000000 rtneq ui_button_state_down 
+7bbe 7047eb00 jam ui_button_state_down ,mem_ui_button_last_state 
+7bbf 6800c7fc fetch 1 ,mem_ui_button_timeout 
+7bc0 6000c7ea store 1 ,mem_ui_button_timer 
+7bc1 20407bd5 call lpm_button_get_wake_lock 
+7bc2 700b7d2c jam bt_evt_button_down ,mem_fifo_temp 
+7bc3 20207c27 branch ui_ipc_send_event 
+
+ui_button_up:
+7bc4 680147f4 fetch 2 ,mem_ui_state_map 
+7bc5 793ffe0c set0 ui_state_btn_down 
+7bc6 600147f4 store 2 ,mem_ui_state_map 
+7bc7 6800c7eb fetch 1 ,mem_ui_button_last_state 
+7bc8 c1008000 rtneq ui_button_state_up 
+7bc9 7047eb01 jam ui_button_state_up ,mem_ui_button_last_state 
+7bca 7047ea00 jam 0 ,mem_ui_button_timer 
+7bcb 20407bd7 call lpm_button_clean_wake_lock 
+7bcc 700b7d2d jam bt_evt_button_up ,mem_fifo_temp 
+7bcd 20207c27 branch ui_ipc_send_event 
+
+ui_button_check_long_press:
+7bce 6800c7ea fetch 1 ,mem_ui_button_timer 
+7bcf 207a0000 rtn blank 
+7bd0 1fe0ffff increase -1 ,pdata 
+7bd1 6000c7ea store 1 ,mem_ui_button_timer 
+7bd2 247a0000 nrtn blank 
+7bd3 700b7d10 jam bt_evt_button_long_pressed ,mem_fifo_temp 
+7bd4 20207c27 branch ui_ipc_send_event 
+
+lpm_button_get_wake_lock:
+7bd5 d8e00007 arg wake_lock_button ,queue 
+7bd6 20203dc2 branch lpm_get_wake_lock 
+
+lpm_button_clean_wake_lock:
+7bd7 d8e00007 arg wake_lock_button ,queue 
+7bd8 20203dc6 branch lpm_put_wake_lock 
+
+ui_led_init:
+7bd9 6800c7f7 fetch 1 ,mem_led_gpio 
+7bda c17f8000 rtneq ui_button_gpio_disable 
+7bdb 98000400 iforce temp 
+7bdc 204069da call gpio_config_output 
+7bdd 20207be2 branch ui_led_off 
+
+ui_led_blink_stop:
+7bde 680147f4 fetch 2 ,mem_ui_state_map 
+7bdf 793ffe0d set0 ui_state_led_blink 
+7be0 600147f4 store 2 ,mem_ui_state_map 
+7be1 7047e900 jam ui_led_stop ,mem_led_switch 
+
+ui_led_off:
+7be2 680147f4 fetch 2 ,mem_ui_state_map 
+7be3 793ffe0e set0 ui_state_led_on 
+7be4 600147f4 store 2 ,mem_ui_state_map 
+7be5 6808c7f7 fetcht 1 ,mem_led_gpio 
+7be6 202069ed branch gpio_out_inactive 
+
+ui_led_on:
+7be7 680147f4 fetch 2 ,mem_ui_state_map 
+7be8 79207e0e set1 ui_state_led_on 
+7be9 600147f4 store 2 ,mem_ui_state_map 
+7bea 7047e900 jam ui_led_stop ,mem_led_switch 
+7beb 6808c7f7 fetcht 1 ,mem_led_gpio 
+7bec 202069ef branch gpio_out_active 
+
+ui_led_blink_start:
+7bed 680147f4 fetch 2 ,mem_ui_state_map 
+7bee 79207e0d set1 ui_state_led_blink 
+7bef 600147f4 store 2 ,mem_ui_state_map 
+7bf0 7047e901 jam ui_led_start ,mem_led_switch 
+7bf1 20600000 rtn 
+
+ui_led_blink_polling:
+7bf2 79200025 set1 mark_ext_patch ,mark 
+7bf3 44c34030 bpatch patch30_6 ,mem_patch30 
+7bf4 6800c7e9 fetch 1 ,mem_led_switch 
+7bf5 c1000000 rtneq ui_led_stop 
+7bf6 d8e00009 arg ui_led_blink ,queue 
+7bf7 20407e53 call timer_check 
+7bf8 247a0000 nrtn blank 
+7bf9 6800c7e9 fetch 1 ,mem_led_switch 
+7bfa c0017bff beq ui_led_dark_time ,ui_led_blink_polling_dark 
+7bfb 20407be7 call ui_led_on 
+7bfc 7047e902 jam ui_led_dark_time ,mem_led_switch 
+7bfd 680147fa fetch 2 ,mem_led_light_time 
+7bfe 20207c02 branch ui_led_blink_timer_start 
+
+ui_led_blink_polling_dark:
+7bff 20407be2 call ui_led_off 
+7c00 7047e903 jam ui_led_light_time ,mem_led_switch 
+7c01 680147f8 fetch 2 ,mem_led_dark_time 
+
+ui_led_blink_timer_start:
+7c02 d8e00009 arg ui_led_blink ,queue 
+7c03 20207e4c branch timer_init 
+
+ui_timer_check:
+7c04 79200025 set1 mark_ext_patch ,mark 
+7c05 44c3c030 bpatch patch30_7 ,mem_patch30 
+7c06 da200000 arg 0 ,rega 
+7c07 680a47ec fetcht 4 ,mem_ui_timer_last_btclk 
+7c08 1c422400 copy clkn_bt ,regb 
+
+ui_timer_check_loop:
+7c09 1a427e00 copy regb ,pdata 
+7c0a 184084a0 increase 160 ,temp 
+7c0b 184084a0 increase 160 ,temp 
+7c0c 98467c00 isub temp ,null 
+7c0d 24217c16 nbranch ui_timer_check_end ,positive 
+7c0e 1a20a201 increase 1 ,rega 
+7c0f 1a217e0f and rega ,0x0f ,pdata 
+7c10 243a7c09 nbranch ui_timer_check_loop ,blank 
+7c11 da200000 arg 0 ,rega 
+7c12 20407c1d call ui_timer_check_send_evt 
+
+ui_timer_init:
+7c13 1c427e00 copy clkn_bt ,pdata 
+7c14 600247ec store 4 ,mem_ui_timer_last_btclk 
+7c15 20600000 rtn 
+
+ui_timer_check_end:
+7c16 79200025 set1 mark_ext_patch ,mark 
+7c17 44c44031 bpatch patch31_0 ,mem_patch31 
+7c18 1a227e00 copy rega ,pdata 
+7c19 207a0000 rtn blank 
+7c1a 18408560 increase -160 ,temp 
+7c1b 18408560 increase -160 ,temp 
+7c1c 600a47ec storet 4 ,mem_ui_timer_last_btclk 
+
+ui_timer_check_send_evt:
+7c1d 1fe0fe50 increase bt_evt_timer_init ,pdata 
+7c1e 60008b7d store 1 ,mem_fifo_temp 
+7c1f 20207c27 branch ui_ipc_send_event 
+
+ui_ipc_get_lock:
+7c20 7047dd01 jam 1 ,mem_ipc_lock_bt 
+
+ui_ipc_get_lock_wait:
+7c21 6800c7de fetch 1 ,mem_ipc_lock_c51 
+7c22 243a7c21 nbranch ui_ipc_get_lock_wait ,blank 
+7c23 20600000 rtn 
+
+ui_ipc_put_lock:
+7c24 7047dd00 jam 0 ,mem_ipc_lock_bt 
+7c25 20600000 rtn 
+
+ui_ipc_fifo_out:
+7c26 20207f9f branch fifo_out 
+
+ui_ipc_send_event:
+7c27 79200025 set1 mark_ext_patch ,mark 
+7c28 44c4c031 bpatch patch31_1 ,mem_patch31 
+7c29 6800c132 fetch 1 ,mem_device_option 
+7c2a c1008000 rtneq dvc_op_hci 
+7c2b 20407c20 call ui_ipc_get_lock 
+7c2c 1a227e00 copy rega ,pdata 
+7c2d 600208ab store 4 ,mem_ipc_rega_temp 
+7c2e da2047df arg mem_ipc_fifo_bt2c51 ,rega 
+7c2f 20407f92 call fifo_in 
+7c30 680208ab fetch 4 ,mem_ipc_rega_temp 
+7c31 1fe22200 copy pdata ,rega 
+7c32 20207c24 branch ui_ipc_put_lock 
+
+ui_ipc_send_cmd:
+7c33 79200025 set1 mark_ext_patch ,mark 
+7c34 44c54031 bpatch patch31_2 ,mem_patch31 
+7c35 6800c132 fetch 1 ,mem_device_option 
+7c36 c1008000 rtneq dvc_op_hci 
+7c37 20407c20 call ui_ipc_get_lock 
+7c38 1a227e00 copy rega ,pdata 
+7c39 600208ab store 4 ,mem_ipc_rega_temp 
+7c3a da2047e4 arg mem_ipc_fifo_c512bt ,rega 
+7c3b 20407f92 call fifo_in 
+7c3c 680208ab fetch 4 ,mem_ipc_rega_temp 
+7c3d 1fe22200 copy pdata ,rega 
+7c3e 20207c24 branch ui_ipc_put_lock 
+
+ui_ipc_clean_all_fifo:
+7c3f 79200025 set1 mark_ext_patch ,mark 
+7c40 44c5c031 bpatch patch31_3 ,mem_patch31 
+7c41 58000000 setarg 0 
+7c42 6002c7e4 store util_fifo_len ,mem_ipc_fifo_c512bt 
+7c43 6002c7df store util_fifo_len ,mem_ipc_fifo_bt2c51 
+7c44 20600000 rtn 
+
+check_51cmd:
+7c45 79200025 set1 mark_ext_patch ,mark 
+7c46 44c64031 bpatch patch31_4 ,mem_patch31 
+7c47 6800c272 fetch 1 ,mem_hci_cmd 
+7c48 247a0000 nrtn blank 
+7c49 da2047e4 arg mem_ipc_fifo_c512bt ,rega 
+7c4a 20407fac call fifo_is_empty 
+7c4b 207a0000 rtn blank 
+7c4c 7008aa00 jam ipc_continue_process ,mem_ipc_skip_continue_proc 
+7c4d 20407c51 call check_51cmd_once 
+7c4e 680088aa fetch 1 ,mem_ipc_skip_continue_proc 
+7c4f 203a7c45 branch check_51cmd ,blank 
+7c50 20600000 rtn 
+
+check_51cmd_once:
+7c51 79200025 set1 mark_ext_patch ,mark 
+7c52 44c6c031 bpatch patch31_5 ,mem_patch31 
+7c53 20407c20 call ui_ipc_get_lock 
+7c54 da2047e4 arg mem_ipc_fifo_c512bt ,rega 
+7c55 20407f9f call fifo_out 
+7c56 1fe20400 copy pdata ,temp 
+7c57 20407c24 call ui_ipc_put_lock 
+7c58 18427e00 copy temp ,pdata 
+7c59 207a0000 rtn blank 
+7c5a c000fc97 beq bt_cmd_start_discovery ,check_51cmd_start_discovery 
+7c5b c0017c9c beq bt_cmd_stop_discovery ,check_51cmd_stop_discovery 
+7c5c c001fca2 beq bt_cmd_reconnect ,check_51cmd_reconnect 
+7c5d c003fca7 beq bt_cmd_enter_sniff_subrating ,check_51cmd_enter_sniff_subrating 
+7c5e c0047ca8 beq bt_cmd_exit_sniff_subrating ,check_51cmd_exit_sniff_subrating 
+7c5f c004fca9 beq bt_cmd_sniff_test ,check_51cmd_sniff_test 
+7c60 c005fcac beq bt_cmd_start_inquiry ,check_51cmd_inq 
+7c61 c0067cad beq bt_cmd_stop_inquiry ,check_51cmd_stop_inq 
+7c62 c006fcae beq bt_cmd_start_adv ,check_51cmd_adv 
+7c63 c0077cb1 beq bt_cmd_stop_adv ,check_51cmd_stop_adv 
+7c64 c007fcb3 beq bt_cmd_start_direct_adv ,check_51cmd_direct_adv 
+7c65 c0087cb6 beq bt_cmd_stop_direct_adv ,check_51cmd_stop_direct_adv 
+7c66 c0097cbb beq bt_cmd_le_update_conn ,check_51cmd_le_update_conn 
+7c67 c00afbed beq bt_cmd_led_blink ,ui_led_blink_start 
+7c68 c00a7be7 beq bt_cmd_led_on ,ui_led_on 
+7c69 c009fbde beq bt_cmd_led_off ,ui_led_blink_stop 
+7c6a c00b7cbc beq bt_cmd_le_start_conn ,check_51cmd_le_start_con 
+7c6b c00bfcc1 beq bt_cmd_le_start_scan ,check_51cmd_start_scan 
+7c6c c00c7cc3 beq bt_cmd_le_stop_scan ,check_51cmd_stop_scan 
+7c6d c00cfcc8 beq bt_cmd_enter_hibernate ,check_51cmd_hibernate 
+7c6e c00dfcc6 beq bt_cmd_le_smp_security_request ,check_51cmd_le_smp_sec_req 
+7c6f c00e7cd3 beq bt_cmd_le_start_write ,check_51cmd_le_start_write 
+7c70 c00f7cd5 beq bt_cmd_bb_reconn_cancel ,check_51cmd_bb_reconn_cancel 
+7c71 60008b7d store 1 ,mem_fifo_temp 
+7c72 79200025 set1 mark_ext_patch ,mark 
+7c73 44c74031 bpatch patch31_6 ,mem_patch31 
+7c74 6800807c fetch 1 ,mem_lmo_opcode2 
+7c75 203a7c79 branch check_51cmd_once_continue ,blank 
+7c76 204061d9 call lmo_fifo_process 
+7c77 6800807c fetch 1 ,mem_lmo_opcode2 
+7c78 243a7c8c nbranch check_51cmd_restore ,blank 
+
+check_51cmd_once_continue:
+7c79 68008b7d fetch 1 ,mem_fifo_temp 
+7c7a c584fc87 bmark0 mark_context ,check_51cmd_check_idle 
+
+check_51cmd_once_continue0:
+7c7b c002ca19 beq bt_cmd_enter_sniff ,cmd_in_sniff 
+7c7c c0034a28 beq bt_cmd_exit_sniff ,cmd_exit_sniff 
+7c7d c0057caa beq bt_cmd_set_pin_code ,check_51cmd_pincode 
+7c7e c0027ca4 beq bt_cmd_disconnect ,check_51cmd_disconnect 
+7c7f c008fcb8 beq bt_cmd_le_disconnect ,check_51cmd_le_disconnect 
+7c80 c00efc8e beq bt_cmd_role_switch ,check_51cmd_role_switch 
+7c81 c00fe90c beq bt_cmd_store_reconn_info_le ,eeprom_store_le_reconn_info 
+7c82 c0106910 beq bt_cmd_store_reconn_info_bt ,eeprom_store_bd_reconn_info 
+7c83 c0097c85 beq bt_cmd_le_update_conn ,bt_cmd_le_update_conn_1 
+7c84 20600000 rtn 
+
+bt_cmd_le_update_conn_1:
+7c85 700b7d2f jam xt_ll_connection_param_req ,mem_fifo_temp 
+7c86 20205620 branch le_xtype_fifo_in 
+
+check_51cmd_check_idle:
+7c87 60008b7d store 1 ,mem_fifo_temp 
+7c88 204032ee call context_check_idle 
+7c89 2022fc8c branch check_51cmd_restore ,zero 
+7c8a 204032f9 call context_search_plap 
+7c8b 24628000 nrtn zero 
+
+check_51cmd_restore:
+7c8c 7008aa01 jam ipc_skip_continue_process ,mem_ipc_skip_continue_proc 
+7c8d 20207c33 branch ui_ipc_send_cmd 
+
+check_51cmd_role_switch:
+7c8e 70007c34 jam lmp_slot_offset ,mem_lmo_opcode2 
+7c8f 79200003 set1 mark_switch_initiated ,mark 
+7c90 24748000 nrtn master 
+7c91 70474800 jam switch_flag_init ,mem_switch_flag 
+7c92 70007c13 jam lmp_switch_req ,mem_lmo_opcode2 
+7c93 68008177 fetch 1 ,mem_connection_options 
+7c94 793ffe02 set0 connection_switch ,pdata 
+7c95 60008177 store 1 ,mem_connection_options 
+7c96 20600000 rtn 
+
+check_51cmd_start_discovery:
+7c97 680147f4 fetch 2 ,mem_ui_state_map 
+7c98 79207e06 set1 ui_state_bt_discovery 
+7c99 600147f4 store 2 ,mem_ui_state_map 
+7c9a 70413303 jam 3 ,mem_scan_mode 
+7c9b 20600000 rtn 
+
+check_51cmd_stop_discovery:
+7c9c 7047f200 jam 0 ,mem_hid_handshake_timer_count 
+7c9d 70413300 jam 0 ,mem_scan_mode 
+7c9e 680147f4 fetch 2 ,mem_ui_state_map 
+7c9f 793ffe06 set0 ui_state_bt_discovery 
+7ca0 600147f4 store 2 ,mem_ui_state_map 
+7ca1 20600000 rtn 
+
+check_51cmd_reconnect:
+7ca2 70427205 jam hci_cmd_create_conn ,mem_hci_cmd 
+7ca3 20600000 rtn 
+
+check_51cmd_disconnect:
+7ca4 70007c07 jam lmp_detach ,mem_lmo_opcode2 
+7ca5 70044613 jam other_end_terminated ,mem_disconn_reason_send 
+7ca6 20600000 rtn 
+
+check_51cmd_enter_sniff_subrating:
+7ca7 20600000 rtn 
+
+check_51cmd_exit_sniff_subrating:
+7ca8 20600000 rtn 
+
+check_51cmd_sniff_test:
+7ca9 20600000 rtn 
+
+check_51cmd_pincode:
+7caa 70045002 jam pincode_state_pincode_ready ,mem_pincode_state 
+7cab 202049da branch cmd_pair 
+
+check_51cmd_inq:
+7cac 20600000 rtn 
+
+check_51cmd_stop_inq:
+7cad 20600000 rtn 
+
+check_51cmd_adv:
+7cae 7043d801 jam on ,mem_le_adv_enable 
+7caf 7044db00 jam adv_ind ,mem_le_adv_type 
+7cb0 20600000 rtn 
+
+check_51cmd_stop_adv:
+7cb1 7043d800 jam off ,mem_le_adv_enable 
+7cb2 20600000 rtn 
+
+check_51cmd_direct_adv:
+7cb3 7043d801 jam on ,mem_le_adv_enable 
+7cb4 7044db01 jam adv_direct_ind ,mem_le_adv_type 
+7cb5 20600000 rtn 
+
+check_51cmd_stop_direct_adv:
+7cb6 7043d800 jam off ,mem_le_adv_enable 
+7cb7 20600000 rtn 
+
+check_51cmd_le_disconnect:
+7cb8 58000001 setarg 1 
+7cb9 600103ef store 2 ,mem_le_superto 
+7cba 20600000 rtn 
+
+check_51cmd_le_update_conn:
+7cbb 20600000 rtn 
+
+check_51cmd_le_start_con:
+7cbc 7043d201 jam on ,mem_le_scan_enable 
+7cbd 7042721b jam hci_cmd_le_create_conn ,mem_hci_cmd 
+7cbe 68030268 fetch 6 ,mem_app_peer_addr 
+7cbf 600344e7 store 6 ,mem_le_conn_peer_addr 
+7cc0 20600000 rtn 
+
+check_51cmd_start_scan:
+7cc1 7043d201 jam on ,mem_le_scan_enable 
+7cc2 20600000 rtn 
+
+check_51cmd_stop_scan:
+7cc3 7043d200 jam off ,mem_le_scan_enable 
+7cc4 70427200 jam 0 ,mem_hci_cmd 
+7cc5 20600000 rtn 
+
+check_51cmd_le_smp_sec_req:
+7cc6 700b7d4b jam xt_smp_security_request ,mem_fifo_temp 
+7cc7 20205620 branch le_xtype_fifo_in 
+
+check_51cmd_hibernate:
+7cc8 79200025 set1 mark_ext_patch ,mark 
+7cc9 44c7c031 bpatch patch31_7 ,mem_patch31 
+7cca 68014288 fetch 2 ,mem_cb_before_hibernate 
+7ccb 20407f66 call callback_func 
+7ccc 6800c7fd fetch 1 ,mem_ui_button_gpio 
+7ccd c07ffcd0 beq ui_button_gpio_disable ,check_51cmd_hibernate_btn_disabled 
+7cce 1fe20400 copy pdata ,temp 
+7ccf 204069d1 call gpio_config_input 
+
+check_51cmd_hibernate_btn_disabled:
+7cd0 20407be2 call ui_led_off 
+7cd1 20407c3f call ui_ipc_clean_all_fifo 
+7cd2 20203ccd branch lpm_hibernate 
+
+check_51cmd_le_start_write:
+7cd3 7046f801 jam 1 ,mem_le_switch_send_data 
+7cd4 20600000 rtn 
+
+check_51cmd_bb_reconn_cancel:
+7cd5 18000e04 force page_length_timer ,queue 
+7cd6 20207e4b branch timer_stop 
+
+ui_check_paring_button:
+7cd7 6800c7f4 fetch 1 ,mem_ui_state_map 
+7cd8 c4060000 rtnbit0 ui_state_btn_down 
+7cd9 c4038000 rtnbit0 ui_state_bt_reconnect 
+7cda 20207cd5 branch check_51cmd_bb_reconn_cancel 
+
+usb_isr:
+7cdb 79200025 set1 mark_ext_patch ,mark 
+7cdc 44eac03a bpatch patch3a_5 ,mem_patch3a 
+7cdd 20407df3 call usb_tx_test 
+7cde 68108c26 hfetch 1 ,core_usb_status 
+7cdf 600088af store 1 ,mem_usb_status 
+7ce0 68108c27 hfetch 1 ,core_usb_fifo_empty 
+7ce1 600088b0 store 1 ,mem_usb_fifo_empty 
+7ce2 708c26e0 hjam 0xe0 ,core_usb_status 
+7ce3 680088b0 fetch 1 ,mem_usb_fifo_empty 
+7ce4 2fe00201 compare 0x1 ,pdata ,0x1 
+7ce5 2040fd3a call usb0_fifo_empty ,true 
+7ce6 79200025 set1 mark_ext_patch ,mark 
+7ce7 44eb403a bpatch patch3a_6 ,mem_patch3a 
+7ce8 680088af fetch 1 ,mem_usb_status 
+7ce9 2fe00201 compare 0x1 ,pdata ,0x1 
+7cea 2040fcf8 call usb_status1 ,true 
+7ceb 680088f8 fetch 1 ,mem_usb_state 
+7cec c0817dc2 bne usb_connected ,usb_tx 
+7ced 680108f9 fetch 2 ,mem_usb_idle_cnt 
+7cee 1fe0fe01 increase 1 ,pdata 
+7cef 600108f9 store 2 ,mem_usb_idle_cnt 
+7cf0 680908fb fetcht 2 ,mem_usb_idle_timeout 
+7cf1 98467c00 isub temp ,null 
+7cf2 20217db2 branch usb_init ,positive 
+7cf3 680088af fetch 1 ,mem_usb_status 
+7cf4 c3037dc2 bbit0 usb_status_nak ,usb_tx 
+7cf5 58000000 setarg 0 
+7cf6 600108f9 store 2 ,mem_usb_idle_cnt 
+7cf7 20207dc2 branch usb_tx 
+
+usb_status1:
+7cf8 79200025 set1 mark_ext_patch ,mark 
+7cf9 44ebc03a bpatch patch3a_7 ,mem_patch3a 
+7cfa 708c2611 hjam 0x11 ,core_usb_status 
+7cfb 68108c20 hfetch 1 ,core_usb_ep_len 
+7cfc 600088b1 store 1 ,mem_usb_read_len 
+7cfd 1fe27200 copy pdata ,loopcnt 
+7cfe 203a7d18 branch usb_rx_no_data ,blank 
+7cff d8a008ff arg mem_usb_setup ,contw 
+7d00 20407d36 call usb_rx_read 
+7d01 680088b1 fetch 1 ,mem_usb_read_len 
+7d02 1fe67c07 sub pdata ,7 ,null 
+7d03 20610000 rtn positive 
+
+usb_class_type:
+7d04 79200025 set1 mark_ext_patch ,mark 
+7d05 44ec403b bpatch patch3b_0 ,mem_patch3b 
+7d06 680088ff fetch 1 ,mem_usb_setup_bmrequesttype 
+7d07 c0107d16 beq hci_class_request_type ,usb_hci_class_req_type 
+7d08 c010fd22 beq hid_class_request_type ,usb_hid_class_req_type 
+7d09 c0007d10 beq zero_class_request_type ,usb_zero_class_req_type 
+7d0a 68008900 fetch 1 ,mem_usb_setup_brequest 
+7d0b c002fd9b beq set_address ,usb0_request_set_address 
+7d0c c0037d3d beq get_descriptor ,usb0_request_get_descriptor 
+7d0d c004fd98 beq set_configuration ,usb0_request_set_configuration 
+7d0e c005fda2 beq set_interface ,usb0_request_set_interface 
+7d0f 20207d32 branch usb0_force_stall 
+
+usb_zero_class_req_type:
+7d10 68008900 fetch 1 ,mem_usb_setup_brequest 
+7d11 c000fdaf beq clear_feature ,usb0_request_clear_feature 
+7d12 c001fdab beq set_feature ,usb0_request_set_feature 
+7d13 c004fd34 beq set_configuration ,usb0_reply_zerolen 
+7d14 c002fd9b beq set_address ,usb0_request_set_address 
+7d15 20207d32 branch usb0_force_stall 
+
+usb_hci_class_req_type:
+7d16 20407d34 call usb0_reply_zerolen 
+7d17 20600000 rtn 
+
+usb_rx_no_data:
+7d18 680088af fetch 1 ,mem_usb_status 
+7d19 c2827d04 bbit1 usb_status_setup ,usb_class_type 
+7d1a 20600000 rtn 
+
+usb_set_protocol_req:
+7d1b 680088f6 fetch 1 ,mem_usb_set_protocol_count 
+7d1c 1fe0fe01 increase 1 ,pdata 
+7d1d 600088f6 store 1 ,mem_usb_set_protocol_count 
+7d1e 2fe1fe02 compare 2 ,pdata ,0xff 
+7d1f 2420fd34 nbranch usb0_reply_zerolen ,true 
+7d20 7008f701 jam 1 ,mem_usb_desc 
+7d21 20207d34 branch usb0_reply_zerolen 
+
+usb_hid_class_req_type:
+7d22 68008900 fetch 1 ,mem_usb_setup_brequest 
+7d23 c0057d27 beq set_idle ,usb_set_idle 
+7d24 c004fd2e beq set_report ,usb_set_report 
+7d25 c005fd1b beq set_protocol ,usb_set_protocol_req 
+7d26 20207d32 branch usb0_force_stall 
+
+usb_set_idle:
+7d27 680088f8 fetch 1 ,mem_usb_state 
+7d28 c002fd2c beq usb_setidle_1 ,usb_set_idle_connected 
+7d29 c0827d34 bne usb_resume ,usb0_reply_zerolen 
+7d2a 7008f805 jam usb_setidle_1 ,mem_usb_state 
+7d2b 20207d34 branch usb0_reply_zerolen 
+
+usb_set_idle_connected:
+7d2c 7008f802 jam usb_connected ,mem_usb_state 
+7d2d 20207d34 branch usb0_reply_zerolen 
+
+usb_set_report:
+7d2e 7008f701 jam 1 ,mem_usb_desc 
+7d2f da2008f7 arg mem_usb_desc ,rega 
+7d30 da400001 arg 1 ,regb 
+7d31 20207d65 branch usb0_respond 
+
+usb0_force_stall:
+7d32 708c1101 hjam 1 ,core_usb_stall 
+7d33 20600000 rtn 
+
+usb0_reply_zerolen:
+7d34 708c1240 hjam 0x40 ,core_usb_clear 
+7d35 20600000 rtn 
+
+usb_rx_read:
+7d36 68108c18 hfetch 1 ,core_usb_ep 
+7d37 e0a08000 istore 1 ,contw 
+7d38 c2007d36 loop usb_rx_read 
+7d39 20600000 rtn 
+
+usb0_fifo_empty:
+7d3a 708c2701 hjam 0x1 ,core_usb_fifo_empty 
+7d3b 20407d7c call usb0_tx 
+7d3c 20600000 rtn 
+
+usb0_request_get_descriptor:
+7d3d 79200025 set1 mark_ext_patch ,mark 
+7d3e 44ecc03b bpatch patch3b_1 ,mem_patch3b 
+7d3f 793f8023 set0 mark_isstr ,mark 
+7d40 68008902 fetch 1 ,mem_usb_setup_bvalueh 
+7d41 c000fd47 beq dsc_device ,dsc_device_info 
+7d42 c0017d49 beq dsc_config ,dsc_config_info 
+7d43 c001fd4b beq dsc_string ,dsc_string_info 
+7d44 c010fd57 beq dsc_hid ,dsc_hid_info 
+7d45 c0117d5b beq dsc_hid_report ,dsc_hid_report_info 
+7d46 20600000 rtn 
+
+dsc_device_info:
+7d47 da200912 arg mem_devicedesc ,rega 
+7d48 20207d62 branch usb0_respond_length 
+
+dsc_config_info:
+7d49 da200ab6 arg mem_confdesc ,rega 
+7d4a 20207d62 branch usb0_respond_length 
+
+dsc_string_info:
+7d4b 68008901 fetch 1 ,mem_usb_setup_bvalue 
+7d4c 1fe17e03 and_into 3 ,pdata 
+7d4d da200b1a arg mem_string0 ,rega 
+7d4e c0007d62 beq 0 ,usb0_respond_length 
+7d4f 79200023 set1 mark_isstr ,mark 
+7d50 da200b1f arg mem_string1 ,rega 
+7d51 c000fd62 beq 1 ,usb0_respond_length 
+7d52 da200b3d arg mem_string2 ,rega 
+7d53 c0017d62 beq 2 ,usb0_respond_length 
+7d54 da200b5b arg mem_string3 ,rega 
+7d55 c001fd62 beq 3 ,usb0_respond_length 
+7d56 20203bf1 branch assert 
+
+dsc_hid_info:
+7d57 da200ac8 arg mem_confdesc + 18 ,rega 
+7d58 68008ac8 fetch 1 ,mem_confdesc + 18 
+7d59 1fe22400 copy pdata ,regb 
+7d5a 20207d65 branch usb0_respond 
+
+dsc_hid_report_info:
+7d5b 68010903 fetch 2 ,mem_usb_setup_windex 
+7d5c c000fd5f beq 1 ,dsc_hid_report_info0 
+7d5d da200926 arg mem_hidreportdesc_kb ,rega 
+7d5e 20207d62 branch usb0_respond_length 
+
+dsc_hid_report_info0:
+7d5f 7008f801 jam usb_got_report_req ,mem_usb_state 
+7d60 da2009ee arg mem_hidreportdesc_m ,rega 
+7d61 20207d62 branch usb0_respond_length 
+
+usb0_respond_length:
+7d62 ea208000 ifetch 1 ,rega 
+7d63 98002400 iforce regb 
+7d64 1a20a201 increase 1 ,rega 
+
+usb0_respond:
+7d65 79200025 set1 mark_ext_patch ,mark 
+7d66 44ed403b bpatch patch3b_2 ,mem_patch3b 
+7d67 c591fd71 bmark0 mark_isstr ,usb0_respond0 
+7d68 1a40fe01 add regb ,1 ,pdata 
+7d69 1fe3fe00 lshift pdata ,pdata 
+7d6a 60108c18 hstore 1 ,core_usb_dfifo0 
+7d6b 708c1803 hjam 3 ,core_usb_dfifo0 
+7d6c 68008905 fetch 1 ,mem_usb_setup_blength 
+7d6d 1fe0fffe increase -2 ,pdata 
+7d6e 1fe37e00 rshift pdata ,pdata 
+7d6f 60008905 store 1 ,mem_usb_setup_blength 
+7d70 c0007d7a beq 0 ,usb_no_respond_data 
+
+usb0_respond0:
+7d71 68008905 fetch 1 ,mem_usb_setup_blength 
+7d72 9a467c00 isub regb ,null 
+7d73 20217d75 branch usb0_respond1 ,positive 
+7d74 1fe22400 copy pdata ,regb 
+
+usb0_respond1:
+7d75 1a227e00 copy rega ,pdata 
+7d76 6001090f store 2 ,mem_bufptr 
+7d77 1a427e00 copy regb ,pdata 
+7d78 60008911 store 1 ,mem_remain 
+7d79 20207d7c branch usb0_tx 
+
+usb_no_respond_data:
+7d7a d8e00000 arg 0 ,queue 
+7d7b 20207dd5 branch usb_trig 
+
+usb0_tx:
+7d7c 79200025 set1 mark_ext_patch ,mark 
+7d7d 44edc03b bpatch patch3b_3 ,mem_patch3b 
+7d7e 68008911 fetch 1 ,mem_remain 
+7d7f 207a0000 rtn blank 
+7d80 1fe27200 copy pdata ,loopcnt 
+7d81 1fe67c40 sub pdata ,ep0_packet_size ,null 
+7d82 20217d84 branch usb0_tx_info ,positive 
+7d83 df200040 arg ep0_packet_size ,loopcnt 
+
+usb0_tx_info:
+7d84 68008911 fetch 1 ,mem_remain 
+7d85 9f267e00 isub loopcnt ,pdata 
+7d86 60008911 store 1 ,mem_remain 
+7d87 6801090f fetch 2 ,mem_bufptr 
+7d88 1fe20c00 copy pdata ,contr 
+
+usb0_tx0:
+7d89 e8c08000 ifetch 1 ,contr 
+7d8a 60108c18 hstore 1 ,core_usb_dfifo0 
+7d8b c591fd8d bmark0 mark_isstr ,usb0_tx1 
+7d8c 708c1800 hjam 0 ,core_usb_dfifo0 
+
+usb0_tx1:
+7d8d c2007d89 loop usb0_tx0 
+7d8e 18c27e00 copy contr ,pdata 
+7d8f 6001090f store 2 ,mem_bufptr 
+7d90 d8e00000 arg 0 ,queue 
+7d91 20407dd5 call usb_trig 
+7d92 68008911 fetch 1 ,mem_remain 
+7d93 247a0000 nrtn blank 
+7d94 680088f8 fetch 1 ,mem_usb_state 
+7d95 c1808000 rtnne usb_got_report_req 
+7d96 7008f802 jam usb_connected ,mem_usb_state 
+7d97 20600000 rtn 
+
+usb0_request_set_configuration:
+7d98 68008901 fetch 1 ,mem_usb_setup_bvalue 
+7d99 1fe67c01 sub pdata ,1 ,null 
+7d9a 24217d32 nbranch usb0_force_stall ,positive 
+
+usb0_request_set_address:
+7d9b 680088ff fetch 1 ,mem_usb_setup_bmrequesttype 
+7d9c c0807d32 bne in_device ,usb0_force_stall 
+7d9d 68010903 fetch 2 ,mem_usb_setup_windex 
+7d9e c0807d32 bne 0 ,usb0_force_stall 
+7d9f 68008905 fetch 1 ,mem_usb_setup_blength 
+7da0 c0807d32 bne 0 ,usb0_force_stall 
+7da1 20207d34 branch usb0_reply_zerolen 
+
+usb0_request_set_interface:
+7da2 680088ff fetch 1 ,mem_usb_setup_bmrequesttype 
+7da3 c080fd32 bne in_interface ,usb0_force_stall 
+7da4 68008901 fetch 1 ,mem_usb_setup_bvalue 
+7da5 c0807d32 bne 0 ,usb0_force_stall 
+7da6 68008902 fetch 1 ,mem_usb_setup_bvalueh 
+7da7 c0807d32 bne 0 ,usb0_force_stall 
+7da8 68008905 fetch 1 ,mem_usb_setup_blength 
+7da9 c0807d32 bne 0 ,usb0_force_stall 
+7daa 20207d34 branch usb0_reply_zerolen 
+
+usb0_request_set_feature:
+7dab 68008901 fetch 1 ,mem_usb_setup_bvalue 
+7dac c080fd32 bne 1 ,usb0_force_stall 
+7dad 7008f803 jam usb_sleep ,mem_usb_state 
+7dae 20207d34 branch usb0_reply_zerolen 
+
+usb0_request_clear_feature:
+7daf 68008901 fetch 1 ,mem_usb_setup_bvalue 
+7db0 c080fd32 bne 1 ,usb0_force_stall 
+7db1 20207d34 branch usb0_reply_zerolen 
+
+usb_init:
+7db2 79200025 set1 mark_ext_patch ,mark 
+7db3 44ee403b bpatch patch3b_4 ,mem_patch3b 
+7db4 708c0000 hjam 0x00 ,core_usb_config 
+7db5 20002710 nop 10000 
+7db6 708c10c0 hjam 0xc0 ,core_usb_trig 
+7db7 68110050 hfetch 2 ,core_clkoff 
+7db8 793ffe0a set0 clock_off_usb ,pdata 
+7db9 60110050 hstore 2 ,core_clkoff 
+7dba 708c003c hjam 0x3c ,core_usb_config 
+7dbb 708c26ff hjam 0xff ,core_usb_status 
+7dbc 708c27ff hjam 0xff ,core_usb_fifo_empty 
+7dbd 700ff000 jam 0 ,mem_mcmd 
+7dbe 7008f800 jam 0 ,mem_usb_state 
+7dbf 58000000 setarg 0 
+7dc0 600108f9 store 2 ,mem_usb_idle_cnt 
+7dc1 20600000 rtn 
+
+usb_tx:
+7dc2 79200025 set1 mark_ext_patch ,mark 
+7dc3 44eec03b bpatch patch3b_5 ,mem_patch3b 
+7dc4 68008ff0 fetch 1 ,mem_mcmd 
+7dc5 207a0000 rtn blank 
+7dc6 680088f8 fetch 1 ,mem_usb_state 
+7dc7 c001fdec beq usb_sleep ,usb_wakeup 
+7dc8 c1810000 rtnne usb_connected 
+7dc9 68008ff0 fetch 1 ,mem_mcmd 
+7dca 700ff000 jam 0 ,mem_mcmd 
+7dcb df200006 arg 6 ,loopcnt 
+7dcc d8c00ff1 arg mem_mouse_data ,contr 
+7dcd c0017dd0 beq send_kb_data_cmd ,usb_tx_ep1 
+7dce c000fde9 beq send_mouse_data_cmd ,usb_tx_ep2 
+7dcf 20203bf1 branch assert 
+
+usb_tx_ep1:
+7dd0 da208c19 arg core_usb_dfifo1 ,rega 
+7dd1 d8e00001 arg 1 ,queue 
+
+usb_tx_loop:
+7dd2 e8c08000 ifetch 1 ,contr 
+7dd3 e2208000 istore 1 ,rega 
+7dd4 c2007dd2 loop usb_tx_loop 
+
+usb_trig:
+7dd5 79200025 set1 mark_ext_patch ,mark 
+7dd6 44ef403b bpatch patch3b_6 ,mem_patch3b 
+7dd7 78487c00 disable swfine 
+7dd8 680108fd fetch 2 ,mem_usb_trig_timeout 
+7dd9 98003600 iforce stop_watch 
+7dda 708c2640 hjam 0x40 ,core_usb_status 
+
+usb_trig_waitnak_loop:
+7ddb 68108c26 hfetch 1 ,core_usb_status 
+7ddc 2021fdb2 branch usb_init ,timeout 
+7ddd c3037ddb bbit0 usb_status_nak ,usb_trig_waitnak_loop 
+7dde 680108fd fetch 2 ,mem_usb_trig_timeout 
+7ddf 98003600 iforce stop_watch 
+7de0 d8400000 arg 0 ,temp 
+7de1 f9200400 qset1 temp 
+7de2 60188c27 hstoret 1 ,core_usb_fifo_empty 
+
+usb_trig_loop:
+7de3 2021fdb2 branch usb_init ,timeout 
+7de4 60188c10 hstoret 1 ,core_usb_trig 
+7de5 68108c27 hfetch 1 ,core_usb_fifo_empty 
+7de6 afec0000 qisolate0 pdata 
+7de7 2020fde3 branch usb_trig_loop ,true 
+7de8 20600000 rtn 
+
+usb_tx_ep2:
+7de9 d8e00002 arg 2 ,queue 
+7dea da208c1a arg core_usb_dfifo2 ,rega 
+7deb 20207dd2 branch usb_tx_loop 
+
+usb_wakeup:
+7dec 79200025 set1 mark_ext_patch ,mark 
+7ded 44efc03b bpatch patch3b_7 ,mem_patch3b 
+7dee 708c00fc hjam 0xfc ,core_usb_config 
+7def 20002710 nop 10000 
+7df0 708c003c hjam 0x3c ,core_usb_config 
+7df1 7008f804 jam usb_resume ,mem_usb_state 
+7df2 20600000 rtn 
+
+usb_tx_test:
+7df3 68008ff0 fetch 1 ,mem_mcmd 
+7df4 247a0000 nrtn blank 
+7df5 680108f2 fetch 2 ,mem_usb_cnt 
+7df6 207a0000 rtn blank 
+7df7 1fe0ffff increase -1 ,pdata 
+7df8 600108f2 store 2 ,mem_usb_cnt 
+7df9 700ff001 jam send_mouse_data_cmd ,mem_mcmd 
+7dfa 20600000 rtn 
+
+right_shift_n:
+7dfb 1f267c00 sub loopcnt ,0 ,null 
+7dfc 20628000 rtn zero 
+
+right_shift_n_loop:
+7dfd 1fe37e00 rshift pdata ,pdata 
+7dfe c2007dfd loop right_shift_n_loop 
+7dff 20600000 rtn 
+
+push_stack:
+7e00 18a27e00 deposit contw 
+7e01 600102b9 store 2 ,mem_contw 
+7e02 600c02a0 storet 8 ,mem_temp 
+7e03 19627e00 deposit timeup 
+7e04 600202a8 store 4 ,mem_timeup 
+7e05 1a227e00 deposit rega 
+7e06 600202ac store 4 ,mem_rega 
+7e07 1a427e00 deposit regb 
+7e08 600202b0 store 4 ,mem_regb 
+7e09 1a627e00 deposit regc 
+7e0a 600182b4 store 3 ,mem_regc 
+7e0b 18c27e00 deposit contr 
+7e0c 600102b7 store 2 ,mem_contr 
+7e0d 20600000 rtn 
+
+pop_stack:
+7e0e 680c02a0 fetcht 8 ,mem_temp 
+7e0f 680202a8 fetch 4 ,mem_timeup 
+7e10 98001600 iforce timeup 
+7e11 680202ac fetch 4 ,mem_rega 
+7e12 98002200 iforce rega 
+7e13 680202b0 fetch 4 ,mem_regb 
+7e14 98002400 iforce regb 
+7e15 680182b4 fetch 3 ,mem_regc 
+7e16 98002600 iforce regc 
+7e17 680102b9 fetch 2 ,mem_contw 
+7e18 98000a00 iforce contw 
+7e19 680102b7 fetch 2 ,mem_contr 
+7e1a 98000c00 iforce contr 
+7e1b 20600000 rtn 
+
+save_cont_pointers:
+7e1c 18a27e00 copy contw ,pdata 
+7e1d 60010b7b store 2 ,mem_hold_contw 
+7e1e 18c27e00 copy contr ,pdata 
+7e1f 60010b79 store 2 ,mem_hold_contr 
+7e20 20600000 rtn 
+
+load_cont_pointers:
+7e21 68010b7b fetch 2 ,mem_hold_contw 
+7e22 1fe20a00 copy pdata ,contw 
+7e23 68010b79 fetch 2 ,mem_hold_contr 
+7e24 1fe20c00 copy pdata ,contr 
+7e25 20600000 rtn 
+
+delay_10ms:
+7e26 1c427e00 copy clkn_bt ,pdata 
+7e27 1fe0fe10 increase 16 ,pdata 
+7e28 1fe0fe10 increase 16 ,pdata 
+
+delay_ms_wait:
+7e29 1c420400 copy clkn_bt ,temp 
+7e2a 98467c00 isub temp ,null 
+7e2b 20217e29 branch delay_ms_wait ,positive 
+7e2c 20600000 rtn 
+
+memcpy48:
+7e2d e8c40000 ifetch 8 ,contr 
+7e2e e0a40000 istore 8 ,contw 
+7e2f e8c40000 ifetch 8 ,contr 
+7e30 e0a40000 istore 8 ,contw 
+
+memcpy32:
+7e31 e8c40000 ifetch 8 ,contr 
+7e32 e0a40000 istore 8 ,contw 
+
+memcpy24:
+7e33 e8c40000 ifetch 8 ,contr 
+7e34 e0a40000 istore 8 ,contw 
+
+memcpy16:
+7e35 e8c40000 ifetch 8 ,contr 
+7e36 e0a40000 istore 8 ,contw 
+7e37 e8c40000 ifetch 8 ,contr 
+7e38 e0a40000 istore 8 ,contw 
+7e39 20600000 rtn 
+
+bn_zero:
+7e3a 18007203 force 3 ,loopcnt 
+
+memset0:
+7e3b 18007e00 force 0 ,pdata 
+
+memset8:
+7e3c e0a40000 istore 8 ,contw 
+7e3d c2007e3c loop memset8 
+7e3e 20600000 rtn 
+
+clear_mem:
+7e3f 1f227e00 deposit loopcnt 
+7e40 207a0000 rtn blank 
+7e41 58000000 setarg 0 
+
+clear_mem_loop:
+7e42 e0a08000 istore 1 ,contw 
+7e43 c2007e42 loop clear_mem_loop 
+7e44 20600000 rtn 
+
+memcpy:
+7e45 1f227e00 deposit loopcnt 
+7e46 207a0000 rtn blank 
+
+memcpy_loop:
+7e47 e8c08000 ifetch 1 ,contr 
+7e48 e0a08000 istore 1 ,contw 
+7e49 c2007e47 loop memcpy_loop 
+7e4a 20600000 rtn 
+
+timer_stop:
+7e4b 58000000 setarg 0 
+
+timer_init:
+7e4c d8a0423e arg mem_timers ,contw 
+7e4d 98000400 iforce temp 
+7e4e 18e3fe00 lshift queue ,pdata 
+7e4f 98a08a00 iadd contw ,contw 
+7e50 e0a90000 istoret 2 ,contw 
+7e51 20600000 rtn 
+
+timer_reinit:
+7e52 d8e00000 arg 0 ,queue 
+
+timer_check:
+7e53 79200025 set1 mark_ext_patch ,mark 
+7e54 44de4037 bpatch patch37_4 ,mem_patch37 
+7e55 680a4134 fetcht 4 ,mem_last_clkn 
+7e56 1c437e00 rshift clkn_bt ,pdata 
+7e57 60024134 store 4 ,mem_last_clkn 
+7e58 98461600 isub temp ,timeup 
+7e59 19620400 copy timeup ,temp 
+7e5a d8c0423e arg mem_timers ,contr 
+7e5b 18c20a00 copy contr ,contw 
+7e5c df200010 arg 16 ,loopcnt 
+
+timer_loop:
+7e5d e8c10000 ifetch 2 ,contr 
+7e5e 98467e00 isub temp ,pdata 
+7e5f 20217e61 branch timer_counting ,positive 
+7e60 18007e00 force 0 ,pdata 
+
+timer_counting:
+7e61 e0a10000 istore 2 ,contw 
+7e62 c2007e5d loop timer_loop 
+7e63 d8c0423e arg mem_timers ,contr 
+7e64 18e3fe00 lshift queue ,pdata 
+7e65 98c08c00 iadd contr ,contr 
+7e66 e8c10000 ifetch 2 ,contr 
+7e67 20600000 rtn 
+
+lshift8_queue:
+7e68 18e08e01 increase 1 ,queue 
+
+lshift8_queue_loop:
+7e69 18e08fff increase -1 ,queue 
+7e6a 20628000 rtn zero 
+7e6b 1fed7e00 lshift8 pdata ,pdata 
+7e6c 20207e69 branch lshift8_queue_loop 
+
+clk_add:
+7e6d 98408400 iadd temp ,temp 
+7e6e 18427200 copy temp ,loopcnt 
+7e6f 58000ea6 setarg 3750 
+7e70 9f267e00 isub loopcnt ,pdata 
+7e71 20610000 rtn positive 
+7e72 1fe67e00 sub pdata ,0 ,pdata 
+7e73 18510400 rshift16 temp ,temp 
+7e74 18408401 increase 1 ,temp 
+7e75 18500400 lshift16 temp ,temp 
+7e76 98418400 ior temp ,temp 
+7e77 20600000 rtn 
+
+clk_diff_rt:
+7e78 20407e7a call clk_diff 
+7e79 20207e84 branch clk2rt 
+
+clk_diff:
+7e7a 78547c00 disable user 
+7e7b 98467e00 isub temp ,pdata 
+7e7c 20217e7f branch clk_diff_pos ,positive 
+7e7d 78347c00 enable user 
+7e7e 1fe67e00 sub pdata ,0 ,pdata 
+
+clk_diff_pos:
+7e7f c4078000 rtnbit0 15 
+7e80 d85f0ea6 arg -61786 ,temp 
+7e81 9840fe00 iadd temp ,pdata 
+7e82 793ffe40 set0 64 ,pdata 
+7e83 20600000 rtn 
+
+clk2rt:
+7e84 98000c00 iforce contr 
+7e85 1ff17e00 rshift16 pdata ,pdata 
+7e86 d8400ea6 arg 3750 ,temp 
+7e87 984ffe00 imul32 temp ,pdata 
+7e88 98c0fe00 iadd contr ,pdata 
+7e89 20600000 rtn 
+
+clk2lpo:
+7e8a 1fed7e00 lshift8 pdata ,pdata 
+7e8b 1ff27e00 lshift4 pdata ,pdata 
+7e8c 6809c210 fetcht 3 ,mem_clks_per_lpo 
+7e8d 9846fc00 idiv temp 
+7e8e 20407efd call wait_div_end 
+7e8f 18078400 quotient temp 
+7e90 20600000 rtn 
+
+clk2bt:
+7e91 d8400ea6 arg 3750 ,temp 
+7e92 9846fc00 idiv temp 
+7e93 20407efd call wait_div_end 
+7e94 1807fe00 quotient pdata 
+7e95 1ff07e00 lshift16 pdata ,pdata 
+7e96 18070400 remainder temp 
+7e97 98418400 ior temp ,temp 
+7e98 20600000 rtn 
+
+mem3_hex2string_to_uart:
+7e99 df200003 arg 3 ,loopcnt 
+7e9a 20207e9e branch hex2string_to_uart0 
+
+mem2_hex2string_to_uart:
+7e9b df200002 arg 2 ,loopcnt 
+7e9c 20207e9e branch hex2string_to_uart0 
+
+adss_hex2string_to_uart:
+7e9d df200006 arg 6 ,loopcnt 
+
+hex2string_to_uart0:
+7e9e ea208000 ifetch 1 ,rega 
+7e9f 1fe20400 copy pdata ,temp 
+7ea0 1ff1fe00 rshift4 pdata ,pdata 
+7ea1 20407eaa call dialog2uchar 
+7ea2 e1408000 istore 1 ,contwu 
+7ea3 18427e00 copy temp ,pdata 
+7ea4 1fe17e0f and pdata ,0xf ,pdata 
+7ea5 20407eaa call dialog2uchar 
+7ea6 e1408000 istore 1 ,contwu 
+7ea7 1a20a201 increase 1 ,rega 
+7ea8 c2007e9e loop hex2string_to_uart0 
+7ea9 20600000 rtn 
+
+dialog2uchar:
+7eaa 1fe67c09 sub pdata ,9 ,null 
+7eab 20217eae branch dialog2uchar0to9 ,positive 
+7eac 1fe0fe57 increase 87 ,pdata 
+7ead 20600000 rtn 
+
+dialog2uchar0to9:
+7eae 1fe0fe30 add pdata ,0x30 ,pdata 
+7eaf 20600000 rtn 
+
+string2dec_from_uart:
+7eb0 d8400000 arg 0 ,temp 
+
+string2dec_from_uart_done:
+7eb1 18422600 copy temp ,regc 
+7eb2 e8608000 ifetch 1 ,contru 
+7eb3 1fe67c2c sub pdata ,at_comma ,null 
+7eb4 20628000 rtn zero 
+7eb5 20407ec9 call uchar2dialog 
+7eb6 1a620400 copy regc ,temp 
+7eb7 20407f32 call swap 
+7eb8 da40000a arg 10 ,regb 
+7eb9 9a4ffe00 imul32 regb ,pdata 
+7eba 9840fe00 iadd temp ,pdata 
+7ebb 1fe20400 copy pdata ,temp 
+7ebc 20207eb1 branch string2dec_from_uart_done 
+
+mem2_string2hex_from_uart:
+7ebd df200002 arg 2 ,loopcnt 
+7ebe 20207ec0 branch string2hex_from_uart 
+
+adss_string2hex_from_uart:
+7ebf df200006 arg 6 ,loopcnt 
+
+string2hex_from_uart:
+7ec0 e8608000 ifetch 1 ,contru 
+7ec1 20407ec9 call uchar2dialog 
+7ec2 1ff22600 lshift4 pdata ,regc 
+7ec3 e8608000 ifetch 1 ,contru 
+7ec4 20407ec9 call uchar2dialog 
+7ec5 9a60fe00 iadd regc ,pdata 
+7ec6 e0a08000 istore 1 ,contw 
+7ec7 c2007ec0 loop string2hex_from_uart 
+7ec8 20600000 rtn 
+
+uchar2dialog:
+7ec9 d840003a arg 0x3a ,temp 
+7eca 98467c00 isub temp ,null 
+7ecb 24217ed2 nbranch uchar2dialog_number ,positive 
+7ecc d8400061 arg 0x61 ,temp 
+7ecd 98467c00 isub temp ,null 
+7ece 20217ed5 branch uchar2dialog_a2f ,positive 
+7ecf d8400037 arg 0x37 ,temp 
+7ed0 98467e00 isub temp ,pdata 
+7ed1 20600000 rtn 
+
+uchar2dialog_number:
+7ed2 d8400030 arg 0x30 ,temp 
+7ed3 98467e00 isub temp ,pdata 
+7ed4 20600000 rtn 
+
+uchar2dialog_a2f:
+7ed5 d8400057 arg 0x57 ,temp 
+7ed6 98467e00 isub temp ,pdata 
+7ed7 20600000 rtn 
+
+pn9:
+7ed8 18426000 copy temp ,alarm 
+7ed9 580001ff setarg 0x1ff 
+7eda 18002400 force 0 ,regb 
+
+pn9_loop:
+7edb 1fe92200 rshift3 pdata ,rega 
+7edc 1a232200 rshift rega ,rega 
+7edd 9a22a200 ixor rega ,rega 
+7ede 2a2ffe00 isolate1 0 ,rega 
+7edf 7920fe09 setflag true ,9 ,pdata 
+7ee0 18430400 rshift temp ,temp 
+7ee1 2feffe00 isolate1 0 ,pdata 
+7ee2 79208407 setflag true ,7 ,temp 
+7ee3 1fe37e00 rshift pdata ,pdata 
+7ee4 1a40a401 increase 1 ,regb 
+7ee5 2a400e00 compare 0 ,regb ,0x7 
+7ee6 2420fedb nbranch pn9_loop ,true 
+7ee7 e0a88000 istoret 1 ,contw 
+7ee8 c2007edb loop pn9_loop 
+7ee9 1e020400 copy alarm ,temp 
+7eea 20600000 rtn 
+
+bcd_byte:
+7eeb 1fe6fc0a div pdata ,10 
+7eec 20407efd call wait_div_end 
+7eed 1807fe00 quotient pdata 
+7eee 1feba200 lshift2 pdata ,rega 
+7eef 1a2ba200 lshift2 rega ,rega 
+7ef0 18077e00 remainder pdata 
+7ef1 9a21fe00 ior rega ,pdata 
+7ef2 20600000 rtn 
+
+bcd_pack:
+7ef3 2a2ffe00 isolate1 0 ,rega 
+7ef4 2020fef7 branch bcd_pack_hi ,true 
+7ef5 98002400 iforce regb 
+7ef6 20600000 rtn 
+
+bcd_pack_hi:
+7ef7 1febfe00 lshift2 pdata ,pdata 
+7ef8 1febfe00 lshift2 pdata ,pdata 
+7ef9 9a41fe00 ior regb ,pdata 
+7efa e0a08000 istore 1 ,contw 
+7efb 18a08bfe increase -2 ,contw 
+7efc 20600000 rtn 
+
+wait_div_end:
+7efd 207a8000 rtn modone 
+7efe 20207efd branch wait_div_end 
+
+bcd2:
+7eff 60040161 store 8 ,mem_pdatatemp 
+7f00 18007e20 force 0x20 ,pdata 
+7f01 18007208 force 8 ,loopcnt 
+7f02 d8a00028 arg mem_bcd ,contw 
+
+lpo_clear:
+7f03 e0a08000 istore 1 ,contw 
+7f04 c2007f03 loop lpo_clear 
+7f05 d8a00028 arg mem_bcd ,contw 
+7f06 18a08a07 increase 7 ,contw 
+7f07 68040161 fetch 8 ,mem_pdatatemp 
+
+bcd_loop:
+7f08 1fe6fc0a div pdata ,10 
+7f09 20407efd call wait_div_end 
+7f0a 18077e00 remainder pdata 
+7f0b 1fe1fe30 or_into 0x30 ,pdata 
+7f0c e0a08000 istore 1 ,contw 
+7f0d 18a08bfe increase -2 ,contw 
+7f0e 1807fe00 quotient pdata 
+7f0f 207a0000 rtn blank 
+7f10 20207f08 branch bcd_loop 
+
+bcd:
+7f11 60040161 store 8 ,mem_pdatatemp 
+7f12 18007e00 force 0 ,pdata 
+7f13 60040028 store 8 ,mem_bcd 
+7f14 d8a00028 arg mem_bcd ,contw 
+7f15 18a08a07 increase 7 ,contw 
+7f16 68040161 fetch 8 ,mem_pdatatemp 
+7f17 18002200 force 0 ,rega 
+
+bcd_pack_loop:
+7f18 1fe6fc0a div pdata ,10 
+7f19 20407efd call wait_div_end 
+7f1a 18077e00 remainder pdata 
+7f1b 20407ef3 call bcd_pack 
+7f1c 1a20a201 increase 1 ,rega 
+7f1d 1807fe00 quotient pdata 
+7f1e 1fe67c09 sub pdata ,9 ,null 
+7f1f 24217f18 nbranch bcd_pack_loop ,positive 
+7f20 20407ef3 call bcd_pack 
+7f21 2a2ffe00 isolate1 0 ,rega 
+7f22 20608000 rtn true 
+7f23 e0a08000 istore 1 ,contw 
+7f24 20600000 rtn 
+
+string_compare:
+7f25 ea208000 ifetch 1 ,rega 
+7f26 ea488000 ifetcht 1 ,regb 
+7f27 98467c00 isub temp ,null 
+7f28 24628000 nrtn zero 
+7f29 1a20a201 increase 1 ,rega 
+7f2a 1a40a401 increase 1 ,regb 
+7f2b c2007f25 loop string_compare 
+7f2c 18007c00 force 0 ,null 
+7f2d 20600000 rtn 
+
+ceiling:
+7f2e 98467c00 isub temp ,null 
+7f2f 24610000 nrtn positive 
+7f30 18427e00 deposit temp 
+7f31 20600000 rtn 
+
+swap:
+7f32 9840fe00 iadd temp ,pdata 
+7f33 98460400 isub temp ,temp 
+7f34 98467e00 isub temp ,pdata 
+7f35 20600000 rtn 
+
+clean_mem:
+7f36 df200200 arg 0x200 ,loopcnt 
+7f37 d8a04000 arg 0x4000 ,contw 
+7f38 20207e3b branch memset0 
+
+slave_savelist:
+7f39 6802809c fetch 5 ,mem_sync_clke 
+7f3a 60028161 store 5 ,mem_pdatatemp 
+7f3b 68014210 fetch 2 ,mem_clks_per_lpo 
+7f3c e0a10000 istore 2 ,contw 
+7f3d 58000000 setarg 0 
+7f3e 7936fe07 setflag match ,7 ,pdata 
+7f3f 7935fe06 setflag wake ,6 ,pdata 
+7f40 792c7e05 setflag sync ,5 ,pdata 
+7f41 79377e04 setflag attempt ,4 ,pdata 
+7f42 e0a08000 istore 1 ,contw 
+7f43 20207f52 branch savelist_2 
+
+le_savelist:
+7f44 6802809c fetch 5 ,mem_sync_clke 
+7f45 60028161 store 5 ,mem_pdatatemp 
+7f46 68008016 fetch 1 ,mem_le_ch_mapped 
+7f47 e0a08000 istore 1 ,contw 
+7f48 680103da fetch 2 ,mem_le_event_count 
+7f49 d8c00fff arg 0x0fff ,contr 
+7f4a 98c17e00 iand contr ,pdata 
+7f4b 7936fe0f setflag match ,15 ,pdata 
+7f4c 7935fe0e setflag wake ,14 ,pdata 
+7f4d 792c7e0d setflag sync ,13 ,pdata 
+7f4e 79377e0c setflag attempt ,12 ,pdata 
+7f4f e0a10000 istore 2 ,contw 
+7f50 20207f52 branch savelist_2 
+
+savelist:
+7f51 60040161 store 8 ,mem_pdatatemp 
+
+savelist_2:
+7f52 6800c16e fetch 1 ,mem_seqi 
+7f53 c13f8000 rtneq 0x7f 
+7f54 1fe17e7f and_into 0x7f ,pdata 
+7f55 1fe9fe00 lshift3 pdata ,pdata 
+7f56 d8a04c00 arg mem_savelist ,contw 
+7f57 98a08a00 iadd contw ,contw 
+7f58 68040161 fetch 8 ,mem_pdatatemp 
+7f59 e0a40000 istore 8 ,contw 
+7f5a 6800c16e fetch 1 ,mem_seqi 
+7f5b 2feffe07 isolate1 7 ,pdata 
+7f5c 1fe0fe01 increase 1 ,pdata 
+7f5d 1fe17e7f and_into 0x7f ,pdata 
+7f5e 7920fe07 setflag true ,7 ,pdata 
+7f5f 6000c16e store 1 ,mem_seqi 
+7f60 68040161 fetch 8 ,mem_pdatatemp 
+7f61 20600000 rtn 
+
+dirty_mem:
+7f62 df200800 arg 0x800 ,loopcnt 
+7f63 d8a00000 arg 0 ,contw 
+7f64 59010101 setarg 0x01010101 
+7f65 20207e3c branch memset8 
+
+callback_func:
+7f66 207a0000 rtn blank 
+7f67 1fe27a00 copy pdata ,pc 
+
+wait_uarttx:
+7f68 6811010e hfetch 2 ,core_uart_txitems 
+7f69 243a7f68 nbranch wait_uarttx ,blank 
+7f6a 20600000 rtn 
+
+get_uart_rrptr:
+7f6b 68110058 hfetch 2 ,core_uart_rrptr 
+7f6c 1fe20600 copy pdata ,contru 
+7f6d 20600000 rtn 
+
+get_uart_twptr:
+7f6e 6811005e hfetch 2 ,core_uart_twptr 
+7f6f 1fe21400 copy pdata ,contwu 
+7f70 20600000 rtn 
+
+send_mem_to_uart:
+7f71 18c22200 copy contr ,rega 
+7f72 20407f6e call get_uart_twptr 
+7f73 1a220c00 copy rega ,contr 
+
+send_mem_to_uart0:
+7f74 20404976 call uart_copy_tx_bytes 
+7f75 204068fa call uartd_send 
+7f76 20207f68 branch wait_uarttx 
+
+ice_break:
+7f77 70820301 hjam 0x1 ,core_ice_ctrl 
+7f78 20600000 rtn 
+
+ice_setbp:
+7f79 60110205 hstore 2 ,core_ice_break0 
+7f7a 68108203 hfetch 1 ,core_ice_ctrl 
+7f7b 79207e04 set1 4 ,pdata 
+7f7c 60108203 hstore 1 ,core_ice_ctrl 
+7f7d 20600000 rtn 
+
+ice_setbp2:
+7f7e 60110207 hstore 2 ,core_ice_break1 
+7f7f 68108203 hfetch 1 ,core_ice_ctrl 
+7f80 79207e06 set1 6 ,pdata 
+7f81 60108203 hstore 1 ,core_ice_ctrl 
+7f82 20600000 rtn 
+
+ice_set_write_bp:
+7f83 60110205 hstore 2 ,core_ice_break0 
+7f84 70820330 hjam 0x30 ,core_ice_ctrl 
+7f85 20600000 rtn 
+
+test_no_white:
+7f86 68108043 hfetch 1 ,core_config 
+7f87 79207e04 set1 whiteoff_bit ,pdata 
+7f88 60108043 hstore 1 ,core_config 
+7f89 20600000 rtn 
+
+test_enable_white:
+7f8a 68108043 hfetch 1 ,core_config 
+7f8b 793ffe04 set0 whiteoff_bit ,pdata 
+7f8c 60108043 hstore 1 ,core_config 
+7f8d 20600000 rtn 
+
+check_uart_tx_buff:
+7f8e 6811010e hfetch 2 ,core_uart_txitems 
+7f8f d8400200 arg uart_air_control_threshold ,temp 
+
+pdata_sub_temp:
+7f90 98467c00 isub temp ,null 
+7f91 20600000 rtn 
+
+fifo_in:
+7f92 79200025 set1 mark_ext_patch ,mark 
+7f93 44dec037 bpatch patch37_5 ,mem_patch37 
+7f94 ea2a8000 ifetcht util_fifo_len ,rega 
+7f95 18417eff and temp ,0xff ,pdata 
+7f96 243a7f99 nbranch fifo_in_push ,blank 
+7f97 184cfe00 rshift8 temp ,pdata 
+7f98 e2228000 istore util_fifo_len ,rega 
+
+fifo_in_push:
+7f99 1a20a204 increase util_fifo_len + util_fifo_offset ,rega 
+7f9a ea208000 ifetch 1 ,rega 
+7f9b 243a3bf1 nbranch assert ,blank 
+7f9c 68008b7d fetch 1 ,mem_fifo_temp 
+7f9d e2208000 istore 1 ,rega 
+7f9e 20600000 rtn 
+
+fifo_out:
+7f9f 79200025 set1 mark_ext_patch ,mark 
+7fa0 44df4037 bpatch patch37_6 ,mem_patch37 
+7fa1 df200005 arg util_fifo_len ,loopcnt 
+7fa2 ea228000 ifetch util_fifo_len ,rega 
+7fa3 207a0000 rtn blank 
+
+fifo_out_loop:
+7fa4 ea208000 ifetch 1 ,rega 
+7fa5 243a7fa9 nbranch fifo_out_end ,blank 
+7fa6 1a20a201 increase 1 ,rega 
+7fa7 c2007fa4 loop fifo_out_loop 
+7fa8 20203bf1 branch assert 
+
+fifo_out_end:
+7fa9 d8400000 arg 0 ,temp 
+7faa e2288000 istoret 1 ,rega 
+7fab 20600000 rtn 
+
+fifo_is_empty:
+7fac ea228000 ifetch util_fifo_len ,rega 
+7fad 20600000 rtn 
+
+fifo_is_full:
+7fae ea208000 ifetch 1 ,rega 
+7faf 20600000 rtn 
+
+fifo_is_near_full:
+7fb0 ea210000 ifetch 2 ,rega 
+7fb1 20600000 rtn 
+
+fifo_content_count:
+7fb2 d8400000 arg 0 ,temp 
+
+fifo_content_count_loop:
+7fb3 68008006 fetch 1 ,contr 
+7fb4 c2007fb3 loop fifo_content_count_loop ,blank 
+7fb5 18408401 increase 1 ,temp 
+7fb6 c2007fb3 loop fifo_content_count_loop 
+7fb7 18427e00 copy temp ,pdata 
+7fb8 20600000 rtn 
+
+not_greater_than:
+7fb9 98467c00 isub temp ,null 
+7fba 24610000 nrtn positive 
+7fbb 18427e00 copy temp ,pdata 
+7fbc 20600000 rtn 
+
Index: btkb/output/romcode.rom
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/output/romcode.rom	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/output/romcode.rom	(working copy)
@@ -0,0 +1,20480 @@
+20403c74
+793f8025
+44804000
+20800000
+20403a9e
+20406805
+20403bfa
+20404d98
+793f8025
+4480c000
+20406b53
+20405b62
+20407b9d
+20403e4f
+793f8025
+44814000
+2055be5f
+20407719
+2055bcf1
+793f8025
+4481c000
+20407813
+20405373
+20404449
+793f8025
+44824000
+2040303e
+20403e6a
+204030a1
+793f8025
+4482c000
+20403392
+20403407
+20403024
+20403d1c
+20203013
+20403029
+c6848000
+793f8009
+204032bd
+202053d7
+793f8025
+44834000
+204032fe
+2422b033
+204032a3
+1a208c01
+e8c08000
+c2805377
+c280b1a7
+20203473
+793f8025
+4483c000
+204032c6
+1f227c00
+20628000
+204032a3
+68008030
+c281b103
+68008031
+c280b1a7
+20203473
+6800c272
+207a0000
+c000b04e
+c0013053
+c001b056
+c002b05b
+c00db04b
+204032f6
+20628000
+204032f9
+20628000
+70427200
+20600000
+70041c1b
+70427200
+20600000
+7920001c
+793f801e
+70008eff
+70008c1f
+20203049
+793f801c
+18003600
+20203049
+204032f9
+20628000
+18000401
+70017805
+20203068
+793f8025
+44844001
+6800c132
+c000b064
+68034274
+203a3049
+7047f301
+70005503
+20203067
+68034274
+203a3049
+60030040
+18000425
+793f8025
+4484c001
+680080f3
+203a306f
+1fe9fe00
+1ff27e00
+1fe0ffff
+6000c146
+600080f2
+70008d1f
+793f800c
+204032d6
+2422b090
+20403bd1
+60008077
+6008807c
+68034274
+60030040
+793f8025
+44854001
+18007e00
+2841fe01
+7d20fe05
+79207e03
+60008030
+700b7d03
+20407c27
+18007e00
+7920fe04
+6000804c
+58000000
+79207e01
+60008031
+7834fc00
+204032bd
+7854fc00
+18000e04
+68014159
+20407e4c
+20203049
+793f8025
+4485c001
+68034274
+60030040
+2841fe01
+2020b099
+18000407
+20404826
+20203049
+d8a00103
+df200008
+20407e3b
+18000e07
+20404898
+700b7d04
+20407c27
+20203049
+c68e0000
+18000e02
+20407e53
+7d3a001c
+243a30a7
+20600000
+793f8025
+44864001
+6809415b
+18000e04
+2040383d
+20740000
+20403a12
+18004800
+20618000
+793f800b
+793f8000
+1c40c201
+280ffe1e
+7920c802
+2c200400
+2420b0d3
+793f8025
+4486c001
+68008012
+1fe0fe01
+60008012
+20403a49
+20403a42
+20403a66
+20403bae
+20403bb4
+20403bc5
+2040375c
+204030c5
+202030af
+793f8025
+44874001
+6800808c
+1fe0ffff
+6000808c
+20610000
+70008c1f
+6800808e
+1fe0ffff
+6000808e
+20610000
+7940001e
+70008eff
+20600000
+793f8025
+4487c001
+20403a49
+20403a3b
+20403a66
+20403bba
+20403b3a
+20403b63
+202c30de
+204030c5
+202030b2
+793f8025
+44884002
+20403af3
+20403bcd
+204035e1
+793f8001
+c6858000
+793f8025
+4488c002
+6800c2a4
+c2804221
+2040477b
+68008013
+1fe0fe01
+60008013
+20600000
+793f800b
+204030fe
+20403a49
+20403a3b
+204034e1
+20403bba
+20403b3a
+20403b63
+202c30f8
+20600000
+20403bcd
+204035e1
+793f8001
+202330e5
+2040479b
+202030ea
+d9600600
+34730200
+1c417e03
+c080b0ff
+20600000
+793f8025
+44894002
+7834fc00
+78387c00
+68014155
+203a310c
+18000e0d
+20407e53
+247a0000
+793f8025
+4489c002
+68094157
+18000e28
+2040383d
+2034314e
+18000e04
+20407e53
+243a3127
+6800804c
+c282311a
+18000404
+20404826
+2020311f
+d8a00103
+df200008
+20407e3b
+18000e04
+20404898
+793f8025
+448a4002
+70003000
+20405b63
+7047f300
+700b7d13
+20407c27
+2020314e
+793f8025
+448ac002
+18001600
+34730200
+680080f4
+1fe0ffff
+9c42fe00
+2fe00600
+2420b127
+18827e00
+6000818b
+18004c00
+18004800
+793f8025
+448b4002
+2021b14e
+20403a4d
+d9600600
+34730200
+793f8025
+448bc002
+680200f4
+98004200
+1fe0fe01
+600200f4
+280ffe0c
+7920c802
+2c200400
+2420b164
+6800800c
+1fe0fe01
+6000800c
+20403a42
+20403bae
+20403bb4
+20403bc5
+2040375c
+20403155
+20203134
+793f8025
+448c4003
+7854fc00
+68014155
+207a0000
+18000e0d
+20207e4c
+793f8025
+448cc003
+6800808d
+1fe0ffff
+6000808d
+20610000
+70008d1f
+680080f2
+1fe0ffff
+600080f2
+20610000
+7940000c
+6800c146
+600080f2
+20600000
+793f8025
+448d4003
+20403a3b
+20403bba
+20403b3a
+20403b63
+202c316d
+20403155
+2020313a
+2040375c
+6800800d
+1fe0fe01
+6000800d
+18003600
+680200f4
+793f8025
+448dc003
+20403bac
+20403a4d
+1cc0cc01
+1c2143fd
+1c8149fc
+20403a42
+20403bae
+20403bb4
+20403bc5
+1c427e00
+6002016b
+18000800
+18000202
+20403bcd
+204038c1
+793f8025
+448e4003
+20403baa
+1c21c202
+1c8149fc
+20403a3b
+20403bba
+20403b3a
+20403b63
+204c375c
+202c3194
+68008010
+203a3134
+1fe0ffff
+60008010
+20203173
+793f8025
+448ec003
+6800800e
+1fe0fe01
+6000800e
+204034ed
+2040338b
+202c319f
+2040350e
+243a319a
+20203134
+793f8025
+448f4003
+68008030
+793ffe03
+60008030
+204034f9
+7854fc00
+20600000
+793f8025
+448fc003
+7834fc00
+78387c00
+2040324e
+20740000
+20403e25
+20403bac
+1c40c201
+20403a54
+18004803
+2040327c
+20406a54
+20406e10
+20403547
+20403a42
+20403bae
+20403bb4
+20403bc5
+204038bf
+793f8025
+44904004
+20405b78
+20404995
+204048a9
+2040337c
+2436b1c7
+20403bec
+20403870
+6800800f
+1fe0fe01
+6000800f
+793f8025
+4490c004
+20406dec
+204031d5
+24748000
+20403812
+243a31d2
+20406a5c
+20403290
+7854fc00
+20600000
+20403547
+20403371
+202031bb
+2036b1d8
+20403be2
+202131e6
+20403204
+243431e6
+6800804c
+c4020000
+c3818000
+6800804b
+c3818000
+2040320d
+247a0000
+68008178
+1fe0ffff
+60008178
+247a0000
+20205ed5
+793f8025
+44914004
+20403516
+7854fc00
+6800804c
+c28231f2
+68008030
+c30231f0
+68088046
+202048c4
+18000408
+20204826
+18000e00
+6800804c
+c281c898
+18000e04
+d8a00103
+df200008
+20407e3b
+20204898
+793f8025
+4491c004
+68008030
+c4010000
+68088046
+680080ac
+98467c00
+24628000
+20403869
+20203293
+793f8025
+44924004
+78347c00
+6800804b
+c4018000
+2040320d
+247a0000
+78547c00
+20600000
+68008072
+1fe0ffff
+60008072
+20600000
+793f8025
+4492c004
+68008030
+c283b21f
+6800c132
+c000b21d
+680087e1
+203a321f
+7007e100
+700b7d18
+20407c27
+2020321f
+20406216
+2440c852
+793f8025
+44934004
+204032f0
+68008030
+79207e07
+60008030
+70425e01
+68008055
+c08b3228
+20600000
+7007e101
+68008030
+793ffe07
+60008030
+20600000
+793f8025
+4493c004
+78547c00
+68008030
+c4008000
+68010032
+247a0000
+68020034
+20383239
+9d067e00
+2020323a
+9c467e00
+1fe67c04
+24610000
+68008030
+793ffe01
+60008030
+78347c00
+20600000
+1fe20400
+793f8025
+44944005
+60020034
+70474801
+68008030
+79207e01
+60008030
+18007e00
+60010032
+70008a0a
+70007301
+20600000
+793f8025
+4494c005
+2040322e
+24740000
+78547c00
+70001120
+793f800b
+20403bac
+2040337f
+c505b263
+2040350e
+243a3255
+793f8025
+44954005
+78547c00
+1c427e00
+6002416a
+78387c00
+7834fc00
+700b7d2a
+20207c27
+793f8025
+4495c005
+20403baa
+20403374
+78587c00
+7854fc00
+20403982
+204034ed
+793f8025
+44964005
+20403539
+2036b272
+2040350e
+243a326b
+2020325a
+18000401
+2040487f
+68008031
+793ffe01
+60008031
+20403bec
+204039ac
+78347c00
+700b7d2b
+20207c27
+793f8025
+4496c005
+c6838000
+68008030
+c4010000
+20403c23
+680080b3
+68088047
+600880b4
+60008047
+18827e00
+600080b2
+6800c1f9
+98000800
+793f8008
+6800c165
+6000c167
+6800c166
+6000c165
+20600000
+793f8025
+44974005
+c6838000
+20403847
+24608000
+20403799
+680080b4
+68088047
+60008047
+600880b3
+680080b2
+98000800
+6800c165
+6000c166
+6800c167
+6000c165
+5800ffff
+60014168
+20600000
+793f8025
+4497c005
+79200009
+1a227e00
+6001001e
+18007250
+d8a003c0
+1a208c01
+e8c08000
+1a220c00
+c2807e45
+d8a00030
+20407e45
+78577c00
+68008077
+98000800
+70008a01
+2034b2b6
+70008a01
+68008030
+c4008000
+68008073
+6000808a
+68008074
+6000808b
+20600000
+793f8025
+44984006
+6801001e
+98000a00
+18007250
+d8c003c0
+203b7e45
+d8c00030
+20207e45
+68088015
+df200003
+18408401
+2841fe03
+2420b2cc
+d8400000
+60088015
+184ffe50
+da204040
+9a20a200
+ea208000
+c280b2d4
+c3800000
+c3818000
+c20032c8
+20600000
+793f8025
+4498c006
+da60330b
+20403301
+24628000
+1a227e00
+6001001e
+18007c00
+20600000
+20403847
+2020b2e7
+6801001e
+1fe08a17
+68008047
+e0a08000
+da603334
+20203301
+68008047
+2feffe03
+2020b2ec
+18007c01
+20600000
+18007c00
+20600000
+da603331
+20203301
+6809001e
+da603366
+20203301
+6809001e
+da603359
+20203301
+6808c273
+da603316
+20203301
+793f8025
+44994006
+680b4274
+da60330f
+20203301
+da60331c
+20203301
+da603350
+793f8025
+4499c006
+da204040
+18007203
+ea208000
+1a627a00
+1a20a250
+c2003305
+18007c01
+20600000
+c2803307
+c281b307
+18007c00
+20600000
+c281b311
+c3003307
+1a208c10
+e8c30000
+98467c00
+20628000
+20203307
+c3003307
+1a208c16
+e8c08000
+98467c00
+20628000
+20203307
+c300b307
+2040333d
+c28db322
+284c001b
+2020b322
+79207e1c
+98467e00
+1fe0fe01
+2021332b
+1fe0fe05
+24213307
+18424200
+20403349
+18007c00
+20600000
+98002400
+1a208c02
+e8c10000
+203a3327
+20403349
+2020331d
+c3003307
+18007c00
+20600000
+c3003307
+1a208c01
+e8c08000
+c2803307
+1a208c17
+e8c08000
+c301b307
+18007c00
+20600000
+1a208c01
+e8c88000
+1c427e00
+284ffe01
+1a208c04
+e8ca0000
+20608000
+1a208c08
+e8c30000
+204039c0
+1d027e00
+20600000
+1a208c02
+1a208a04
+e8c10000
+98409600
+19627e00
+e0a20000
+20205434
+c300b307
+2040333d
+9b60fe00
+9b60fe00
+98e0fe00
+98467c00
+24213307
+18007c00
+20600000
+c3003307
+18427e00
+9a267c00
+203f3307
+1a208c01
+e8c08000
+c2803307
+1a208a18
+e8a08000
+243a3307
+18007e2d
+e0a08000
+20203307
+c3003307
+18427e00
+9a267c00
+203f3307
+1a208c01
+e8c08000
+c2803307
+ea208000
+793ffe07
+e2208000
+20203307
+793f8025
+449a4006
+20403bac
+1c40c201
+20403a54
+18004803
+20403a42
+20403bae
+20403bb4
+20403bc5
+202038bf
+793f8025
+449ac006
+20403baa
+1c40c201
+20403a54
+18004803
+20403a3b
+204034e1
+20403b41
+20403bba
+20403b3a
+20403b63
+246c0000
+20403af3
+202035df
+793f8025
+449b4006
+6800818b
+98000800
+18000201
+20403371
+2020337c
+6800c133
+c4000000
+18000e05
+20407e53
+247a0000
+6809414d
+18000e04
+2040383d
+20740000
+204033a2
+18000e05
+6801414f
+242c7e4c
+180a7e00
+9ea17e00
+20207e4c
+793f8025
+449bc006
+70018b00
+78587c00
+78577c00
+20403a12
+1c4143fc
+18004801
+20403a49
+20403a3b
+7940001d
+68008006
+1fe0fe01
+60008006
+20403a66
+20403b3a
+20403b6b
+246c0000
+793f8025
+449c4007
+18003600
+20403a6d
+68008007
+1fe0fe01
+60008007
+20403a49
+20403baa
+1c21c202
+18004801
+20403a42
+20403a66
+20403bae
+20403bbf
+1c427e00
+6002016b
+20403bc5
+18000202
+18000800
+20403bcd
+204038c1
+204033ce
+1c2143fd
+1cc0cc01
+20600000
+793f8025
+449cc007
+6800c172
+207a0000
+d8a001bc
+6800c702
+1fe27200
+1fe0fe01
+e0a08000
+18a20400
+1fe0fe01
+60010091
+18420a00
+58000009
+e0a08000
+d8c04703
+20407e45
+da604771
+df200004
+204033f1
+da60475b
+df200001
+204033f1
+1800020a
+70009002
+580001bc
+60010179
+20403baa
+20403a42
+20403bae
+20403bbf
+20403bc5
+20403bcd
+204038c1
+20600000
+18a20400
+1a620c00
+e8c08000
+207a0000
+1fe3fe00
+c20033f5
+1fe22200
+1fe0fe02
+1fe20e00
+68010091
+98e0fe00
+60010091
+18420a00
+1a227e00
+1fe0fe01
+e0a08000
+1a620c00
+e8c08000
+e8c08000
+e0a08000
+1a227200
+20207e45
+6800c133
+c4008000
+18000e06
+20407e53
+247a0000
+68094151
+18000e28
+2040383d
+20740000
+18000800
+70001008
+793f800b
+20403417
+18000e06
+68014153
+20207e4c
+793f8025
+449d4007
+78587c00
+20403a12
+68008008
+1fe0fe01
+60008008
+18004c00
+20403a54
+1c40c201
+18004802
+793f8025
+449dc007
+20403a3b
+20403b3a
+20403b6b
+246c0000
+20403a6d
+68008009
+1fe0fe01
+60008009
+18003600
+20403baa
+1c21c202
+18004801
+20403a42
+20403bae
+20403bbf
+20403bc5
+2040375c
+18000800
+d9600600
+35330200
+1d01d003
+1c2143fd
+793f8025
+449e4007
+1cc0cc01
+20403a3b
+20403b3a
+20403b5d
+242c3444
+20403bcd
+204035e1
+c505b44c
+793f8025
+449ec007
+68008010
+207a0000
+1fe0ffff
+60008010
+20403bac
+2020343a
+793f8025
+449f4007
+793fd001
+79205000
+6800800a
+1fe0fe01
+6000800a
+20403baa
+1c21c202
+20403a42
+20403bae
+20403bbf
+20403bc5
+2040375c
+2d000603
+2020b45e
+37cb8200
+2020345a
+6802016f
+1fe1fe03
+1fe25000
+793f8025
+449fc007
+68030182
+60030040
+204034ed
+20403539
+2036b46b
+2040350e
+243a3466
+20600000
+793f8025
+44a04008
+204034f9
+204032d6
+24628000
+70003100
+204039ac
+202032bd
+793f8025
+44a0c008
+204039bc
+204034a5
+20740000
+2040327c
+20406a54
+793f8025
+44a14008
+20403e25
+20406dec
+204035d6
+20407f39
+2436b48d
+20403bec
+20403870
+20406e10
+20403547
+204038b1
+20405b78
+20404995
+204048a9
+6800800b
+1fe0fe01
+6000800b
+204039ac
+793f8025
+44a1c008
+20403d61
+20403be2
+20213498
+20403204
+24343498
+20403812
+243a347a
+20406a5c
+20203290
+793f8025
+44a24008
+70015300
+70018900
+20403516
+793f8011
+20407f8a
+68008030
+c30234a3
+68088046
+202048c4
+18000406
+20204826
+793f8025
+44a2c008
+2040322e
+24740000
+18820400
+20403bd1
+6000818b
+18420800
+70001120
+793f8025
+44a34008
+20403bac
+18000202
+204038a8
+1c427e00
+6002016b
+204038bf
+20403baa
+7837fc00
+204035b7
+202c34c1
+20403a6d
+2040350e
+243a34ae
+c6820000
+70007c34
+79200003
+20600000
+78387c00
+204034ed
+20403a12
+793f8025
+44a3c008
+2040338b
+202c34ce
+2040350e
+243a34c4
+78587c00
+1d027e00
+6002416a
+20600000
+18000400
+2040487f
+7834fc00
+c58234d6
+793f8004
+70007c03
+70007d33
+20406212
+18827e00
+60008077
+18007e00
+60030038
+68008031
+79207e01
+60008031
+20403bec
+7854fc00
+78347c00
+20600000
+793f8025
+44a44009
+7856fc00
+793f8005
+793f800a
+793f8010
+793f800f
+68008047
+793ffe05
+79207e04
+60008047
+20600000
+793f8025
+44a4c009
+70001120
+70004750
+6801415f
+6001003e
+1c427e00
+6002416a
+20780000
+1d027e00
+6002416a
+20600000
+793f8025
+44a54009
+20405b6f
+20403512
+60008046
+58001c80
+60010051
+68008030
+79207e00
+60008030
+70004b00
+70004c00
+7000a200
+20203bec
+793f8025
+44a5c009
+18007e00
+60044262
+e0a40000
+2040322a
+202032f0
+68008011
+1fe0ffff
+60008011
+20600000
+6800c170
+1fe0fe01
+6000c170
+20600000
+793f8025
+44a64009
+204031fa
+6800c272
+c001b51d
+68008048
+c080b521
+204049be
+2422b521
+204031f5
+70427200
+793f8025
+44a6c009
+20403f18
+20404995
+20403806
+700b7d02
+20407c27
+20405b63
+20404d99
+20407719
+68008030
+793ffe00
+60008030
+7047f300
+6800804c
+2fe18000
+2020b533
+793f8001
+68008047
+c301b535
+6800804b
+c4030000
+793f8002
+20600000
+793f8025
+44a74009
+6800817e
+207a0000
+1fe20800
+204035d6
+24768000
+18000200
+204038b1
+18827e00
+60008077
+18007e00
+6000817e
+20600000
+793f8025
+44a7c009
+68008030
+c3013555
+18000207
+c583b554
+20403847
+2420b555
+20373555
+20403583
+58000002
+60014168
+20600000
+24770000
+793f8025
+44a8400a
+204032df
+2422b568
+68008047
+c301b571
+c502b575
+68008189
+c283357c
+68014168
+1fe0ffff
+60014168
+203a3565
+6800c165
+98000200
+20600000
+793f8025
+44a8c00a
+20403799
+20403847
+2020b571
+20405ed9
+20343580
+6800804b
+c2833582
+c502b575
+68008189
+c283357c
+18000201
+20748000
+18000200
+20600000
+793f8025
+44a9400a
+68008019
+98000200
+c1808000
+18000200
+20600000
+6800815a
+1fe1020f
+79200005
+20600000
+18000213
+20203583
+2040358d
+793f8025
+44a9c00a
+68088047
+79200403
+60088047
+18227e00
+6000c165
+5800ffff
+60014168
+20600000
+793f8025
+44aa400a
+6800804c
+2feffe05
+68010091
+2020b5a1
+18000203
+1fe67c11
+20610000
+18000204
+1fe67c1b
+20610000
+1800020a
+1fe67c79
+20610000
+1800020e
+1fe67ce0
+20610000
+1800020f
+20600000
+18000203
+1fe67c11
+20610000
+18000204
+1fe67c36
+20610000
+1800020a
+d840016f
+98467c00
+24610000
+1800020e
+d84002a7
+98467c00
+24610000
+1800020f
+20600000
+68008030
+c300b5b6
+68010032
+203a35b6
+243735b8
+20403bac
+1d00c201
+78287c00
+6801003e
+1fe37e00
+d8400500
+9840fe00
+20403b7d
+20403a5d
+18004803
+20403a3b
+204034e1
+20403b41
+793f8025
+44aac00a
+6801003e
+1fe37e00
+20403b7d
+20403b3a
+7826fc00
+6801003e
+d84003bb
+9840b600
+37c18400
+1b420400
+600b009c
+7846fc00
+246c0000
+dd2003bb
+1c225000
+2035bcb6
+20600000
+793f8025
+44ab400a
+204035b1
+242c3a6d
+20403af3
+c588b5df
+680100f8
+1fe0fe01
+600100f8
+1c230400
+18419c40
+793f8025
+44abc00a
+7823fc00
+78257c00
+7825fc00
+09800003
+198cfe00
+6000815f
+09800004
+08008007
+19827e00
+60008019
+09800003
+198cfe00
+60008160
+68008019
+1fe67c03
+202135f7
+c003b5f7
+6800804c
+2feffe05
+7920aa01
+793f8025
+44ac400b
+09800008
+7845fc00
+78457c00
+2023373e
+c588b601
+680100fa
+1fe0fe01
+600100fa
+793f8025
+44acc00b
+6800815f
+2fe00e00
+7920800a
+2020b613
+a8800e00
+2020b612
+c583b75c
+680880b2
+a8400e00
+2420b75c
+20403290
+68008047
+793ffe05
+79207e04
+60008047
+7836fc00
+793f8025
+44ad400b
+68008019
+1fe20200
+c5053623
+68088160
+68008047
+793ffe00
+284ffe00
+7920fe00
+284ffe01
+7920fe01
+60008047
+284c0001
+2020b623
+20403799
+793f8025
+44adc00b
+d8400000
+20403b74
+18217e0f
+c000b656
+c000375c
+c0013769
+68088160
+68008047
+a8400800
+2420b632
+c5853631
+c303b632
+7920000f
+793f8025
+44ae400b
+18227e00
+c001b658
+c002365c
+c003b642
+c004365b
+d8400004
+20403b74
+c0053657
+c005b65a
+d8400008
+20403b74
+c0073657
+c007b65a
+20600000
+793f8025
+44aec00b
+7826fc00
+7824fc00
+78277c00
+d8a000d3
+1800721e
+09800008
+19897e00
+e0a08000
+c2003649
+c583b75c
+09800010
+7d230008
+20433653
+2023374b
+2020372c
+1b427e00
+60030020
+20600000
+2020375c
+79200010
+78267c00
+2020365d
+79200010
+79202a02
+7826fc00
+793f8025
+44af400b
+c500b75c
+2aac0001
+2020b66a
+7843fc00
+7826fc00
+78467c00
+1c409602
+34530400
+242c374b
+79200010
+7823fc00
+793f8025
+44afc00b
+78277c00
+7824fc00
+09800003
+198cfe00
+6000818a
+09800005
+c5083676
+19897200
+1f297200
+20203679
+09800005
+19837200
+09800003
+793f8025
+44b0400c
+1f227e00
+60010169
+203a36ee
+9ea67c00
+2021374b
+793f8025
+44b0c00c
+793f8000
+6800818a
+1fe17e03
+d8a004de
+c001b68f
+c508b6ea
+6800c132
+c000b694
+6800818a
+1fe17e03
+c00136c3
+c000b6d8
+2020374b
+68010169
+1fe67c70
+2421374b
+c507b72c
+202036ea
+793f8025
+44b1400c
+c507b72c
+68010169
+203a374b
+20404494
+2420b6a1
+68090291
+1fe0fe0a
+98467c00
+242136a7
+20404449
+2020369b
+6811010e
+d840012c
+98467c00
+2021374b
+68014800
+203a374b
+793f8025
+44b1c00c
+20404972
+68008046
+6808818a
+18410403
+184d0400
+18520400
+9841fe00
+e1410000
+68090169
+18427200
+e1490000
+793f8025
+44b2400c
+09800008
+19897e00
+e1408000
+c20036b4
+1840f204
+20404494
+2420b6c1
+79200013
+18000e06
+20404378
+202036ee
+20404424
+202036ee
+793f8025
+44b2c00c
+c507b72c
+68010169
+d84002e0
+98467c00
+2021374b
+680082ca
+c30036ce
+c300b6d3
+2020375c
+7002c801
+680102c4
+c080375c
+d8a01000
+202036ea
+7002c802
+680102c6
+c080375c
+d8a01400
+202036ea
+793f8025
+44b3400c
+c507b72c
+68010169
+d84002e0
+98467c00
+2021374b
+680082c8
+c000b6e3
+c00136e7
+2020375c
+d8a01000
+680102c4
+98a08a00
+202036ea
+d8a01400
+680102c6
+98a08a00
+09800008
+19897e00
+e0a08000
+c20036ea
+793f8025
+44b3c00c
+09800010
+20233745
+20403e0f
+6800c3cc
+c000b75c
+c508b718
+c507b759
+6800818a
+2fe00603
+2020b718
+68010169
+203a3718
+6800c132
+c000b718
+793f8025
+44b4400d
+680082c8
+c000b704
+c001370e
+20203bf1
+680102c4
+68090169
+9840fe00
+600102c4
+c0003bf1
+68091000
+18408404
+98467c00
+2042b8a0
+20203718
+680102c6
+68090169
+9840fe00
+600102c6
+c0003bf1
+68091400
+18408404
+98467c00
+2042b8a4
+20203718
+793f8025
+44b4c00d
+6808804c
+6800818a
+2fe00603
+79208406
+7d208407
+6008804c
+2420b722
+79200001
+c588b72c
+284ffe06
+2020b72c
+680100fc
+1fe0fe01
+600100fc
+79200005
+793f8407
+793f8001
+6008804c
+793f8025
+44b5400d
+68088160
+68008047
+79207e05
+284ffe02
+7920fe02
+280ffe0a
+7920fe07
+60008047
+68010169
+243a375c
+6800804c
+793ffe07
+6000804c
+6800818a
+2fe00e01
+2020375c
+793f8025
+44b5c00d
+7856fc00
+6801001a
+1fe0fe01
+6001001a
+2020375c
+6801001c
+1fe0fe01
+6001001c
+2040374c
+c588b74b
+79200005
+2020375c
+793f8025
+44b6400d
+6800818a
+2fe00603
+2420b755
+6808804c
+793f8406
+6008804c
+20600000
+6808804c
+793f8407
+6008804c
+2020443b
+68008047
+79207e05
+60008047
+793f8025
+44b6c00d
+784efc00
+784e7c00
+7846fc00
+78467c00
+7844fc00
+78477c00
+7843fc00
+2030ba6d
+37d38200
+20000064
+20203a6d
+793f8025
+44b7400d
+7824fc00
+78267c00
+09800048
+2feffe3a
+79208000
+1c020400
+57e04000
+57e03c00
+782afc00
+380bffff
+380cffff
+20000020
+29a80000
+1d827e00
+60018182
+1da27e00
+60008185
+18424000
+2020b77f
+2020374b
+793f8025
+44b7c00d
+09800048
+57e03e00
+57e00800
+57e05c00
+57e02400
+18007e00
+09800010
+2023374b
+5ffffffc
+9a417e00
+6002016f
+1ba27e00
+6001817f
+1b827e00
+6000817d
+18827e00
+6000817e
+1dc27e00
+60010186
+1c227e00
+08008220
+28201e02
+7920800b
+2020375c
+793f8025
+44b8400e
+68008047
+c4018000
+793ffe03
+79407e06
+60008047
+6800c165
+c009b7b1
+c1038000
+6800804b
+c4030000
+793ffe06
+79207e07
+6000804b
+793f8002
+6800c132
+c1008000
+680142af
+247a0000
+6800804b
+793ffe07
+6000804b
+20205267
+793f8025
+44b8c00e
+68008433
+1fe37e00
+c008b7d0
+c00937da
+c00c3806
+c03fb7bf
+c016385e
+c1818000
+68008434
+c015b7c8
+c008b7c3
+20600000
+68008434
+79207e07
+c046b85e
+20600000
+20748000
+68008030
+c3820000
+70007c31
+20600000
+20748000
+68008031
+2feffe04
+2020b7cd
+20600000
+793ffe04
+60008031
+20600000
+793f8025
+44b9400e
+6800804c
+79207e02
+6000804c
+70801101
+68008030
+2feffe04
+2020c845
+20600000
+793f8025
+44b9c00e
+6800804c
+793ffe02
+6000804c
+70801100
+20600000
+793f8025
+44ba400e
+1c427e00
+600242a5
+1c40a203
+2034b7e8
+1d00a203
+68090032
+1a227e00
+793ffe1b
+9846fc00
+68010075
+20407efd
+18072600
+9a667e00
+202137f2
+9840fe00
+9a20fe00
+60020034
+70474800
+68008030
+79207e01
+60008030
+68008073
+6000808a
+70416e80
+58000000
+6001c20a
+6001c20d
+6000c1fa
+700b7d0b
+20407c27
+68014161
+6001003e
+24748000
+18808fff
+20600000
+793f8025
+44bac00e
+68008030
+c4008000
+793ffe01
+60008030
+70416e7f
+6801415f
+6001003e
+7855fc00
+700b7d0c
+20207c27
+793f8025
+44bb400e
+78377c00
+68008030
+c280b820
+c6088000
+68008047
+c3818000
+68008048
+247a0000
+6800804b
+c3830000
+18007e00
+20600000
+c3013830
+6800808a
+c0013826
+68008047
+c281b839
+c5843839
+20403290
+2434b839
+68008048
+243a3839
+680080f1
+1fe0ffff
+600080f1
+243a381e
+7000f110
+20203839
+6800808a
+c080b839
+6800808b
+203a3839
+1fe0ffff
+6000808b
+68008047
+c3818000
+24768000
+6800808a
+1fe0ffff
+6000808a
+20600000
+793f8025
+44bbc00e
+78487c00
+18423600
+20403300
+78547c00
+24628000
+18003600
+78347c00
+20600000
+6800c1f9
+a881fe00
+20600000
+793f8025
+44bc400f
+70417101
+20406a40
+18007e0c
+60010032
+680080af
+1fe3fe00
+60010075
+68008030
+79207e02
+60008030
+70007303
+70008a03
+204037e1
+18000400
+20404914
+7000b350
+7000f110
+20600000
+793f8025
+44bcc00f
+20403806
+70417105
+20406a4a
+68008030
+793ffe02
+60008030
+d8400e00
+7002c013
+202048c4
+793f8025
+44bd400f
+7000b100
+2040385e
+20403290
+793f8007
+20600000
+793f8025
+44bdc00f
+6800c132
+c000b898
+793f8001
+7002d100
+680082ca
+207a0000
+2feffe00
+d8c01000
+2040cda8
+793f8025
+44be400f
+680082d1
+c000b88c
+7002d100
+680082ca
+c4008000
+d8c01400
+20404da8
+680082d1
+c000b892
+20600000
+6800804c
+793ffe07
+6000804c
+793f8001
+2020443b
+680082ca
+793ffe00
+600082ca
+58000000
+600102c4
+20600000
+680082ca
+793ffe01
+600082ca
+58000000
+600102c6
+20600000
+6800804c
+c4038000
+20404435
+68014800
+203a3bf1
+1fe0ffff
+60014800
+20203887
+680082ca
+79207e00
+600082ca
+20600000
+680082ca
+79207e01
+600082ca
+20600000
+793f8025
+44bec00f
+1d00c201
+20403a5d
+18004803
+20403a42
+20403bae
+20403bbf
+20203bc5
+793f8025
+44bf400f
+20403baa
+1d027e00
+680a416a
+98467e00
+c1808000
+28203e00
+2420b8bc
+68008019
+207a0000
+204038a8
+28203e10
+2020b75c
+1c230400
+18419c40
+793f8025
+44bfc00f
+7823fc00
+78257c00
+782dfc00
+793f8010
+18827e00
+08008603
+18227e00
+08008604
+68008047
+08008004
+08008603
+78247c00
+08008608
+784dfc00
+78447c00
+78457c00
+793faa02
+d8400000
+20403b74
+793f8025
+44c04010
+18217e1f
+c009b913
+c000375c
+c000b75c
+c00138f5
+c001b925
+c002392b
+c003b8e9
+c004392a
+d8400004
+20403b74
+c0053927
+c005b92d
+d8400008
+20403b74
+c007b92d
+20203927
+793f8025
+44c0c010
+782efc00
+7824fc00
+78277c00
+1800721e
+d8c000b5
+e8c08000
+08008608
+c20038f0
+c503b960
+2020375c
+793f8025
+44c14010
+6800818b
+1fe20800
+6800808f
+1fe23800
+6801c14a
+1fe23a00
+68014144
+1fe25c00
+7824fc00
+782e7c00
+1c022200
+20403a54
+782afc00
+20000020
+1c221600
+6802016b
+1fe24200
+53c07e00
+79207e3a
+08008648
+53e07e00
+08008648
+19624200
+1a224000
+78247c00
+08008610
+78447c00
+2020375c
+793f8025
+44c1c010
+78277c00
+7824fc00
+782e7c00
+68008432
+1fe105f8
+d8c00432
+18408408
+1840a7b8
+24213922
+e8c48000
+08008648
+1a620400
+2020391c
+e8c48000
+08418600
+20203960
+782e7c00
+20203930
+782e7c00
+79200010
+20203930
+79202a02
+782efc00
+20203930
+79202a02
+782efc00
+79200010
+793f8025
+44c24010
+6800804c
+c302b946
+18267c03
+20213946
+78477c00
+784e7c00
+782efc00
+7843fc00
+79202a01
+2aaffe02
+2020b940
+580abeee
+08008614
+20203944
+585faeba
+08008618
+58000012
+08008606
+7823fc00
+79200010
+78277c00
+7824fc00
+c502b969
+68008090
+08008603
+68010091
+98007200
+c5083950
+08008605
+20203951
+0800860d
+6800c132
+c000b95b
+1f227e00
+203a3960
+68010179
+98000c00
+e8c08000
+08008608
+c2003957
+20203960
+68010179
+98000600
+e8608000
+08008608
+c200395d
+78247c00
+08008610
+78447c00
+20403583
+6800804c
+c302b75c
+18007e00
+08008606
+2020375c
+793f8025
+44c2c010
+c5083972
+6800818a
+08008603
+68008169
+98002600
+08008605
+20203977
+6800818a
+08008603
+68010169
+98002600
+0800860d
+d8c004de
+1a627c00
+2022b97e
+e8c08000
+08008608
+1a60a7ff
+20203978
+680100fe
+1fe0fe01
+600100fe
+20203960
+6802016f
+1fe0a207
+6801017b
+243a3988
+1a20a3fd
+20203990
+1feffe0c
+68190040
+18408401
+98467e00
+2421398f
+1a20a3ff
+2020398b
+1fe67e00
+37d18200
+2c400600
+2420b990
+98005200
+1a225000
+98005200
+20600000
+793f8025
+44c34010
+37d10200
+1b427e00
+98000c00
+1ff17e00
+9c467200
+1f217203
+2422b9a2
+18007e00
+202039a6
+d8400ea6
+18007e00
+9840fe00
+c20039a4
+98c0fe00
+1fe6fc0c
+20407efd
+1807fe00
+6001017b
+20600000
+793f8025
+44c3c010
+1b427e00
+1b220400
+98467c00
+7d217e2c
+98460400
+58000ea6
+284c000f
+2020b9b8
+5fff0ea6
+98408400
+600b03c8
+207b0000
+600b0038
+20600000
+78587c00
+680303c8
+203b39c0
+68030038
+9b20e000
+1e00e00a
+58000ea6
+9e067e00
+2fec000f
+2020b9ca
+5800f15a
+9e00e000
+1e023400
+20600000
+18007c00
+202039c8
+793f8025
+44c44011
+20403a7a
+1c227e00
+1fe17f80
+2c800e03
+2420b9d6
+1fe97e00
+9ae0fe00
+202039d7
+1ae27e00
+1fe6fc4f
+782afc00
+20407efd
+18072200
+1a2085d8
+202139df
+1a238400
+202039e1
+18438400
+18408401
+793f8025
+44c4c011
+68008031
+c301b9f3
+68024173
+9c267c00
+202139f3
+20403a12
+6800c17a
+207a0000
+68008031
+79207e02
+60008031
+6802c188
+6002c17b
+e8c28000
+6002c180
+20403a17
+68008031
+c4010000
+2c2ffe01
+2020ba0f
+18492200
+18410e07
+5800417b
+9a20a200
+ea208000
+afec0000
+2020ba00
+18427e00
+20203a0c
+6800c185
+98002400
+1c227e00
+1fe17f80
+1fe97e00
+9ae0fe00
+9a46fc00
+58004193
+20407efd
+18072200
+9a208c00
+e8c08000
+6000c186
+98000400
+20600000
+6800c186
+98000400
+20600000
+68008031
+793ffe02
+793ffe03
+60008031
+20600000
+793f8025
+44c54011
+d8a04193
+1800720a
+20407e3b
+d8a04193
+18002600
+18000e02
+6802c17b
+98000400
+28e1fe02
+2020ba24
+18430400
+284c0000
+2020ba28
+1a627e00
+e0a08000
+184b0400
+1a60a602
+2a61fc28
+2420ba31
+6802c180
+98000400
+28e1fe02
+2020ba31
+18430400
+1a667c4e
+20213a24
+18002601
+18e08fff
+2422ba1f
+da204193
+18a27e00
+9a267e00
+6000c185
+20600000
+793f8025
+44c5c011
+204039cc
+68008189
+c302ba41
+68088448
+20203a82
+793f8025
+44c64011
+204039cc
+68008189
+c3023a48
+68088447
+20203a91
+18005a00
+6801c147
+98005800
+20600000
+793f8025
+44c6c011
+6800c277
+1fe25a00
+6801c274
+1fe25800
+20600000
+793f8025
+44c74011
+68014144
+1fe25c00
+6800c143
+1fe25a00
+6801c140
+1fe25800
+20600000
+793f8025
+44c7c011
+68010044
+1fe25c00
+68008043
+1fe25a00
+68018040
+1fe25800
+20600000
+c5103a69
+c68e8000
+c68f8000
+1d815900
+782afc00
+20000020
+20600000
+793f8025
+44c84012
+18002a00
+7850fc00
+78507c00
+782f7c00
+70890200
+70890100
+70890000
+70890300
+70890470
+70890600
+20600000
+793f8025
+44c8c012
+70890200
+70890100
+70890018
+708903a7
+7089047f
+20600000
+793f8025
+44c94012
+60088017
+1840a204
+20203ab6
+793f8025
+44c9c012
+708901cf
+2000000a
+708900ff
+708903af
+708904ff
+2000000a
+708902a0
+20600000
+793f8025
+44ca4012
+60088017
+1840a202
+20403ab6
+58000500
+20403bf3
+70890601
+7089003c
+708901e0
+708903b7
+7089027f
+20600000
+70804206
+20403c29
+20403c3a
+68014163
+c3073aa1
+98000c00
+d8408900
+e8c08000
+c07fbaab
+98418a00
+e8c08000
+e0a08000
+20203aa5
+793f8025
+44cac012
+20403d91
+20403b0a
+580007d0
+9c40fe00
+60020173
+79202a03
+18002a00
+2455bace
+20203ae2
+793f8025
+44cb4012
+58000960
+9a208400
+6800c15d
+70895f04
+984ffe00
+6808c15e
+9846fc00
+20407efd
+1807a200
+18077e00
+1ff07e00
+1ff27e00
+9846fc00
+20407efd
+1807fe00
+1fed7e00
+1fe3fe00
+9a21fe00
+60120960
+70895f44
+70895fc4
+20600000
+793f8025
+44cbc012
+70890602
+5803d090
+20403bf3
+7089007f
+20000082
+70895230
+708901d0
+70895270
+708952f0
+18007232
+68108980
+c282badd
+c2003ada
+6000c16f
+70890100
+70890000
+70890600
+20600000
+793f8025
+44cc4013
+6800c16f
+79207e05
+60108952
+68188950
+18410407
+1fe9fe00
+9841fe00
+60108950
+68108951
+793ffe00
+60108951
+68108952
+793ffe05
+60108952
+20600000
+793f8025
+44ccc013
+68110981
+1ff1fe00
+1fe97e00
+1fe67e00
+1fe17eff
+1fe6fc0a
+20407efd
+1807fe00
+1ff27e00
+18070400
+9841fe00
+60008018
+20600000
+7080420a
+70890500
+68118138
+6011804c
+70804cfc
+20403db0
+200003e8
+20600000
+70804206
+6810896b
+793ffe04
+793ffe05
+6010896b
+70890500
+70890400
+70890470
+708905ff
+6810896b
+79207e04
+79207e05
+6010896b
+20403b38
+68108968
+79207e07
+60108968
+793ffe07
+60108968
+79207e07
+60108968
+70804205
+20600000
+200003e8
+70804204
+2000000a
+7080b400
+70800680
+6810812d
+c300bb26
+68198149
+70804205
+2000000a
+70800680
+6810812d
+c300bb2c
+68118149
+98467e00
+20213b32
+1fe67e00
+6001018c
+1fe67c46
+24213b34
+20600000
+58000f0f
+20203da7
+5800080f
+20203da7
+793f8025
+44cd4013
+20403a87
+78507c00
+7830fc00
+782b7c00
+20600000
+793f8025
+44cdc013
+6800804c
+2feffe02
+7920fe00
+60108011
+d8c00062
+e8c48000
+98006400
+e8c38000
+98006600
+68008054
+1fe0e9ff
+782d7c00
+20600000
+793f8025
+44ce4013
+7826fc00
+d9600600
+35330400
+1b427e00
+6003009c
+7846fc00
+242c3a6d
+dd2003bb
+1d00d001
+1d0151fc
+20600000
+7826fc00
+37cb8400
+202c3b55
+2d000402
+2420bb5e
+20203b55
+793f8025
+44cec013
+d9600600
+7826fc00
+34730400
+7846fc00
+242c3a6d
+20600000
+793f8025
+44cf4013
+7826fc00
+37c18400
+7846fc00
+242c3a6d
+dd2003bb
+1d0151fc
+20600000
+793f8025
+44cfc013
+98002200
+1c227e00
+98409600
+19627e00
+6002416a
+1a227e00
+20600000
+1fe20400
+793f8025
+44d04014
+18427e00
+20407e91
+1c307e00
+79207e2c
+20407e7a
+793ffe2c
+20403bda
+20407e7a
+20740000
+20407e84
+98003600
+37c18200
+20600000
+793f8025
+44d0c014
+20383b93
+35330200
+1d020400
+20203b96
+20373b95
+34730200
+1c420400
+20343ba3
+28400601
+2420bb8d
+793f8025
+44d14014
+68008030
+c4000000
+6802416a
+98467e00
+24610000
+1fe67cff
+20213b8d
+20600000
+28400603
+2420bb8d
+20203b99
+793f8025
+44d1c014
+d9600600
+20203b8d
+78547c00
+20203ba6
+78347c00
+20203ba6
+793f8025
+44d24014
+20403b41
+7850fc00
+78307c00
+20600000
+793f8025
+44d2c014
+d9600e43
+34730200
+782b7c00
+20600000
+793f8025
+44d34014
+d9600d00
+34730200
+20600000
+793f8025
+44d3c014
+d9600e43
+35330200
+782b7c00
+20600000
+793f8025
+44d44015
+51207e00
+782efc00
+79202a00
+08008648
+784efc00
+20600000
+1ca20400
+18418460
+18421c00
+20600000
+793f8025
+44d4c015
+6800c130
+1fe0fe01
+c083bbd7
+18007e01
+6000c130
+98000800
+20600000
+1b220400
+20748000
+1b420400
+20600000
+1c427e00
+20748000
+1d027e00
+20600000
+793f8025
+44d54015
+680a004d
+20403bde
+98461600
+19627e00
+68090051
+18438400
+98467e00
+20600000
+793f8025
+44d5c015
+20403bde
+6002004d
+20600000
+20203bf1
+20203bf2
+207a0000
+1fe37e00
+1fe0fffd
+1fe0ffff
+2422bbf6
+18007e00
+20600000
+df200010
+d8a00000
+20407e3b
+d8a003c0
+df20000a
+20407e3b
+7007de00
+700b7d00
+70040d00
+70018900
+70044d00
+793f8025
+44d64015
+70017700
+70015300
+70015e00
+589e8b33
+6001c147
+58000153
+60010083
+7000851e
+70008601
+70008807
+5812e904
+60018080
+58000a04
+6001c6fd
+580012e9
+60014700
+70008f60
+70417105
+70001402
+204075cd
+793f8025
+44d6c015
+20758000
+58000000
+60010091
+1c437e00
+60024134
+20600000
+580000aa
+d8a000d3
+1800721e
+e0a08000
+c2003c26
+20600000
+70890702
+7089081f
+7089091f
+70890ae0
+70890b4e
+70891245
+70895300
+70894cfb
+70894def
+70894e0c
+70896f88
+70897330
+70895300
+708956c9
+7089586c
+70895950
+20600000
+708930a9
+70892fb1
+70892eb9
+70892dad
+70892cb1
+70892bb5
+70892aba
+708929be
+708928c2
+708927c6
+708926ca
+708925ce
+708924d2
+708923d6
+708922da
+708921de
+708920e2
+70891fe6
+70891eea
+70891dee
+70891cf2
+70891bf6
+70891afb
+708947f5
+708946e5
+708945d5
+708944d8
+708943c9
+708942c8
+70894189
+70894088
+70893f87
+70893e48
+70893d09
+70893c08
+70893bc9
+70893ac8
+708939c7
+708938c6
+708937c5
+708936c4
+708935c3
+708934c2
+708933c1
+708932c0
+70893180
+20600000
+783b7c00
+588e89be
+1fed7e00
+1fe1fed6
+98001200
+70891407
+70890aa0
+70890d8f
+7089110f
+70891287
+20600000
+5800ee21
+60110050
+6810813e
+c301e725
+7835fc00
+c303bc7f
+7855fc00
+1ce27e00
+243a3c7f
+d85fffff
+20203cec
+6811813c
+6011804c
+e8c08000
+1fe1feef
+e0a08000
+20403db2
+6810804f
+79207e04
+6010804f
+20403db2
+2055bc90
+6810804e
+793ffe03
+6010804e
+20403db2
+20758000
+20206725
+6800c239
+60108086
+6801c22e
+60118080
+68024222
+60120074
+6802421e
+60120070
+68044226
+60140078
+68044231
+98000000
+68140140
+600400a3
+20406781
+20600000
+18027e00
+60044231
+68140070
+6004421e
+e8c40000
+e0a40000
+68118080
+6001c22e
+68108086
+6000c239
+20203db8
+681080b4
+243a3cb1
+6801c210
+247a0000
+7080b4c0
+70800680
+6810812d
+c4008000
+68118149
+6001c210
+20600000
+793f8025
+44d74015
+1b427e00
+20407e78
+680a4200
+18467cff
+20610000
+1fed7e00
+1ff27e00
+9846fc00
+20407efd
+1807fe00
+d84000c8
+20407f2e
+6000809b
+24343cc7
+1fe67e00
+6809c210
+9840fe00
+6001c210
+58000000
+60024200
+20600000
+793f8025
+44d7c015
+20403db8
+68120138
+793ffe0f
+6012004c
+20403db0
+d85fffff
+6800c1f8
+6000c21d
+6800c21b
+79207e07
+6000c21b
+793f8025
+44d84016
+68024200
+9840fe00
+60024200
+20403ca0
+6802c219
+6012004c
+1fef2200
+37d98200
+1b227e00
+60034204
+70800502
+37d98200
+37d98200
+1a227e00
+6010804f
+70800502
+37d98200
+37d98200
+601a004c
+70800510
+37df8200
+793f8025
+44d8c016
+58000000
+1ce27c00
+2022bcfd
+6810813c
+6818813d
+98467c00
+20213cfb
+18427e00
+9ce67e00
+1fe0fe01
+1fe0fe08
+37d98200
+9e20fe00
+680a41fc
+9840fe00
+6809c210
+984ffe00
+1fecfe00
+1ff1fe00
+1fe0fe6e
+d8400ea6
+9846fc00
+20407efd
+1807fe00
+1ff07e00
+18070400
+9841fe00
+680b4204
+20407e6d
+18423200
+68034048
+204039c0
+1b427e00
+60030161
+1ce27e00
+e0a08000
+6810811d
+1fe1fef0
+e0a08000
+20407f52
+20600000
+793f8025
+44d94016
+20403cab
+6801c210
+207a0000
+6800c131
+207a0000
+20403dca
+247a0000
+6800c040
+2fe00e03
+2420bd4d
+68014042
+207a0000
+20758000
+793f8025
+44d9c016
+680880a2
+68014042
+984ffe00
+18518400
+184b0400
+98467e00
+680a4044
+9840fe00
+6808c1f7
+98467e00
+1ff06000
+793f8025
+44da4016
+6801404e
+1fe37e00
+20407e91
+1e027e00
+20407e7a
+1b420400
+20407e78
+20740000
+20407e8a
+793f8025
+44dac016
+6800c219
+98467c00
+20213cca
+600a41fc
+20403ea9
+2040530c
+680a41fc
+20203cda
+793f8025
+44db4016
+6800c040
+c3800000
+c3818000
+6800c7dc
+203a3d56
+6800c793
+207a0000
+6800c3d8
+243a3d5a
+6800c133
+207a0000
+680141f5
+207a0000
+6808c1f7
+98467e00
+d8401d4c
+984ffe00
+20203d42
+793f8025
+44dbc016
+7855fc00
+68008030
+c4008000
+2436bd7b
+20403d76
+68014161
+6001003e
+68008047
+c281bd8a
+c586bd8a
+2040527e
+243a3d8a
+7000a200
+c586bd8a
+6800c215
+203a3d8e
+1fe0ffff
+6000c215
+20600000
+7041fa00
+6801c20a
+1fe0fe01
+6001c20a
+20600000
+793f8025
+44dc4017
+68094161
+18430400
+6801003e
+9840fe00
+6001003e
+7000a200
+6801c20d
+1fe0fe01
+6001c20d
+6800c1fa
+1fe0fe01
+6000c1fa
+20600000
+7000a200
+6800c214
+6000c215
+20600000
+6808c213
+600880a2
+20600000
+793f8025
+44dcc017
+6800c219
+247a0000
+70804206
+58000f0c
+20403da7
+58030d40
+20403bf3
+37d98200
+1e226000
+20403b36
+70804204
+2000000a
+37d98200
+1e227e00
+9e067e00
+1fe0fe30
+d84000ff
+20407f2e
+6000c219
+20600000
+d8a00fff
+98a10a00
+6800c216
+1fe17ef0
+1fed7e00
+98a1fe00
+6011004c
+e8c10000
+e0a10000
+58000001
+20203db3
+58000002
+37d98200
+60108005
+37d98200
+37d98200
+20600000
+793f8025
+44dd4017
+680200a3
+6012004c
+58000004
+20403db3
+680200a7
+6012004c
+58000008
+20203db3
+680141f3
+f9207e00
+600141f3
+20600000
+680141f3
+f93ffe00
+600141f3
+20600000
+793f8025
+44ddc017
+20403ea7
+680141f3
+1fe22200
+6800804c
+2feffe06
+7920a20b
+68008078
+6808807c
+9840fe00
+68088048
+9840fe00
+7d3a220a
+793f8025
+44de4017
+680102c4
+680902c6
+9840fe00
+7d3a220d
+6802c7df
+7d3a220f
+6802c7e4
+7d3a220e
+6800c272
+7d3a2208
+6800c132
+2fe1fe0a
+2040bdf5
+793f8025
+44dec017
+6800c132
+c080bdfa
+20403df5
+6800c25e
+793a2203
+680242a5
+d8401710
+98408400
+1c427e00
+98467c00
+7d212204
+20203dfc
+68110112
+7d3a2206
+6811010e
+7d3a2205
+20600000
+5ffffff8
+9a212200
+1a227e00
+600141f3
+207a0000
+20768000
+7835fc00
+20600000
+68120138
+793ffe1b
+6012004c
+20403db0
+20203bf1
+6812013c
+79207e14
+6012004c
+20203db2
+6812013c
+793ffe14
+6012004c
+20203db2
+793f8025
+44df4017
+6800c132
+c1808000
+20406a8b
+20608000
+68024807
+243a3e1a
+1c427e00
+60024807
+20206a6b
+793f8025
+44dfc017
+1c427e00
+680a4807
+98467e00
+d8400021
+98467c00
+24610000
+58000000
+60024807
+20204599
+680141f1
+c2803bf1
+20600000
+680141f1
+c280bbf1
+20600000
+680141f1
+c2813bf1
+20600000
+58003e37
+6001428e
+58003e3d
+60014292
+58003e37
+60014290
+20758000
+7047e901
+20600000
+68008030
+c300de9f
+7920000d
+6803420a
+60034703
+20207bde
+1a627e00
+c1880000
+20407bb1
+6800c7eb
+c000be3f
+20407be2
+20203ccd
+18000402
+184085fe
+20403a7a
+20403a91
+7843fc00
+782efc00
+79202a00
+20403bae
+68008000
+08008608
+20203e4c
+79200025
+44e6c039
+6800c132
+203a3e4f
+c0035aa2
+c003cb33
+c0024293
+c001cc09
+c000c461
+c004f624
+c00562ef
+c0064bf3
+c006ea8e
+c07fbe2e
+c2836486
+20600000
+79200025
+44e74039
+70015300
+70018900
+70018a00
+58000000
+600287da
+6800c132
+203a3e5f
+c005631f
+20600000
+20407ba1
+20407c45
+20403e73
+68014290
+20207f66
+6801428e
+20207f66
+6801428c
+20207f66
+79200025
+44e7c039
+da2047df
+20407f9f
+207a0000
+1fe22600
+20403e7d
+20203ea5
+da600000
+20600000
+c000be92
+c0083ed9
+c002beb6
+c0093ebd
+c0033ed5
+c0023efe
+c0013f03
+c009befe
+c00a3ecc
+c00abed0
+c001beaf
+c005bec1
+c0063ec8
+c00b3edd
+c00c3eab
+c0153e9b
+c015be99
+1fe1040f
+1fe17ef0
+c0283ee1
+20600000
+680147f4
+79207e00
+600147f4
+680142a2
+793ffe00
+600142a2
+20600000
+70025800
+20600000
+68008258
+1fe0fe01
+60008258
+1fe67c01
+20213f6c
+70025800
+680142a2
+79207e09
+600142a2
+20203f77
+68014292
+20207f66
+68014286
+20207f66
+6801428a
+20207f66
+680142a2
+79207e01
+600142a2
+20203fa2
+680147f4
+79207e07
+600147f4
+680142a2
+79207e02
+600142a2
+20600000
+680147f4
+79207e01
+600147f4
+680142a2
+79207e04
+600142a2
+20600000
+680147f4
+79207e03
+600147f4
+20600000
+680147f4
+79207e05
+600147f4
+680142a2
+79207e03
+600142a2
+20600000
+680147f4
+793ffe05
+600147f4
+20600000
+680147f4
+79207e09
+600147f4
+20600000
+680147f4
+793ffe09
+600147f4
+7046f800
+20203fa6
+680147f4
+79207e02
+600147f4
+20600000
+680142a2
+79207e00
+600142a2
+20600000
+680142a2
+79207e08
+600142a2
+20203f77
+79200025
+44e8403a
+60088259
+68008259
+207a0000
+1fe0ffff
+60008259
+20407bb1
+20403f60
+20403eed
+20403ef5
+20203ee4
+6800c29d
+207a0000
+1fe0ffff
+6000c29d
+247a0000
+204032ee
+2022bf9e
+20600000
+680147f0
+207a0000
+1fe0ffff
+600147f0
+247a0000
+20403f7e
+20403f98
+68014294
+20207f66
+20403f15
+680147f4
+793ffe07
+600147f4
+20600000
+70429d00
+680147f4
+c283bf08
+2fec0001
+2040be7b
+680147f4
+793ffe00
+793ffe01
+793ffe02
+793ffe03
+793ffe04
+600147f4
+20203fa6
+20403f12
+20203f9a
+58000000
+600142a0
+20600000
+58000000
+600142a2
+20600000
+680142a2
+600142a0
+58000000
+600142a2
+20600000
+680142a2
+79207e07
+600142a0
+58000000
+600142a2
+20600000
+2040691d
+68034274
+20600000
+6800c48b
+203a3f2a
+20403f96
+20203f82
+20403f94
+20203f88
+79200025
+44e8c03a
+da400244
+da603f31
+20203301
+d8400000
+c3003f35
+1a208c10
+e8cb0000
+18427e00
+245a3f3a
+e24b0000
+1a40a406
+20203307
+6800c29a
+1fe0fe01
+6000c29a
+20600000
+70429a00
+20203f2c
+6800c7f4
+2feffe05
+20600000
+58000000
+20203f46
+5800aa55
+600102a8
+79200025
+44e9403a
+d8400002
+da2002a8
+da4000c3
+2020683e
+79200025
+44e9c03a
+d8400002
+da200161
+da4000c3
+2040681d
+68010161
+d840aa55
+98467c00
+20600000
+6800c747
+6000c29d
+20600000
+d8e00009
+20203dc2
+d8e00009
+20203dc6
+70429e05
+20203f5a
+6800c29e
+207a0000
+1fe0ffff
+6000c29e
+247a0000
+20203f5c
+7043cc01
+20600000
+7043cc00
+20600000
+700b7d0a
+20207c33
+700b7d1d
+20207c33
+79200025
+44ea403a
+6800c29f
+60008177
+70025701
+700b7d03
+20207c33
+700b7d1e
+20207c33
+700b7d04
+20207c33
+680147fe
+600147f0
+20403f94
+700b7d01
+20207c33
+58000000
+600147f0
+700b7d02
+20207c33
+700b7d0f
+20207c33
+700b7d10
+20207c33
+700b7d0e
+20207c33
+700b7d0d
+20207c33
+700b7d17
+20207c33
+700b7d18
+20207c33
+700b7d16
+20207c33
+700b7d11
+20207c33
+700b7d1c
+20207c33
+700b7d15
+20207c33
+700b7d14
+20207c33
+700b7d13
+20207c33
+700b7d19
+20207c33
+700b7d06
+20207c33
+700b7d05
+20207c33
+700b7d1f
+20207c33
+700b7d20
+20207c33
+7920000d
+20600000
+793f800d
+20600000
+79200025
+44c84032
+d8400020
+da204419
+da4000a0
+2040681d
+d8400020
+da204702
+da40007f
+2040681d
+d8400006
+da204140
+da400063
+2040681d
+d8400006
+da2044f9
+da400069
+2040681d
+20405adb
+d8400002
+da2042ac
+da4000c0
+2040681d
+20406909
+20203fc1
+d840000e
+da20054f
+da40006f
+2020681d
+79200025
+44c8c032
+20403f4d
+2022bfa8
+20403fd2
+20403fd7
+20405adb
+20403fdc
+20403fe0
+204062e9
+20403fe4
+20403fe9
+20203f45
+6808c702
+18408401
+da204702
+da40007f
+2020683e
+6808c419
+18408401
+da204419
+da4000a0
+2020683e
+d8400006
+da2044f9
+da400069
+2020683e
+d8400006
+da204140
+da400063
+2020683e
+6808854f
+18408401
+da20054f
+da40006f
+2020683e
+580001a0
+600102a8
+d8400002
+da2002a8
+da4000c0
+2020683e
+79200025
+44c94032
+6801480e
+d840012c
+98467c00
+2021427f
+20403e2b
+20407f6b
+18622200
+6801480e
+1fe0fffe
+98608600
+e8610000
+d8400a0d
+98467c00
+24628000
+1a220600
+da404850
+df200003
+20404237
+2420c27f
+20204005
+79200025
+44c9c032
+18622200
+da404827
+18007204
+20404237
+2020c06d
+da404824
+18007207
+20404237
+2020c074
+da40482e
+18007204
+20404237
+2020c07b
+da40482b
+18007207
+20404237
+2020c081
+da404832
+18007204
+20404237
+2020c087
+da404820
+18007204
+20404237
+2020c08c
+da40481c
+18007204
+20404237
+2020c08f
+da404836
+18007205
+20404237
+2020c095
+da404853
+18007204
+20404237
+2020c09b
+da404857
+18007204
+20404237
+2020c0a1
+da40485b
+18007205
+20404237
+2020c0a5
+da404860
+18007204
+20404237
+2020c0ab
+da404864
+18007204
+20404237
+2020c0b0
+da404868
+18007204
+20404237
+2020c0b7
+da40486f
+18007204
+20404237
+2020c0d6
+da40486c
+18007207
+20404237
+2020c0dd
+da404873
+18007205
+20404237
+2020c0f2
+da404878
+18007204
+20404237
+2020c0f8
+da40487c
+18007207
+20404237
+2020c0fb
+da404841
+18007206
+20404237
+2020c100
+da404883
+18007206
+20404237
+2020c12c
+da404849
+18007203
+20404237
+2020c10e
+da40484c
+18007204
+20404237
+2020c117
+da40483b
+18007206
+20404237
+2020c127
+da404889
+18007203
+20404237
+2020c129
+2020427f
+e8608000
+c01fc071
+c01ec131
+2020427f
+20407f6e
+20404194
+20204286
+e8608000
+c01fc078
+c01ec136
+2020427f
+20407f6e
+2040419b
+20204286
+e8608000
+c01fc07f
+c01ec13c
+2020427f
+204041a2
+20204286
+e8608000
+c01fc085
+c01ec140
+2020427f
+204041a8
+20204286
+e8608000
+c01fc08a
+2020427f
+204041ae
+20204286
+e8608000
+c01ec149
+2020427f
+e8608000
+c01fc093
+c01ec144
+2020427f
+20404204
+20204286
+e8608000
+c01fc099
+c01ec157
+2020427f
+204041b4
+20204286
+e8608000
+c01fc09f
+c01ec172
+2020427f
+204041ba
+20204286
+e8608000
+c01fc0e1
+c01ec15a
+2020427f
+e8608000
+c01fc0a9
+c01ec16b
+2020427f
+2040420b
+20204286
+e8608000
+c01fc0ae
+2020427f
+204041c0
+20204286
+e8608000
+c01fc0b3
+20204286
+204032ee
+2422c27f
+204041cd
+20204286
+e8608000
+c01fc0ba
+2020427f
+6800c040
+c300427f
+20407f6e
+6800c041
+c28040c0
+202040cb
+da204868
+df200004
+20404232
+20404247
+58000034
+e1408000
+2040424e
+da2003d0
+20407e9d
+204068fa
+20204286
+da204868
+df200004
+20404232
+20404247
+58000033
+e1408000
+2040424e
+da200040
+20407e9d
+204068fa
+20204286
+79200025
+44ca4032
+20403f3e
+6800c29a
+c080427f
+204041f0
+20204286
+79200025
+44cac032
+204041f6
+20204286
+da204857
+df200004
+20404232
+204032ee
+2422c24a
+6800c041
+c280c0eb
+204040ef
+204068fa
+20204286
+5800004d
+e1408000
+204068fa
+20204286
+58000053
+e1408000
+20600000
+e8608000
+c01fc0f6
+c01ec17e
+2020427f
+204041d8
+20204286
+e8608000
+c01ec151
+2020427f
+e8608000
+c01fc0fe
+2020427f
+204041de
+20204286
+6800c29f
+60008177
+2040691d
+20403f3e
+6800c29a
+c080427f
+6800c2a9
+c019c10c
+c01a410a
+2020427f
+20403f82
+20204286
+20403f6e
+20204286
+20403f3e
+6800c29a
+c080c27f
+6800c041
+c2804115
+20403f77
+20204286
+20403f90
+20204286
+e8608000
+c01ec11a
+2020427f
+e8608000
+c018c122
+c018411e
+2020427f
+20403f40
+2020c286
+20403f9e
+20204286
+20403f40
+2420c286
+204063ab
+20406414
+20204286
+20403f43
+20204286
+e8608000
+c01ec187
+2020427f
+20403f3e
+6800c29a
+c080427f
+2040638a
+20204286
+da204703
+2040422b
+6008c702
+20403fd2
+20204286
+da20441a
+2040422b
+6008c419
+20403fd7
+20405adb
+20204286
+d8a04140
+20407ebf
+20403fe0
+20204286
+d8a044f9
+20407ebf
+20403fdc
+20204286
+da200550
+2040422b
+6008854f
+20403fe4
+20204286
+20407eb0
+5adc6c00
+9846fc00
+20407efd
+1807fe00
+600102a8
+20403feb
+20204286
+e8608000
+1fe67c33
+2421427f
+1fe17e03
+6000c812
+20204286
+e8618000
+6001c14a
+20204286
+204032ee
+2422c27f
+e8608000
+c029c160
+c026c163
+2020427f
+6800c041
+c280c166
+2020427f
+6800c041
+c300c166
+2020427f
+6800c813
+79207e04
+6000c813
+70427218
+2020428c
+d8a04280
+20407ebd
+d8a04282
+20407ebd
+d8a04284
+20407ebd
+20204286
+e8608000
+c018c176
+c019417c
+2020427f
+e8608000
+d8a001b4
+20407ebf
+20406931
+24740000
+20204286
+2040693d
+20204286
+e8608000
+6808c812
+7d3a0402
+6008c812
+203a4286
+e8608000
+d8a04814
+20407ebf
+20204286
+79200025
+44cb4032
+df200014
+d8a01000
+2040497c
+da201000
+68009000
+2fe1fe12
+2040eb19
+68009000
+2fe1fe13
+2040eb45
+20204286
+da204827
+df200004
+20404232
+6800c702
+1fe27200
+d8c04703
+20207f74
+da204824
+18007207
+20404232
+20405b08
+e8c08000
+1fe27200
+20207f74
+da20482e
+df200004
+20404232
+da204140
+20407e9d
+202068fa
+da20482b
+df200007
+20404232
+da2044f9
+20407e9d
+202068fa
+da204832
+df200004
+20404232
+df200006
+d8c04804
+20207f74
+da204836
+df200005
+20404232
+df200003
+d8c0414a
+20207f74
+da204853
+df200004
+20404232
+20406988
+20404253
+202068fa
+20406929
+da204860
+df200004
+20404232
+680081b3
+c019c1c8
+c01a41c8
+202068fa
+e1408000
+2040424e
+da2001b4
+20407e9d
+202068fa
+79200025
+44cbc032
+da204864
+df200004
+20404232
+204041d4
+202068fa
+da200018
+df200001
+20207e9e
+20600000
+da204873
+df200005
+20404232
+da204814
+20407e9d
+202068fa
+da20487c
+df200007
+20404232
+6800c812
+1fe22200
+6800c040
+2feffe00
+7920a203
+2feffe01
+7920a205
+6800c041
+2feffe01
+7920a204
+2feffe00
+7920a206
+1a227e00
+e1408000
+202068fa
+589e8b33
+6001c147
+6800c2a4
+79207e00
+6000c2a4
+20204636
+20403f3e
+6800c29a
+c080427f
+20403f8a
+6800c2a4
+79207e01
+6000c2a4
+58000200
+6001481a
+da20486c
+df200006
+20404232
+20407f74
+2020428c
+da20481c
+df200004
+20404232
+6800854f
+1fe27200
+d8c00550
+20207f74
+da20485b
+df200005
+20404232
+20404247
+58000054
+e1408000
+20404244
+da204280
+20407e9b
+20404247
+58000041
+e1408000
+20404244
+da204282
+20407e9b
+20404247
+5800004f
+e1408000
+20404244
+da204284
+20407e9b
+20207f74
+20407f6e
+20404247
+da200182
+20407e9d
+2040424e
+da20017f
+20407e99
+2040424e
+204041d4
+202068fa
+2040422d
+2020497c
+20404269
+1fe20400
+1fe27200
+1a220a00
+20600000
+20407f6e
+20404241
+1a220c00
+20404976
+20204244
+e8608000
+ea488000
+98467c00
+7840fc00
+2422c240
+1a40a401
+c2004237
+7820fc00
+20600000
+20204251
+5800002b
+e1408000
+20600000
+5800003a
+e1408000
+20600000
+5800003e
+e1408000
+20600000
+5800004e
+e1408000
+204068fa
+20204286
+5800002c
+e1408000
+20600000
+1a220600
+20600000
+da600195
+df200004
+1f227e00
+60008161
+ea608000
+c019c25b
+c01a425b
+20204267
+20404247
+ea608000
+e1408000
+1a60a601
+2040424e
+1a622200
+20407e9d
+1a60a606
+68008161
+1fe27200
+c2004255
+20600000
+1a60a601
+20204262
+79200025
+44cc4033
+68110058
+98667e00
+20628000
+20214273
+6809480e
+9840fe00
+1fe0fffe
+20600000
+20404278
+98608400
+68110058
+98467e00
+2020426f
+dfe04fff
+1fe0fe01
+d8404a00
+98467e00
+20600000
+6809480e
+20206903
+79200025
+44ccc033
+20407f6e
+58525245
+e1418000
+204068fa
+2020428c
+79200025
+44cd4033
+20407f6e
+58004b4f
+e1410000
+204068fa
+79200025
+44cdc033
+2040427d
+58000000
+6001480e
+6002480a
+20600000
+20407db2
+20403f94
+5800429f
+6001428c
+580042be
+60014292
+58007cdb
+60014290
+70025a05
+70026e00
+7042721b
+20600000
+7840fc00
+20403f3e
+70041c1b
+6800c29a
+2fe00602
+24608000
+7043d200
+20600000
+68008340
+c30042b0
+68030342
+680b03d0
+98467c00
+24628000
+680303d0
+600344e7
+20600000
+da2000ff
+20405b52
+24628000
+e8c10000
+68090270
+98467c00
+24628000
+6800826e
+1fe0fe01
+6000826e
+6808826f
+98467c00
+202142ad
+20600000
+1a627e00
+c00ac2c5
+c00a42d7
+1fe1040f
+1fe17ef0
+c02842cd
+20600000
+58000000
+600344e7
+70026e00
+58000000
+60028ff1
+700ff001
+20407cdb
+20203f8a
+20600000
+6800c3d2
+207a0000
+6800825a
+207a0000
+1fe0ffff
+6000825a
+247a0000
+204042d8
+20203f8e
+20203f8c
+70025a05
+68008267
+c000c2e1
+c00142dd
+20600000
+6803025b
+60030268
+70026701
+20600000
+68030261
+60030268
+70026702
+20600000
+e8610000
+203a4490
+98002600
+e8608000
+60008293
+98002200
+c30342ed
+1a60a7fe
+e8610000
+1ff1f200
+1fe1100f
+9a20a200
+1fecfe00
+9a20a200
+e8608000
+9a20fe00
+c0ffc319
+1a60fffc
+9f267c00
+2422c316
+68008293
+2fec0007
+2020c302
+793f801b
+c50dc302
+1fe17e07
+6808828c
+98467c00
+2422c316
+58000640
+18000e07
+20407e4c
+19027e00
+20404320
+20740000
+68008293
+98002200
+1fe90400
+18410407
+6800828b
+98467e00
+1fe67e00
+1fe17e07
+c080c316
+6008828b
+68008272
+1fe0fe01
+60008272
+20204319
+68008273
+1fe0fe01
+60008273
+68110058
+98000600
+e8610000
+98608600
+18627e00
+60110058
+20600000
+78547c00
+207a0000
+c000c328
+c0014346
+c002c507
+c00344dd
+c0044a56
+20600000
+793f8018
+e8608000
+c06d432f
+c0564336
+c056c33a
+c06f4344
+20600000
+c50bc333
+180004da
+58ededdc
+2040433c
+180004ac
+58eeefaf
+2020433c
+79200017
+180004ad
+58edacef
+2020433c
+180004de
+58d0d0ad
+1fed7e00
+98418400
+20404972
+e14a0000
+18000e01
+18007204
+793f8013
+20204378
+18006000
+20204933
+1f226000
+20404371
+18002400
+20404972
+1e027200
+e8608000
+58000001
+e1408000
+793f801a
+e8608000
+1a40a401
+c00e435b
+2a41fe04
+2420c35d
+793a001a
+c09d435d
+580007d0
+18000e00
+20407e4c
+79200018
+20600000
+2a41fe06
+2020c366
+280ffe1a
+2040c368
+e1408000
+c200434f
+793f8019
+1e027200
+79200013
+18000e02
+20204378
+79200019
+2020435d
+c60c8000
+2a41fe0a
+2020c36f
+2a41fe0b
+24608000
+58000012
+20600000
+580000e9
+20600000
+68008293
+1fe0fe01
+1fe17e07
+6000828c
+18007200
+18000e00
+793f8013
+1f20a404
+6800828c
+1fe9a600
+280c0014
+7d20a606
+2020c37f
+1a40a402
+c589c389
+79202607
+68008294
+9a61a600
+1fe0fe01
+1fe17e07
+60008294
+68008274
+1fe0fe01
+60008274
+6801028f
+98001400
+1a427e00
+280ffe13
+7920fe0f
+e1410000
+19422200
+1a627e00
+e1408000
+1f327e00
+98e1fe00
+9a60a600
+e1410000
+1fecfe00
+9a60fe00
+1fe67eff
+e1408000
+c58a439f
+1f20f204
+1a221400
+20404986
+e1410000
+6801028f
+9a409400
+19409402
+19427e00
+6001028f
+6011005e
+6809028d
+204043d8
+204043ab
+58000640
+18000e07
+20207e4c
+58000190
+18000e01
+20407e4c
+79200015
+20600000
+c68a8000
+18000e01
+20407e53
+247a0000
+6801028d
+60110060
+202043ab
+6801028f
+6809028d
+98467c00
+2022c3d6
+18421400
+e9410000
+98002200
+9ea17e00
+99409400
+68110110
+99467e00
+9ea12400
+6801028f
+99467e00
+9ea17e00
+9a467e00
+24610000
+2a2c000f
+2020c3d1
+68008272
+207a0000
+1fe0ffff
+60008272
+68008274
+1fe0ffff
+60008274
+19420400
+6009028d
+6801028f
+204043d8
+202043b7
+793f8015
+20600000
+98467e00
+9ea17e00
+9ea67e00
+1fe67e00
+60010291
+20600000
+6801028f
+99409400
+20600000
+20600000
+79200025
+44f6403d
+6800c272
+247a0000
+204043e9
+2454440e
+20600000
+79200025
+44f6c03d
+18622200
+d8400004
+e8608000
+c000c3f4
+18408401
+c00143f4
+18627e00
+60110058
+20600000
+68110112
+98467c00
+242143f4
+78547c00
+1a220600
+20404417
+98408400
+68110112
+98467c00
+242143fb
+1a220600
+e8608000
+c000c507
+c0014403
+20203bf1
+79200025
+44f7403d
+18622200
+e8610000
+1a220600
+68088046
+a841fe00
+2020c4dd
+203b58ea
+78347c00
+20600000
+79200025
+44f7c03d
+68110058
+98000600
+20404417
+98608600
+18627e00
+60110058
+20600000
+e8608000
+18608602
+c001441c
+e8608000
+20600000
+e8610000
+20600000
+6811005e
+194095fb
+99409400
+20600000
+d8400004
+20204425
+d8400002
+79200025
+44f8403e
+1f20f201
+6811005e
+1fe21400
+1f227e00
+e1488000
+1fe0ffff
+99409400
+19427e00
+6001029d
+18427e00
+c1010000
+6801029d
+6011005e
+2020443b
+79200025
+44f8c03e
+6801029d
+203a3bf1
+6011005e
+2020443b
+58000000
+6001029d
+20600000
+68190110
+6811005e
+98462200
+24214447
+6819005a
+6811005c
+98467e00
+9a260400
+20600000
+1a2605ff
+20600000
+793f8025
+44e6c019
+6800c132
+c1808000
+204044a3
+20404494
+2040c3b0
+20404494
+2040c3b7
+202044e6
+c68c0000
+18000e00
+20407e53
+247a0000
+20404472
+20404494
+24608000
+793f8017
+180004da
+58ededdc
+2040433c
+580007d0
+18000e00
+20207e4c
+793f8025
+44e74019
+20758000
+58004aed
+60014290
+580001a0
+600142ac
+793f8025
+44e7c019
+20406a0d
+58001800
+60110054
+58001bff
+60110056
+58001c00
+6011005a
+20404489
+793f8025
+44e8401a
+70806200
+70028b00
+70028c00
+70029400
+58001c00
+6001028f
+6001028d
+6011005e
+60110060
+58001800
+60110058
+60010289
+793f8025
+44e8c01a
+68110050
+793ffe0f
+60110050
+20406909
+70804301
+70806281
+20204497
+58001fff
+6011005c
+68108081
+1fe1fe07
+60108081
+70029fff
+20600000
+68110116
+60110058
+7920001b
+20600000
+68108062
+2feffe03
+20600000
+58004803
+60010295
+60010297
+18000401
+9840fe00
+9840fe00
+1fe0fe02
+60010299
+58000000
+6000829c
+6000829b
+20600000
+793f8025
+44e9401a
+6810810c
+98002400
+c301c4ad
+68110112
+98002600
+d840044f
+98467c00
+24628000
+68110058
+98000600
+20404494
+2020c2e5
+202043e2
+20404494
+2020c371
+20600000
+6818810c
+284ffe06
+2020c4b5
+60108015
+20600000
+68090299
+68010295
+98000a00
+18627e00
+e0a10000
+18a27e00
+60010295
+a841fe00
+2040c4c7
+6800829b
+1fe0fe01
+6000829b
+20600000
+58004803
+60010295
+20600000
+6800829b
+207a0000
+68090299
+68010297
+98000c00
+e8c10000
+98000600
+18c27e00
+60010297
+a841fe00
+2040c4da
+6800829b
+1fe0ffff
+6000829b
+18007e01
+20600000
+58004803
+60010297
+20600000
+793f8025
+44e9c01a
+6800829b
+1fe67c02
+202144e4
+78347c00
+202044e6
+204044b2
+204044ba
+793f8025
+44ea401a
+c6010000
+204044ca
+207a0000
+e8688000
+204032f7
+24628000
+e8608000
+1ff1fe00
+1fe17e03
+243a44f3
+79207e01
+79207e02
+60008090
+e8610000
+60010091
+18627e00
+60010179
+79200002
+c584c502
+68008046
+98467c00
+2422c502
+6800804b
+79207e06
+6000804b
+20600000
+1a20a21b
+ea208000
+79207e06
+e2208000
+20600000
+793f8025
+44eac01a
+6800c272
+203a450d
+78347c00
+20600000
+204044b2
+e8610000
+98006000
+98000e00
+e8608000
+98000400
+1e0b7e00
+1fecfe00
+c000c51e
+c001453d
+c001c54f
+c0024569
+c002c572
+c003457c
+c01fc585
+c00445e0
+20600000
+793f8025
+44eb401a
+18e27e00
+c000c634
+c0014643
+c001c949
+c0024949
+c002c645
+c003464f
+c003c949
+c004465d
+c004c739
+c005473f
+c005c664
+c006466a
+c006c66d
+c0074675
+c007c743
+c008c688
+c009c68b
+c00ac949
+c00bc949
+c00cc690
+c00dc69b
+c00e4696
+c00ec6a1
+c00fc6a7
+c01446ab
+c014c6b6
+c015c67b
+2020474d
+793f8025
+44ebc01a
+18e27e00
+c004c6cc
+c006c6d7
+c000c949
+c001c74f
+c002475a
+c002c949
+c0034949
+c003c949
+c005c760
+c0064949
+c0074949
+c007c949
+c0084949
+c008c75f
+2020474d
+793f8025
+44ec401b
+18e27e00
+c000c725
+c001c949
+c00946da
+c009c6c2
+c00a46b8
+c00c46db
+c00cc705
+c00d46de
+c00e46e1
+c00f46e6
+c01046ec
+c01146eb
+c01246ef
+c0134949
+c018c949
+c019c949
+c01ac62e
+c021c949
+c022c949
+c023c949
+c028c6f2
+c02b4701
+2020474d
+793f8025
+44ecc01b
+18e27e00
+c000c70a
+c001c70f
+c0024714
+c002c71b
+c004c720
+2020474d
+793f8025
+44ed401b
+18e27e00
+c000c949
+c0014726
+c001c727
+c002c72d
+c0034733
+c003c736
+2020474d
+793f8025
+44edc01b
+18e27e00
+c000c949
+c0014949
+c001c949
+c0024949
+2020474d
+20600000
+793f8025
+44ee401b
+18e27e00
+c0004949
+c000c59d
+c00145a2
+c001c5a6
+c00245b9
+c002c949
+c00345ca
+c003c593
+c00845cd
+c008c5d5
+20204949
+20404949
+20407f68
+20406a68
+20403f5c
+20403f66
+20206a7d
+7042ae00
+20403f5a
+20404468
+20203f68
+2040496e
+68110000
+e1410000
+18007206
+2020494c
+e8610000
+600142ac
+60110052
+20600000
+e8608000
+1fe20400
+60108024
+e8608000
+98408400
+79207e07
+60108023
+e8608000
+98408400
+1fe27200
+e8608000
+60108025
+98408400
+c20045b0
+184104ff
+e8608000
+98467c00
+2422c5c8
+20204949
+df200020
+d8a04000
+d8400000
+e8608000
+e0a08000
+98408400
+c20045bc
+184104ff
+e8608000
+98467c00
+2422c5c8
+70802300
+20404949
+2040440e
+20203001
+70802300
+20203000
+e8630000
+60034140
+20204949
+e8608000
+600082c1
+1fe27200
+e8610000
+600102c2
+1fe20a00
+2040497c
+20204949
+e8608000
+600082c1
+1fe27200
+e8610000
+600102c2
+d8a01000
+2040497c
+680882c1
+da201000
+680102c2
+20206842
+793f8025
+44eec01b
+18e27e00
+c000c949
+c00145f3
+c001c5f8
+c00345ff
+c0044603
+c004c607
+c005460b
+c005c60e
+c0064611
+c006c614
+c0074626
+c00ac627
+c00b4933
+c009c949
+2020474d
+20600000
+2040496e
+58000000
+e1418000
+18007207
+2020494c
+2040496e
+58000001
+e1410000
+58000000
+e1430000
+1800720c
+2020494c
+df20000f
+d8a044d7
+2040497c
+20204949
+df200020
+d8a043d9
+2040497c
+20204949
+df200020
+d8a043f9
+2040497c
+20204949
+e8608000
+6000c3d8
+20204949
+e8638000
+6003c4f6
+20204949
+e8608000
+6000c3d2
+20204949
+e8620000
+600243d3
+e8608000
+6000c4f8
+df200014
+d8a044e6
+2040497c
+7043d201
+6800c4ed
+6000c4f7
+680144f0
+600143d0
+680144f2
+600103ed
+680144f4
+600103ef
+7042721b
+20204933
+20204949
+2040496e
+e8610000
+e1410000
+581fffff
+e1428000
+1800720b
+2020494c
+e8618000
+e8698000
+68014800
+9840fe00
+60014800
+20600000
+e8618000
+6001c147
+70427201
+e8608000
+d8400640
+984ffe00
+d840ffff
+98467c00
+2421463e
+18427e00
+18000e02
+20407e4c
+6800c2a4
+c280428c
+20204933
+70427202
+20204949
+20404763
+e8610000
+60010275
+e8610000
+600080f3
+20404776
+e8608000
+6000c802
+70427205
+20204933
+70427206
+e8610000
+6000c273
+e8608000
+60008446
+7002c016
+6800c273
+680880ad
+98467c00
+2422c933
+70427211
+680080ac
+6000c273
+20204933
+2040496e
+20404965
+1800720a
+2040494c
+7042721a
+18000402
+20204826
+20404763
+d8a04262
+18007210
+2040497c
+7042720b
+20204677
+20404763
+7042720c
+20204677
+20404763
+e8608000
+6000854f
+98007200
+d8a00550
+2040497c
+70427209
+20204677
+20404763
+7042720a
+2040496e
+20404965
+1800720a
+2020494c
+18608606
+e8618000
+600187e6
+680087db
+c009c683
+c001c683
+70427216
+20204684
+7007dd01
+2040496e
+20404965
+1800720a
+2020494c
+20404766
+7042720d
+20204933
+20404766
+e8608000
+1fe0fe0e
+6000c272
+20204933
+20404763
+e8610000
+600080f3
+20404776
+70427203
+20204933
+e8610000
+e8608000
+60008449
+70427215
+20204933
+68008046
+18002202
+203a493d
+20404766
+70427204
+20204933
+68008046
+18002202
+203a493d
+20404766
+70427214
+20204933
+2040476e
+18000e1c
+18007205
+20204952
+20404766
+1860860a
+e8610000
+60010281
+e8608000
+60008283
+e8610000
+60010284
+7000ab02
+70427210
+20204933
+7042721c
+20204933
+2040496e
+d8c04703
+18c672ff
+20404976
+18007e00
+18c67303
+1f20f2f8
+20404982
+180072fc
+2020494c
+d8a04703
+18a672ff
+e8608000
+e0a08000
+203a46c8
+c20046c4
+18a67f03
+1fe67e00
+6000c702
+20204949
+2040496e
+2040496b
+18007e00
+7d34fe00
+e1408000
+18007207
+de000809
+2040494c
+202049bc
+70427217
+20600000
+20404769
+18007206
+2020494c
+20204949
+e8610000
+60014159
+20204949
+e8608000
+6000c133
+20204949
+e8610000
+60014153
+e8610000
+60014151
+20204949
+e8610000
+6001414f
+e8610000
+6001414d
+20204949
+20204949
+e8608000
+60008453
+20204949
+e8618000
+6001c14a
+20204949
+18427e00
+203a4949
+20404970
+18007e01
+e1408000
+1e027e00
+e1410000
+18007e12
+e1408000
+58000000
+1f20f2f1
+20404982
+18000e0e
+180072f5
+20204952
+e8608000
+245a6003
+205a6009
+20204949
+2040496e
+6800c133
+e1408000
+18007205
+2020494c
+2040496e
+68040080
+e1440000
+1800720c
+2020494c
+2040496e
+68044138
+e1440000
+1800720c
+2020494c
+2040496e
+58000101
+e1410000
+58000001
+e1440000
+1800720e
+2020494c
+2040496e
+68038083
+e1438000
+1800720b
+2020494c
+2040496e
+68034140
+e1430000
+1800720a
+2020494c
+20204949
+20204949
+2040496e
+2040496b
+580000ff
+e1408000
+18007207
+2020494c
+2040496e
+2040496b
+58000000
+e1408000
+18007207
+2020494c
+793f8025
+44ef401b
+20204949
+793f8025
+44efc01b
+20204949
+20404763
+70427207
+e8608000
+c000c933
+70427219
+20204933
+20204739
+20404763
+70427208
+20204949
+20404933
+20404970
+58000000
+e1408000
+e8620000
+e1420000
+18007208
+d8e0001d
+df200005
+20204952
+18002201
+2020493d
+20404766
+e8610000
+60014280
+e8610000
+6001027b
+e8610000
+60014282
+e8610000
+60014284
+70427212
+20204933
+20404766
+2040475d
+20204933
+70427213
+20600000
+20204949
+20404763
+70427218
+20204933
+e8630000
+60034274
+20600000
+e8610000
+6000c273
+20600000
+20404766
+2040496e
+6800c273
+e1410000
+20600000
+20404766
+20404933
+20404970
+18007e00
+e1408000
+6800c273
+e1410000
+20600000
+e8610000
+9c40fe00
+1fe17ffc
+600200f4
+20600000
+793f8025
+44f0401c
+68008274
+1fe67c02
+24610000
+680b0182
+204032fc
+20628000
+20404972
+58010f22
+e1418000
+68030182
+e1430000
+6800817d
+1fe20400
+1fe97e00
+1fe97e00
+e1408000
+18427e00
+1fe17e30
+1fe97e00
+1fe37e00
+e1408000
+6801817f
+e1418000
+6802016f
+9c467e00
+e1410000
+580000c8
+e1408000
+1800720f
+20204959
+793f8025
+44f0c01c
+1800041c
+68010291
+98467c00
+24610000
+68098286
+68018185
+98467c00
+20628000
+207a0000
+60018286
+68008274
+1fe67c02
+24610000
+680b0182
+204032fc
+20628000
+204047cc
+1800040f
+680084df
+c084c7c5
+680084de
+203a47c5
+98007200
+e1408000
+98408400
+18408401
+d8c004df
+e8c08000
+e1408000
+c20047b8
+e8c08000
+203a47c5
+98007200
+e1408000
+98408400
+18408401
+e8c08000
+e1408000
+c20047c1
+202047bb
+18467eff
+98007200
+58000000
+e1408000
+c20047c7
+180072ff
+20204959
+793f8025
+44f1401c
+20404972
+5801ff2f
+e1418000
+68030182
+e1430000
+6800817d
+1fe20400
+1fe97e00
+1fe97e00
+e1408000
+18427e00
+1fe17e30
+1fe97e00
+1fe37e00
+e1408000
+6801817f
+e1418000
+6802016f
+9c467e00
+e1410000
+580000c8
+e1408000
+20600000
+793f8025
+44f1c01c
+6800c132
+c1808000
+20404968
+e14c0000
+1800720b
+18000e0b
+20204952
+793f8025
+44f2401c
+6800c132
+c1808000
+20404970
+68030040
+e1430000
+e14c0000
+1800720e
+18000e3d
+20204952
+793f8025
+44f2c01c
+6800c132
+c1808000
+20404968
+68008449
+e1408000
+58000001
+e1408000
+e14c0000
+1800720d
+18000e23
+20204952
+793f8025
+44f3401c
+6800c132
+c1808000
+20404968
+e14a8000
+18007208
+18000e0c
+20204952
+793f8025
+44f3c01c
+6800c132
+c1808000
+20404970
+68030040
+e1430000
+680187e9
+e1418000
+18007209
+18000e32
+20204952
+793f8025
+44f4401d
+6800c132
+c1808000
+20404970
+68030040
+e1430000
+18007206
+18000e31
+20204952
+18000400
+793f8025
+44f4c01d
+6800c132
+c1808000
+18000e03
+70480005
+20404970
+e1488000
+2040496b
+20404965
+18007e01
+e1408000
+18007e00
+6808804c
+284ffe02
+7920fe00
+e1408000
+1800720b
+20204952
+793f8025
+44f5401d
+6800c132
+c1808000
+18000e04
+20404970
+20404965
+6801817f
+e1418000
+e1488000
+1800720a
+20204952
+793f8025
+44f5c01d
+6800c132
+c1808000
+20404968
+18007e00
+6808804c
+284ffe02
+7920fe00
+e1408000
+18000e08
+18007204
+20204952
+793f8025
+44f6401d
+6800c132
+c1808000
+18000e18
+20404970
+20404965
+d8c04262
+18007210
+20404976
+18007e05
+e1408000
+18007217
+20204952
+6800c132
+c1808000
+18000e33
+20404970
+20404965
+680207ec
+e1420000
+1800720a
+20204952
+6800c132
+c1808000
+18000e36
+20404970
+58000000
+e1408000
+20404965
+18007207
+20204952
+793f8025
+44f6c01d
+18000e17
+6800c132
+c1808000
+20404970
+20404965
+18007206
+20204952
+6800c132
+c1808000
+18000e16
+20204875
+6800c132
+c1808000
+18000e12
+20404970
+18007e00
+e1408000
+20404965
+e1488000
+18007208
+20204952
+6800c132
+c1808000
+18000400
+2434c88e
+18000401
+6800c132
+c1808000
+18000e12
+20404970
+18007e35
+e1408000
+20404965
+e1488000
+18007208
+20204952
+793f8025
+44f7401d
+6800c132
+c1808000
+20404972
+5800ff07
+e1410000
+18e27e00
+e1408000
+20404965
+d8c00103
+180072f8
+e8c08000
+e1408000
+c20048a4
+180072ff
+20204959
+793f8025
+44f7c01d
+6800c132
+c1808000
+6810810e
+247a0000
+6800804b
+c4038000
+793ffe07
+6000804b
+20404970
+18007e01
+e1408000
+2040496b
+18007e01
+e1410000
+18000e13
+18007205
+20204952
+793f8025
+44f8401e
+6800c132
+c1808000
+20404968
+18000e06
+18007203
+20204952
+793f8025
+44f8c01e
+6800c132
+c1808000
+20404970
+18007e00
+e1408000
+e1490000
+680082c0
+e1408000
+18000e05
+18007204
+20204952
+793f8025
+44f9401e
+6800c132
+c1808000
+20404970
+58000102
+e1410000
+68088340
+18417e0f
+e1408000
+1a227e00
+e1408000
+68088341
+184085fa
+68030342
+e1430000
+e1488000
+18427200
+20404976
+5800007f
+e1408000
+18427200
+1f20f20c
+18000e3e
+20204952
+793f8025
+44f9c01e
+6800c132
+c1808000
+20404970
+58000001
+e1408000
+e1488000
+680083d6
+e1410000
+680083c1
+1fe37e00
+79407e00
+e1408000
+6800c4e6
+e1408000
+680303d0
+e1430000
+680143d0
+e1410000
+680103ed
+e1410000
+680103ef
+e1410000
+680083f8
+e1408000
+18000e3e
+df200013
+20204952
+793f8025
+44fa401e
+6800c132
+c1808000
+20404970
+20404968
+e1488000
+68010032
+1fe37e00
+e1410000
+18007206
+18000e14
+20204952
+793f8025
+44fac01e
+6800c132
+c1808000
+793f8025
+44fb401e
+20404970
+e1488000
+58000e00
+e1410000
+20404965
+18007e00
+c503c924
+18007e00
+e1438000
+2020492c
+6800c132
+c1808000
+58020602
+e1418000
+5800001e
+e1410000
+5800001e
+e1410000
+6800c132
+c1808000
+680080ab
+e1408000
+18000e2c
+18007211
+20204952
+793f8025
+44fbc01e
+20404970
+58000100
+e1410000
+1e027e00
+e1410000
+18007204
+18000e0f
+20204952
+793f8025
+44fc401f
+20404970
+1a227e00
+e1408000
+58000001
+e1408000
+1e027e00
+e1410000
+18007204
+18000e0f
+20204952
+793f8025
+44fcc01f
+18007204
+20404970
+18007e01
+e1408000
+1e027e00
+e1418000
+18000e0e
+793f8025
+44fd401f
+20404972
+18e27e00
+e1408000
+1f227e00
+e1408000
+79200013
+18000e05
+1f20f202
+20404494
+2020c378
+20204422
+18000eff
+20404970
+58000001
+e1408000
+18007201
+20204952
+68030040
+e1430000
+20600000
+20404970
+18007e00
+e1408000
+68008046
+e1410000
+20600000
+1800140c
+20204973
+18001408
+20204973
+18001406
+20404494
+2020c3de
+2020441e
+1f227e00
+207a0000
+e8c08000
+e1408000
+c2004978
+20600000
+1f227e00
+207a0000
+e8608000
+e0a08000
+c200497e
+20600000
+e1408000
+1fecfe00
+c2004982
+20600000
+7827fc00
+7824fc00
+e9408000
+08008008
+c2004988
+78247c00
+08008010
+78447c00
+7844fc00
+7847fc00
+1ff0fe00
+20600000
+20000001
+70820301
+20204992
+793f8025
+44fdc01f
+6800c272
+207a0000
+6800807c
+247a0000
+204049be
+2422c9aa
+6800c272
+c001c9d4
+c004c9da
+c00549e6
+c005c9ed
+c00649f7
+c0044a32
+c00c49cc
+c003c9c6
+c00cc9ca
+c00d4a53
+c0094a19
+c009ca28
+793f8025
+44fe401f
+204049c2
+247a0000
+6800c272
+c006ca01
+c007ca0b
+c0074a0d
+c0084a2a
+c008ca34
+c00e4a38
+c0024a0f
+c00aca14
+c00a4a17
+c00bca48
+c00b4a51
+c1830000
+20405ed5
+70427200
+20600000
+68034274
+680b0040
+98467c00
+20600000
+6800c273
+68088046
+98467e00
+20600000
+70007c03
+70007d33
+20406212
+202049bc
+2034ca38
+79200004
+70007c34
+79200003
+2434c9bc
+70007c13
+68008177
+793ffe02
+60008177
+202049bc
+70007c01
+70005300
+202049bc
+7007dd01
+7007db12
+202049bc
+6800804b
+c28149df
+20406209
+70007c08
+202049bc
+793ffe02
+6000804b
+20405ed0
+58000000
+7934fe01
+6000807f
+202049bc
+70044618
+70007c07
+68008030
+c28049bc
+18000418
+20404826
+202049bc
+2040321f
+6800804b
+c280ca08
+c28049f3
+c28149df
+202049bc
+793ffe00
+6000804b
+70007c0c
+202049bc
+6800804b
+c28049fb
+2040487b
+202049bc
+793ffe00
+6000804b
+70007c04
+70007d0b
+70007e06
+202049bc
+6800804b
+79207e01
+6000804b
+68008030
+c283ca08
+20404872
+202049bc
+20406209
+70007c0b
+202049bc
+70007c0f
+202049bc
+70007c0f
+202049bc
+793f8025
+44fec01f
+70007c27
+70427250
+20600000
+70007c83
+70427251
+20600000
+70007c25
+202049bc
+70007c17
+d8a00455
+58000000
+2d0ffe1b
+7920fe01
+e0a08000
+58000000
+e0a10000
+68014280
+e0a10000
+6800c282
+e0a10000
+6800c284
+e0a10000
+202049bc
+70007c18
+202049bc
+20403512
+600080ad
+68008046
+600080ac
+70007c2b
+79200007
+70007c8c
+202049bc
+20405ed5
+202049bc
+70007c2c
+c583c9bc
+70007c8d
+202049bc
+2034ca41
+70007c03
+70007d2b
+c583c9bc
+680080b0
+c083dc04
+70007c81
+70007d8c
+202049bc
+20403512
+600080ad
+68008046
+600080ac
+70007c2b
+c583c9bc
+20205c04
+2040496e
+2040496b
+18007e00
+7d34fe00
+e1408000
+18007207
+de000809
+2040494c
+202049bc
+70007c9a
+202049bc
+70007c07
+70044613
+202049bc
+7002bc00
+e8608000
+600082bb
+20404a6d
+20407e00
+680082bb
+1fe20400
+6800829f
+1fe0fe01
+a841fe00
+2420ca77
+6000829f
+20407e0e
+e8608000
+c000cad8
+c0014aae
+c001cadf
+c002cac3
+c0034a80
+c003ca91
+c0044aa8
+c004cae6
+20600000
+1fe20400
+20407e00
+680082bc
+9840fe00
+600082bc
+20207e0e
+18007e01
+204044b5
+6800829f
+202044b5
+20407e0e
+20204a7c
+6800829f
+1fe0ffff
+6000829f
+18007e00
+204044b5
+6800829f
+202044b5
+20404a6d
+e8608000
+600082bd
+20404a6d
+e8608000
+1fed0a00
+20404a6d
+680082bd
+98a08a00
+e8608000
+e0a08000
+20404a6d
+e8608000
+20404a6d
+680082bc
+c0ffca79
+20204a73
+20404a6d
+e8608000
+600082bd
+20404a6d
+e8608000
+600082be
+20404a6d
+e8608000
+20404a6d
+680082bc
+c0ffca79
+680082be
+1fed0400
+680082bd
+98408600
+e8608000
+600082bd
+18007e01
+204044b5
+680082bd
+204044b5
+70029fff
+20600000
+20404a6d
+e8608000
+20404a6d
+680082bc
+c0ffca79
+20204a73
+20404a6d
+e8608000
+60108024
+20404a6d
+e8608000
+79207e07
+60108023
+793ffe07
+20404a6d
+e8608000
+1fe27200
+20404a6d
+e8608000
+60108025
+20404a6d
+c2004aba
+e8608000
+20404a6d
+680082bc
+c0ffca79
+20204a73
+20404a6d
+e8608000
+600082bd
+20404a6d
+e8608000
+1fed0a00
+20404a6d
+680082bd
+98a08a00
+e8608000
+98007200
+20404a6d
+e8608000
+e0a08000
+20404a6d
+c2004acf
+e8608000
+20404a6d
+680082bc
+c0ffca79
+20204a73
+20404a6d
+e8608000
+20404a6d
+680082bc
+c0ffca79
+70802380
+20204a73
+20404a6d
+e8608000
+20404a6d
+680082bc
+c0ffca79
+70802300
+20204a73
+20404a6d
+e8608000
+20404a6d
+680082bc
+c0ffca79
+20404a73
+20203001
+20406a8b
+20608000
+d8400007
+204069e5
+2420caf4
+7042ae01
+20600000
+6800c2ae
+c1808000
+20404599
+2020495f
+79200025
+44ce4033
+680102cb
+1fe20c00
+e8c08000
+1fe1040f
+1ff1fe00
+c004cb18
+c003cb18
+c0054b24
+c002cb11
+c000cb05
+20600000
+18427e00
+c002cb09
+c001cb10
+20600000
+700b7d27
+20407c27
+6800c132
+c1830000
+18427e00
+c002e946
+20600000
+20600000
+da200001
+20404b2c
+680142b5
+e0a10000
+58000000
+e0a08000
+20600000
+da200001
+20404b2c
+680142b5
+e0a10000
+58000000
+e0a08000
+7008a801
+6800c2bb
+79207e06
+6000c2bb
+700b7d12
+20207c27
+e8c08000
+c000cb27
+20600000
+18c22200
+6800c132
+c1818000
+1a220c00
+20204c4a
+20405248
+1a220400
+600888a8
+1fe20a00
+1a227e00
+e0a10000
+20600000
+58004b5b
+6001428c
+58004b44
+60014296
+2040691d
+20405347
+7080a29e
+70808108
+70807505
+5fffffff
+793ffe01
+793ffe15
+60120070
+70807802
+20758000
+7043d801
+20600000
+ea208000
+6000c803
+c001cb4f
+c0024b51
+c002cb53
+c00a4b64
+c00acb67
+c1810000
+e8c08000
+6000c804
+20600000
+d8a04807
+20204b55
+d8a04825
+20204b55
+68014800
+98000a00
+df200013
+20407e45
+18a27e00
+60014800
+70480300
+20600000
+6800c803
+c000cb71
+c0014b8d
+c0054b7a
+c005cb7a
+c0064b7a
+c0044b8d
+c004cb6a
+20600000
+70421300
+70480300
+20600000
+7042131e
+70480300
+20600000
+70480300
+db6fffff
+20404b91
+20600000
+680903c2
+9840fe00
+600203c4
+680203c4
+9d067e00
+24214b6e
+1fe33600
+20404b91
+207a0000
+7048030c
+d8401800
+60094800
+2040561c
+247a0000
+7044c214
+700b7d1b
+20405620
+68010419
+98000a00
+68014800
+98000c00
+df200014
+20407e45
+18c27e00
+60014800
+68014805
+1fe0ffec
+60014805
+20610000
+70480300
+20600000
+6800c804
+20404be2
+70480300
+20600000
+20404b97
+58001800
+98a67e00
+1fe67e00
+60014805
+20600000
+78487c00
+d8a01800
+20618000
+6810811e
+c302cb99
+1b220400
+df200080
+20407e3b
+d8a01800
+da600000
+db6000b4
+20618000
+6810811e
+9a62fe00
+c282cba2
+1b227e00
+98006000
+20407e78
+1fe67cff
+20214ba2
+2a6c0005
+7920fe17
+e0a18000
+18acfe00
+c10e0000
+1e020400
+1a62a620
+20204ba1
+20344bc7
+20364bca
+d8404826
+6800c825
+9840fe00
+9a267c00
+2022cbda
+ea208000
+18c22200
+c303cbc1
+78367c00
+1fe1247f
+1a29a200
+20204bca
+1ff19000
+1fe17e0f
+99067c00
+20628000
+78347c00
+20600000
+19027e00
+78547c00
+20600000
+1a427e00
+203a4bd6
+1a210e07
+1a290c00
+e8c08000
+1a20a201
+1a40a5ff
+afec0000
+6800c807
+2020cbc1
+6800c808
+20204bc1
+78567c00
+1a20a207
+1a292200
+20204bb5
+580000ff
+20600000
+1fe38c00
+98c0fe00
+d8c04809
+98c08c00
+e8c18000
+20600000
+78287c00
+98007200
+78547c00
+78567c00
+da204826
+20404bb3
+c07fcbf1
+20404bdc
+c30bcbed
+793ffe17
+7080a09e
+98003600
+37c18200
+7080a000
+20204be7
+c2004be4
+20600000
+20404c21
+58004d21
+60014290
+58004c59
+6001428e
+58004d37
+60014292
+58004d7e
+6001428a
+58004d7b
+60014294
+58004d7e
+60014288
+58004d22
+60014286
+20758000
+680147f4
+c2863f79
+20403f23
+203a4d79
+20403f7e
+20203f6e
+20404c21
+58004d21
+60014290
+58004c59
+6001428e
+58004d37
+60014292
+58004d7e
+6001428a
+58004d7b
+60014294
+58004d7e
+60014288
+58004d22
+60014286
+20758000
+7007dc00
+7007dd00
+680147f4
+c2863f79
+20403f23
+203a4d79
+20403f7e
+20203f6e
+79200025
+44db4036
+68008140
+203a3bf1
+70807000
+708078ff
+708071ff
+708072ff
+68108073
+1fe1fe0f
+60108073
+70808000
+70808100
+708083ff
+708084ff
+68108085
+1fe1fe03
+60108085
+70806f00
+58000013
+1fe9fe00
+1fe0fe07
+60108064
+68108043
+79207e02
+60108043
+68108051
+793ffe01
+60108051
+7080630d
+708067d3
+70806500
+70806631
+20403e0b
+6808c80e
+204069da
+6808c80f
+204069da
+6808c810
+204069da
+20600000
+79200025
+44dbc036
+e8c08000
+1fe22200
+6808c80f
+2a2ffe00
+204069f0
+6808c80e
+2a2ffe01
+204069f0
+6808c810
+2a2ffe02
+204069f0
+70480901
+20600000
+20404c99
+24740000
+24760000
+68008450
+c000cc69
+6800c2bc
+c19f8000
+da20000a
+20404b2c
+680142b7
+e0a10000
+580001a1
+e0a10000
+68044800
+e0a40000
+20600000
+6808854f
+58000550
+98408a00
+6800c802
+203a4c72
+c0154c74
+c0944c7e
+6008854f
+20203f6a
+6008854f
+20600000
+6800854f
+207a0000
+1fe0ffff
+6000854f
+d8a00550
+98a08a00
+58000000
+e0a08000
+78367c00
+20204c8d
+1fe67c1d
+20610000
+d8400030
+1fe67c27
+24610000
+2022cc87
+d840001d
+98460400
+18418430
+e0a88000
+6800854f
+1fe0fe01
+6000854f
+78567c00
+20204c8d
+680142b7
+207a0000
+da200003
+20404b2c
+680142b7
+e0a10000
+5800ffa1
+e0a10000
+58000000
+79367e00
+e0a08000
+20600000
+78547c00
+78567c00
+68108119
+c3800000
+6810811b
+c2804ca3
+68108119
+c3034ca3
+6810811a
+20204c99
+78347c00
+78367c00
+6810811b
+2fec0000
+6810811a
+d8c04811
+98c08c00
+e8c08000
+c283cce4
+2420cccc
+78567c00
+98000400
+6800c808
+1fe67c04
+24610000
+1fe22200
+df200003
+d8c04802
+e8c08000
+98467c00
+2022cc99
+c2004cb5
+1a227e00
+d8a04802
+98a08a00
+e0a88000
+1fe0fe01
+6000c808
+6810811b
+1fe97e00
+243a4cc3
+20204cca
+1fe0ffff
+2022ccca
+6810811b
+1fe17e01
+c0004c99
+c000ccca
+20600000
+78367c00
+20600000
+1fe104ff
+6800c808
+207a0000
+98007200
+d8c04802
+e8c08000
+98467c00
+2022ccd6
+c2004cd1
+20600000
+18c08bff
+20407e45
+6800c808
+1fe0ffff
+6000c808
+6810811b
+1fe97e00
+243a4cdf
+20600000
+6810811b
+1fe17e01
+c0004cca
+c000cc99
+20600000
+1fe10e07
+6800c800
+f920fe00
+6000c800
+20600000
+58000000
+60044800
+6000c808
+20600000
+6810811b
+6810811a
+68108119
+c3004ced
+580000ff
+78347c00
+20600000
+680944c2
+20405866
+c4000000
+6800c6f8
+c4000000
+2040561c
+247a0000
+20404c99
+24740000
+24760000
+20403f5e
+70421302
+680944c2
+20405a88
+18c08a01
+68044800
+e0a40000
+700b7d1b
+20405620
+680083e4
+c281bbf2
+20600000
+1a627e00
+c0084d15
+c00a4d13
+c0144d11
+c014cd11
+c0173f57
+20600000
+20403fa4
+20203f92
+20404ced
+20204ce9
+20405b30
+20403f90
+20403f88
+20203f94
+6800c42e
+207a0000
+1fe0ffff
+6000c42e
+247a0000
+6800c4db
+207a0000
+20203f98
+20204d2e
+6811811c
+1fe22400
+6810811f
+1fe17e0f
+1ff07e00
+1fed7e00
+9a41fe00
+680a480a
+98467e00
+207a0000
+da4000bb
+20203f5e
+6800c133
+247a0000
+6800c27f
+247a0000
+6800c7ea
+207a0000
+6800c7eb
+247a0000
+20203f9a
+1a627e00
+c0034d8b
+c0054d7c
+c0034d8f
+c0084d68
+c0173f57
+c000cd77
+c0014d51
+c0024d4e
+c009cd4e
+1fe1040f
+1fe17ef0
+c0284d45
+20600000
+79200025
+44dc4037
+60088259
+68008259
+207a0000
+1fe0ffff
+60008259
+20404d62
+20204d48
+680147f4
+c2864d79
+20203f10
+79200025
+44dcc037
+20404d59
+680142a0
+c2803f12
+c280cd5c
+c2814d5f
+20204d79
+70425e00
+70448b00
+20600000
+c282bf10
+c281bf10
+20204d79
+680147f4
+c2864d79
+20203f10
+6800c7f2
+207a0000
+1fe0ffff
+6000c7f2
+247a0000
+20204d8f
+20404d6a
+20204d79
+79200025
+44dd4037
+680147f4
+2feffe07
+2040bf75
+680147fe
+600147f0
+680142a2
+79207e00
+600142a2
+680147f4
+c2803f77
+20600000
+20403f7e
+20203f98
+20403f7c
+20203f94
+20203f9a
+70054f00
+20600000
+70808300
+70808400
+68108085
+1fe17ef0
+60108085
+58000000
+600200a7
+580000ff
+6808c7fd
+18420e00
+f9207e00
+600200a3
+20600000
+58000002
+6000c7f2
+20404ced
+20204ce9
+79200025
+44ddc037
+70427f01
+20403fa4
+20403fa2
+58000000
+600147f0
+6000c7f2
+20203f9e
+2035cd9d
+580043ce
+d8a042af
+98a67200
+20407e3f
+79200025
+448b4022
+580004de
+d8a004a9
+98a67200
+20407e3f
+58000330
+d8a002c4
+98a67200
+20407e3f
+2020532a
+79200025
+448bc022
+18c20400
+18420c00
+e8c10000
+600102cd
+e8c10000
+600102cf
+18c27e00
+600102cb
+6800c7f3
+c0004db5
+202050fa
+79200025
+448c4023
+680102cd
+203a4dfc
+680082cf
+c000cdc0
+c0284de7
+c028cdf4
+c0294df2
+c029cdf2
+20204dfc
+2040527a
+247a0000
+7043cd00
+204052c4
+20404e01
+680902d6
+203a4dfb
+204052ce
+680102d6
+e0a10000
+18007e01
+e0a10000
+20204dfc
+6800c132
+c1008000
+6800c3cd
+207a0000
+1fe22200
+6802033c
+d8400100
+98408400
+1c427e00
+98467c00
+24610000
+7043cd00
+1a227e00
+c0284ddc
+20203bf1
+204052c4
+20404e84
+204052d0
+20407e1c
+20404eb7
+204052ce
+5800000c
+e0a10000
+18007e01
+e0a10000
+20204dfc
+2040527e
+247a0000
+204052d2
+20406f72
+204052dc
+680102dc
+203a4dfb
+e0a10000
+680142b1
+e0a10000
+20204dfc
+20404af8
+20204dfc
+79200025
+448cc023
+7002eb00
+20406bdc
+680082eb
+c1008000
+20204dfc
+2040526f
+58000000
+600102cd
+600102cf
+7002d101
+20600000
+79200025
+448d4023
+204052d0
+18002400
+680102cd
+1fe22600
+680102cb
+98000c00
+20404e11
+1a627e00
+1a60a7fc
+1fe0fffc
+243a4e09
+1a427e00
+600102d6
+20600000
+79200025
+448dc023
+e8c08000
+c000ce54
+c0014e5c
+c001cee0
+c0024f0f
+c002cfad
+c0034fd5
+c003d024
+c0045058
+c004d068
+c0054e21
+c005d069
+2040506a
+20600000
+e8c08000
+1fe20e00
+e8c10000
+1fe22200
+1a627e00
+9a262600
+1a227e00
+98c08c00
+5800000b
+e0a08000
+18e27e00
+e0a08000
+18007e08
+e0a10000
+18007e02
+e0a10000
+18007e00
+e0a10000
+18007e00
+e0a10000
+18007e00
+e0a10000
+18007e0c
+9a40a400
+20204e20
+e8c08000
+1fe20e00
+e8c10000
+1fe22200
+1a627e00
+9a262600
+1a227e00
+98c08c00
+204052d0
+5800000b
+e0a08000
+18e27e00
+e0a08000
+18007e08
+e0a10000
+18007e02
+e0a10000
+18007e00
+e0a10000
+18007e00
+e0a10000
+18007e00
+e0a10000
+18007e0c
+9a40a400
+20204e20
+e8c08000
+1fe20e00
+e8c10000
+1fe22200
+98c08c00
+1a627e00
+9a262600
+20204e20
+20407e1c
+20407e21
+d9000000
+e8c08000
+1fe20e00
+e8c10000
+1fe22200
+e8c10000
+1fe20400
+e8c10000
+1fe21600
+18427e00
+c000ce6e
+c001ce90
+c008ce9c
+c009cea7
+2040506a
+20204edf
+20407e1c
+d8400050
+680142b1
+243a4ed9
+19627e00
+600142b1
+1c427e00
+6002033c
+20404e78
+20204eb3
+6009033a
+19627e00
+60010330
+1a227e00
+60010332
+1a427e00
+60010334
+1a627e00
+60010336
+18e27e00
+60010338
+20600000
+6809033a
+68010330
+1fe21600
+68010332
+1fe22200
+68010334
+1fe22400
+68010336
+1fe22600
+68010338
+1fe20e00
+20600000
+20407e1c
+58000051
+d8400051
+680142b3
+243a4ed9
+19627e00
+600142b3
+6800c2ba
+79207e00
+79207e01
+6000c2ba
+20204ebb
+20407e1c
+d8400052
+680142b5
+243a4ed9
+19627e00
+600142b5
+6800c2bb
+79207e00
+79207e01
+6000c2bb
+20204ebb
+20407e1c
+1b427e00
+d8400053
+680142b7
+243a4ed9
+19627e00
+600142b7
+6800c2bc
+79207e00
+79207e01
+6000c2bc
+20204ebb
+58000001
+600102e4
+7043cd50
+20204ebd
+6800c2b9
+79207e00
+79207e01
+6000c2b9
+58000000
+600102e4
+79200025
+448e4023
+20407e21
+58000003
+e0a08000
+18e27e00
+e0a08000
+58000008
+e0a10000
+18427e00
+e0a10000
+19627e00
+e0a10000
+680102e4
+c000ced4
+290c0000
+2020cecf
+58000004
+e0a10000
+18007e00
+e0a10000
+5800000c
+20204edb
+e0a10000
+18007e02
+e0a10000
+5800000c
+20204edb
+79201000
+20204ebb
+9a40a400
+1a627e00
+9a262600
+20204edf
+20204e20
+e8c08000
+1fe20e00
+e8c10000
+1fe22200
+1a627e00
+9a262600
+e8c10000
+1fe21600
+e8c10000
+1fe20400
+58000050
+98467c00
+2022cef7
+58000051
+98467c00
+2022cefd
+58000052
+98467c00
+2022cf09
+58000053
+98467c00
+2022cf03
+20600000
+19627e00
+600142b1
+6800c2b9
+79207e01
+6000c2b9
+20204e20
+19627e00
+600142b3
+6800c2ba
+79207e01
+6000c2ba
+20600000
+19627e00
+600142b5
+6800c2bc
+79207e01
+6000c2bc
+20600000
+19627e00
+600142b7
+6800c2bb
+79207e01
+6000c2bb
+20600000
+e8c08000
+1fe20e00
+e8c10000
+1fe22200
+1a627e00
+9a262600
+e8c10000
+1fe20400
+18422200
+58000050
+98467c00
+2022cf25
+58000051
+98467c00
+2022cf43
+58000052
+98467c00
+2022cf2f
+58000053
+98467c00
+2022cf39
+2020506a
+18a21600
+6800c2b9
+79207e04
+79207e03
+6000c2b9
+19620a00
+d9600050
+680142b1
+1fe20400
+20204f4c
+18a21600
+6800c2bb
+79207e04
+79207e03
+6000c2bb
+19620a00
+d9600052
+680142b5
+1fe20400
+20204f4c
+18a21600
+6800c2bc
+79207e04
+79207e03
+6000c2bc
+19620a00
+d9600053
+680142b7
+1fe20400
+20204f4c
+18a21600
+6800c2ba
+79207e04
+79207e03
+6000c2ba
+19620a00
+d9600051
+680142b3
+1fe20400
+79200025
+448ec023
+58000005
+e0a08000
+18e27e00
+e0a08000
+58000006
+e0a10000
+18427e00
+e0a10000
+18007e00
+e0a10000
+18007e00
+e0a10000
+18007e0a
+9a40a400
+600902e9
+18e27e00
+600082e8
+18007e50
+a961fe00
+2020cf63
+1fe0fe01
+20600000
+78547c00
+c3810000
+c4000000
+c4008000
+79207e02
+18c20a00
+18a08bff
+e0a08000
+78347c00
+20600000
+6800c2b9
+20404f64
+24344f75
+7002e750
+680142b1
+600102e9
+20204f89
+6800c2ba
+20404f64
+24344f7c
+7002e751
+680142b3
+600102e9
+20204f89
+6800c2bb
+20404f64
+24344f83
+7002e752
+680142b5
+600102e9
+20204f89
+6800c2bc
+20404f64
+24740000
+7002e753
+680142b7
+600102e9
+79200025
+448f4023
+20405242
+204052c4
+18002400
+204052d0
+18007e04
+e0a08000
+6800c2be
+e0a08000
+58000008
+e0a10000
+680102e9
+e0a10000
+58000000
+e0a10000
+18007e01
+e0a08000
+18007e02
+e0a08000
+680082e7
+c028cfa2
+58000030
+e0a10000
+20204fa4
+580003e3
+e0a10000
+d840000c
+600902d6
+204052ce
+680102d6
+e0a10000
+18007e01
+e0a10000
+7002e700
+20204e20
+18c08c01
+e8c10000
+1fe22200
+1a627e00
+9a262600
+e8c10000
+1fe22200
+58000050
+9a267c00
+2022cfc4
+58000051
+9a267c00
+2022cfc8
+58000052
+9a267c00
+2022cfcc
+58000053
+9a267c00
+2022cfd0
+18c08c02
+e8c10000
+98007c00
+20204e20
+6800c2b9
+79207e05
+6000c2b9
+20204e20
+6800c2ba
+79207e05
+6000c2ba
+20204e20
+6800c2bb
+79207e05
+6000c2bb
+20204e20
+6800c2bc
+79207e05
+6000c2bc
+700b7d06
+20207c27
+e8c08000
+1fe20e00
+e8c10000
+1fe22200
+1a627e00
+9a262600
+e8c10000
+1fe22200
+e8c10000
+1fe21600
+1a220400
+20407e1c
+58000050
+98467c00
+2022cffb
+58000051
+98467c00
+2022d00b
+58000052
+98467c00
+2022cfef
+58000053
+98467c00
+2022cff5
+2040506a
+20205020
+19620400
+680142b5
+98467c00
+2022d001
+2040506a
+20205020
+19620400
+680142b7
+98467c00
+2022d003
+2040506a
+20205020
+19620400
+680142b1
+98467c00
+2022d007
+2040506a
+20205020
+20405081
+20205013
+20405087
+680142b5
+203a5013
+20205013
+2040507c
+680082ef
+243a5013
+20205013
+19620400
+680142b3
+98467c00
+2022d011
+2040506a
+20205020
+20405077
+20205013
+20407e21
+58000007
+e0a08000
+18e27e00
+e0a08000
+58000004
+e0a10000
+1a227e00
+e0a10000
+19627e00
+e0a10000
+18007e08
+20205022
+20407e21
+20205022
+9a40a400
+20204e20
+e8c08000
+1fe20e00
+e8c10000
+1fe22200
+1a627e00
+9a262600
+e8c10000
+1fe21600
+e8c10000
+1fe20400
+20407e1c
+58000050
+98467c00
+2022d03d
+58000051
+98467c00
+2022d043
+58000052
+98467c00
+2022d049
+58000053
+98467c00
+2022d04f
+2040506a
+20205057
+18422200
+19620400
+680142b1
+98467c00
+2042d07c
+20205055
+18422200
+19620400
+680142b3
+98467c00
+2042d077
+20205055
+18422200
+19620400
+680142b5
+98467c00
+2042d081
+20205055
+18422200
+19620400
+680142b7
+98467c00
+2042d087
+20205055
+20407e21
+20204e20
+20204e20
+e8c08000
+1fe20e00
+e8c10000
+1fe22200
+98c08c00
+58000009
+e0a08000
+18e27e00
+e0a08000
+18007e00
+e0a10000
+18007e04
+9a40a400
+1a627e00
+9a262600
+20204e20
+20204e20
+20204e20
+18002400
+204052d0
+58000001
+e0a08000
+18e27e00
+e0a08000
+58000002
+e0a10000
+58000000
+e0a10000
+1a40a406
+da600004
+20204e20
+58000000
+600102e2
+600142b3
+7042ba00
+20600000
+58000000
+600102dc
+600142b1
+7042b900
+20600000
+58000000
+600142b5
+7042bb00
+6800c2bc
+c000508d
+20600000
+58000000
+600142b7
+7042bc00
+6800c2bb
+c000508d
+20600000
+700b7d07
+20207c27
+680082e6
+793ffe00
+600082e6
+680142b7
+207a0000
+204052c4
+680142b7
+1fe22200
+18002453
+202050a2
+680082e6
+793ffe07
+600082e6
+680142b5
+207a0000
+204052c4
+680142b5
+1fe22200
+18002452
+20405242
+204052d0
+18007e06
+e0a08000
+6800c2be
+e0a08000
+58000004
+e0a10000
+1a227e00
+e0a10000
+1a427e00
+e0a10000
+18000408
+202050e9
+79200025
+448fc023
+20405242
+204052d0
+58000002
+e0a08000
+6800c2be
+e0a08000
+58000004
+e0a10000
+18427e00
+e0a10000
+19627e00
+e0a10000
+d8400008
+202050e9
+79200025
+44904024
+20405242
+204052d0
+58000004
+e0a08000
+6800c2be
+e0a08000
+58000008
+e0a10000
+18427e00
+e0a10000
+58000000
+e0a10000
+58000001
+e0a08000
+58000002
+e0a08000
+580003e3
+e0a10000
+d840000c
+202050e9
+79200025
+4490c024
+20405242
+204052d0
+58000006
+e0a08000
+6800c2be
+1fe0fe01
+18a22200
+6000c2be
+1a220a00
+e0a08000
+58000004
+e0a10000
+18427e00
+e0a10000
+19627e00
+e0a10000
+d8400008
+600902d6
+18427e00
+203a526f
+204052ce
+680102d6
+e0a10000
+18007e01
+e0a10000
+20600000
+680102dc
+203a3bf1
+204052dc
+680102dc
+e0a10000
+680142b1
+e0a10000
+20600000
+79200025
+44914024
+680102cd
+203a4dfc
+680082cf
+c000d105
+c0284de7
+c028cdf4
+c0294df2
+c029cdf2
+20204dfc
+79200025
+4491c024
+204052c4
+18002400
+204052d0
+1fe20a00
+680102cd
+1fe22600
+680102cb
+98000c00
+20405115
+1a60a7fc
+2422d10f
+1a420400
+204050e9
+20204dfc
+e8c08000
+c0015120
+c000d123
+c001d12d
+c002d168
+c0025199
+c003d21c
+c00351eb
+c0045058
+c0054e3a
+20205236
+20407e1c
+20407e21
+20204e5c
+e8c08000
+1fe20e00
+e8c10000
+1fe22200
+1a627e00
+9a262600
+e8c08000
+1a20a3ff
+2422d129
+20600000
+e8c08000
+1fe20e00
+e8c10000
+1fe22200
+e8c10000
+1fe21600
+e8c10000
+1fe20400
+e8c10000
+1fe67c00
+2022d13f
+c001513b
+c002513b
+2020513d
+700b7d16
+20407c27
+e8c10000
+20205165
+20407e1c
+58000050
+98467c00
+2022d14d
+58000051
+98467c00
+2022d153
+58000053
+98467c00
+2022d15f
+58000052
+98467c00
+2022d159
+20205165
+19627e00
+600142b1
+6800c2b9
+79207e01
+6000c2b9
+20205164
+19627e00
+600142b3
+6800c2ba
+79207e01
+6000c2ba
+20205164
+19627e00
+600142b5
+6800c2bb
+79207e01
+6000c2bb
+20205164
+19627e00
+600142b7
+6800c2bc
+79207e01
+6000c2bc
+20407e21
+1a627e00
+9a262600
+20600000
+e8c08000
+1fe20e00
+e8c10000
+1fe22200
+1a627e00
+9a262600
+e8c10000
+1fe21600
+e8c10000
+e8c10000
+243a5193
+20407e1c
+19620400
+58000050
+98467c00
+2022d181
+58000051
+98467c00
+2022d185
+58000052
+98467c00
+2022d189
+58000053
+98467c00
+2022d18d
+6800c2b9
+79207e05
+6000c2b9
+20600000
+6800c2ba
+79207e05
+6000c2ba
+20600000
+6800c2bb
+79207e05
+6000c2bb
+20600000
+6800c2bc
+79207e05
+6000c2bc
+700b7d06
+20207c27
+20407e21
+1a20a3fa
+2022d198
+18c08c01
+1a20a3ff
+20205194
+20600000
+e8c08000
+1fe20e00
+e8c10000
+1fe22200
+1a627e00
+9a262600
+e8c10000
+18c08c02
+1fe20400
+58000005
+e0a08000
+18e27e00
+e0a08000
+1a20a202
+1a227e00
+e0a10000
+20407e1c
+58000050
+98467c00
+2022d1b7
+58000051
+98467c00
+2022d1c8
+58000052
+98467c00
+2022d1ce
+58000053
+98467c00
+2022d1d4
+202051d9
+6800c2b9
+79207e04
+79207e03
+6000c2b9
+c28151c5
+680882e6
+79200406
+600882e6
+18e27e00
+1fe0fe01
+600082e8
+6800c2b9
+79207e02
+6000c2b9
+680142b1
+600102e9
+202051d9
+6800c2ba
+79207e04
+79207e03
+6000c2ba
+680142b3
+202051d9
+6800c2bb
+79207e04
+79207e03
+6000c2bb
+680142b5
+202051d9
+6800c2bc
+79207e04
+79207e03
+6000c2bc
+680142b7
+1fe21600
+20407e21
+19627e00
+e0a10000
+18007e00
+e0a10000
+18007e00
+e0a10000
+18007e0a
+9a40a400
+1a20a3fa
+2022d1ea
+e8c08000
+e0a08000
+1a40a401
+1a20a3ff
+202051e4
+20600000
+e8c08000
+1fe20e00
+e8c10000
+1fe22200
+1a627e00
+9a262600
+e8c10000
+1fe22200
+e8c10000
+1fe21600
+20407e1c
+58000050
+1a220400
+98467c00
+2022d203
+58000052
+1a220400
+98467c00
+2022d208
+58000053
+1a220400
+98467c00
+2022d20a
+2020520c
+58000000
+600102dc
+600142b1
+6000c2b9
+2020520e
+20405081
+2020520e
+20405087
+2020520e
+58000000
+600102e2
+20407e21
+58000007
+e0a08000
+18e27e00
+e0a08000
+58000004
+e0a10000
+1a227e00
+e0a10000
+19627e00
+e0a10000
+18007e08
+9a40a400
+20600000
+e8c08000
+1fe20e00
+e8c10000
+1fe22200
+e8c10000
+1fe21600
+e8c10000
+1fe20400
+20407e1c
+6800c2be
+a8e1fe00
+2420d232
+58000050
+98467c00
+2022d22f
+58000051
+98467c00
+2022d232
+20205232
+7042b100
+7042b900
+20205232
+20407e21
+1a627e00
+9a262600
+20600000
+58000001
+e0a08000
+e8c08000
+e0a08000
+58000002
+e0a10000
+58000000
+e0a10000
+58000006
+9a40a400
+18002604
+20600000
+6800c2be
+1fe0fe01
+c0805246
+1fe0fe01
+6000c2be
+20600000
+79200025
+44924024
+da400000
+2040527a
+243a3bf1
+20405287
+da401800
+d8e00000
+6808c2bf
+a84fffff
+2020d258
+204052ab
+19667c00
+20215258
+20405292
+2020525e
+1a40a480
+18e08e01
+58000008
+98e67c00
+20215250
+da400000
+1a427e00
+203a3bf1
+20600000
+79200025
+4492c024
+20405280
+18c08c01
+e8c10000
+20600000
+79200025
+44934024
+20405280
+18c20a00
+18c20400
+58000000
+e0a18000
+20600000
+79200025
+4493c024
+2040527e
+203a3bf1
+6801c2c6
+6001c2c9
+6801c2c3
+6001c2c6
+6801c2c0
+6001c2c3
+20600000
+6801c2c0
+20600000
+6801c2c3
+20600000
+6801c2c9
+20600000
+2040527e
+203a3bf1
+d8c042c0
+e8c18000
+203a5283
+18c08dfd
+20600000
+79200025
+44944025
+df200004
+d8c042c0
+d8400000
+e8c18000
+1fe17eff
+98418400
+c200528c
+6008c2bf
+20600000
+79200025
+4494c025
+2040527a
+243a3bf1
+2040527e
+203a52a0
+6801c2c3
+6001c2c0
+e8c18000
+e0a18000
+e8c18000
+e0a18000
+58000000
+e0a18000
+d8400000
+19627e00
+98e0fe00
+f9200400
+18e08e01
+98e67c00
+2422d2a3
+1a4d7e00
+9841fe00
+6001c2c9
+20600000
+79200025
+44954025
+20405287
+18e22600
+d8400000
+d9600000
+18e27e00
+c00452bc
+6800c2bf
+afefffff
+2020d2bc
+18408480
+18e08e01
+1a227e00
+98467c00
+2022d2bc
+202152b1
+18427e00
+9a267c00
+242152c2
+18e27e00
+1a620400
+98461600
+1a620e00
+20600000
+79200025
+4495c025
+da20007f
+20405248
+600102d2
+1fe0fe04
+600102d4
+58000000
+600102d6
+20600000
+680102d2
+202052f2
+680102d4
+202052f2
+79200025
+44964025
+da2002ff
+20405248
+600102d8
+1fe0fe04
+600102da
+58000000
+600102dc
+20600000
+680102d8
+202052f2
+680102da
+202052f2
+79200025
+4496c025
+20407e00
+7002eb01
+2040527a
+247a0000
+da20007f
+20405248
+600102de
+1fe0fe04
+600102e0
+58000000
+600102e2
+7002eb00
+20207e0e
+680102de
+202052f2
+680102e0
+203a3bf1
+1fe20a00
+20600000
+79200025
+44974025
+da400000
+da2042c0
+1a20a3fe
+1a20a202
+580042cc
+9a267c00
+2022d306
+ea208000
+1a20a201
+203a52fa
+ea290000
+e8410000
+9a40a400
+1a40a404
+202052fa
+1a427e00
+20600000
+d8e0000c
+20203dc2
+d8e0000c
+20203dc6
+79200025
+4497c025
+20405287
+6800c2bf
+207a0000
+204052f5
+d8400100
+98467c00
+20215308
+2040530a
+d8a042cc
+da2042c0
+580042cc
+9a267c00
+20628000
+ea208000
+1a20a201
+243a5321
+e0a10000
+1a20a202
+20205318
+ea210000
+1a20a202
+1fe20c00
+e8c10000
+e0a10000
+1fe27200
+1f20f202
+20407e45
+20205318
+79200025
+44984026
+20405287
+6800c2bf
+207a0000
+da2042c1
+1a20a3fd
+d8c042cc
+1a20a203
+580042cd
+9a267c00
+20628000
+e8c10000
+203a5332
+1fe0fe04
+1fe27200
+18c22400
+ea210000
+1fe20a00
+1a420c00
+18c08dfe
+20407e45
+20205332
+20758000
+58000010
+600143d3
+58000010
+600143d5
+20600000
+d8400014
+20405a88
+18c0fe01
+60010419
+20600000
+79200025
+44994026
+7855fc00
+70427e01
+7003d601
+7003c003
+7003d701
+5fffffff
+600103da
+18007e00
+600083e3
+600083d8
+600083e4
+6001c20a
+6001c20d
+6002c465
+79207e27
+6002c46a
+20205a0b
+79200025
+4499c026
+7834fc00
+7003c103
+7003fa01
+7044bc01
+5800ffff
+600144be
+18007e00
+6002c46a
+79207e27
+6002c465
+2020534c
+79200025
+449a4026
+7854fc00
+7003c101
+7043d800
+7000a200
+2020534c
+204053d2
+204055d3
+20405a0e
+202053d7
+79200025
+449ac026
+204053d2
+20403e71
+680083c1
+c001d37e
+20205395
+79200025
+449b4026
+7834fc00
+20405a02
+20215392
+20403e28
+2040541c
+20405622
+7856fc00
+204054b2
+24768000
+79200025
+449bc026
+68008005
+1fe0fe01
+60008005
+204055a2
+20405a99
+7854fc00
+20600000
+204053ba
+7854fc00
+20600000
+79200025
+449c4027
+78577c00
+20405a02
+202153ba
+20403e28
+2040541c
+20405478
+2436d3ad
+79200025
+449cc027
+204053c8
+204055a2
+20405622
+68008340
+c28253b4
+2040561a
+243a53b4
+79200025
+449d4027
+204054bb
+20407c45
+680083e4
+c281d3ba
+79200025
+449dc027
+20407f44
+20405b19
+20405594
+20405576
+202039ac
+79200025
+449e4027
+78377c00
+204054b2
+2036d39e
+202053aa
+79200025
+449ec027
+204053c0
+20403f1d
+700b7d15
+20207c27
+680883d6
+7002c008
+204048c4
+7003d600
+7003c100
+7003c000
+70427e00
+20600000
+68008005
+1fe0fe01
+60008005
+680083c0
+c3818000
+79207e03
+600083c0
+58000000
+600246f9
+20600000
+79200025
+449f4027
+783b7c00
+70891407
+20203e28
+79200025
+449fc027
+785b7c00
+70891403
+db600000
+20600000
+7844fc00
+7843fc00
+680183e9
+98001e00
+68008016
+1fed8400
+79200401
+18431c00
+20600000
+204053ee
+20403a82
+58000500
+20403bf3
+20203a87
+2036ba98
+204053ee
+20203a91
+79200025
+44a04028
+20403a7a
+6800840d
+243a5402
+68008016
+1fe67c24
+202153fc
+18000400
+c1128000
+18000418
+c1130000
+1800044e
+20600000
+1fe67c0a
+202153ff
+1fe0fe01
+1fe3fe00
+1fe08402
+20600000
+68008016
+1fe38400
+20600000
+d84001f4
+207a0000
+d84000fa
+c1008000
+d8400096
+c1010000
+d8400064
+c1018000
+d840004b
+c1020000
+d8400032
+c1028000
+d8400028
+c1030000
+d8400014
+20600000
+588e89be
+1fed7e00
+1fe1fed6
+98001200
+58555555
+600183e9
+20600000
+79200025
+44a0c028
+78287c00
+680203e5
+98001200
+20405453
+58000200
+2034d426
+680103ce
+1fe37e00
+d8400500
+9840fe00
+20403b7d
+1b427e00
+60030412
+20600000
+79200025
+44a14028
+68008016
+1fe0fe01
+60008016
+c1940000
+70001625
+20600000
+79200025
+44a1c028
+1a208c01
+e8c08000
+c4000000
+1a208a1a
+e8a10000
+1fe0fe01
+e0a10000
+1a208c19
+e8c08000
+1a208a18
+e8a88000
+9840fe00
+1fe67c24
+20215445
+1fe0ffdb
+e0a08000
+20600000
+79200025
+44a24028
+680283f1
+18000400
+18007225
+c300544e
+18408401
+1fe37e00
+c200544c
+1840ffff
+600083e2
+20600000
+79200025
+44a2c028
+680083d8
+98000e00
+680a83f1
+a84fffff
+2020d46b
+79200025
+44a34028
+680083e2
+98e67e00
+20215461
+1fe60fff
+2020545a
+18e27200
+18000e00
+a84fffff
+2020d466
+1f20f201
+1f227e00
+203a546b
+18e08e01
+1f20f3ff
+20205463
+18e27e00
+60008016
+20600000
+2034d471
+37c18200
+20600000
+d9600ea0
+34730200
+20600000
+78487c00
+680143d5
+1fe21600
+2020547e
+79200025
+44a3c028
+78287c00
+680103ce
+680a46f9
+98409600
+204053e6
+79200025
+44a44029
+204053dd
+7856fc00
+7826fc00
+7830fc00
+78507c00
+19623600
+37c18400
+2037548b
+1b420400
+600b009c
+242c375c
+20375492
+dd2001e0
+1c225000
+680083c0
+c301d492
+2055bcb6
+79200025
+44a4c029
+20403af3
+7823fc00
+7824fc00
+09800008
+19897e00
+60008340
+09800008
+19897e00
+e0a08000
+1fe1723f
+2022d4a3
+09800008
+19897e00
+e0a08000
+c200549f
+79200025
+44a54029
+09800018
+78287c00
+db600664
+1fef7e00
+1ff17e00
+e0a18000
+2023375c
+7836fc00
+68008017
+1fe0a202
+20403ab6
+7846fc00
+20203a7a
+79200025
+44a5c029
+204054bd
+68088017
+20403a82
+20403a87
+78287c00
+d9601388
+2020547f
+204054bd
+2020375c
+79200025
+44a64029
+204053dd
+204053eb
+79202a00
+782efc00
+78307c00
+7850fc00
+2040546e
+19317e00
+1fecfe00
+1ff1fe00
+08008628
+7823fc00
+7824fc00
+79200025
+44a6c029
+6800c43e
+08008608
+e8c08000
+1fe1723f
+08008608
+2022d4d7
+e8c08000
+08008608
+c20054d4
+78247c00
+08008618
+78447c00
+37d38200
+20000064
+784efc00
+20600000
+79200025
+44a74029
+6800c4db
+c000d4ef
+6800c4dc
+1ff27e00
+1febfe00
+6000c43e
+6808c3d9
+1840fe06
+6000c43f
+680344f9
+60034440
+18427200
+d8c043da
+20407e45
+202054ff
+680944c2
+20405866
+1a220a00
+58000001
+e0a08000
+6800c4dd
+1ff27e00
+1febfe00
+1fe0fe01
+6000c43e
+5800000c
+6000c43f
+680344f9
+60034440
+68034274
+e0a30000
+79200025
+44a7c029
+68008000
+1fe0fe01
+60008000
+db600708
+7856fc00
+202054b2
+79200025
+44a8402a
+6800c4f6
+c1808000
+68008000
+1fe0fe01
+60008000
+d8400c03
+6800c4f7
+7d3a0406
+1a227e00
+7d3a0407
+6009443e
+680344f9
+e0a30000
+680303d0
+e0a30000
+202054b2
+79200025
+44a8c02a
+d8400004
+6800c4dc
+7d3a0406
+6008c43e
+6808c3f9
+1840fe06
+6000c43f
+680344f9
+60034440
+d8c043fa
+18427200
+20407e45
+202054bb
+79200025
+44a9402a
+18007fff
+38080001
+600283f1
+20405447
+18007204
+d8a003e5
+20406227
+680144f4
+600103ef
+180a7e00
+1fe17e0f
+1fe67c04
+20215533
+600083d9
+60008682
+79200025
+44a9c02a
+680943d0
+600903c2
+18422600
+1c40fe07
+9a66fc00
+20407efd
+18072200
+9a267e00
+9a60fe00
+680943ce
+9840fe00
+600203c4
+9c462200
+1a20a3fa
+da402205
+6800c4ed
+7d3a2406
+6800c4e6
+7d3a2407
+1a427e00
+6001443e
+680344f9
+e0a30000
+680303d0
+e0a30000
+680203e5
+e0a20000
+180a7e00
+e0a10000
+180a7e00
+e0a08000
+18007e02
+e0a08000
+1a2b7e00
+e0a10000
+1a6b7e00
+e0a10000
+79200025
+44aa402a
+680144f2
+e0a10000
+680144f4
+e0a10000
+680283f1
+e0a28000
+680083d9
+d84000a0
+9841fe00
+e0a08000
+204054bb
+5800443e
+1fe08c12
+e8c18000
+600183e9
+20600000
+79200025
+44aac02a
+7854fc00
+20205415
+79200025
+44ab402a
+680083c0
+c4028000
+680103da
+680903e0
+98467e00
+24610000
+680083c0
+793ffe05
+793ffe03
+600083c0
+680203c4
+680903c2
+98462200
+79200025
+44abc02a
+6800c434
+600083ec
+e8c90000
+e8c10000
+1febfe00
+600103c2
+184b8400
+9840fe00
+e8ca0000
+600a03ed
+9a20fe00
+600203c4
+20205a2b
+79200025
+44ac402b
+680083c0
+c4030000
+680103da
+680903e0
+98467e00
+24610000
+680083c0
+793ffe06
+600083c0
+6802c42f
+600283f1
+20205447
+79200025
+44acc02b
+20405a0b
+204055b7
+68008340
+1fe37e00
+9842fe00
+2feffe02
+7920800f
+68008341
+203a55b2
+680083c0
+c30255b2
+20407599
+2040750e
+247a0000
+c6078000
+680883d7
+79400402
+600883d7
+202058ac
+79200025
+44ad402b
+680883d7
+284c0005
+20608000
+68008340
+1fe3fe00
+9842fe00
+c4018000
+793f8405
+79400403
+600883d7
+28400603
+24608000
+6800c440
+c1828000
+680083c0
+79207e04
+600083c0
+20600000
+79200025
+44adc02b
+2040542c
+20405474
+68008001
+1fe0fe01
+60008001
+20600000
+79200025
+44ae402b
+6800c3d2
+c1808000
+d8e00003
+20407e53
+247a0000
+680143d3
+680943d5
+98467e00
+d8e00003
+20407e4c
+7854fc00
+20405572
+204055cb
+24768000
+79200025
+44aec02b
+68030342
+600303d0
+204042a7
+20405b39
+68008002
+1fe0fe01
+60008002
+204055f9
+20748000
+204048d1
+20405507
+24768000
+79200025
+44af402b
+68008004
+1fe0fe01
+60008004
+68048348
+60048103
+202048d1
+79200025
+44afc02b
+6800841c
+c18d8000
+680303d0
+680b44e7
+98467c00
+24628000
+204032d6
+24628000
+20405528
+2040535f
+79200025
+44b0402c
+70427200
+7003f800
+6800c132
+c082560c
+7003e321
+d8400000
+204048ea
+7043d200
+70041c00
+700b7d2c
+20405620
+202032bd
+da200001
+68008340
+c3830000
+da200000
+20600000
+d8c044ff
+20207fb2
+da2044ff
+20207fac
+da2044ff
+20207fae
+da2044ff
+20207fb0
+da2044ff
+20207f92
+79200025
+44b0c02c
+680083d7
+c3828000
+da2044ff
+20407f9f
+243a5630
+6800c132
+c080d890
+d8200000
+204044a3
+18227e00
+247a0000
+20205890
+1fe20400
+79200025
+44b1402c
+18427e00
+c302d64b
+18000203
+793ffe05
+6000c440
+79200025
+44b1c02c
+6800c440
+c000568f
+c000d691
+c0015693
+c001d695
+c00256a6
+c002d6b7
+c00356b9
+c003d6bf
+c00456c1
+c004d6c1
+c00556c5
+c005d6c7
+c00656c9
+c006d6cf
+c007d6d1
+20203bf1
+70444300
+18000202
+c3035662
+c0295662
+c0695662
+70444206
+793ffe06
+6000c444
+79200025
+44b2402c
+6800c444
+c000d6e5
+c00156ed
+c001d6f5
+c00256fa
+c002d6ff
+c0035701
+c003d70b
+c0045712
+c004d717
+c005571e
+c005d721
+20203bf1
+70444204
+6000c444
+79200025
+44b2c02c
+6800c444
+c000d729
+c001572f
+c001d72f
+c0025732
+c002d737
+c0035748
+c003d752
+c0045793
+c004d79b
+c00557be
+c005d7c6
+c00657d1
+c006d7d6
+c00757e5
+c007d7ec
+c0085812
+c008d81a
+c009583e
+c009d845
+c00b585e
+c00bd860
+c00c5862
+c00cd864
+c00dd873
+c00ed882
+c00f5884
+c0295886
+c0695888
+c04f5686
+c04fd688
+20203bf1
+700b7d10
+20405620
+58000011
+6001443e
+680083d7
+79207e05
+600083d7
+700b7d12
+20205620
+1800040c
+20205892
+18000408
+20205892
+18000402
+20205892
+18007e00
+e0a40000
+e0a10000
+18a20400
+d8a00380
+18007208
+20406227
+68040380
+e0440000
+18a20400
+d8a04473
+18007204
+20406227
+68024473
+e0420000
+18000417
+20205892
+18a20400
+d8a00388
+18007208
+20406227
+68040388
+e0440000
+18a20400
+d8a04477
+18007204
+20406227
+68024477
+e0420000
+204074b6
+700b7d25
+20405620
+1800040d
+20205892
+18000401
+20205892
+18000401
+2034d892
+700b7d46
+20405620
+18000401
+20205892
+18000402
+20205892
+58000001
+e0a40000
+18000409
+20205892
+18000406
+20205892
+18000406
+20205892
+58000a06
+e0a18000
+58001d87
+e0a10000
+18000406
+20205892
+18000402
+20205892
+18a08bff
+5800000c
+e0a10000
+58000005
+e0a10000
+5800b412
+e0a10000
+58000008
+e0a10000
+58000008
+e0a10000
+58000010
+e0a10000
+58000000
+e0a10000
+5800012c
+e0a10000
+2040588a
+18000202
+20205892
+59000401
+600244ae
+58070710
+e0a18000
+680344af
+60034445
+1800040b
+20205892
+59000302
+600244b5
+58010410
+e0a18000
+680344b6
+60034445
+1800040b
+20205892
+204074b0
+d8a04445
+204075a3
+18000415
+20205892
+680403b0
+2034d6fd
+6804449c
+20405723
+20205892
+18000406
+20205892
+700b7d29
+20407c27
+700b7d47
+20405620
+d8a003a0
+20406226
+680403a0
+6804447b
+20405723
+20205892
+700b7d48
+20405620
+d8a04445
+18007208
+20406227
+1800040f
+20205892
+700b7d49
+20405620
+d8a04445
+20406226
+2020588a
+700b7d4a
+20405620
+18007e00
+6000c445
+680344f9
+e0a30000
+2020588a
+d8a04445
+20406226
+2020588a
+18000406
+20205892
+60044445
+e8c40000
+e0a40000
+18000415
+20600000
+7003fc0a
+70444401
+680183f9
+6001c445
+680083fc
+e0a08000
+2020588a
+58000017
+e0a10000
+2020588a
+680144bc
+60014445
+680144be
+e0a10000
+2020588a
+18007e01
+6000c445
+20405a74
+20405a7d
+203a5746
+24215744
+78547c00
+e0a10000
+e8c10000
+e0a10000
+e8c08000
+98c08c00
+2020573a
+18c08c02
+20205741
+20345728
+2020588a
+680144bc
+203a5688
+60014445
+680144be
+e0a10000
+680144c4
+e0a10000
+680144c0
+e0a10000
+2020588a
+2040577b
+20740000
+680944c4
+58002800
+98467c00
+2022d762
+58002801
+98467c00
+2022d728
+58002802
+98467c00
+2022d728
+58002803
+98467c00
+2022d728
+20205728
+680944c0
+18c08c02
+e8c08000
+1fe22600
+1a60a601
+1a60a7ff
+2022d728
+e8c10000
+98467c00
+2022d76e
+18c08c04
+20205767
+e8c10000
+1fe22200
+e8c10000
+1fe22400
+20405785
+20740000
+70444407
+1a227e00
+60014445
+1a427e00
+e0a10000
+18000409
+20205892
+78547c00
+680944bc
+680144be
+98467c00
+24215782
+18427e00
+c1800000
+78347c00
+7003fc01
+20205729
+78547c00
+680944bc
+1a227e00
+98467c00
+24215791
+680144be
+9a467c00
+24215791
+1a427e00
+9a267c00
+24215791
+20600000
+78347c00
+20205728
+680144bc
+e0a10000
+680144be
+e0a10000
+680144c0
+e0a10000
+1800040b
+20205892
+680944c0
+58002803
+98467c00
+58000007
+2022d7a5
+58002800
+98467c00
+58000006
+2022d7a5
+20205728
+6000c445
+20405a74
+18006003
+20405a7d
+203a57bc
+242157b8
+98002200
+e8c10000
+98467c00
+2422d7b9
+78547c00
+1a227e00
+e0a10000
+e8c08000
+1fe0f204
+20407e45
+1e00e1ff
+2022d7bc
+202057b9
+18c08c02
+e8c08000
+98c08c00
+202057a8
+20345728
+2020588a
+6800c43d
+1fe0ffff
+6000c43d
+1fe3fe00
+98c08c00
+e8c90000
+60094445
+2020588a
+680903fa
+20405a88
+203a5728
+e8c08000
+203a588a
+1fe67c16
+202157ce
+18007e16
+1fe27200
+20407e45
+2020588a
+58000003
+60014445
+58000008
+e0a10000
+2020588a
+680144c0
+98002200
+680903fa
+20405a88
+203a5728
+e8c08000
+9a267200
+24215728
+1f267c16
+202157e1
+18007216
+1a227e00
+98c08c00
+20407e45
+2020588a
+58000003
+e0a10000
+58000007
+e0a10000
+58000009
+e0a10000
+2020588a
+6800c43d
+1fe22600
+da200347
+da404445
+d9600000
+7858fc00
+1a220c00
+e8c90000
+18c22200
+20405a88
+203a5805
+e8c08000
+1fe27200
+99609600
+19667c18
+2421580a
+1a420a00
+e8c08000
+e0a08000
+c20057fd
+18a22400
+7838fc00
+1a60a7ff
+2022d805
+202057f2
+2438d810
+7858fc00
+19620400
+18408405
+20205892
+2438d810
+7858fc00
+19627e00
+9f260400
+18408405
+20205892
+7003fc10
+20205729
+680103fa
+203a5688
+e0a10000
+5800ffff
+e0a10000
+58002800
+e0a10000
+2020588a
+58000006
+6000c445
+680144c0
+98002200
+20405a74
+18007203
+20405a7d
+203a5835
+2421583a
+98006000
+e8c10000
+9a267c00
+2422d83b
+1e027e00
+2034582f
+1fe0ffff
+e0a10000
+e0a90000
+1fe0fe01
+1f20f3ff
+2022d88a
+78547c00
+e0a10000
+18c08c01
+e8c90000
+18c08dfd
+2020583b
+20345728
+18007fff
+e0a10000
+e0a90000
+2020588a
+18c08c02
+e8c08000
+98c08c00
+20205820
+680144c2
+60014445
+6800c4c6
+1fe27200
+d8c044c7
+20407e45
+2020588a
+680903fa
+20405a88
+203a585c
+18c08dfe
+e8c90000
+58002902
+98467c00
+2422d85c
+18c08c01
+e8c90000
+58000001
+98467c00
+2022d856
+58000000
+98467c00
+2422d85c
+2020585c
+18c08df9
+e8c10000
+1fe0ffff
+600144c2
+700b7d1b
+20405620
+18000405
+20205892
+18000406
+20205892
+18000406
+20205892
+18000406
+20205892
+18000406
+20205892
+79200025
+44b3402c
+18408401
+20405a88
+18c08dfe
+e8c10000
+d8402902
+98467c00
+24628000
+18c08c01
+18c22200
+e8c08000
+20600000
+70041b00
+68014298
+20407f66
+d8a04444
+18a08a01
+680944c2
+e0a90000
+20405a88
+e8c08000
+1fe27200
+20407e45
+6808841b
+18408407
+20405892
+20205ace
+18000406
+20205892
+18000406
+20205892
+18000406
+20205892
+18000406
+20205892
+79200025
+44b3c02c
+58004440
+98a67e00
+1fe60400
+20205892
+18000400
+18000201
+79200025
+44b4402d
+6008c43f
+28200602
+2420d899
+1840fffc
+60014440
+680883d7
+2040561a
+7d3a0404
+79200405
+18417efc
+9821fe00
+600083d7
+1fe17e1f
+6000c43e
+79200025
+44b4c02d
+6800c43e
+28200601
+20608000
+6803c43f
+680083c0
+c4020000
+20407599
+202074f7
+79200025
+44b5402d
+2040561c
+243a3bf1
+247a0000
+68008341
+207a0000
+68008340
+2fe00601
+2020d8cf
+68038341
+68008340
+2fe00602
+2020d8cf
+68008342
+60008418
+1fe22600
+79200025
+44b5c02d
+1a627e00
+c0005924
+c000d92c
+c0015934
+c001d938
+c002593f
+c002d944
+c0035949
+c003d94c
+c004594d
+c004d94f
+c0055950
+c005d951
+c0065952
+c006d955
+20203bf1
+68008341
+1fe17e1f
+207a0000
+6800c132
+c000d8d8
+68010344
+c0025903
+c00358f4
+20600000
+79200025
+44b6402d
+20404972
+680083d6
+68088340
+18410403
+184d0400
+18520400
+9841fe00
+e1410000
+68088341
+1841041f
+e1490000
+18427200
+20404976
+1840f204
+20404424
+20204435
+79200025
+44b6c02d
+d8200002
+e8610000
+e8610000
+203a3bf1
+1fe27200
+d8a04440
+2040497c
+2020588a
+79200025
+44b7402d
+e8c08000
+c000d956
+c001595b
+c001d960
+c0025966
+c002d96f
+c0035970
+c003d972
+c0045973
+c004d974
+c0055975
+c005d976
+20203bf1
+79200025
+44b7c02d
+e8c18000
+600183f9
+c000d977
+c001598e
+c001d990
+c0025991
+c002d997
+c003599a
+c003d9a4
+c00459a5
+c004d9ad
+c00559ae
+c005d9b2
+c00659b5
+c006d9b9
+c00759ba
+c007d9c0
+c00859c1
+c008d9c9
+c00959ca
+c009d9da
+c00b59dc
+c00bd9dd
+c00c59de
+c00cd9df
+c00dd9e0
+c00ed9eb
+c00f59ec
+c02959ed
+c0695a01
+20203bf1
+e8c48000
+6004c434
+e8c10000
+600103e0
+680083c0
+79207e05
+600083c0
+20600000
+e8c28000
+6002c42f
+e8c10000
+600103e0
+680083c0
+79207e06
+600083c0
+20600000
+680083e4
+79207e03
+600083e4
+20600000
+18c08c0a
+e8c40000
+60040380
+e8c20000
+60024473
+700b7d24
+20205620
+e8c40000
+60040388
+e8c20000
+60024477
+202074b6
+680083c0
+79207e04
+600083c0
+700b7d26
+20205620
+20748000
+700b7d26
+20205620
+20600000
+700b7d29
+20205620
+20600000
+20600000
+20600000
+20748000
+700b7d2c
+20205620
+20600000
+6000c4ae
+e8c30000
+e0a30000
+700b7d42
+20205620
+6000c4b5
+e8c30000
+e0a30000
+700b7d43
+20205620
+d8a0448c
+20407e35
+700b7d44
+2034d620
+700b7d43
+20205620
+204074a8
+2022d96a
+700b7d45
+20205620
+204074a5
+700b7d23
+2034d620
+700b7d44
+20205620
+20600000
+d8a00390
+20207e35
+20600000
+20600000
+20600000
+20600000
+20600000
+18c08dfe
+e8c88000
+58000006
+98467c00
+2022d989
+58000004
+98467c00
+2022d98a
+58000008
+98467c00
+2022d98b
+5800000c
+98467c00
+2022d98c
+5800000e
+98467c00
+2022d98d
+20600000
+20600000
+20600000
+20600000
+20600000
+20600000
+700b7d03
+20205620
+20600000
+1fecfe00
+600144bc
+e8c10000
+600144be
+700b7d05
+20205620
+20600000
+20600000
+20600000
+1fecfe00
+600144bc
+e8c10000
+600144be
+e8c10000
+600144c4
+e8c10000
+600144c0
+700b7d07
+20205620
+20600000
+1fecfe00
+600144bc
+e8c10000
+600144be
+e8c10000
+600144c0
+700b7d09
+20205620
+20600000
+68010347
+600103fa
+700b7d0b
+20205620
+20600000
+20600000
+20600000
+e8c10000
+600144c0
+700b7d0d
+20205620
+20600000
+68008341
+1fe0fffb
+1fe37e00
+6000c43d
+700b7d0f
+20205620
+20600000
+1fecfe00
+600144bc
+e8c10000
+600144be
+e8c10000
+600144c0
+700b7d11
+20205620
+20600000
+68008341
+1fe0fff9
+1fe27200
+680903fa
+20405a88
+203a59d8
+e8c08000
+9f267c00
+242159d8
+18c20a00
+d8c00349
+20407e45
+700b7d28
+20407c27
+700b7d13
+20205620
+680083e3
+20600000
+20600000
+20600000
+20600000
+20600000
+e8c28000
+60028ff1
+700ff001
+20407cdb
+20600000
+1a220c00
+e8c40000
+60040ff1
+700ff002
+20407cdb
+20600000
+20600000
+20600000
+68008341
+1fe0fff9
+1fe27200
+680903fa
+20405a88
+203a59fd
+e8c08000
+9f267c00
+242159fd
+18c20a00
+18c22200
+1f222400
+d8c00349
+20407e45
+70048101
+204059fe
+20600000
+68014296
+207a0000
+98007a00
+20600000
+680a03dc
+20403bde
+98461600
+19627e00
+680903ef
+18520400
+18438400
+98467e00
+20600000
+20403bde
+600203dc
+20600000
+79200025
+44b8402e
+6800c3d8
+207a0000
+d8e00001
+20407e53
+247a0000
+7854fc00
+78287c00
+20405572
+2040542c
+204054de
+2436da24
+79200025
+44b8c02e
+68008003
+1fe0fe01
+60008003
+68008340
+1fe17e0f
+c001d519
+c002da41
+20002710
+68008016
+c093da0e
+20405ad8
+d8e00001
+680144d9
+20207e4c
+79200025
+44b9402e
+680083f8
+20405405
+680103c2
+984ffe00
+d8400177
+984ffe00
+d84186a0
+9846fc00
+680083ec
+d8404e20
+984ffe00
+600246f9
+79200025
+44b9c02e
+68014161
+20407efd
+18078400
+9840fe00
+600103ce
+20600000
+79200025
+44ba402e
+68030348
+680b44f9
+98467c00
+24628000
+20405613
+1a227e00
+6000c4e6
+68038355
+60038103
+e8c40000
+e0a40000
+68030342
+600303d0
+79200025
+44bac02e
+18c08c06
+e8c40000
+600403e5
+e8c90000
+184b8400
+e8c10000
+1febfe00
+600103c2
+600203c4
+98467e00
+1fe0d1fe
+e8c48000
+600483ed
+79200025
+44bb402e
+e8c08000
+1ff18400
+18430400
+600883f8
+1fe17e1f
+600083d9
+20405a2b
+20405447
+2040536c
+204032d6
+24628000
+79200025
+44bbc02e
+d8400000
+204048ea
+204039ac
+700b7d14
+20407c27
+202032bd
+79200025
+44bc402f
+680144bc
+98002400
+680144be
+98002600
+d8c04504
+78347c00
+20600000
+e8c10000
+207a0000
+9a467c00
+24610000
+9a667c00
+20628000
+20215a86
+18007c01
+20600000
+18007e00
+20600000
+d8c04504
+e8c10000
+207a0000
+18c08c02
+98467c00
+20628000
+e8c08000
+98c08c00
+20205a89
+7044c602
+58000001
+600144c7
+7003e325
+700b7d12
+20205620
+20600000
+20600000
+79200025
+44bcc02f
+6800c132
+c1820000
+680083e3
+c010da91
+c012da97
+c0135a98
+20600000
+58005aae
+6001428c
+70806281
+580001a0
+60110052
+70804301
+70808104
+58005ac6
+60014296
+20405347
+20758000
+2020691d
+680083c1
+2fe1fe01
+58000005
+2040ea04
+2440e9ff
+204068fd
+203a5abe
+68010419
+98000a00
+1f267c14
+20215aba
+18007214
+e8608000
+e0a08000
+c2005aba
+20406906
+7044c214
+68090419
+e8408000
+207a0000
+2040561c
+247a0000
+700b7d1b
+20205620
+1a420400
+204068f7
+1a220c00
+1a427200
+e8c08000
+e1408000
+c2005aca
+202068fa
+6800c132
+c1830000
+680144c2
+c18a0000
+68090419
+58000000
+e0448000
+e0a48000
+e0a10000
+20600000
+6808c3d7
+79400407
+202069f3
+79200025
+44bd402f
+20405adf
+20205aed
+6800c419
+1fe27200
+d8402a00
+20405b0c
+18c08c01
+18c20a00
+d8c0441a
+20407e45
+6800c419
+1fe67214
+1f220400
+1f227e00
+245a5b15
+20600000
+6800c3d9
+6808c3da
+98467e00
+1fe27200
+1fe22200
+6800c3da
+1fe0fe01
+d8c043da
+98c08c00
+d8a0041d
+20407e45
+79200025
+44bdc02f
+6800c419
+1fe27200
+1fe0fe01
+6000c3da
+d8a043dc
+d8c0441a
+20407e45
+1a227200
+d8c0041d
+20407e45
+6800c3da
+9a20fe00
+6000c3d9
+20600000
+79200025
+44be402f
+d8402a00
+20205b0c
+d8c04504
+e8c10000
+203a3bf1
+e8c10000
+98467c00
+20628000
+e8c08000
+98c08c00
+20205b0d
+58000020
+e0a08000
+c2005b15
+20600000
+79200025
+44bec02f
+7855fc00
+20375b1e
+2436db2a
+20403d76
+68014161
+600103ce
+68008340
+2fe00601
+2420bd8a
+6800c43e
+2fe00601
+2420bd8a
+680083c0
+c282bd8a
+20203d6f
+68094161
+18430400
+680103ce
+9840fe00
+600103ce
+20203d82
+79200025
+44bf402f
+7046f800
+680944c2
+20405866
+1a220a00
+58000000
+e0a08000
+20600000
+6800c132
+c1850000
+20407f6e
+da2003d0
+20407e9d
+5800002c
+e1408000
+204041d4
+202068fa
+d8400014
+20405866
+c4000000
+2040561c
+247a0000
+d8400014
+600944c2
+20405a88
+203a3bf1
+18c08a01
+df200014
+d8c0046d
+20407e45
+700b7d1b
+20205620
+20600000
+79200025
+44bfc02f
+68008341
+d8c00348
+98c0f200
+e8c88000
+e8c08000
+9a267c00
+20628000
+1840ffff
+98c08c00
+1f227e00
+98c67c00
+20215b57
+18007c01
+20600000
+20758000
+58000000
+60008048
+60008055
+60008078
+6000807c
+6000c1f9
+60008453
+60008177
+600087e1
+70474800
+70025800
+70045400
+79200025
+44f0403c
+7007e100
+7007e000
+70044d00
+6800c132
+c1808000
+70425e00
+20600000
+79200025
+44f0c03c
+2054e219
+2454e21d
+6800807c
+245a61d9
+6800807c
+247a0000
+6800804c
+c4030000
+793ffe06
+793f8001
+6000804c
+680084de
+6808804c
+2feffe00
+79208401
+6008804c
+18410402
+6008807f
+6808804c
+1fe37e00
+6000807d
+79200025
+44f1403c
+6800807d
+c03fdbdc
+c001dc56
+c0025c67
+c01e5bcf
+c002dbcb
+c007de48
+c0085ce1
+c011dcff
+c01cde67
+c01c5e62
+c018dce4
+c01bdd72
+c013dd6e
+c019dd68
+c012dd70
+c0135cfb
+c003dcf3
+c016dcea
+c0175ceb
+c000dd64
+c0015d4f
+c0145e53
+c004dd45
+c005dd1a
+c0045d00
+c0065d2c
+c00fdcf7
+c0105cf9
+c010dd8d
+c0115d8e
+c01add8f
+c01b5d90
+c0125d91
+c0165d92
+c015dd95
+c01a5d9f
+c00bdda2
+c008ddb7
+c0095dbb
+c009ddbd
+c006ddcf
+c0075dd0
+c017dd6c
+c0185dd1
+c0055dd2
+c00c5dd3
+c0195dda
+c01edddb
+c01f5dff
+c01fddf9
+c0205e22
+c020de34
+c0035e47
+c01d5bcd
+70007e19
+70007c04
+20600000
+70007c06
+20600000
+70007c3b
+20600000
+680204df
+1fe3fe00
+60024173
+680084e3
+6000c17a
+680284e4
+6002c188
+680284e9
+e0a28000
+68008031
+79207e03
+60008031
+20600000
+680084df
+79207e07
+6000807d
+c040dc26
+c0415c2e
+c04add73
+c04b5d8c
+c045dd81
+c041dc49
+c0425c4b
+c0485bf1
+c04bdc42
+c04c5c47
+c04cdc14
+c04d5c19
+c046dc11
+c0465bf4
+c1420000
+70007c82
+70007e19
+20600000
+70007c82
+70007e2e
+20600000
+680084e0
+600080ad
+680084e1
+6000c1f9
+680084e3
+600080af
+680084e7
+600080b0
+680084ec
+600080ab
+c503dc07
+79200007
+20405d16
+60008452
+18000400
+20204839
+70007c8c
+7000b101
+202049bc
+680080b0
+c083dc0b
+70007c81
+20205c0f
+793f8007
+70007c82
+18000401
+20404914
+70007d8c
+20600000
+70007c81
+70007d8d
+20203869
+20405c1d
+6800c132
+c000dc21
+70007c9a
+20600000
+20405c1d
+6800c132
+c000dc21
+20205c22
+d8a007e9
+680184e0
+e0a18000
+20600000
+2040480f
+20406216
+2440c81b
+2020f80f
+20600000
+680084e1
+79207e07
+60008445
+c045dc36
+c046384a
+c046dc2d
+20600000
+20203869
+680084e1
+79207e07
+60008445
+c045dc3a
+c0465c34
+20600000
+793f8007
+20600000
+6800c1fb
+6808804c
+7d3a0405
+6008804c
+68008030
+c4028000
+793ffe05
+60008030
+68008453
+243a4872
+70007c31
+20600000
+2434dc45
+70007c12
+20206205
+70007c97
+20600000
+20406205
+20205ecd
+70007c84
+20600000
+680884e2
+18410401
+6008844c
+6800c272
+c0a8dc52
+70427200
+204047f9
+68008055
+c18a8000
+70005504
+20206235
+680084df
+60008445
+c019dc7d
+c0045c90
+c007dc97
+c0085c9d
+c008dc9e
+c0095ca6
+c00c5ccc
+c00bdcd1
+c015b84a
+c009dc74
+c01edde9
+c01f5e18
+c0205deb
+c020ddef
+20600000
+680084df
+60008445
+c000dcc3
+c019dc87
+c005dca7
+c015dc8e
+c0045cba
+c009dc77
+c0205cc4
+c020dcc7
+c00c5cca
+c00bdcdf
+20600000
+700b7d20
+20407c27
+20203245
+700b7d19
+20407c27
+70474802
+58000050
+d8e0000a
+20207e4c
+6800844d
+79207e00
+6000844d
+700b7d01
+20407c27
+70007c8b
+68008055
+c082db77
+70005506
+20600000
+7004460b
+70007c07
+18000410
+20404826
+70005500
+2020db77
+20600000
+70007c2b
+20600000
+6800c25e
+247a0000
+20403507
+20405ecb
+20748000
+79200021
+20600000
+24748000
+70007c10
+6800804c
+c4010000
+70007c12
+20600000
+20205ecd
+20405f2d
+68008030
+c3820000
+70007c31
+68008055
+c1850000
+7000550b
+20600000
+20600000
+6800c132
+c080dcb7
+6800c25e
+207a0000
+68088055
+70005500
+70425e00
+680084e0
+c1830000
+60088055
+7007e001
+6801044a
+6808844c
+98417e00
+203a49da
+202049d7
+70007c07
+70044613
+20600000
+680084e0
+c0035cc0
+c18c0000
+70044618
+70007c07
+20600000
+70044606
+70007c07
+20600000
+20600000
+7007da00
+70007c07
+20205b77
+7007da00
+70007c07
+20205b77
+700b7d24
+20207c27
+700b7d23
+20407c27
+20403806
+18000400
+20204907
+700b7d22
+20407c27
+18000402
+20404907
+58000000
+60010075
+68014280
+1fe3fe00
+60010032
+6800c282
+60008073
+6800c284
+60008074
+202037e1
+700b7d21
+20207c27
+680884df
+60088054
+20205cf5
+6800844d
+79207e02
+6000844d
+c3818000
+70007c31
+20205b77
+20600000
+6800c171
+680884df
+98467c00
+20215cf5
+70007c04
+70007e1f
+70007d2e
+20600000
+2040605a
+20205cf5
+70007c03
+20600000
+70007c21
+20600000
+70007c22
+20600000
+68008055
+c1098000
+70005502
+20600000
+20600000
+20405ec8
+70045001
+6800c132
+c000dd06
+700b7d0a
+20407c27
+2040487b
+2040620d
+2420ded0
+2434dd0e
+70007c04
+70007d08
+70007e23
+20600000
+6800804b
+79207e02
+6000804b
+20600000
+6808804c
+7d3a0401
+6008804c
+20600000
+6800807f
+1fe37e00
+1fe17e01
+20600000
+20405d16
+60008451
+20405ec8
+70007c0c
+6800c25e
+247a0000
+68008030
+c3830000
+70007e06
+6800c132
+c080dbc9
+68008453
+243a5bc9
+70007c00
+6800804b
+79207e00
+6000804b
+20204872
+da200040
+2040739d
+680204df
+680a051f
+98467c00
+2022dd35
+70007c07
+70044605
+20600000
+2040749b
+20403211
+6800804b
+2feffe01
+793ffe01
+6000804b
+2040c8bc
+68008055
+c00cdd40
+c00c5d40
+20600000
+680087e1
+c1800000
+6800804c
+c3810000
+202062cf
+da2004df
+da40050f
+d8a004ef
+20407467
+da200040
+2040622b
+70007c0b
+68008030
+c3035ecb
+20600000
+68010169
+1fe0f3fd
+680884df
+58000103
+98408a00
+d8c004e1
+20407e45
+68088053
+680084e0
+98467e00
+1fe67c0e
+20215d5f
+1840fe0e
+60008053
+70007c01
+20600000
+6800804c
+79207e03
+6000804c
+c2825ed5
+20600000
+680084df
+6000807d
+70007c02
+20600000
+6800c132
+c080dcf5
+18000401
+20204839
+70007c30
+20600000
+70007c28
+20600000
+70007c26
+20600000
+20600000
+68010032
+98000400
+680084e0
+60008097
+984f8400
+680104e1
+1fe3fe00
+60010098
+680204e3
+1fe3fe00
+60020093
+18427e00
+6001009a
+20600000
+6808c1fb
+680084e0
+9842fc00
+2422dbee
+2feffe00
+6800804c
+7920fe05
+6000804c
+70007c81
+70007d8b
+20600000
+20600000
+20600000
+20600000
+20205cf5
+20205cf5
+20600000
+2040385e
+70007d2c
+20205cf5
+680084df
+600080ad
+680084e1
+600080af
+680084e4
+600080ab
+20405d16
+60008452
+18000400
+20204839
+680104df
+6001017b
+20600000
+68008030
+c280ddb5
+680104e0
+1fe3fe00
+60010075
+680104e2
+1fe3fe00
+60010032
+680104e4
+60008073
+98000400
+680104e6
+60008074
+98467c00
+24215db2
+60008073
+70007c03
+70007d17
+20600000
+70007e24
+20205bc9
+20405cf5
+20405ec8
+204073a0
+202037d0
+20405cf5
+202037da
+680204df
+1fe3fe00
+2034ddc9
+6808c25e
+243a5dc6
+70007c04
+70007d13
+70007e24
+20600000
+70007c34
+70005500
+20203241
+20403241
+79200022
+68008177
+793ffe02
+60008177
+20205cf5
+20600000
+20600000
+20600000
+20600000
+70007c03
+70007d18
+700b7d2e
+20407c27
+18000400
+20404907
+20203806
+20600000
+680084df
+c080dde7
+680084e0
+c080dde7
+680084e1
+c0985de7
+20406216
+2020dde4
+7007da01
+70007c03
+70007d3d
+20205b77
+70007e24
+20205bc9
+70007c3e
+20600000
+20406216
+20608000
+7007da08
+20600000
+20406216
+2440fa9d
+2040faab
+20404860
+20404869
+20406216
+20608000
+7007da0c
+7007dc01
+20600000
+d8a00888
+680404df
+e0a40000
+680404e7
+e0a40000
+2020780f
+680087db
+c003de03
+680087da
+c080de16
+680087e3
+1fe60a20
+24215e16
+d8a007f0
+98a08a00
+680404df
+e0a40000
+680404e7
+e0a40000
+680087e3
+1fe0fe10
+600087e3
+c0985cf5
+20406216
+2020dcf5
+7007e401
+7007da02
+7007dc01
+20205cf5
+70007e24
+20205bc9
+680087e2
+c0185e1c
+70007c3e
+20205b77
+20406216
+2020de21
+7007dc01
+7007da04
+20205b77
+20205b77
+680087db
+c003de26
+680087da
+c0835e32
+d8a00848
+680404df
+e0a40000
+680404e7
+e0a40000
+20406216
+2020de30
+7007da07
+7007dc01
+20205cf5
+7007db04
+2020780f
+70007e24
+20205bc9
+680087db
+c005de38
+680087da
+c0845e45
+d8a00878
+680404df
+e0a40000
+680404e7
+e0a40000
+20406216
+2020de42
+7007da09
+7007dc01
+20205b77
+7007db09
+7007dd01
+20205b77
+70007e24
+20205bc9
+20205b77
+68008177
+793ffe01
+60008177
+20405cf5
+24748000
+680084df
+6808804b
+793a0404
+7d3a0405
+6008804b
+20600000
+680c04df
+6800c272
+c0a85e58
+70427200
+204047e5
+68008055
+c1818000
+6800c132
+c000de5e
+68008177
+c3025e60
+70005514
+20600000
+70005504
+20600000
+68008189
+6000815d
+70007c03
+70007d38
+20600000
+70007c03
+70007d39
+18007209
+d8c004df
+d8a00154
+e8c08000
+1fe2fe55
+e0a08000
+c2005e6c
+68008154
+68088153
+793f8407
+793f8404
+c07fde80
+c0005e99
+c002de8d
+c003de8c
+c0035e8d
+c0045e8c
+c000de85
+c0015e85
+c001de85
+c004de85
+c0025e85
+20600000
+68008153
+79207e03
+79207e02
+60008153
+20600000
+79200404
+70018a05
+6801015b
+98007200
+60010169
+d8a004de
+20407ed8
+79200407
+79200402
+18007e00
+6000800b
+600100fc
+600100fe
+600100fa
+600100f8
+68008155
+2fe1fe00
+79208406
+60088153
+20600000
+793f8011
+70015300
+68008189
+793ffe06
+60008189
+20600000
+68008153
+c4010000
+6800815e
+1fe0fe01
+6000815e
+c1828000
+70015e00
+68008153
+793ffe02
+60008153
+c281dec0
+2feffe07
+2040ff86
+2440ff8a
+6800815a
+2fe06020
+6800804c
+7920fe05
+6000804c
+68008153
+68088189
+2feffe04
+79208406
+2feffe06
+79208404
+79208405
+60088189
+68008156
+60008447
+68008157
+60008448
+79200011
+20600000
+793f8011
+70015300
+6800815d
+60008189
+68108043
+1fe17efb
+60108043
+20600000
+d8c004df
+d8a004ef
+20207e35
+70007c09
+20600000
+24748000
+70007c11
+20600000
+da204140
+2040736a
+70007c03
+70007d08
+20600000
+7000720a
+70007c07
+70044616
+20600000
+79200025
+44f1c03c
+78547c00
+204061d9
+68008048
+207a0000
+c283df10
+c000e072
+c0015f9b
+c001df1d
+c0025f36
+c013e0f2
+c0145fbf
+c0185fab
+c012e0ed
+c0135fba
+c018e0dc
+c01be06d
+c019e05f
+c0046174
+c004e16a
+c005e17f
+c0066188
+c007e065
+c00861af
+c008e1a5
+c003e055
+c0156081
+c0056082
+c015e0b5
+c0035fb0
+c010e062
+c016e0d2
+c01760d7
+c0116062
+c01660cb
+c01a6083
+c009e098
+c00be0a7
+c00961ac
+c017e0ad
+c00c60b2
+c01ee119
+c01f6125
+c01fe137
+c0206142
+c020e157
+c011e166
+c01de161
+c002e167
+c014e168
+c01c6169
+c01ce078
+20203bf1
+20600000
+c0465fc4
+c046dfe3
+c040df43
+c0425f76
+c0415f50
+c041dfec
+c045dff7
+c04be051
+c04cdf8c
+c04d5f81
+c04adf91
+c04b5f92
+20203bf1
+18007e02
+204061b5
+68008049
+e0a08000
+c015df5a
+204061c4
+68008049
+c0045f5d
+c007df61
+c0085f6c
+c00bdf33
+c019df6f
+c0165f74
+c020df75
+c008df2d
+20600000
+68008055
+207a0000
+7000551b
+5800000c
+d8e0000b
+20207e4c
+18000402
+20404907
+202037e1
+18007e03
+204061b5
+68008049
+c005df3e
+e0a08000
+6800804a
+e0a08000
+202061c4
+e0a08000
+6800804a
+e0a08000
+d8400451
+202061fb
+18000e04
+204061bd
+5800007f
+e0a08000
+68008049
+793ffe07
+e0a08000
+68008049
+c0465f5a
+204061c4
+68008049
+c046df74
+20600000
+18000e05
+204061bd
+5800007f
+e0a08000
+68008049
+793ffe07
+e0a08000
+6800804a
+e0a08000
+202061c4
+2040384a
+d8400452
+202061fb
+20403507
+2040620d
+20608000
+20205ecb
+6800804b
+c282df68
+c4020000
+70007c12
+793ffe04
+20406205
+20205f6a
+70007c10
+793ffe05
+6000804b
+20600000
+20406216
+2020decd
+20600000
+6800844d
+79207e00
+6000844d
+700b7d01
+20207c27
+20600000
+20600000
+18000e0c
+204061bd
+58000001
+e0a08000
+6801044a
+e0a10000
+58000000
+e0a18000
+58000000
+e0a20000
+202061cd
+18000e05
+204061bd
+6800c132
+c000df89
+58040003
+e0a18000
+600187e6
+202061cd
+680187e6
+e0a18000
+202061cd
+18000e05
+204061bd
+680187e6
+e0a18000
+202061cf
+20600000
+18000e09
+204061bd
+68008097
+e0a08000
+68010098
+e0a10000
+68020093
+e0a20000
+202061cd
+18007e11
+204061b5
+68008049
+1fe20400
+c0005fa3
+c0075fa3
+c00e5fa3
+20600000
+e0a08000
+6800c702
+e0a08000
+1fe27200
+58004703
+98408c00
+20407e45
+202061cd
+18007e03
+204061b5
+58000114
+e0a10000
+202061cd
+18007e03
+204061b5
+6802016f
+9c467e00
+2034dfb6
+1fe67e00
+1feb7e00
+793ffe0f
+e0a10000
+202061cd
+18007e06
+204061b5
+6802c6fd
+e0a28000
+202061cd
+18007e09
+204061b5
+68044138
+e0a40000
+202061cd
+2034dfc6
+20205fc7
+7041f907
+7000af00
+18000e10
+204061bd
+680080ad
+e0a08000
+6800c1f9
+e0a08000
+58000000
+e0a08000
+680080af
+e0a08000
+58000006
+e0a08000
+58000002
+e0a08000
+58000007
+e0a08000
+e0a08000
+5800001e
+e0a10000
+e0a10000
+680080ab
+e0a08000
+680080b1
+e0a08000
+243a61cd
+2034e1cd
+202061cf
+18000e04
+204061bd
+680080ad
+e0a08000
+68008446
+e0a08000
+680080b4
+60008047
+202061cf
+18000e0c
+204061bd
+58000001
+e0a08000
+6801044a
+e0a10000
+58000000
+e0a18000
+58000000
+e0a20000
+202061cf
+18000e03
+204061bd
+6800c1fb
+e0a08000
+78547c00
+204061cf
+24740000
+24748000
+6800c179
+c4000000
+2040600f
+20206019
+6800c13e
+79207e03
+6000c13e
+58000101
+6001044a
+20600000
+6800c13e
+793ffe03
+6000c13e
+58000000
+6001044a
+20600000
+70417903
+58000000
+600241e3
+d8a0417b
+20406023
+d8a04188
+20406023
+d8a041e7
+20406023
+2020602a
+d8a04188
+20406023
+2040602a
+2020602d
+6802c1e7
+6002c188
+e8c28000
+e0a28000
+2040602a
+2020602d
+58ffffff
+e0a18000
+e0a18000
+e0a18000
+5800007f
+e0a08000
+20600000
+58000000
+60014177
+20600000
+6800c179
+79207e02
+6000c179
+20600000
+24748000
+18007e10
+204061b5
+1c427e00
+d84001dc
+9840fe00
+1fe37e00
+1fe0fe01
+793ffe00
+e0a20000
+1fe20400
+58000001
+e0a08000
+6802c188
+e0a28000
+e8c28000
+e0a28000
+18438400
+600a4173
+204061cf
+68008031
+79207e03
+60008031
+70417a01
+68024173
+d842ee00
+9840fe00
+600241e3
+6800c179
+c3820000
+70007c90
+20600000
+18000e02
+204061bd
+2434e1cd
+202061cf
+18007e02
+204061b5
+68008446
+e0a08000
+204061cf
+6800804b
+79207e03
+6000804b
+70007232
+20600000
+18007e01
+204061b5
+202061cf
+18007e01
+204061b5
+202061cd
+18007e02
+204061b5
+6800804c
+2fec0002
+7920fe00
+1fe17e01
+e0a08000
+202061cf
+18007e03
+204061b5
+68010051
+e0a10000
+202061cf
+700072fa
+18007e02
+204061b5
+68008053
+e0a08000
+202061cf
+18007e0a
+204061b5
+d8c00154
+18007209
+e8c08000
+1fe2fe55
+e0a08000
+c200607c
+202061cf
+202061cf
+202061cf
+20748000
+20403997
+18007e09
+204061b5
+6801017b
+e0a10000
+6801c140
+e0a18000
+6800c143
+e0a08000
+68014144
+e0a10000
+c581e094
+793f8003
+204061cf
+70007c13
+20600000
+204061cd
+70007c03
+70007d13
+20600000
+d8400200
+2034e09c
+1d027e00
+2020609d
+1c427e00
+1c227e00
+9840fe00
+1fe17ffc
+60020034
+18007e05
+204061b5
+68020034
+1fe37e00
+e0a20000
+202061cf
+18007e0a
+204061b5
+d8c00455
+e8c48000
+e0a48000
+202061cf
+18007e03
+204061b5
+58000114
+e0a10000
+202061cf
+18007e01
+204061b5
+202061cf
+2034e0ba
+7000ad00
+68008031
+79207e04
+60008031
+7000af00
+18007e07
+204061b5
+680080ad
+e0a08000
+58000000
+e0a08000
+680080af
+e0a08000
+58000006
+e0a08000
+58000002
+e0a08000
+680080ab
+e0a08000
+2034e1cd
+202061ca
+18007e03
+204061b5
+680080ad
+e0a08000
+18007e13
+e0a08000
+202061cf
+18007e02
+204061b5
+6800c171
+e0a08000
+202061cf
+18007e02
+204061b5
+58000005
+e0a08000
+202061cf
+68008030
+79207e04
+60008030
+1c427e00
+60020465
+6800844d
+c281e0eb
+79207e03
+6000844d
+700b7d05
+20407c27
+20404825
+18007e01
+204061b5
+202061cf
+70004800
+20600000
+18007e06
+204061b5
+6802c6fd
+e0a28000
+202061cf
+18007e09
+204061b5
+68044138
+e0a40000
+202061cf
+2040481b
+6800c132
+c000e0fd
+7007dd01
+6800c793
+c1808000
+7007db13
+20600000
+20406209
+70007c99
+7007db03
+20600000
+20406209
+70007c3d
+7007db07
+20600000
+da200868
+da400888
+df200010
+20407f25
+2022e111
+7007db00
+20407811
+70007e24
+70007d40
+20205bc9
+7007db0a
+2040780f
+70007d40
+20205cf5
+70007c40
+20600000
+70007c3d
+20600000
+7007e200
+18007e04
+204061b5
+18007e01
+e0a08000
+18007e01
+e0a08000
+18007e30
+e0a08000
+20406216
+2020e1cf
+202061cd
+18007e11
+204061b5
+680087e2
+d8c047ac
+98c08c00
+e8c40000
+e0a40000
+e8c40000
+e0a40000
+680087e2
+1fe0fe10
+600087e2
+20406216
+2020e1cf
+202061cd
+7007da06
+70007c3f
+20600000
+18007e11
+204061b5
+d8c00868
+e8c40000
+e0a40000
+e8c40000
+e0a40000
+202061cd
+204061d9
+70007c40
+20600000
+20406216
+2040f74d
+18007e11
+204061b5
+d8c00838
+e8c40000
+e0a40000
+e8c40000
+e0a40000
+20406216
+2420e1cd
+2020e1cf
+7007db0f
+20406209
+70007c0b
+20406221
+2020f785
+2020778f
+20406205
+70007c41
+20600000
+18007e11
+204061b5
+d8c00868
+e8c40000
+e0a40000
+e8c40000
+e0a40000
+20406216
+2420e1cd
+2020e1cf
+18007e03
+204061b5
+5800fffe
+e0a10000
+202061cd
+202061cf
+202061cf
+202061cf
+202061cf
+20406225
+da204140
+2040622b
+18007e11
+204061b5
+da20050f
+da4004ef
+20407467
+2434e1c4
+202061ca
+20406225
+da200040
+2040736a
+18007e11
+204061b5
+d8c004ef
+20407e35
+68008055
+c00ce1cf
+c00c61cf
+202061ca
+680087e1
+203a6185
+20406216
+2040e209
+2440e205
+20206186
+20406209
+20406225
+20206177
+da204140
+2040739d
+18007e05
+204061b5
+6802051f
+e0a20000
+d8400451
+204061fb
+2040749b
+20406216
+2020e197
+70045401
+680087e1
+207a0000
+70007c0b
+6800c25e
+207a0000
+20406216
+2040c852
+20406216
+2420e1a1
+68008453
+207a0000
+70007c0f
+20600000
+c6908000
+793f8021
+70007c0f
+20600000
+20406225
+204073a0
+18007e11
+204061b5
+d8c004ef
+20407e35
+202061ca
+18007e01
+204061b5
+202061ca
+18007e02
+204061b5
+18007e10
+e0a08000
+60008054
+202061ca
+1fe9fe00
+1fe1fe07
+60008432
+df200011
+d8a00434
+20407e3f
+d8a00434
+20600000
+1fe1227f
+7000487f
+18e27e00
+204061b5
+1a227e00
+e0a08000
+20600000
+68008048
+1fe3fe00
+6808804c
+284ffe01
+7920fe00
+202061d4
+6808804c
+18410401
+202061d0
+18000400
+202061d0
+18000401
+68008048
+1fe3fe00
+7934fe00
+9842fe00
+60008433
+70004800
+204061e0
+78347c00
+20600000
+79200025
+44f2403c
+68008048
+203a61e0
+68008078
+247a0000
+202061ea
+68008078
+203a61f0
+68018078
+60018048
+6808807b
+6800804c
+793ffe01
+9841fe00
+6000804c
+70007800
+6800807c
+207a0000
+6802007c
+60020078
+70007c00
+20600000
+6800807c
+207a0000
+6801807c
+60018048
+6808807f
+6800804c
+793ffe01
+9841fe00
+6000804c
+70007c00
+20600000
+79200025
+44f2c03c
+6800804c
+1fe22600
+e8408000
+20405d12
+204061c4
+1a627e00
+6000804c
+20600000
+6808804c
+793f8400
+6008804c
+20600000
+6808804c
+79200400
+6008804c
+20600000
+7d34fe01
+6808804c
+9842fe00
+2feffe01
+20600000
+6800804c
+7934fe01
+6000804c
+20600000
+680087e0
+2fe0fe01
+20600000
+680087e0
+79207e07
+600087e0
+20600000
+680087e0
+793ffe07
+600087e0
+20600000
+680087e0
+2feffe07
+600087e0
+20600000
+d8a004ef
+18007210
+180a7e00
+e0a08000
+c2006227
+20600000
+2040736e
+da204262
+da40051f
+ea240000
+68088030
+7d3a0406
+60088030
+1a220a00
+20407467
+20203229
+79200025
+44f3403c
+6800807c
+203a623c
+204061d9
+6800807c
+247a0000
+68008055
+207a0000
+c002628d
+c002e292
+c0016284
+c001e29a
+c0076287
+c00362b6
+c003e2ce
+c004e2cf
+c00562d8
+c005e2dc
+c00662a4
+c006e2a7
+c007e2ad
+c0096277
+c009e29a
+c008627a
+c00a6274
+c00ae29a
+c00b626e
+c00c6273
+c00be267
+c00ce26d
+c00d6258
+c00de262
+70005500
+20600000
+6800844d
+c4010000
+c4018000
+70005500
+2040625e
+20206e41
+68008177
+c4008000
+7000550a
+20600000
+d8e0000b
+20407e53
+247a0000
+7000551a
+20600000
+68008177
+793ffe00
+60008177
+70005519
+70007c0b
+20600000
+20600000
+68008450
+c1810000
+204062de
+70005518
+20600000
+20600000
+70005515
+70007c83
+20600000
+70005513
+70007c25
+20600000
+6800c748
+c1000000
+c000e282
+d8e0000a
+20407e53
+247a0000
+70474800
+2020629b
+20748000
+202062b6
+70005503
+70007c27
+20600000
+70007c13
+79200003
+70005505
+580001ff
+6001044e
+20600000
+70005505
+70044eff
+793f8022
+70007c33
+20205b6f
+c6110000
+6801044e
+1fe67e01
+2022e298
+6001044e
+20600000
+7000550e
+20600000
+20600000
+6800844d
+c4018000
+c4010000
+68008177
+793ffe02
+60008177
+70007c13
+70005510
+20600000
+7000550d
+70007c31
+20600000
+6800844d
+c4010000
+70005500
+20600000
+70005506
+20600000
+6800844e
+1fe0ffff
+203a62b2
+6000844e
+20600000
+70007c07
+70044616
+70005500
+20600000
+68008177
+c281629b
+c28062bb
+7000551a
+20600000
+6800c25e
+203a62c7
+6800844d
+c4018000
+c4010000
+68020465
+d8400064
+98408400
+1c427e00
+98467c00
+24610000
+20206267
+70005516
+70054f04
+58003030
+60010550
+e0a10000
+70045002
+2020626e
+20600000
+68008177
+c280e2d3
+7000551a
+20600000
+68008177
+793ffe01
+60008177
+70007c0f
+20600000
+68008454
+207a0000
+70005500
+202062d3
+7000550c
+20600000
+6800804b
+c28162e3
+20406209
+70007c08
+202049bc
+6800804b
+793ffe02
+6000804b
+20405ed0
+20406212
+202049bc
+58000004
+6000854f
+58003030
+e0a10000
+e0a10000
+20600000
+20758000
+70481300
+20406321
+20406438
+5800632e
+60014290
+5800632f
+6001428e
+58006337
+60014292
+580063b6
+60014296
+5800632f
+6001428c
+79200025
+44c04030
+5800632a
+60014286
+580063be
+60014298
+58000000
+6002480a
+60014810
+2040630a
+20403fc5
+20403e2b
+2020691d
+20758000
+580001a0
+600142ac
+20406a0d
+58004a00
+60110054
+58004fff
+60110056
+58001c00
+6011005a
+58001fff
+6011005c
+70808104
+70029fff
+70806200
+58001c00
+6011005e
+60110060
+58004a00
+60110058
+20204480
+2040630d
+20206321
+20407bd9
+20403f94
+6808c803
+204069da
+2040639e
+6808c801
+204069d1
+6808c800
+202069d2
+6808c801
+204069e5
+2420bf5c
+20203f5a
+20206330
+20206330
+79200025
+44c0c030
+2040641c
+20406421
+2040527a
+247a0000
+202063a0
+1a627e00
+c0056368
+c0026383
+c009e387
+c001634c
+c00ce36a
+c010636f
+c0116374
+c010e375
+c011e376
+c0126379
+c00a637a
+c000e382
+c00ae364
+c002e35d
+c005e352
+c0063fa6
+1fe1040f
+1fe17ef0
+c02863ec
+20600000
+2040638a
+680142a0
+c4020000
+df200003
+d8c04849
+20207f71
+68014042
+1fe37e00
+68094280
+98467c00
+2422e358
+20203fa4
+6800c813
+c3800000
+68110112
+245a640c
+20203f9c
+20406395
+2040642e
+2022e361
+20203f77
+df200004
+d8c0488e
+20207f71
+2040638a
+df200005
+d8c04847
+20207f71
+20403fc1
+20203f6a
+6800c813
+c4020000
+793ffe04
+6000c813
+2020427f
+6800c813
+c4020000
+793ffe04
+6000c813
+20204286
+20600000
+20600000
+6800c813
+c3003f9e
+20206410
+20600000
+20406395
+da4003d0
+2040642e
+2022e37f
+20203f90
+df200006
+d8c0488c
+20207f71
+20600000
+df200007
+d8c04899
+20407f71
+2020638a
+df200007
+d8c04892
+20407f71
+2040638c
+20206393
+6800c812
+2feffe00
+2040bf7c
+6800c812
+2feffe01
+2040bf88
+20600000
+6808c803
+202069ef
+20406397
+2020639e
+6800c812
+2feffe00
+2040bf7e
+6800c812
+2feffe01
+2040bf86
+20600000
+6808c803
+202069ed
+6800c132
+c1850000
+68110112
+207a0000
+6001480e
+204063a9
+2020bfef
+20406400
+202063af
+6808c800
+202069e5
+6800c813
+c3800000
+2040640c
+20203f9c
+6800c040
+c300428c
+6800c041
+c28063d5
+20403f40
+2020e3ab
+20206d97
+20405a88
+e8c08000
+18c22200
+20407f6e
+1a427200
+1a220c00
+20404976
+202068fa
+68014810
+207a0000
+d8400014
+20407fb9
+60010469
+1fe20400
+68014810
+98467e00
+60014810
+24213bf1
+d8400014
+600944c2
+20405a88
+203a3bf1
+18c08a01
+68010469
+1fe27200
+20407f6b
+2040497c
+68010469
+6001480e
+6001041b
+2020428c
+c6848000
+204063d8
+204063d8
+2040561e
+247a0000
+68110112
+207a0000
+68094810
+98467e00
+24213bf1
+6001480e
+207a0000
+20406407
+68014810
+6809480e
+9840fe00
+60014810
+68094810
+68110112
+98462200
+24213bf1
+700b7d1b
+20205620
+60088259
+68008259
+207a0000
+1fe0ffff
+60008259
+204063f3
+202063ed
+6801481a
+207a0000
+1fe0ffff
+6001481a
+247a0000
+6800c2a4
+7042a400
+c280e3fd
+c28063fe
+20203bf1
+20203f8c
+70427202
+20600000
+6800c041
+c2806407
+6801480e
+d840006e
+20407fb9
+6001480e
+20600000
+6801480e
+d8400014
+20407fb9
+6001480e
+20600000
+6800c813
+79207e00
+6000c813
+20600000
+6800c813
+793ffe00
+6000c813
+20600000
+6800c813
+79207e07
+6000c813
+20600000
+6800c813
+793ffe07
+6000c813
+20600000
+79200025
+44c14030
+20407f8e
+20213f66
+20203f68
+204063a9
+2020e428
+68190052
+680142ac
+98467c00
+20628000
+20206909
+68190052
+580001a0
+98467c00
+20628000
+60110052
+20600000
+79200025
+44c1c030
+6800c812
+2fec0002
+2020e436
+da204814
+df200006
+20207f25
+18007c00
+20600000
+79200025
+44c24030
+d8a0481c
+38035350
+38055115
+38092415
+380d0951
+e0a48000
+3802454c
+38075053
+38082454
+380d1531
+e0a48000
+38034441
+380594d4
+38092455
+380d0d4d
+e0a48000
+3803414c
+3804d4d4
+380924c4
+380d3119
+e0a48000
+38015247
+3807d0d1
+3808e4e4
+380d1531
+e0a48000
+38034944
+380514d4
+3808e535
+380d5105
+e0a48000
+38014c2b
+380514d2
+3808f525
+380d1531
+e0a48000
+38014e53
+38059192
+380844c4
+380d5915
+e0a48000
+38035352
+3804d254
+38085444
+380d0959
+e0a48000
+3801454c
+38045392
+38083525
+380d3d35
+e0a48000
+38014544
+380513d3
+38084454
+380d4d35
+e0a48000
+38004154
+38051155
+38093494
+380d3d0d
+e0a48000
+38004f56
+38071055
+38083454
+380d393d
+e0a48000
+3801504e
+380551d0
+380954f4
+380d4951
+e0a48000
+38024345
+38065051
+380804c4
+e0a30000
+20600000
+580065d7
+6001428c
+5800652e
+6001428e
+580064e3
+6001428a
+580065f3
+60014292
+580064a9
+60014290
+58006561
+60014298
+7007dc00
+7007dd00
+793f8025
+44e04018
+204064c4
+20758000
+2040649f
+204064a7
+580064e0
+60014288
+680147f4
+c2866697
+20206693
+20403f4d
+2022e4a4
+20406963
+204066ba
+20203f45
+2040691d
+20406967
+202066c0
+70481c01
+202064bb
+20407cd7
+204064ac
+202064f6
+6808c825
+204069e5
+2420e4b3
+6800c81c
+c1000000
+70481c00
+20600000
+6800c81c
+c1008000
+70481c01
+6800c81b
+1fe0fe01
+1fe17e03
+6000c81b
+202064bb
+58000006
+204066d8
+1fe104fc
+6800c81b
+9840fe00
+1fed7e00
+1fe0fe06
+204066d7
+202066ba
+204065c5
+204064ca
+68110050
+793ffe0b
+60110050
+20600000
+20403e0b
+6808c827
+204069d1
+6808c828
+204069d1
+6808c822
+204069d1
+6808c823
+204069d1
+6808c824
+204069d1
+6808c826
+204069d1
+6808c825
+204069d1
+6810807b
+1fe1fe18
+6010807b
+6810807f
+1fe17ee7
+6010807f
+20600000
+5800bc05
+204066d7
+7000a201
+204064f6
+d8400019
+204069da
+70808100
+6808c827
+204069b4
+6808c828
+204069b4
+6808c822
+204069b4
+6808c823
+204069b4
+6808c824
+204069b4
+6808c826
+204069b9
+680080a2
+247a0000
+202069c4
+793f8025
+44e0c018
+da200000
+6808c827
+204069e5
+7920a200
+6808c828
+204069e5
+7920a201
+1a227e00
+1fe17e03
+6808c808
+6000c808
+98467c00
+2022e514
+6800c807
+6000c806
+6008c807
+6800c808
+1ff27e00
+6808c807
+184b8400
+9840fe00
+6808c806
+9840fe00
+c01c6515
+c01a6519
+c005e519
+c003e515
+20600000
+20600000
+6800c809
+1fe0fe01
+6000c809
+20600000
+6800c809
+1fe0ffff
+6000c809
+20600000
+20600000
+5800b805
+202066d7
+20600000
+20403fa0
+70482002
+20403fa4
+20203f92
+6801481e
+207a0000
+1fe0ffff
+6001481e
+247a0000
+20203f9a
+58000002
+6000c7f2
+20600000
+6800c27f
+207a0000
+2040527c
+247a0000
+20406578
+24740000
+2040655e
+2040655a
+da200008
+20404b2c
+680142b7
+e0a10000
+580002a1
+e0a10000
+6800c805
+e0a08000
+68014800
+d8400fff
+98417e00
+68094802
+18520400
+184d0400
+9841fe00
+e0a18000
+6800c804
+e0a08000
+58000000
+e0a08000
+7008a808
+20600000
+793f8025
+44e14018
+6800c81a
+207a0000
+1fe0ffff
+6000c81a
+247a0000
+2040527e
+247a0000
+58000000
+6002c800
+20406536
+70481a50
+20600000
+68014810
+60014818
+70481a50
+20600000
+6801480e
+60014816
+20600000
+680944c2
+20405a88
+e8c08000
+6000841b
+20600000
+793f8025
+44e1c018
+680944c2
+20405a88
+18c08a01
+6800c805
+e0a08000
+68014800
+d8400fff
+98417e00
+68094802
+18520400
+184d0400
+9841fe00
+e0a18000
+6800c804
+e0a08000
+20600000
+793f8025
+44e24018
+78547c00
+58000000
+6002c800
+20406581
+204065b4
+2040659c
+202065a2
+6800c821
+c1810000
+6800c80a
+205a65ba
+70480a01
+78547c00
+6808c826
+204069e5
+24608000
+58000000
+204066d8
+c09866c6
+58000002
+204066d8
+c4038000
+58000003
+204066d8
+204065d3
+60014800
+58000004
+204066d8
+204065d3
+1fe67e00
+60014802
+68024800
+78347c00
+20600000
+6800c809
+207a0000
+6000c804
+70480900
+78347c00
+20600000
+da200000
+6808c822
+204069e5
+7920a200
+6808c823
+204069e5
+7920a201
+6808c824
+204069e5
+7920a202
+1a227e00
+6808c805
+6000c805
+9842fe00
+1fe67c00
+20628000
+78347c00
+20600000
+d840001a
+204069e5
+20608000
+58000000
+204066d8
+202065b4
+df200000
+58000002
+204066d8
+20000064
+1f20f201
+6808c826
+204069e5
+2020e5bb
+1f227e00
+6001046b
+20600000
+2040678e
+20758000
+58000000
+204066d8
+60008256
+c01865ce
+204066c6
+20002710
+202065c7
+58008006
+204066d7
+200003e8
+70482102
+20600000
+c4038000
+d840ff00
+9841fe00
+20600000
+2040561e
+247a0000
+680944c2
+20405866
+c4000000
+6800c6f8
+c4000000
+20406578
+24740000
+2040655e
+700b7d1b
+20405620
+20206566
+20740000
+6800c81d
+1fe0fe01
+6000c81d
+d8400001
+c303e5eb
+d840ffff
+600ac800
+78347c00
+20600000
+78547c00
+6800c820
+c1010000
+78347c00
+20600000
+1a627e00
+c00a6606
+c000e6a6
+c00ae617
+c0016617
+c002e616
+c008666a
+c009668a
+c0036614
+c0146521
+c014e524
+c0026611
+c009e611
+c005660f
+c0173f57
+1fe1040f
+1fe17ef0
+c0286634
+20600000
+680142a2
+793ffe00
+600142a2
+58000000
+60014814
+6800c829
+1fe0fe01
+6000c829
+202066a6
+204062e9
+20203f6a
+680147f4
+c2866697
+20203f10
+2040652b
+20600000
+20600000
+793f8025
+44e2c018
+20406621
+680142a0
+c283e630
+c2803f12
+c280e62a
+c281662d
+c281e62d
+20206697
+58000000
+60024806
+70481a00
+70480a00
+70427f00
+70448b00
+70482000
+70480b00
+20600000
+c282e62d
+c281e62d
+20206697
+680147f4
+c2866697
+20203f10
+20405b30
+680142a0
+c2803f12
+20203f10
+793f8025
+44e34018
+60088259
+68008259
+207a0000
+1fe0ffff
+60008259
+20406649
+2040664f
+20406656
+20406664
+6800c820
+2fe1fe02
+2040e648
+6800c820
+2fe1fe01
+2040e646
+20206637
+2040665d
+2020654c
+20600000
+6800c7f2
+207a0000
+1fe0ffff
+6000c7f2
+247a0000
+2020668a
+68014812
+207a0000
+1fe0ffff
+60014812
+247a0000
+204066a6
+20203f9a
+68014814
+207a0000
+1fe0ffff
+60014814
+247a0000
+20403f84
+20203f9a
+68014818
+207a0000
+1fe0ffff
+60014818
+247a0000
+70481a00
+20600000
+68014816
+207a0000
+1fe0ffff
+60014816
+247a0000
+202066b1
+793f8025
+44e3c018
+70481a00
+70480b01
+58000000
+60014814
+204066b1
+6800c132
+2feffe01
+2040e688
+6800c132
+2feffe00
+2040e684
+20403fa6
+20206697
+68034274
+203a3f79
+20203f6e
+68034274
+203a6682
+6801480c
+60014814
+20403fa4
+20203f82
+20403f94
+20203f88
+680147f4
+2feffe07
+2040bf75
+20600000
+20405b30
+20600000
+70427f01
+20403fa4
+20403fa2
+70482001
+58000000
+600147f0
+6000c7f2
+20403f9e
+2020655a
+6800c2a9
+c019e679
+c01a667c
+20206697
+793f8025
+44e44019
+6800c4f9
+1fe0fe01
+6000c4f9
+20403fa6
+680147fe
+60014812
+6800c132
+2feffe01
+2040bf88
+6800c132
+2feffe00
+2040bf7c
+20203f94
+793f8025
+44e4c019
+58000000
+60014812
+6800c132
+2feffe01
+2040bf86
+6800c132
+2feffe00
+2040bf7e
+20203f98
+793f8025
+44e54019
+58000000
+60014816
+680147f4
+c284bf90
+680147f4
+c2803f77
+20600000
+793f8025
+44e5c019
+d8400001
+da20481b
+da4000c6
+2020683e
+793f8025
+44e64019
+d8400001
+da20481b
+da4000c6
+2020681d
+793f8025
+44ff401f
+68108073
+d8400006
+9841fe00
+60108073
+68108077
+9841fe00
+60108077
+70808100
+68108077
+793ffe01
+793ffe02
+60108077
+2000001e
+70808101
+20600000
+202067a1
+202067a9
+243466dd
+68108085
+1fe1fe20
+60108085
+18427c00
+2022e6e0
+1a627a00
+2fcc0000
+20206763
+18000404
+da20022c
+68108085
+1fe17edf
+60108085
+204066dd
+da2055aa
+6801022c
+e8c90000
+9a267c00
+20600000
+d8400002
+da200232
+204066dd
+68010232
+60010225
+205466f4
+20600000
+d8400010
+da200234
+68108085
+1fe17edf
+60108085
+204066dd
+d8c00234
+df200010
+20407584
+2040753d
+2040759d
+20207534
+7856fc00
+204066e2
+24628000
+7836fc00
+70802380
+70802200
+70802400
+da208025
+204066d9
+70802300
+204066e2
+24628000
+18007e00
+60110288
+da20828a
+204066d9
+d8400006
+204066e3
+24628000
+e8c10000
+98002200
+204066dd
+20206710
+20407f36
+58001000
+60010225
+da606823
+df200002
+204066e2
+24628000
+68010225
+1ff0fe00
+9840fe00
+1ff0fe00
+60010225
+c200671c
+20206710
+70805025
+70828005
+20407f36
+78547c00
+2040688a
+58000000
+da200221
+d8400002
+204068d3
+68010221
+c303e738
+580007f0
+da200234
+d8400010
+204068d3
+70800608
+d8c00234
+20407590
+78347c00
+68010221
+1ff0fe00
+d84007ff
+98417e00
+2022e744
+2040688f
+da6068d8
+205466f4
+20406700
+68008220
+2fe00603
+2420e738
+2040688d
+68008221
+c282e751
+58000000
+60018224
+204067b9
+da6067db
+204066ed
+20406700
+2436e751
+68008220
+2fe00603
+2420e744
+68008221
+c283675d
+58000000
+60010225
+da606823
+20406805
+204066ed
+20406700
+2436e75d
+68008220
+2fe00603
+2420e751
+70805021
+68008221
+c4020000
+20404461
+204044a3
+20206761
+68008220
+1fe3fe00
+7920fe00
+2a2c000f
+20608000
+60008220
+20600000
+68108085
+c4028000
+20206770
+6810812c
+afefffff
+20608000
+68108108
+c300e76d
+20407534
+2020676d
+1f220400
+6009423c
+70802380
+70802200
+70802400
+6001423a
+98000a00
+1f2bf200
+68108025
+e0a08000
+c200677c
+70802300
+20600000
+6801423a
+207a0000
+70802380
+70802200
+70802400
+6809423c
+184bf200
+98000c00
+e8c08000
+60108025
+c2006789
+70802300
+20600000
+793f8025
+44ffc01f
+70808675
+7080870a
+58000223
+6011008a
+58000228
+6011008c
+68108081
+79207e00
+793ffe01
+60108081
+20600000
+68108086
+79207e07
+60108086
+793ffe07
+60108086
+20600000
+79207e07
+60010223
+79200025
+44804020
+70808802
+70808e00
+70800602
+202067b3
+18000401
+60008223
+79200025
+4480c020
+70808801
+6019008e
+70800602
+204067b3
+68008228
+20600000
+68014177
+1fe0fe01
+60014177
+6810812c
+c301e7b3
+20600000
+70808640
+70808700
+68108081
+793ffe00
+79207e01
+60108081
+58000000
+60020223
+20600000
+58000000
+6011008e
+58000001
+60108088
+58000223
+6011008a
+70022306
+70800602
+202067b3
+18408404
+60190088
+1a20a3fc
+d8400002
+e2288000
+1ff10400
+e0a88000
+1fec8400
+e0a88000
+e0a08000
+1a227e00
+6011008a
+58000000
+6011008e
+70800602
+202067b3
+6019008e
+58000004
+60110088
+70022303
+58000223
+6011008a
+1a227e00
+6011008c
+68108086
+2a2c000f
+7920fe06
+60108086
+70800602
+6810812c
+c283e7e8
+d8e00003
+2040676a
+204067b3
+2feffe02
+20406763
+68008224
+1ff02400
+68008225
+1fed7e00
+9a41a400
+68008226
+9a41fe00
+9840fe00
+60008226
+1fecfe00
+60008225
+1fecfe00
+60008224
+20600000
+7080420a
+70809102
+70809203
+70809303
+70809403
+70809503
+70809602
+20600000
+70809105
+70809207
+70809307
+70809407
+70809507
+70809605
+20600000
+6810812c
+c302e80c
+20600000
+60008224
+58000224
+6011009a
+58000001
+60110098
+6019009e
+1a227e00
+6011009c
+70809001
+70800604
+2020680c
+1ff0fe00
+60010225
+20600000
+79200025
+44814020
+6801429b
+9a40fe00
+1ff0fe00
+60010225
+79200025
+4481c020
+58000004
+60110098
+700224a0
+700227a1
+58000224
+6011009a
+6019009e
+1a227e00
+6011009c
+58000002
+2a2c000f
+7920fe00
+60108090
+70800604
+d8e00005
+2040676a
+2040680c
+2feffe04
+20406763
+68010225
+1ff0fe00
+9840fe00
+1ff0fe00
+60010225
+20600000
+79200025
+44824020
+6801429b
+9a40fe00
+60010161
+79200025
+4482c020
+600902a0
+1a227e00
+600102b7
+20406858
+680902b0
+680102b7
+1fe22200
+68010161
+20406870
+680102b0
+680902b7
+98408400
+600902b7
+68090161
+98408400
+60090161
+680102a0
+243a6848
+20600000
+79200025
+44834020
+680142aa
+1fe0ffff
+68090161
+9841fe00
+1fe0fe01
+600182b4
+680102a0
+9840fe00
+680982b4
+98467e00
+2421686b
+600102a0
+680182b4
+68090161
+98467e00
+600102b0
+20600000
+680102a0
+600102b0
+58000000
+600102a0
+20600000
+1fe22400
+79200025
+4483c020
+1a427e00
+18408403
+60190098
+1a20a3fd
+ea298000
+18422400
+d84000a0
+e2288000
+1ff0fe00
+e0a10000
+1a227e00
+6011009a
+58000000
+6011009e
+70809001
+70800604
+2040680c
+1a427e00
+e2218000
+20002710
+20002710
+20002710
+20600000
+70897370
+20000bb8
+20600000
+70897330
+20600000
+1fe9fe00
+60110045
+70804b00
+20600000
+2040688f
+204068c0
+ea288000
+1a20a201
+18000e00
+a84c0000
+2020e8b7
+68108046
+79207e06
+79207e07
+60108046
+70804702
+70804782
+793ffe07
+60108046
+7080478a
+2000000b
+708047ca
+20000021
+7080474a
+2000002c
+708047ca
+20000016
+7080478a
+20000021
+70804782
+20000001
+70804792
+2000000a
+708047b2
+68108007
+70804792
+20000001
+70804782
+afec0000
+2020e898
+68110045
+1fe0fe01
+60110045
+18e08e01
+28e01e08
+2420e898
+c2006895
+70804783
+20600000
+70804782
+2000000c
+70804780
+70804782
+20000096
+20600000
+204068c0
+708047a2
+1a227e00
+60110048
+7920040b
+2fec000f
+7920840f
+6019004a
+70800601
+20600000
+6810812c
+c300e8d0
+20600000
+2040688f
+204068c6
+204068d0
+70804783
+20600000
+68110124
+60110045
+204068c6
+d8e00001
+2040676a
+204068d0
+2feffe00
+20406763
+70804783
+20600000
+70427a01
+18000e0e
+6801427c
+20207e4c
+68110112
+207a0000
+6808c27b
+98467c00
+202168f2
+6800c27a
+203a68e2
+d8e0000e
+20407e53
+203a68f2
+58000000
+20600000
+18000e0e
+20407e4b
+70427a00
+68110112
+20600000
+6811005e
+98001400
+20600000
+19427e00
+6011005e
+20600000
+68110112
+207a0000
+98007200
+68110058
+98000600
+20600000
+68110058
+9840fe00
+1fe20600
+18627e00
+60110058
+20600000
+680142ac
+60110052
+20600000
+680303d0
+600301b4
+7001b334
+20206913
+68030040
+600301b4
+7001b333
+79200025
+44844021
+20406954
+20406950
+680081b3
+c01a691b
+c019e97c
+20600000
+2040697a
+20206963
+79200025
+4484c021
+20406929
+680081b2
+c17f8000
+680301b4
+60034274
+680081b3
+6000c2a9
+c019e92d
+c01a692f
+20600000
+2040694c
+680081b2
+c17f8000
+2020696b
+20406983
+202069a2
+20406981
+202069a8
+20406988
+78547c00
+2040698c
+2434427f
+680901ba
+184085ff
+58000000
+e0438000
+d840001c
+da200195
+da400000
+2020683e
+79200025
+44854021
+d8a0018e
+18007204
+20407e3b
+d840001c
+da20018e
+da400000
+2020683e
+79200025
+4485c021
+58000000
+60018040
+e0a18000
+20206954
+d8400001
+da2001b2
+da40001c
+2020681d
+d8400001
+da2001b2
+da40001c
+2020683e
+79200025
+44864021
+20406988
+78547c00
+2040698c
+20740000
+7001b200
+680301b4
+6003018f
+680081b3
+6000818e
+d840001c
+da20018e
+da400000
+2020683e
+d8400006
+da2044f9
+da40001d
+2020683e
+d8400006
+da2044f9
+da40001d
+2020681d
+79200025
+4486c021
+d8400007
+da2001b3
+da400000
+680081b2
+1feffe07
+9a40a400
+2020681d
+d8400010
+da400023
+680081b2
+1ff27e00
+9a40a400
+20600000
+da20447b
+2020697d
+da204262
+79200025
+44874021
+20406974
+2020683e
+da20447b
+20206984
+da204262
+79200025
+4487c021
+20406974
+2020681d
+d840001c
+da200195
+da400000
+2020681d
+79200025
+44884022
+58000195
+600101ba
+7001b200
+df200004
+1f227e00
+60008161
+680101ba
+1fe22200
+204069ac
+20740000
+680101ba
+1fe0fe07
+600101ba
+680081b2
+1fe0fe01
+600081b2
+68008161
+1fe27200
+c2006992
+20600000
+68044262
+680c426a
+9841fe00
+207a0000
+70425e01
+20600000
+68034274
+207a0000
+70448b01
+20600000
+da4001b3
+df200007
+20407f25
+2022e9b1
+20600000
+78347c00
+20600000
+20203bf1
+79200025
+4488c022
+79200407
+204069e5
+7d208407
+79200025
+44894022
+284c0007
+18410e1f
+680200a3
+f920fe00
+600200a3
+680200a7
+fd20fe00
+600200a7
+20600000
+79200025
+4489c022
+284c0007
+18410e1f
+680200a3
+f93ffe00
+600200a3
+680200a7
+f93ffe00
+600200a7
+20600000
+204069c4
+202069d2
+2455e9b9
+d8a0807c
+204069f4
+79400407
+d8a08078
+204069f4
+793f8407
+d8a08070
+202069f4
+79400407
+204069f3
+79200407
+d8a08070
+202069f4
+18410e07
+18497e00
+1fe17e03
+98a08a00
+e8a08000
+20600000
+d8a0811c
+204069df
+284ffe07
+2020e9eb
+afec0000
+20600000
+afefffff
+20600000
+2fcffe07
+202069f0
+2fcc0007
+58000000
+7d20fe07
+98428400
+d8a08074
+204069df
+284ffe07
+f920fe00
+e0a08000
+20600000
+6800c16e
+c13f8000
+70807700
+2000001e
+70807708
+20600000
+1fed7e00
+1ff27e00
+601100a2
+601100a0
+20600000
+58000000
+601100a2
+58000001
+601100a0
+20600000
+58000000
+601100a2
+601100a0
+20600000
+d8a08800
+df200020
+20407e3b
+580004f9
+60110848
+6011084a
+6011084c
+6011086c
+6011088c
+601108ac
+58000204
+601108ae
+58000506
+601108b0
+58000504
+601108b2
+58000200
+601108b4
+5800fefb
+601108b6
+5800faf9
+601108b8
+5800fafb
+601108ba
+5800fd00
+601108bc
+58000408
+601108be
+58000a0c
+601108c0
+58000b09
+601108c2
+58000500
+601108c4
+5800f8f1
+601108c6
+5800ece8
+601108c8
+5800e9eb
+601108ca
+5800f500
+601108cc
+58001223
+601108ce
+5800374b
+601108d0
+58005e71
+601108d2
+5800787f
+601108d4
+20600000
+79200025
+448a4022
+68110050
+793ffe0e
+60110050
+7080b011
+7080b101
+7080b201
+7080b311
+20600000
+79200025
+448ac022
+68110050
+79207e0e
+60110050
+7080b004
+7080b304
+7080b100
+7080b200
+20600000
+68008030
+c4010000
+d8a000b5
+df20001e
+68108134
+e0a08000
+c2006a58
+20600000
+68008030
+c4010000
+d8c000d3
+1800721e
+e8c08000
+60108009
+c2006a60
+20600000
+20600000
+20406a87
+d8400006
+202069da
+20406a65
+d8400006
+202069ed
+20406a65
+d8400006
+202069ef
+20406a87
+d8400007
+202069da
+20406a6e
+d8400007
+202069ed
+20406a6e
+d8400007
+202069ef
+20406a87
+68108078
+79207e06
+60108078
+d8400006
+202069d1
+20406a87
+68108078
+79207e07
+60108078
+d8400007
+202069d1
+68108081
+1fe1fe04
+60108081
+20600000
+68108081
+1fe17efb
+60108081
+20600000
+68108081
+2feffe02
+20600000
+58006a91
+60014296
+20600000
+20406b14
+68008481
+c000ea96
+c0016a9c
+20203bf1
+d8400017
+600944c2
+20405a88
+e8c08000
+20406a9e
+20205b42
+20406a9e
+20205b51
+18c22200
+79200025
+4498c026
+e8c08000
+c0006ab7
+c000eabc
+c0016abd
+c001eabe
+c0026b50
+c002eaff
+c0036b51
+c003eb52
+c0046abf
+c004eac0
+c0056ac1
+c005eac2
+c0066ac3
+c006ead5
+c0076ae3
+c007eaf0
+c0086af1
+c008eaf8
+c0096b19
+c009eb45
+20600000
+1a220c00
+e8c08000
+1fed7e00
+6001846d
+20600000
+20600000
+20600000
+20600000
+20600000
+20600000
+20600000
+20600000
+e8c20000
+60108082
+1fecfe00
+68188081
+1841047f
+98418400
+60188081
+1fecfe00
+68188051
+184104df
+98418400
+60188051
+1fecfe00
+68188042
+1841043f
+98418400
+60188042
+20206ab7
+e8c48000
+68188085
+1841043f
+98418400
+60188085
+1fecfe00
+601100a0
+1ff17e00
+601100a2
+1ff17e00
+601100a4
+1ff17e00
+601100a6
+20206ab7
+e8c20000
+60120070
+e8c20000
+60120078
+e8c20000
+6012007c
+e8c08000
+60108080
+e8c08000
+60108081
+e8c08000
+60108082
+20206ab7
+20206af1
+70046d10
+d8a0046e
+68120074
+e0a20000
+6812011c
+e0a20000
+20600000
+e8c88000
+e8c08000
+1fe9fe00
+1ff27e00
+98418400
+204069f3
+20206ab7
+e8c88000
+60188301
+e8c08000
+2fe1fe01
+e8c08000
+60108307
+2020eb08
+e8c08000
+60108307
+e8c08000
+1fe27200
+1fe0ffff
+1fe1fe90
+60108302
+70830302
+20000001
+d8a0046d
+68108307
+e0a08000
+c2006b10
+20600000
+58000000
+6002046d
+e0a40000
+e0a40000
+20600000
+1a227e00
+1fe0fe01
+60010483
+68014749
+c0006b28
+68014749
+68090483
+e8490000
+9840fe00
+68090483
+18408402
+18420c00
+e8c88000
+18c22200
+20206842
+58000002
+1ff0fe00
+60010225
+da606823
+df200002
+204066e2
+2422eb36
+68010225
+1ff0fe00
+9840fe00
+60014749
+1ff0fe00
+60010225
+c2006b2d
+68014749
+1ff0fe00
+60010225
+da606823
+df20ffff
+204066e2
+2422eb1e
+68010225
+1ff0fe00
+9840fe00
+1fe0fe02
+60014749
+1ff0fe00
+60010225
+c2006b3b
+68014749
+1fe0fe02
+1ff0fe00
+60014749
+da204749
+d8400002
+dfe00000
+20406842
+58000000
+60014749
+20600000
+20600000
+20600000
+20600000
+20758000
+70475500
+70048503
+70048603
+70048a11
+70048b13
+58000000
+60018487
+6000c2bd
+7047f300
+79200025
+44dfc037
+58000000
+6000c2bd
+6000c752
+6000c74b
+70475750
+20600000
+18418402
+20600000
+18427e00
+1fedfe00
+6000c750
+18007e3f
+1fedfe00
+6000c74f
+18007e01
+1fedfe00
+6000c74e
+20406b9d
+18427e00
+20600000
+1fedfe00
+6000c750
+18007e73
+1fedfe00
+6000c74f
+18007e01
+1fedfe00
+6000c74e
+20206b9d
+6800c751
+203a6b80
+58000070
+20600000
+580000aa
+20600000
+1fedfe00
+6000c750
+18007eef
+20406b91
+6809048f
+18420a00
+e0a08000
+18a20400
+6009048f
+18007eff
+20406b91
+6809048f
+18420a00
+e0a08000
+20600000
+1fedfe00
+6000c74f
+6801474f
+1fed7e00
+6001848c
+da200107
+da40000f
+20406baa
+1fe2fed7
+1fe47e00
+1fedfe00
+20600000
+6801c74e
+6001848c
+da200107
+da40000f
+20406baa
+1fed7e00
+da400007
+20406baa
+1fe2fe2b
+1fe47e00
+1fedfe00
+1fe20400
+20600000
+da600000
+1a427200
+20407dfb
+1fe20400
+18427e00
+1a63a600
+c3046bb3
+9a228400
+1a60a601
+18438400
+6801848c
+1a40a5ff
+2a41feff
+2020ebbd
+1a427200
+20407dfb
+2feffe00
+79208400
+20206bae
+18437e00
+20600000
+6808c74b
+184b8400
+79200400
+6800c751
+245a6b65
+600884a5
+20600000
+184b8400
+79200400
+6800c751
+205a6b65
+20600000
+18438400
+6800c751
+793a0400
+20600000
+68088494
+700496d7
+20406cf6
+6800c2ba
+79207e06
+79207e07
+6000c2ba
+70475100
+20206cd7
+6800c2ba
+79207e07
+6000c2ba
+20206cd7
+79200025
+44e04038
+6800c7f3
+c0006be1
+20206c8b
+680102cb
+1fe20c00
+20406c0f
+68008494
+c0006be7
+20206c57
+79200025
+44e0c038
+68008495
+c01febcf
+c039ebd8
+c077ebef
+c1298000
+20203bf1
+68010499
+1fe20c00
+20406c1a
+6800849b
+c020ebf8
+c0206c04
+c038ec3f
+c0386c4e
+20206cd7
+20406c06
+6800c74b
+1fe37e00
+1fe67c01
+2022ebfe
+20203bf1
+6800c2bd
+79207e00
+79207e01
+6000c2bd
+20406d22
+20206cd7
+20406c06
+20206cd7
+20406c22
+20206c30
+20406c22
+e8c08000
+1fe97e00
+6000c758
+e8c08000
+600084a0
+20600000
+e8c08000
+60008493
+1fe97e00
+60008494
+e8c08000
+60008495
+20406c27
+60090497
+18c27e00
+60010499
+20600000
+e8c08000
+1fe37e00
+6000849b
+20406c27
+6009049c
+18c27e00
+6001049e
+20600000
+6801049e
+1fe20c00
+20600000
+6801049e
+1fe20c00
+e8c08000
+1fe20400
+18430400
+c3800000
+e8c08000
+1fe9fe00
+1ff27e00
+98408400
+20600000
+e8c08000
+6000c74b
+e8c08000
+600084a1
+e8c08000
+600084a2
+e8c08000
+600084a3
+e8c10000
+6001474c
+e8c08000
+600084a4
+e8c08000
+6000c756
+20600000
+20406c08
+6800c758
+1fe67c01
+2022ec44
+20203bf1
+6800c2bd
+79207e05
+79207e06
+6000c2bd
+6808c74b
+184b8400
+18418403
+20406d55
+70475503
+20206cd7
+20406c08
+6800c758
+1fe67c01
+2022ec53
+20203bf1
+6800c2bd
+79207e07
+6000c2bd
+20206cd7
+68008494
+1fe67c01
+2022ec5b
+20203bf1
+68008495
+c039ec62
+c01fec66
+c077ec80
+c07fec78
+c029ec85
+20203bf1
+6800c2bd
+79207e03
+6000c2bd
+20206cd7
+6800c2bd
+79207e03
+79207e02
+6000c2bd
+68008493
+20406b73
+60008496
+20406cf6
+68008493
+1feb7e00
+6000c74b
+1febfe00
+793ffe01
+79207e00
+d8404753
+6009048f
+20406b82
+20206cd7
+68010499
+1fe20c00
+1fe0fe01
+60010499
+e8c08000
+6808c756
+9840fe00
+6000c756
+20406d88
+20406bbf
+20406d6d
+20406d8e
+20206cd7
+20406b5d
+68008493
+20406b73
+60008496
+20406cf6
+20206cd7
+680102cb
+1fe20c00
+20406c0f
+68008494
+c0006c91
+20206cc6
+79200025
+44e14038
+68008495
+c01febcf
+c039ebd8
+c077ec98
+20206cd7
+68010499
+1fe20c00
+20406c1a
+6800849b
+c020eca1
+c0206ca1
+c038ecac
+c0386cbc
+20206cd7
+20406c06
+6800c74b
+1fe37e00
+6808c752
+98467c00
+2022eca8
+20203bf1
+6800c2bd
+79207e01
+6000c2bd
+20206cd7
+20406c08
+6800c758
+6808c752
+98467c00
+2022ecb3
+20203bf1
+20206cd7
+6800c2bd
+79207e05
+79207e06
+6000c2bd
+6808c74b
+184b8400
+18418403
+20406d55
+20206cd7
+20406c08
+6800c758
+6808c752
+98467c00
+2022ecc2
+20203bf1
+6800c2bd
+79207e07
+6000c2bd
+20206cd7
+68008494
+6808c752
+98467c00
+2022eccc
+20203bf1
+20206cd7
+68008495
+c039ecd1
+c077ec80
+c07fec78
+c029ecd6
+6800c2bd
+79207e03
+6000c2bd
+20206cd7
+20206cd5
+20206c85
+20600000
+6800c755
+207a0000
+c001ecdc
+20203bf1
+70475500
+204052e0
+d8400001
+18498400
+18418403
+da2000aa
+20406d3f
+204052ef
+18a20c00
+e8c10000
+203a3bf1
+20600000
+79200025
+44e1c038
+204052ef
+58000004
+e0a10000
+680142b3
+e0a10000
+68008493
+e0a08000
+5800013f
+e0a10000
+68008496
+e0a08000
+20600000
+79200025
+44e24038
+204052e0
+204052ef
+58000004
+e0a10000
+680142b3
+e0a10000
+68008493
+e0a08000
+58000173
+e0a10000
+68008496
+e0a08000
+20600000
+79200025
+44e2c038
+204052ef
+5800000e
+e0a10000
+680142b3
+e0a10000
+6800c751
+1fe3fe00
+79207e00
+e0a08000
+580015ef
+e0a10000
+58001183
+e0a10000
+18427e00
+e0a08000
+580000f0
+e0a18000
+5800007f
+e0a10000
+58000000
+e0a08000
+58000001
+e0a08000
+20406b7c
+e0a08000
+70475710
+20600000
+79200025
+44e34038
+204052e0
+204052ef
+5800000e
+e0a10000
+680142b3
+e0a10000
+6800c751
+1fe3fe00
+79207e00
+e0a08000
+580015ef
+e0a10000
+58001181
+e0a10000
+6800c74b
+e0a08000
+580000e0
+e0a18000
+5800007f
+e0a10000
+58000000
+e0a08000
+58000007
+e0a08000
+20406b7c
+e0a08000
+20600000
+79200025
+44e3c038
+204052ef
+58000008
+e0a10000
+680142b3
+e0a10000
+6800c751
+1fe3fe00
+79207e00
+e0a08000
+580009ef
+e0a10000
+580005e3
+e0a10000
+18427e00
+e0a08000
+5800008d
+e0a08000
+20406b7c
+e0a08000
+20600000
+79200025
+44e44039
+204052e0
+204052ef
+58000008
+e0a10000
+680142b3
+e0a10000
+18421600
+6800c751
+1fe3fe00
+79207e00
+e0a08000
+580009ef
+e0a10000
+580005e1
+e0a10000
+19627e00
+e0a08000
+5800008d
+e0a08000
+20406b7c
+e0a08000
+20600000
+79200025
+44e4c039
+6800c757
+207a0000
+68110112
+247a0000
+1a227e00
+60008162
+60088161
+2040527a
+247a0000
+204052e0
+204052ef
+58000005
+e0a10000
+680142b3
+e0a10000
+680084a5
+e0a08000
+580001ff
+e0a10000
+6800c757
+e0a08000
+6800c754
+e0a08000
+70475700
+20600000
+68010497
+207a0000
+6800c757
+1fe0fe01
+6000c757
+20600000
+79200025
+44e54039
+68010497
+1fe27200
+204068f7
+68010499
+1fe20c00
+20404976
+202068fa
+79200025
+44e5c039
+6800c756
+207a0000
+1fe0ffff
+6000c756
+6801474c
+6809480e
+98467c00
+20216da2
+6001480e
+6800c757
+203a6daa
+7004a801
+6800c754
+600084a7
+580000ff
+600084a6
+20206daf
+7004a800
+6800c753
+600084a7
+580000ef
+600084a6
+79200025
+44e64039
+6800c80e
+1fe67c7f
+20216db7
+680084a8
+1fe0fe01
+600084a8
+20406bbf
+6801480e
+1fe0fe08
+680884a8
+9840a200
+20405248
+600102de
+1fe0fe04
+600102e0
+1fe20a00
+680084a5
+e0a08000
+680084a6
+e0a08000
+20406dd8
+20406de8
+20407f6b
+6800c80e
+1fe27200
+2040497c
+680084a7
+e0a08000
+680102de
+1fe20a00
+6801480e
+680884a8
+9840fe00
+1fe0fe04
+e0a10000
+680142b3
+e0a10000
+70475700
+2020428c
+6801480e
+1fe67c7f
+24216ddf
+1fe3fe00
+79207e00
+e0a08000
+20600000
+6801480e
+1fe97e00
+1ff18400
+1fe17e7f
+1fe3fe00
+793ffe00
+e0a08000
+e0a88000
+20600000
+6800c757
+207a0000
+e0a08000
+20600000
+79200025
+44cec033
+20407c45
+20403e73
+20406235
+79200025
+44cf4033
+20407813
+204077ee
+204077fe
+79200025
+44cfc033
+6800c132
+c1008000
+2040527a
+247a0000
+20404dcd
+2040527a
+247a0000
+79200025
+44d04034
+20406e47
+20404f6e
+20406cd8
+20406e0a
+79200025
+44d0c034
+2040527a
+247a0000
+20203e6f
+79200025
+44d14034
+680082e6
+c280508f
+c283d099
+20600000
+79200025
+44d1c034
+2040527e
+207a0000
+6800804b
+c3830000
+20405261
+60010179
+1fe20c00
+e8c10000
+1fe0fe04
+60010091
+70009006
+79200025
+44d24034
+680142af
+203a6e2d
+6800804b
+c4038000
+793ffe07
+6000804b
+70009005
+680942af
+68010179
+9840fe00
+60010179
+68010091
+98467e00
+60010091
+79200025
+44d2c034
+68010091
+203a3bf1
+d8400104
+98467e00
+24216e3b
+79200025
+44d34034
+60090091
+680142af
+9840fe00
+600142af
+20206e3d
+58000000
+600142af
+6800804b
+79207e06
+6000804b
+20600000
+6800c7f6
+c2806e45
+7002ee01
+20600000
+7002ee0f
+20600000
+6800c7f3
+243a6e4d
+680082ed
+207a0000
+7002ed00
+20600000
+79200025
+44d3c034
+680082ee
+207a0000
+c000ee6e
+c0016ec7
+c001ee74
+c0026ecb
+c01dee7e
+c01e6ece
+c006ee83
+c0076ed3
+c007ee86
+c0086ed9
+c008ee8c
+c0096edd
+c009ee92
+c00a6ee1
+c00aee98
+c00b6ee5
+c00bee9e
+c00c6eea
+c00ceea4
+c00d6eee
+c00deeaa
+c00e6ef2
+c00eeeb0
+c00f6ef7
+c00feeb6
+c0106efb
+c010eec1
+c0116eff
+20600000
+20406f0a
+7002ee02
+6800c2b9
+79207e00
+6000c2b9
+20600000
+7002ee04
+6800c2b9
+c3810000
+7002ee03
+20406f12
+7002ee04
+6800c2b9
+79207e02
+6000c2b9
+20600000
+2040527e
+247a0000
+20406f23
+7002ee3c
+20600000
+20406f18
+7002ee0e
+20600000
+20406f36
+7002ee10
+6800c2bb
+79207e00
+6000c2bb
+20600000
+20406f3e
+7002ee12
+6800c2bb
+79207e02
+6000c2bb
+20600000
+20406f44
+7002ee14
+6800c2bc
+79207e00
+6000c2bc
+20600000
+20406f4c
+7002ee16
+6800c2bc
+79207e02
+6000c2bc
+20600000
+20406f28
+7002ee18
+6800c2ba
+79207e00
+6000c2ba
+20600000
+20406f30
+7002ee1a
+6800c2ba
+79207e02
+6000c2ba
+20600000
+20406f52
+7002ee1c
+6800c2ba
+79207e06
+6000c2ba
+20600000
+20406f5a
+6800c2bd
+79207e00
+6000c2bd
+7002ee1e
+20600000
+20406f61
+6800c2bd
+79207e02
+6000c2bd
+7002ee20
+6800c752
+1fe9fe00
+1fe1fe03
+d8404753
+6009048f
+20206b82
+20406f6c
+6800c2bd
+79207e04
+6000c2bd
+7002ee22
+20600000
+6800c2b9
+c4008000
+7002ee03
+20206e4d
+6800c2b9
+c19f8000
+7002ee3b
+680082ec
+c18b8000
+7002ec00
+7002ee0d
+20206e4d
+6800c2b9
+247a0000
+6800c7f6
+c2806f02
+c2836f04
+20206f08
+6800c2bb
+c4008000
+7002ee11
+20206e4d
+6800c2bb
+c19f8000
+7002ee13
+20206e4d
+6800c2bc
+c4008000
+7002ee15
+20206e4d
+6800c2bc
+c19f8000
+6800c7f6
+c2836f04
+20206f08
+6800c2ba
+c4008000
+7002ee19
+20206e4d
+6800c2ba
+c19f8000
+7002ee1b
+20206e4d
+6800c2ba
+c1ff8000
+6800c7f6
+c2836f06
+20206f08
+6800c2bd
+c4008000
+7002ee1f
+20206e4d
+6800c2bd
+c4018000
+7002ee21
+20206e4d
+6800c2bd
+c1ff8000
+20206f08
+7002ee0f
+20206e4d
+7002ee17
+20206e4d
+7002ee1d
+20206e4d
+7002ee00
+20600000
+79200025
+44d44035
+204052c4
+58000001
+1fe20400
+58000050
+1fe21600
+202050b0
+79200025
+44d4c035
+204052c4
+680142b1
+1fe20400
+202050c0
+79200025
+44d54035
+204052c4
+680142b1
+1fe20400
+d9600050
+204050d6
+6800c2b9
+793ffe05
+6000c2b9
+20600000
+79200025
+44d5c035
+204052d2
+204071b0
+202050f2
+79200025
+44d64035
+204052c4
+58000003
+1fe20400
+58000051
+1fe21600
+202050b0
+79200025
+44d6c035
+204052c4
+680142b3
+1fe20400
+202050c0
+79200025
+44d74035
+204052c4
+58000011
+1fe20400
+58000052
+1fe21600
+202050b0
+79200025
+44d7c035
+204052c4
+680142b5
+1fe20400
+202050c0
+79200025
+44d84036
+204052c4
+58000013
+1fe20400
+58000053
+1fe21600
+202050b0
+79200025
+44d8c036
+204052c4
+680142b7
+1fe20400
+202050c0
+79200025
+44d94036
+204052e0
+70049303
+7004961c
+20406ce8
+70475101
+20600000
+79200025
+44d9c036
+204052e0
+6808c752
+20406bcb
+6008c74b
+20206d05
+79200025
+44da4036
+204052e0
+6808c74b
+20406bc0
+20406b67
+60008496
+6808c74b
+20406bc0
+60088493
+20206ce8
+79200025
+44dac036
+204052e0
+6808c74b
+20406bc0
+20206d3f
+79200025
+44f3c03c
+680102cb
+98000c00
+e8c08000
+1fe22400
+600084af
+e8c10000
+600104b0
+e8c08000
+1fed1600
+e8c08000
+99609600
+79200025
+44f4403d
+1a427e00
+c0016f87
+c0026fb0
+c003708b
+c003f1c7
+2020723e
+2040724d
+2841fe01
+2020f2bb
+2841feff
+2020f241
+e8c10000
+600104b4
+196097fe
+196097ff
+2422f23b
+d96004a9
+e9610000
+207a0000
+19609602
+20407307
+204052de
+18007e03
+e0a08000
+680104b0
+e0a10000
+18ebfe00
+1fe0fe05
+1fe0a605
+1ff0fe00
+e0a10000
+18e27e00
+1ff0fe00
+e0a10000
+e0a10000
+d8c004c5
+18e27200
+2022efaa
+e8c20000
+e0a20000
+c2006fa7
+18007e00
+e0a08000
+1a627e00
+600082dc
+203a3bf1
+20600000
+e8c20000
+600204be
+196097fc
+98000400
+e8c10000
+1ff0fe00
+1fe0ffee
+600104b2
+196097fe
+204072a4
+2022f241
+2a21fe05
+2020efc0
+d8a00491
+18000e00
+20206fd0
+e8c08000
+c0857241
+e8c10000
+243a6fce
+e8c08000
+c0ffefcc
+e8c08000
+c0ffefca
+18c08dfb
+20207022
+18c08dfb
+20206fbd
+18c08dfc
+20206fbd
+18c08dfd
+20206fbd
+e8c08000
+c004efe5
+c0056fd3
+e8c10000
+e0a10000
+18e08e01
+1ff0a400
+e8c10000
+1ff0fe00
+1a40a401
+9a467c00
+24216fe2
+1fe22600
+1a50fe00
+e0a10000
+18e08e01
+1a627e00
+20206fd9
+196097fb
+1a20a3fb
+20206fea
+e8c10000
+e0a10000
+18e08e01
+196097fd
+1a20a3fd
+24217241
+2422efd0
+196097ff
+2422f241
+204052de
+18a08a0a
+da200491
+18e27e00
+203a7004
+ea210000
+203a7004
+98002400
+680204be
+98000400
+2040734e
+203a7001
+18c08dfd
+e8c18000
+e0a18000
+20407199
+203a7001
+98007200
+20407e45
+1a20a202
+18e08fff
+20206ff1
+18007e00
+e0a08000
+18a08bff
+680902da
+1840fe0a
+98a67e00
+1fe62200
+1a30fe00
+1840a408
+e2410000
+1a20a203
+1a30fe00
+1840a405
+e2410000
+1a20a203
+1a30fe00
+1840a403
+e2410000
+1a20a205
+1a227e00
+600102dc
+58000036
+1840a407
+e2408000
+58000005
+e0408000
+680104b0
+1840a401
+e2410000
+20600000
+e8c08000
+c0857241
+e8c10000
+243a7241
+e8c08000
+c0fff241
+e8c08000
+c0fff241
+196097fb
+e8c08000
+c000702f
+c000f032
+c0017036
+600104ad
+196097ff
+2020703a
+e8c08000
+600104ad
+196097fe
+2020703a
+e8c10000
+1ff0fe00
+600104ad
+196097fd
+2422f23b
+2040731e
+2422f238
+18c22200
+204052de
+1a220c00
+18a08a03
+18c21600
+204072e8
+1fe22200
+680104ad
+1fe22400
+1a227e00
+9a462400
+680104b2
+9a467c00
+24217066
+78547c00
+680104ad
+203a7059
+99608c00
+1a40a403
+1a427200
+1f227e00
+1fe0fe03
+1ff0fe00
+e0a10000
+1f227e00
+1ff0fe00
+e0a10000
+20207074
+1a20f206
+2034705d
+1f30fe00
+20207060
+1f227e00
+1fe0fe02
+1ff0fe00
+e0a10000
+1f20f3fd
+1f30fe00
+e0a10000
+19620c00
+20207074
+78347c00
+680104b2
+1fe22200
+1fe27200
+680104ad
+203a7059
+99608c00
+1a227e00
+1fe0fe05
+1ff0fe00
+e0a10000
+1a227e00
+1ff0fe00
+e0a10000
+e8c08000
+e0a08000
+c2007074
+2434707f
+18007e02
+e0a08000
+18c27e00
+99667e00
+1ff0fe00
+e0a10000
+20207081
+18007e00
+e0a08000
+680102da
+98a67e00
+1fe67e00
+600102dc
+204052de
+58000005
+e0a08000
+680104b0
+e0a10000
+20600000
+2040724d
+2841feff
+2020f0b4
+e8c10000
+600104b2
+196097fe
+204072a4
+d8a00491
+18000e00
+e8c18000
+c084f0b4
+1fecfe00
+e0a10000
+18e08e01
+196097fd
+1a20a3fd
+24217241
+2422f094
+196097ff
+2422f241
+204052de
+18a08a0d
+680104a9
+98002600
+da200491
+ea220000
+203a70c4
+ea210000
+98002400
+2040732a
+203a70b2
+18c08dfd
+e8c18000
+e0a18000
+20407199
+98007200
+e8c08000
+e0a08000
+c20070af
+1a20a202
+202070a4
+e8c08000
+e8c08000
+196097fb
+1a20a3fb
+24217241
+d96004a9
+e9610000
+19609602
+20407307
+18e27e00
+600084dd
+203a72be
+d8e00000
+204052de
+18a08a0a
+20207108
+18007e00
+e0a08000
+18a08bff
+680902da
+1840fe0d
+98a67e00
+2022f0e8
+1fe67e00
+1840a40c
+e2408000
+1fe0fe03
+1840a409
+e2408000
+1fe0fe03
+1ff0fe00
+1840a405
+e2410000
+1fecfe00
+1fe0fe03
+1ff0fe00
+1840a403
+e2410000
+1fecfe00
+1fe0fe05
+600082dc
+680104b0
+1840a401
+e2410000
+58000007
+e0408000
+58000036
+1840a407
+e2410000
+1840a40a
+e2410000
+20600000
+7002dc0a
+204052de
+58000007
+e0a08000
+680104b0
+e0a10000
+58000500
+e0a10000
+58000200
+e0a10000
+58000035
+e0a18000
+20600000
+e8c08000
+e0a08000
+1a40a401
+1a20a3ff
+2022f0fb
+c20070f5
+18a21600
+1a427e00
+600104ad
+1a227e00
+600104b2
+203a7117
+20347152
+19620a00
+18e08e01
+680084dd
+98e67c00
+2422f108
+20207171
+d8c004c5
+18ebfe00
+98c08c00
+e8c20000
+98000400
+2040731e
+18c21600
+204072e8
+1fe0f203
+680104b2
+1fe22200
+680104ad
+1fe22400
+19620c00
+202070f5
+d8e00000
+da400000
+d8c004c5
+18ebfe00
+98c08c00
+e8c20000
+98000400
+2040731e
+204072e8
+1fe0fe03
+9a40a400
+18e08e01
+680084dd
+98e67c00
+2422f119
+19620a00
+18007e02
+e0a08000
+680104ad
+1ff0fe00
+e0a10000
+18a08bfd
+680902da
+1840fe0a
+98a67e00
+1fe67e00
+98002200
+1a427e00
+1840a409
+e2408000
+1fecfe00
+1840a408
+e2408000
+1a20a203
+1a227e00
+1840a406
+e2408000
+1fecfe00
+1840a405
+e2408000
+1a20a205
+1a227e00
+1840a404
+e2408000
+1fecfe00
+1840a403
+e2408000
+1a20a205
+1a227e00
+600102dc
+58000007
+e0408000
+58000036
+1840a407
+e2408000
+1840a401
+680104b0
+e2410000
+20600000
+19620a00
+18007e00
+e0a08000
+18a08bff
+680902da
+1840fe07
+98a67e00
+1fe67e00
+98002200
+1a227e00
+1840a406
+e2408000
+1fecfe00
+1840a405
+e2408000
+1a20a203
+1a227e00
+1840a404
+e2408000
+1fecfe00
+1840a403
+e2408000
+1a20a205
+1a227e00
+600102dc
+58000007
+e0408000
+680104b0
+1840a401
+e2410000
+20600000
+18007e00
+e0a08000
+18a08bff
+680902da
+1840fe0a
+98a67e00
+1fe67e00
+98002200
+1a227e00
+1840a409
+e2408000
+1fecfe00
+1840a408
+e2408000
+1a20a203
+1a227e00
+1840a406
+e2408000
+1fecfe00
+1840a405
+e2408000
+1a20a203
+1a227e00
+1840a404
+e2408000
+1fecfe00
+1840a403
+e2408000
+1a20a205
+1a227e00
+600102dc
+58000036
+1840a407
+e2408000
+58000007
+e0408000
+680104b0
+1840a401
+e2410000
+20600000
+18c21600
+e8c08000
+1fe17207
+1fe97e00
+c00371a2
+c000f2e0
+c00272e5
+c002f2e3
+202072de
+204071a4
+202072de
+1f227e00
+c002f1a9
+c00371ac
+18007203
+202072ef
+e8c08000
+1fe0fe02
+20600000
+e8c10000
+1ff0fe00
+1fe0fe03
+20600000
+204052de
+1fe20a00
+58000006
+e0a08000
+5800006e
+e0a10000
+58000f00
+e0a10000
+581a0535
+e0a18000
+58000111
+1ff07e00
+e0a20000
+58002600
+e0a10000
+58000335
+e0a10000
+58000009
+e0a10000
+58000004
+e0a10000
+7002dc14
+20600000
+18c20400
+680104b0
+c03771cb
+202071d4
+18420c00
+196097fd
+19627e00
+c00171d4
+204071d5
+20740000
+6000c752
+7002ec17
+20600000
+20600000
+78347c00
+1fe27200
+d8400400
+e8c10000
+98467c00
+2022f1de
+18c08dff
+c20071d8
+20600000
+d8400300
+e8c10000
+98467c00
+2022f1e5
+18c08dff
+c20071df
+20600000
+e8c08000
+e8c08000
+78547c00
+20600000
+204072a4
+2022f236
+18002400
+e8c08000
+1a20a3ff
+196097ff
+2fe1f018
+2420f230
+2fe00e04
+2420f1f8
+18002401
+18c08c02
+1a20a3fe
+196097fe
+202071fd
+2fe00e02
+2420f1fb
+202071f4
+2fe00e01
+2420f230
+e8c08000
+1a20a3ff
+196097ff
+c080f207
+e8c08000
+1a20a3ff
+196097ff
+c0807230
+7004c3ff
+20207230
+c0807230
+e8c08000
+1a20a3ff
+196097ff
+c081f230
+1a427c00
+2022f210
+18c08df4
+196097f4
+18007eff
+600084c4
+e8c08000
+1a20a3ff
+196097ff
+2fe1f008
+2420f230
+2fe00e00
+2020f22d
+2fe00e01
+2020f22a
+2fe00e02
+2020f227
+2fe00e03
+2020f224
+2fe00e04
+2420f230
+18c08c08
+1a20a3f8
+196097f8
+18c08c04
+1a20a3fc
+196097fc
+18c08c02
+1a20a3fe
+196097fe
+18c08c01
+1a20a3ff
+196097ff
+e8c08000
+1a20a3ff
+196097ff
+196097ff
+1a20a3ff
+20217230
+19609601
+18007e01
+20600000
+18007e00
+20600000
+58000200
+600104b6
+20207243
+58000400
+600104b6
+20207243
+58000600
+600104b6
+20207243
+58000300
+600104b6
+204052de
+e0a08000
+680104b0
+e0a10000
+58000200
+e0a10000
+680104b6
+e0a10000
+7002dc07
+20600000
+18000400
+d8a004a9
+204072a4
+2022f2a2
+e8c08000
+1a20a3ff
+196097ff
+2fe1f018
+2420f2a2
+2fe00e04
+2420f26e
+18000401
+e8c08000
+1a20a3ff
+196097ff
+c0807262
+e8c08000
+1a20a3ff
+196097ff
+c0007273
+20207265
+18c08c01
+1a20a3ff
+196097ff
+18c08c02
+1a20a3fe
+196097fe
+2841fe00
+2020f29d
+18c08c0c
+1a20a3f4
+196097f4
+2020729d
+2fe00e02
+2420f271
+20207259
+2fe00e01
+2420f2a2
+e8c10000
+1a20a3fe
+196097fe
+e0a10000
+2841fe00
+2020f29d
+18c20400
+e8c08000
+c0807292
+e8c08000
+c0807292
+e8c08000
+c0887292
+e8c08000
+c0807292
+e8c08000
+c0c07292
+e8c08000
+c0807292
+e8c08000
+c0807292
+e8c08000
+c0c07292
+e8c08000
+c0aff292
+e8c08000
+c0cdf292
+e8c08000
+c09a7292
+e8c08000
+c07df29b
+18420c00
+18c08c0c
+18000e00
+18000400
+2020729b
+e8c08000
+1a20a3ff
+196097ff
+20207277
+196097f4
+1a20a3f4
+2a21fe00
+2420f251
+18007e00
+e0a10000
+20600000
+d84000ff
+20600000
+e8c08000
+196097ff
+2fe1f030
+2420f2b9
+2fe00e07
+2020f2b2
+2fe00e06
+2020f2b4
+2fe00e05
+2420f2b9
+e8c08000
+1fe22200
+196097ff
+202072b7
+18c08c02
+196097fe
+e8c10000
+1ff0a200
+196097fe
+18007e01
+20600000
+18007e00
+20600000
+58000003
+600084af
+202072c0
+58000007
+600084af
+204052de
+680084af
+e0a08000
+1fe22400
+680104b0
+e0a10000
+58000500
+e0a10000
+2a41fe05
+2020f2d0
+2a41fe07
+2020f2d0
+58000000
+e0a18000
+e0a10000
+202072d4
+58350200
+e0a18000
+58000000
+e0a10000
+7002dc0a
+20600000
+18c21600
+e8c08000
+1fe17207
+1fe97e00
+c00372e5
+c000f2e0
+c00272e5
+c002f2e3
+19620c00
+20600000
+20407301
+1fe0fe01
+202072de
+18007e02
+202072de
+204072f7
+1fe0fe02
+202072de
+e8c08000
+1fe17207
+1fe97e00
+c00372f7
+c000f2ef
+c002f2fc
+20600000
+20407301
+98007200
+18000400
+184d0400
+e8c08000
+98418400
+c20072f2
+20600000
+1f227e00
+c002f2fc
+c00372fe
+18007203
+202072ef
+e8c08000
+20600000
+e8c10000
+1ff0fe00
+20600000
+18007e01
+1f227c00
+20628000
+1fe3fe00
+c2007304
+20600000
+98002600
+79200025
+44f4c03d
+18000e00
+68014759
+98000c00
+d8a004c5
+78547c00
+e8c08000
+207a0000
+98007200
+e8c10000
+9a667c00
+2422f316
+78347c00
+c2007312
+e8c20000
+2434731b
+e0a20000
+18e08e01
+204072e8
+98c08c00
+2020730e
+68014759
+98000c00
+e8c08000
+207a0000
+1fe3fe00
+98c08c00
+e8c20000
+98467c00
+20628000
+204072e8
+98c08c00
+20207320
+79200025
+44f5403d
+68014759
+98000c00
+e8c08000
+203a734b
+98007200
+e8c10000
+9a667c00
+2022f339
+c2007331
+18c08c04
+204072e8
+98c08c00
+2020732e
+1f20f3ff
+1f23fe00
+98c08c00
+18c08c04
+204072e8
+98c08400
+18c08c01
+e8c10000
+9a461600
+7922fe00
+19621600
+20628000
+204072d6
+98c08c00
+18427e00
+98c67c00
+2022f34b
+2020733f
+18000c00
+18007e00
+20600000
+79200025
+44f5c03d
+68014759
+98000c00
+e8c08000
+203a7368
+1fe3fe00
+98c08c00
+e8c20000
+98467c00
+2022f35c
+204072e8
+98c08c00
+20207352
+204072e8
+98c08400
+18c08c01
+e8c10000
+9a467c00
+20628000
+204072d6
+98c08c00
+18427e00
+98c67c00
+2022f368
+2020735e
+18000c00
+20600000
+2040737d
+d8c0051f
+d8a0050f
+20207e35
+78547c00
+20407474
+d8c004ef
+d8a0052f
+1800720f
+20407e45
+e8c08000
+1fe2fe06
+e0a08000
+5800053f
+60010574
+5800052f
+60010572
+79200012
+202073bd
+6808854f
+18002410
+1840a606
+1a667c10
+20217383
+18002610
+d8a0052f
+d8c00550
+18427200
+78547c00
+e8c08000
+e0a08000
+1a40a5ff
+2022f391
+c2007387
+20347384
+78347c00
+18007206
+1a220c00
+20207387
+d8c004ef
+d8a0053f
+20407e35
+6800854e
+9a62fe00
+6000854e
+5800053f
+60010574
+5800052f
+60010572
+79200012
+202073bd
+78547c00
+20407474
+202073a7
+da200056
+78347c00
+20407474
+204073a7
+d8c0051f
+d8a00062
+20207e35
+580004ef
+60010574
+58004262
+60010572
+793f8012
+204073bd
+da20051f
+da4004ef
+d8a0052f
+20407467
+da20052f
+da40053f
+1a420a00
+78347c00
+20407465
+2040747f
+5800053f
+60010574
+5800052f
+60010572
+79200012
+202073bd
+70057600
+68010572
+98000c00
+d8a00560
+20407e35
+68010574
+98000c00
+d8a0051f
+20407e35
+204073e4
+78547c00
+c58973ce
+68008576
+c08273ce
+68010574
+98002400
+20407416
+20407415
+20407428
+68008576
+1fe0fe01
+60008576
+204073e4
+78347c00
+20407415
+20407437
+20407446
+20407437
+20407446
+20407437
+20407446
+20407437
+68008576
+1fe0fe01
+60008576
+c08873c6
+204073e4
+78547c00
+20207415
+68008576
+d8c00560
+203a740b
+98002400
+18007211
+18c20a00
+e8c08000
+1fe98400
+1feb7e00
+1fe97e00
+9841fe00
+e0a08000
+c20073ea
+58000560
+9a408c00
+18007210
+d8a004ff
+e8c08000
+e0a08000
+28c1ff71
+2420f3fa
+18c08def
+c20073f5
+18002200
+1a40a7ff
+1a6ba600
+1a6ba600
+204075c5
+58008400
+9a60a600
+d8a004ff
+18007210
+ea688000
+e8a08000
+9840fe00
+e0a08000
+1a60a601
+c2007404
+202075c9
+18007210
+18000400
+e8c08000
+98428400
+c200740d
+18427e00
+e0c08000
+d8c00560
+d8a004ff
+20207e35
+da4004ff
+18007210
+da20051f
+1a220a00
+ea288000
+ea408000
+9842e000
+1f212603
+2434741f
+1a62a603
+1a662601
+20217422
+9840e000
+1e027e00
+e0a08000
+1a20a201
+1a40a401
+c2007419
+20600000
+204075c5
+18007210
+da20051f
+ea208000
+d8c08500
+1f212603
+1a667c01
+20217431
+d8c08600
+98c08c00
+e8c08000
+e2208000
+1a20a201
+c200742b
+202075c9
+18007208
+d8c0051f
+18c20a00
+e8c08000
+98002200
+e8c08000
+98002400
+1a23fe00
+9a40fe00
+e0a08000
+1a227e00
+9a40fe00
+e0a08000
+c200743a
+20600000
+588ae42c
+98000400
+18007207
+20407455
+580d751b
+98000400
+18007205
+20407455
+6800852e
+98002200
+68008522
+6000852e
+1a227e00
+60008522
+20600000
+1841240f
+18417e0f
+d8a0051f
+98a08a00
+e8a08000
+98002600
+1a227e00
+e0a08000
+1a622200
+18518400
+c2007456
+5800051f
+9a408a00
+1a227e00
+e0a08000
+20600000
+78347c00
+20207468
+78547c00
+18007210
+ea288000
+ea408000
+2034746e
+9842fe00
+2020746f
+9840fe00
+e0a08000
+1a20a201
+1a40a401
+c2007469
+20600000
+d8a0053f
+ea230000
+e0a30000
+2034747a
+ea230000
+2020747b
+e8c30000
+e0a30000
+ea220000
+e0a20000
+20600000
+d8c04262
+d8a0052f
+d8400000
+588395a7
+204074a0
+58b3c1df
+204074a0
+5800e5e9
+204074a1
+18422800
+78547c00
+2040748e
+1a820400
+78347c00
+2020748e
+18007208
+e8c08000
+2f200201
+20347495
+2020f496
+9840fe00
+20207497
+2020f493
+9842fe00
+e0a08000
+184c8400
+c200748f
+20600000
+68030523
+60030056
+e8c30000
+e0a30000
+20600000
+184d0400
+18500400
+98418400
+20600000
+202074a4
+20407540
+d8a0447b
+202075a3
+d8a0449c
+2034f4ab
+d8a003b0
+18c22200
+20407e35
+20407551
+d8c0448c
+202075bc
+da2003b0
+2034f4b3
+da20449c
+1a220a00
+20406226
+20207551
+d8c00380
+20407592
+d8c0447b
+20407593
+18006c38
+18006c00
+2040752f
+d8a003fd
+202075a3
+18007e49
+202074c2
+18007e01
+18007000
+184d5e00
+9de1de00
+1f00f001
+184cde00
+1df15e00
+68014473
+1ff07e00
+9de1de00
+1f00f001
+e8c20000
+98005e00
+1f00f001
+e8c10000
+1a30de00
+1df05e00
+9de1de00
+1f00f001
+20600000
+1a608c01
+e8c08000
+98002200
+204074bf
+20407531
+18007000
+ea608000
+1fe17e03
+1ff05e00
+79205e08
+2040759b
+20407534
+1a227200
+1a608c02
+2040757a
+20407584
+20407534
+1f227e00
+203a74e9
+202074e4
+1800700c
+1de27e00
+60020378
+20600000
+1a20a201
+204074c1
+1a620c00
+2040758e
+20407537
+204075aa
+1a60a610
+1a40a5f0
+202174ed
+20600000
+da60443e
+680ac465
+204074d5
+18007008
+98005e00
+18002200
+204074c1
+20407537
+da604440
+6800c43f
+1fe0a5ff
+9a608a00
+1800700c
+1de27e00
+e0a20000
+204074ed
+6800c43f
+1fe0fe04
+6000c43f
+680ac465
+18408401
+600ac465
+20600000
+68008341
+1fe67c14
+20217511
+da600342
+1fe0a5ff
+1fe0fffc
+60008341
+9a608c00
+e8c20000
+18007008
+98005e00
+18002200
+680ac46a
+204074c1
+20407537
+1800700c
+1de27e00
+6002037c
+204074ed
+da600340
+204074d5
+680a037c
+98467e00
+247a0000
+6802446f
+98467e00
+207a0000
+600a446f
+6802c46a
+1fe0fe01
+6002c46a
+18007e00
+20600000
+243bf52f
+20600000
+18006c30
+18006c00
+2020752f
+18006c32
+18006c02
+2020752f
+18006c34
+18006c04
+2020752f
+18006c36
+18006c06
+2020752f
+18006c01
+18006c00
+20600000
+18007000
+680203b0
+98005e00
+1f00f001
+e8c20000
+98005e00
+1f00f001
+6802449c
+98005e00
+1f00f001
+e8c20000
+98005e00
+1f00f001
+2040759e
+18006c38
+18006c08
+2020752f
+680344f9
+680b03d0
+2034f556
+680303d0
+680b44f9
+18007008
+18425e00
+1f00f001
+184f5e00
+1ff07e00
+9de1de00
+1f00f001
+1fef5e00
+1f00f001
+18005e00
+18007e00
+6800c4e6
+6808c4dc
+2434f566
+6800c4ed
+6808c4e6
+6000c4ac
+6008c4ad
+18007000
+da4044ac
+18007204
+ea220000
+ea4a0000
+9842de00
+1f00f001
+1a20a204
+1a40a404
+c200756b
+2040759e
+18006c38
+18006c0c
+2040752f
+2040759d
+18006c3a
+18006c08
+2020752f
+2f200600
+20608000
+18c27e00
+9f208a00
+18007e00
+e0a08000
+1f20f201
+2f200600
+20608000
+2020757f
+18007000
+1f227e00
+203a7589
+e8c20000
+1f20f3fc
+98005e00
+1f00f001
+2f001e04
+20608000
+20207585
+18007008
+20207593
+18007004
+20207593
+18007000
+18007204
+e8c20000
+98005e00
+1f00f001
+c2007594
+20600000
+d8c003fd
+20207590
+18007204
+202075a0
+18007000
+18007204
+18005e00
+1f00f001
+c200759f
+20600000
+1800700c
+18007204
+1de27e00
+e0a20000
+1f00f001
+c20075a5
+20600000
+1800700c
+1a620a00
+1a40f201
+1f267c0f
+202175b0
+18007210
+1de27e00
+1f267c03
+202175b8
+e0a20000
+1f20f3fc
+20628000
+1f00f001
+202075b0
+e0a08000
+1fecfe00
+c20075b8
+20600000
+1800700c
+18007204
+e8c20000
+9de67c00
+24628000
+1f00f001
+c20075be
+18007c00
+20600000
+68108050
+793ffe00
+60108050
+20600000
+68108050
+79207e00
+60108050
+20600000
+d8a00742
+3803ffff
+3807ffff
+380bffff
+380ffbff
+e0a48000
+3803ffff
+3807ffff
+380bffff
+380fffff
+e0a48000
+3803ffff
+3807ffff
+380bcfff
+380fffff
+e0a48000
+3803ffff
+3807ffff
+380bffef
+380fffff
+e0a48000
+3803ffff
+3807ffff
+380bffff
+380fffff
+e0a48000
+3803ffff
+38066c7f
+3808146b
+380f7bb3
+e0a48000
+3801feb8
+38050c12
+380ab722
+380e9fa6
+e0a48000
+3800e70f
+38056720
+3808519e
+380d9084
+e0a48000
+38031012
+380760bf
+380bf0af
+380c03d3
+e0a48000
+3803a188
+38043ad0
+380bcbf2
+380e43d9
+e0a48000
+3802b030
+38076a03
+38091188
+380de520
+e0a48000
+3803a11e
+3804fe5d
+3808dd57
+380dac93
+e0a48000
+380011ed
+380618c4
+38088da7
+380e57ff
+e0a48000
+3803192b
+38074641
+3809be0c
+380f66ad
+e0a48000
+38001f83
+38055a23
+380bf9b0
+380c3949
+e0a48000
+38013a51
+380553fd
+380b372a
+380cf1bb
+e0a48000
+3803ae85
+3805eed9
+38089e66
+380c01a8
+e0a40000
+20600000
+5800764c
+6001428e
+5800770f
+60014290
+580076ac
+60014292
+58007710
+6001428a
+58007718
+60014294
+79200025
+44fcc03f
+20758000
+70808100
+2040763f
+58007717
+60014288
+70480e00
+70480a00
+70480b00
+58000000
+60024800
+20403f23
+203a3f79
+20403f96
+20403f7e
+20203f6e
+6808c80f
+204069d1
+6808c810
+202069d1
+79200025
+44fd403f
+680a4806
+1c427e00
+60024806
+98467e00
+24610000
+1fe67ec8
+20600000
+6800c2bc
+c19f8000
+79200025
+44fdc03f
+6800c132
+c1848000
+78547c00
+2040769b
+24740000
+78547c00
+6800c133
+c001f706
+6800c80b
+c000f663
+c001767d
+20407643
+20217660
+6800c80a
+c2807674
+c280f682
+70480a00
+70480b00
+20600000
+70480b00
+20407bde
+6800c811
+c000f66a
+70480505
+70480003
+20207688
+70480e00
+2020766c
+70480e02
+20207684
+70480e03
+2020767f
+70480e04
+20207678
+70480e00
+20207667
+70480b01
+20407be7
+6800c811
+c000f67c
+70480505
+58020003
+6001c800
+20207688
+20600000
+70480b00
+20407bde
+7048050a
+70480001
+20207688
+70480b02
+20407be7
+7048050a
+70480001
+58280000
+6001c801
+79200025
+44fe403f
+6800c805
+1fe22200
+20404b2c
+680142b7
+e0a10000
+580000a1
+e0a08000
+680a4800
+e0ac0000
+58000000
+e0a08000
+60024800
+6800c80e
+c001766e
+c001f670
+c0027672
+20600000
+6808c80f
+204069e5
+58000000
+7920fe00
+6000c804
+6808c810
+204069e5
+58000000
+7920fe01
+6808c804
+9841fe00
+6808c80a
+6000c80a
+9842fc00
+20628000
+78347c00
+20600000
+1a627e00
+c002f6d8
+c00376da
+c003f6dd
+c013f6e1
+c00176c9
+c00276d0
+c009f6d0
+c000f6c6
+c00976c0
+c0173f57
+1fe1040f
+1fe17ef0
+c02876e4
+20600000
+6800c7f2
+207a0000
+1fe0ffff
+6000c7f2
+247a0000
+70427f01
+20403fa4
+20403fa2
+20403f7e
+20403f98
+20203f9e
+70480d00
+70480c00
+20600000
+79200025
+44fec03f
+70429d00
+70480c00
+70480d00
+680142a0
+c301f6d4
+680147fe
+600147f0
+20403f12
+20203f7b
+c300f6d6
+202076d0
+c30176d2
+202076d0
+20403f7e
+20203f98
+58000002
+6000c7f2
+20600000
+70480c00
+58000001
+6000c80d
+20600000
+58000005
+6000c80c
+20600000
+79200025
+44ff403f
+60088259
+68008259
+207a0000
+1fe0ffff
+60008259
+204076ef
+204076bb
+204076fa
+202076e7
+6800c80c
+207a0000
+6800c80c
+1fe0ffff
+6000c80c
+247a0000
+680082e6
+79207e00
+79207e07
+600082e6
+20600000
+6800c80d
+207a0000
+6800c80d
+1fe0ffff
+6000c80d
+247a0000
+20203f77
+79200025
+44ffc03f
+6800c133
+c1818000
+2020764e
+20407643
+20610000
+6800c80a
+207a0000
+20403f23
+203a3f79
+20403f96
+20403f7e
+20203f6e
+20207701
+6808c80f
+204069b4
+6800c811
+c080f715
+20600000
+6808c810
+202069b4
+2020763f
+20203f9a
+79200025
+44f9403e
+6800c7dc
+203a6009
+20406003
+58000000
+600407da
+600207e2
+d8a007e9
+e0a38000
+7007e000
+202077a4
+7007dc01
+2020772a
+6800c793
+c000f7c2
+20203bf1
+6800c793
+c000f72d
+202077a4
+204077c2
+680087db
+247a0000
+7007da03
+20600000
+680087de
+c0807750
+2040774d
+d8a00898
+58000848
+e0a10000
+580047c4
+e0a10000
+58000808
+e0a10000
+20207744
+d8a00898
+58000858
+e0a10000
+58000808
+e0a10000
+580047c4
+e0a10000
+20407ad2
+680087db
+c002774a
+7007dc01
+7007da05
+20600000
+7007db14
+20407727
+2020780f
+d8a00838
+18000e08
+202077db
+7007dc01
+20600000
+d8a006c3
+68034140
+e0a30000
+68030040
+e0a30000
+680187e9
+e0a18000
+20407b3c
+da200868
+da400878
+18000e04
+204077e0
+2420f768
+680087db
+c004f765
+7007da0a
+7007dc01
+70007c03
+20600000
+70007c03
+7007db15
+2020780f
+680087db
+c004f76e
+7007da00
+70007c04
+70007e05
+20600000
+70007c04
+7007db00
+20600000
+680087df
+c000f775
+7007db0a
+2020780f
+d8a006c3
+68030040
+e0a30000
+68034140
+e0a30000
+680187e6
+e0a18000
+20407b4a
+680087db
+c0057782
+7007da0b
+7007dc01
+20600000
+7007db0b
+7007dd01
+20600000
+d8a00898
+68030040
+e0a30000
+68034140
+e0a30000
+58000848
+e0a10000
+58000858
+e0a10000
+20207799
+7007da0f
+d8a00898
+68034140
+e0a30000
+68030040
+e0a30000
+58000858
+e0a10000
+58000848
+e0a10000
+d8a006c3
+68030898
+e0a30000
+6803089e
+e0a30000
+20407b06
+70425e01
+d8a04262
+d8c00868
+20407e35
+20203229
+79200025
+44f9c03e
+6800c793
+c1800000
+680087de
+c1800000
+d8a04794
+18000e0b
+204077db
+180a7e00
+1fe37e00
+e0a10000
+d8a0065a
+d8c04794
+20407e33
+d8a00582
+d8c0078a
+20407e2d
+d8a005b2
+20407e3a
+7005b201
+20407b7f
+7007de01
+20600000
+d8a047ac
+d8c005ca
+20407e2d
+70479301
+7007de00
+20600000
+79200025
+44fa403e
+680087e5
+c1800000
+680087de
+c1800000
+d8a0065a
+d8c04794
+20407e33
+d8a00582
+d8c007f0
+20407e2d
+d8a005b2
+20407e3a
+7005b201
+20407b7f
+7007de02
+20600000
+7007df01
+d8a00820
+d8c005ca
+20407e33
+7007e501
+7007de00
+20600000
+18e08fff
+24610000
+180a7e00
+e0a10000
+202077db
+18e08fff
+242177ec
+ea220000
+1fe20400
+ea420000
+9842fe00
+2422f7ea
+1a20a204
+1a40a404
+202077e0
+7840fc00
+20600000
+7820fc00
+20600000
+79200025
+44fac03e
+680087dc
+207a0000
+7007dc00
+680087da
+c001e117
+c002e134
+c003e13f
+c005e155
+c0017725
+c0027732
+c004f752
+c0057771
+c006778f
+20600000
+79200025
+44fb403e
+680087dd
+207a0000
+7007dd00
+680087db
+c00960f7
+c009e0ff
+c001e103
+c002773d
+c00a6107
+c003e115
+c0057771
+c005e154
+c004f752
+c00ae14e
+20600000
+7007dd01
+20600000
+7007dd00
+20600000
+79200025
+44fbc03e
+680087de
+207a0000
+1fe0fe80
+600087de
+c3838000
+68008581
+203a781d
+20207b8a
+20407a0c
+680087de
+c000f7bc
+c00177d4
+20600000
+1fe10e07
+1fe97e00
+98c08c00
+e8c08000
+afec0000
+20600000
+20407e33
+20407e33
+20207e33
+e8c40000
+247a0000
+e8c40000
+247a0000
+e8c40000
+20600000
+18007206
+ea220000
+98000400
+ea420000
+98467c00
+24628000
+1a20a204
+1a40a404
+c2007832
+20600000
+18007206
+1a20a214
+1a40a414
+ea420000
+98000400
+ea220000
+98467e00
+24610000
+247a0000
+1a20a3fc
+1a40a5fc
+c200783e
+20600000
+18007206
+18002600
+ea220000
+98000400
+ea420000
+9840fe00
+9a60fe00
+e0a20000
+2feffe20
+7920a600
+1a20a204
+1a40a404
+c200784a
+20600000
+18007206
+18002600
+ea420000
+98000400
+ea220000
+98467e00
+9a667e00
+e0a20000
+2feffe20
+7920a600
+1a20a204
+1a40a404
+c2007858
+20600000
+18007206
+1a20a214
+18002600
+ea220000
+2feffe00
+7920a601
+1fe37e00
+2a6ffe00
+7920fe1f
+e2220000
+1a20a3fc
+1a632600
+c2007867
+20600000
+18007206
+18002600
+ea220000
+2feffe1f
+7920a601
+1fe3fe00
+2a6ffe00
+7920fe00
+e2220000
+1a20a204
+1a632600
+c2007874
+20600000
+20407872
+2a6ffe00
+2020f888
+da400742
+1a222600
+1a20a3e8
+2040783b
+24610000
+1a622200
+1a20a3e8
+da400742
+1a220a00
+20207856
+20407848
+18a22200
+20207880
+20407856
+2a6c0000
+20608000
+da400742
+18a0a3e8
+1a220a00
+20207848
+18a21600
+1a226000
+da4006b2
+1a420a00
+1a208c18
+e8c40000
+e0a40000
+e0a40000
+18007e00
+e0a40000
+19620a00
+2040788c
+da4006b2
+1a420a00
+18007e00
+e0a40000
+1e008c20
+e8c40000
+e0a40000
+e0a40000
+19622200
+1a220a00
+2040788c
+da4006b2
+1a420a00
+1e008c28
+e8c40000
+e0a40000
+e0a40000
+e0a40000
+19622200
+1a220a00
+2020788c
+18007206
+e8c20000
+98005e00
+1f00f001
+c20078b8
+20600000
+18a21600
+d8a00682
+20407e3a
+d8a00682
+1a220c00
+18007000
+204078b7
+1a420c00
+204078b7
+18002400
+18000400
+18002606
+e8a20000
+98002200
+1a427000
+1de27e00
+1a627000
+9deffe00
+9a20fe00
+9840fe00
+e0a20000
+1fef0400
+1a60a601
+2a61fe0c
+2420f8c9
+18427e00
+e0a20000
+18a08be8
+1a40a401
+2a41fe06
+2420f8c7
+da200682
+19620a00
+20207896
+1a222400
+202078bd
+1a226000
+1e022200
+ea208000
+2feffe00
+20608000
+20407864
+ea408000
+2fec0000
+2020f8f1
+da200742
+1a420a00
+20407848
+ea408000
+9a60fe00
+e2408000
+1a40a5e8
+1a40a218
+18007207
+20407866
+202078e2
+18a21600
+d8a006e2
+20407e3a
+18007e00
+6002069a
+600206fa
+7006e201
+d8a00682
+20407e3a
+d8c00742
+d8a006b2
+20407e33
+1a220c00
+d8a006ca
+20407e33
+d8c006ca
+2040782b
+203a792d
+da2006ca
+da4006e2
+204078e1
+da2006b2
+da400682
+204078e1
+da2006ca
+da4006b2
+2040783b
+2021791f
+da2006b2
+da4006ca
+1a220a00
+20407856
+da2006e2
+da400682
+1a420a00
+20407848
+ea208000
+9a60a600
+ea408000
+9a60fe00
+e2408000
+20207904
+da2006ca
+da4006b2
+1a220a00
+20407856
+da200682
+da4006e2
+1a420a00
+20407848
+ea208000
+9a60a600
+ea408000
+9a60fe00
+e2408000
+20207904
+d8a006e2
+20407e3a
+6800869a
+600086e2
+600086ea
+da2006e2
+da400682
+1a420a00
+2040788c
+da200742
+da400682
+19620a00
+2020788f
+da200642
+d8a006fa
+204078df
+da2006fa
+d8a00712
+204078df
+da20075a
+da400712
+d8a00712
+204078bd
+da200612
+d8a006fa
+204078df
+d8c006fa
+d8a006ca
+20407e33
+da2006ca
+2040787f
+da2006fa
+da4006ca
+d8a006fa
+2040788c
+da2006fa
+da400712
+d8a006fa
+2040788c
+d8c00612
+d8a006ca
+20407e33
+da20062a
+d8a00712
+204078df
+da2006ca
+2040787f
+da2006ca
+2040787f
+da2006ca
+da400712
+d8a006ca
+204078bd
+da200712
+d8a006e2
+204078df
+da2006e2
+2040787f
+da2006e2
+2040787f
+da2006e2
+2040787f
+d8c0062a
+d8a00712
+20407e33
+da200712
+2040787f
+da200712
+da400642
+d8a00642
+204078bd
+da2006fa
+d8a00712
+204078df
+da200712
+da4006ca
+d8a00712
+2040788f
+da200712
+da4006ca
+d8a00612
+2040788f
+da2006ca
+da400612
+d8a00712
+2040788f
+da200712
+da4006fa
+d8a00712
+204078bd
+da200712
+da4006e2
+d8a0062a
+2020788f
+da2005b2
+d8a0072a
+204078df
+da200612
+da40072a
+d8a006e2
+204078bd
+da2005b2
+da40072a
+d8a0072a
+204078bd
+da20062a
+da40072a
+d8a006ca
+204078bd
+da200642
+d8a0072a
+204078df
+da200582
+da40072a
+d8a006fa
+204078bd
+da200642
+da40072a
+d8a0072a
+204078bd
+da20059a
+da40072a
+d8a00712
+204078bd
+da2006e2
+da4006fa
+d8a0072a
+2040788f
+da2006e2
+da4006fa
+d8a006e2
+2040788c
+da2006ca
+da400712
+d8a006fa
+2040788f
+da2006ca
+da400712
+d8a006ca
+2040788c
+da2006ca
+da40072a
+d8a006ca
+204078bd
+da200642
+da4005b2
+d8a00712
+204078bd
+da200712
+da40072a
+d8a00642
+204078bd
+da20072a
+d8a0072a
+204078df
+da20072a
+da4006e2
+d8a00712
+204078bd
+da20072a
+da4006ca
+d8a006ca
+204078bd
+da2006fa
+d8a00612
+204078df
+da200612
+da400712
+d8a00612
+2040788f
+d8c00612
+d8a0072a
+20407e33
+da20072a
+2040787f
+da200712
+da40072a
+d8a00712
+2040788f
+da200712
+da4006fa
+d8a006fa
+204078bd
+da2006fa
+da4006ca
+d8a0062a
+2040788f
+da20062a
+da400742
+d8a0062a
+18002600
+6800862a
+2feffe00
+2040f848
+1a626000
+da20062a
+20407864
+68008641
+2e0ffe00
+7920fe07
+60008641
+20600000
+700581c0
+70058001
+68008581
+1fe0ffff
+24610000
+60008581
+68008580
+205a793a
+68008581
+d8c0065a
+20407822
+2020f9f9
+68008580
+243a7a07
+2040798b
+202079f9
+70058000
+d8c00582
+d8a00612
+20407828
+202079f9
+da200642
+d8a00712
+204078f5
+da200712
+d8a006ca
+204078df
+da200612
+da4006ca
+d8a005ca
+204078bd
+da200712
+da4006ca
+d8a006fa
+204078bd
+da20062a
+da4006fa
+d8a005e2
+202078bd
+18007210
+e8c20000
+18002204
+18a08a03
+e0a08000
+1fecfe00
+18a08bfe
+1a20a3ff
+2422fa22
+18a08a05
+c2007a1f
+20600000
+18ebfe00
+99608c00
+e8c20000
+20600000
+18006010
+d9600582
+1e008ff9
+20407a2a
+98000400
+1e008ff0
+20407a2a
+98408400
+1e008ffe
+20407a2a
+1fee7e01
+98408400
+1e008ff1
+20407a2a
+1fee7e00
+98408400
+1e0bfe00
+99608a00
+e0aa0000
+1e00e001
+2e01fe40
+2420fa30
+20600000
+d8c007ba
+18007007
+e8c20000
+98005e00
+1f00f1ff
+20217a47
+20600000
+79200025
+44fc403f
+20407a2e
+d8a00682
+18007000
+1de27e00
+e0a20000
+1f00f001
+2f01fe08
+2420fa51
+204075c5
+d9608700
+de000582
+18007240
+ee0a0000
+e9620000
+19609604
+1e00e004
+9840fe00
+18007007
+9de08400
+18007004
+1dee7e03
+98408400
+18007005
+1de27e00
+18007006
+9de2fe00
+18007004
+9de17e00
+18007006
+9de2fe00
+98408400
+18007007
+18425e00
+18007003
+1de27e00
+9840de00
+18007000
+1de27e00
+18007001
+9de10400
+9de1fe00
+18007002
+9de17e00
+98418400
+18007000
+1dee7e02
+9840fe00
+18007007
+9de0de00
+980efc00
+c2007a5a
+d8c00682
+18007000
+e8c20000
+9de0de00
+1f00f001
+2f01fe08
+2420fa83
+202075c9
+d8a00858
+18007007
+1de27e00
+e0a20000
+1f00f1ff
+20217a8b
+20600000
+d8a00582
+18c08dfc
+1f262210
+e8c20000
+9842fe00
+e0a20000
+18c08df8
+c2007a93
+1a227200
+18427e00
+e0a20000
+c2007a9a
+20600000
+d8c00808
+d8a00582
+18007206
+20407b97
+d8c047c4
+18007206
+20407b97
+d8c00858
+20407b96
+20407a45
+20407a4c
+d8c00848
+d8a00582
+20207ab8
+d8c047c4
+d8a00582
+18007206
+20407b97
+d8c00808
+18007206
+20407b97
+d8c00848
+20407b96
+20407a45
+20407a4c
+d8c00858
+d8a00582
+20407b96
+58800000
+1fed7e00
+e0a20000
+18007205
+20407e3b
+58000280
+e0a20000
+20407a4c
+68020858
+da2003e8
+9a26fc00
+20407efd
+18077e00
+600207ec
+1807fe00
+da2003e8
+9a26fc00
+20407efd
+18077e00
+da2003e8
+9a2ffe00
+680a07ec
+9840fe00
+600207ec
+20600000
+58363636
+1fed0400
+18418436
+68010898
+1fe20c00
+18007204
+20407a90
+20407a45
+20407a4c
+6801089a
+1fe20c00
+d8a00582
+18007206
+20407b97
+6801089c
+1fe20c00
+18007206
+20407b97
+58800000
+e0a18000
+18007e00
+e0a08000
+18007e00
+e0a40000
+58000388
+e0a20000
+20407a4c
+20407a89
+d8c00858
+d8a006a2
+20407e31
+585c5c5c
+1fed0400
+1841845c
+68010898
+1fe20c00
+18007204
+20407a90
+20407a45
+20407a4c
+d8c006c2
+d8a00582
+18007208
+20407b97
+58800000
+1fed7e00
+e0a20000
+20407e3a
+58000300
+e0a20000
+20407a4c
+20207a89
+58363636
+1fed0400
+18418436
+d8c00838
+18007206
+20407a90
+20407a45
+20407a4c
+680108a4
+1fe20c00
+d8a00582
+20407b96
+680108a6
+1fe20c00
+20407b96
+5862746c
+1fed7e00
+1fe1fe6b
+e0a20000
+d8c006cf
+18007203
+20407b97
+58800000
+1fed7e00
+e0a20000
+18007e00
+e0a40000
+58000380
+e0a20000
+20407a4c
+20407a89
+d8c00858
+d8a006a2
+20407e31
+585c5c5c
+1fed0400
+1841845c
+d8c00838
+18007206
+20407a90
+20407a45
+20407a4c
+d8c006c2
+d8a00582
+18007208
+20407b97
+58800000
+1fed7e00
+e0a20000
+20407e3a
+58000300
+e0a20000
+20407a4c
+20207a89
+58363636
+1fed0400
+18418436
+d8c00838
+18007206
+20407a90
+20407a45
+20407a4c
+d8c00858
+d8a00582
+20407b96
+d8c00848
+20407b96
+20207b57
+58363636
+1fed0400
+18418436
+d8c00838
+18007206
+20407a90
+20407a45
+20407a4c
+d8c00848
+d8a00582
+20407b96
+d8c00858
+20407b96
+58000000
+e0a40000
+e0a40000
+18a20400
+7006c280
+18420a00
+d8c006d2
+20407b96
+20407a4c
+d8a00582
+18007207
+20407e3b
+e0a20000
+580003f8
+e0a20000
+20407a4c
+20407a89
+d8c00858
+d8a006a2
+20407e31
+585c5c5c
+1fed0400
+1841845c
+d8c00838
+18007206
+20407a90
+20407a45
+20407a4c
+d8c006c2
+d8a00582
+18007208
+20407b97
+58800000
+1fed7e00
+e0a20000
+20407e3a
+58000300
+e0a20000
+20407a4c
+20207a89
+700581c0
+68008581
+207a0000
+1fe0ffff
+60008581
+d8c0065a
+20407822
+2020fb80
+d8c00582
+d8a00612
+20207828
+2040793a
+68008581
+1fe0ffff
+60008581
+d8c0065a
+20407822
+20608000
+2020798b
+70058000
+d8c00582
+d8a00612
+20207828
+18007204
+18c08dfc
+e8c20000
+e0a20000
+18c08df8
+c2007b98
+20600000
+20758000
+20407ba5
+20407c13
+20207bd9
+6800c132
+c1008000
+20407bf2
+20207c04
+6800c7fd
+c17f8000
+98000400
+204069da
+6808c7fd
+204069ed
+20000064
+6808c7fd
+204069d1
+20207bb1
+7047fdff
+20600000
+79200025
+44c2c030
+6800c7fd
+c17f8000
+1fe20400
+204069e5
+2420fbc4
+20407bce
+680147f4
+79207e0c
+600147f4
+6800c7eb
+c1000000
+7047eb00
+6800c7fc
+6000c7ea
+20407bd5
+700b7d2c
+20207c27
+680147f4
+793ffe0c
+600147f4
+6800c7eb
+c1008000
+7047eb01
+7047ea00
+20407bd7
+700b7d2d
+20207c27
+6800c7ea
+207a0000
+1fe0ffff
+6000c7ea
+247a0000
+700b7d10
+20207c27
+d8e00007
+20203dc2
+d8e00007
+20203dc6
+6800c7f7
+c17f8000
+98000400
+204069da
+20207be2
+680147f4
+793ffe0d
+600147f4
+7047e900
+680147f4
+793ffe0e
+600147f4
+6808c7f7
+202069ed
+680147f4
+79207e0e
+600147f4
+7047e900
+6808c7f7
+202069ef
+680147f4
+79207e0d
+600147f4
+7047e901
+20600000
+79200025
+44c34030
+6800c7e9
+c1000000
+d8e00009
+20407e53
+247a0000
+6800c7e9
+c0017bff
+20407be7
+7047e902
+680147fa
+20207c02
+20407be2
+7047e903
+680147f8
+d8e00009
+20207e4c
+79200025
+44c3c030
+da200000
+680a47ec
+1c422400
+1a427e00
+184084a0
+184084a0
+98467c00
+24217c16
+1a20a201
+1a217e0f
+243a7c09
+da200000
+20407c1d
+1c427e00
+600247ec
+20600000
+79200025
+44c44031
+1a227e00
+207a0000
+18408560
+18408560
+600a47ec
+1fe0fe50
+60008b7d
+20207c27
+7047dd01
+6800c7de
+243a7c21
+20600000
+7047dd00
+20600000
+20207f9f
+79200025
+44c4c031
+6800c132
+c1008000
+20407c20
+1a227e00
+600208ab
+da2047df
+20407f92
+680208ab
+1fe22200
+20207c24
+79200025
+44c54031
+6800c132
+c1008000
+20407c20
+1a227e00
+600208ab
+da2047e4
+20407f92
+680208ab
+1fe22200
+20207c24
+79200025
+44c5c031
+58000000
+6002c7e4
+6002c7df
+20600000
+79200025
+44c64031
+6800c272
+247a0000
+da2047e4
+20407fac
+207a0000
+7008aa00
+20407c51
+680088aa
+203a7c45
+20600000
+79200025
+44c6c031
+20407c20
+da2047e4
+20407f9f
+1fe20400
+20407c24
+18427e00
+207a0000
+c000fc97
+c0017c9c
+c001fca2
+c003fca7
+c0047ca8
+c004fca9
+c005fcac
+c0067cad
+c006fcae
+c0077cb1
+c007fcb3
+c0087cb6
+c0097cbb
+c00afbed
+c00a7be7
+c009fbde
+c00b7cbc
+c00bfcc1
+c00c7cc3
+c00cfcc8
+c00dfcc6
+c00e7cd3
+c00f7cd5
+60008b7d
+79200025
+44c74031
+6800807c
+203a7c79
+204061d9
+6800807c
+243a7c8c
+68008b7d
+c584fc87
+c002ca19
+c0034a28
+c0057caa
+c0027ca4
+c008fcb8
+c00efc8e
+c00fe90c
+c0106910
+c0097c85
+20600000
+700b7d2f
+20205620
+60008b7d
+204032ee
+2022fc8c
+204032f9
+24628000
+7008aa01
+20207c33
+70007c34
+79200003
+24748000
+70474800
+70007c13
+68008177
+793ffe02
+60008177
+20600000
+680147f4
+79207e06
+600147f4
+70413303
+20600000
+7047f200
+70413300
+680147f4
+793ffe06
+600147f4
+20600000
+70427205
+20600000
+70007c07
+70044613
+20600000
+20600000
+20600000
+20600000
+70045002
+202049da
+20600000
+20600000
+7043d801
+7044db00
+20600000
+7043d800
+20600000
+7043d801
+7044db01
+20600000
+7043d800
+20600000
+58000001
+600103ef
+20600000
+20600000
+7043d201
+7042721b
+68030268
+600344e7
+20600000
+7043d201
+20600000
+7043d200
+70427200
+20600000
+700b7d4b
+20205620
+79200025
+44c7c031
+68014288
+20407f66
+6800c7fd
+c07ffcd0
+1fe20400
+204069d1
+20407be2
+20407c3f
+20203ccd
+7046f801
+20600000
+18000e04
+20207e4b
+6800c7f4
+c4060000
+c4038000
+20207cd5
+79200025
+44eac03a
+20407df3
+68108c26
+600088af
+68108c27
+600088b0
+708c26e0
+680088b0
+2fe00201
+2040fd3a
+79200025
+44eb403a
+680088af
+2fe00201
+2040fcf8
+680088f8
+c0817dc2
+680108f9
+1fe0fe01
+600108f9
+680908fb
+98467c00
+20217db2
+680088af
+c3037dc2
+58000000
+600108f9
+20207dc2
+79200025
+44ebc03a
+708c2611
+68108c20
+600088b1
+1fe27200
+203a7d18
+d8a008ff
+20407d36
+680088b1
+1fe67c07
+20610000
+79200025
+44ec403b
+680088ff
+c0107d16
+c010fd22
+c0007d10
+68008900
+c002fd9b
+c0037d3d
+c004fd98
+c005fda2
+20207d32
+68008900
+c000fdaf
+c001fdab
+c004fd34
+c002fd9b
+20207d32
+20407d34
+20600000
+680088af
+c2827d04
+20600000
+680088f6
+1fe0fe01
+600088f6
+2fe1fe02
+2420fd34
+7008f701
+20207d34
+68008900
+c0057d27
+c004fd2e
+c005fd1b
+20207d32
+680088f8
+c002fd2c
+c0827d34
+7008f805
+20207d34
+7008f802
+20207d34
+7008f701
+da2008f7
+da400001
+20207d65
+708c1101
+20600000
+708c1240
+20600000
+68108c18
+e0a08000
+c2007d36
+20600000
+708c2701
+20407d7c
+20600000
+79200025
+44ecc03b
+793f8023
+68008902
+c000fd47
+c0017d49
+c001fd4b
+c010fd57
+c0117d5b
+20600000
+da200912
+20207d62
+da200ab6
+20207d62
+68008901
+1fe17e03
+da200b1a
+c0007d62
+79200023
+da200b1f
+c000fd62
+da200b3d
+c0017d62
+da200b5b
+c001fd62
+20203bf1
+da200ac8
+68008ac8
+1fe22400
+20207d65
+68010903
+c000fd5f
+da200926
+20207d62
+7008f801
+da2009ee
+20207d62
+ea208000
+98002400
+1a20a201
+79200025
+44ed403b
+c591fd71
+1a40fe01
+1fe3fe00
+60108c18
+708c1803
+68008905
+1fe0fffe
+1fe37e00
+60008905
+c0007d7a
+68008905
+9a467c00
+20217d75
+1fe22400
+1a227e00
+6001090f
+1a427e00
+60008911
+20207d7c
+d8e00000
+20207dd5
+79200025
+44edc03b
+68008911
+207a0000
+1fe27200
+1fe67c40
+20217d84
+df200040
+68008911
+9f267e00
+60008911
+6801090f
+1fe20c00
+e8c08000
+60108c18
+c591fd8d
+708c1800
+c2007d89
+18c27e00
+6001090f
+d8e00000
+20407dd5
+68008911
+247a0000
+680088f8
+c1808000
+7008f802
+20600000
+68008901
+1fe67c01
+24217d32
+680088ff
+c0807d32
+68010903
+c0807d32
+68008905
+c0807d32
+20207d34
+680088ff
+c080fd32
+68008901
+c0807d32
+68008902
+c0807d32
+68008905
+c0807d32
+20207d34
+68008901
+c080fd32
+7008f803
+20207d34
+68008901
+c080fd32
+20207d34
+79200025
+44ee403b
+708c0000
+20002710
+708c10c0
+68110050
+793ffe0a
+60110050
+708c003c
+708c26ff
+708c27ff
+700ff000
+7008f800
+58000000
+600108f9
+20600000
+79200025
+44eec03b
+68008ff0
+207a0000
+680088f8
+c001fdec
+c1810000
+68008ff0
+700ff000
+df200006
+d8c00ff1
+c0017dd0
+c000fde9
+20203bf1
+da208c19
+d8e00001
+e8c08000
+e2208000
+c2007dd2
+79200025
+44ef403b
+78487c00
+680108fd
+98003600
+708c2640
+68108c26
+2021fdb2
+c3037ddb
+680108fd
+98003600
+d8400000
+f9200400
+60188c27
+2021fdb2
+60188c10
+68108c27
+afec0000
+2020fde3
+20600000
+d8e00002
+da208c1a
+20207dd2
+79200025
+44efc03b
+708c00fc
+20002710
+708c003c
+7008f804
+20600000
+68008ff0
+247a0000
+680108f2
+207a0000
+1fe0ffff
+600108f2
+700ff001
+20600000
+1f267c00
+20628000
+1fe37e00
+c2007dfd
+20600000
+18a27e00
+600102b9
+600c02a0
+19627e00
+600202a8
+1a227e00
+600202ac
+1a427e00
+600202b0
+1a627e00
+600182b4
+18c27e00
+600102b7
+20600000
+680c02a0
+680202a8
+98001600
+680202ac
+98002200
+680202b0
+98002400
+680182b4
+98002600
+680102b9
+98000a00
+680102b7
+98000c00
+20600000
+18a27e00
+60010b7b
+18c27e00
+60010b79
+20600000
+68010b7b
+1fe20a00
+68010b79
+1fe20c00
+20600000
+1c427e00
+1fe0fe10
+1fe0fe10
+1c420400
+98467c00
+20217e29
+20600000
+e8c40000
+e0a40000
+e8c40000
+e0a40000
+e8c40000
+e0a40000
+e8c40000
+e0a40000
+e8c40000
+e0a40000
+e8c40000
+e0a40000
+20600000
+18007203
+18007e00
+e0a40000
+c2007e3c
+20600000
+1f227e00
+207a0000
+58000000
+e0a08000
+c2007e42
+20600000
+1f227e00
+207a0000
+e8c08000
+e0a08000
+c2007e47
+20600000
+58000000
+d8a0423e
+98000400
+18e3fe00
+98a08a00
+e0a90000
+20600000
+d8e00000
+79200025
+44de4037
+680a4134
+1c437e00
+60024134
+98461600
+19620400
+d8c0423e
+18c20a00
+df200010
+e8c10000
+98467e00
+20217e61
+18007e00
+e0a10000
+c2007e5d
+d8c0423e
+18e3fe00
+98c08c00
+e8c10000
+20600000
+18e08e01
+18e08fff
+20628000
+1fed7e00
+20207e69
+98408400
+18427200
+58000ea6
+9f267e00
+20610000
+1fe67e00
+18510400
+18408401
+18500400
+98418400
+20600000
+20407e7a
+20207e84
+78547c00
+98467e00
+20217e7f
+78347c00
+1fe67e00
+c4078000
+d85f0ea6
+9840fe00
+793ffe40
+20600000
+98000c00
+1ff17e00
+d8400ea6
+984ffe00
+98c0fe00
+20600000
+1fed7e00
+1ff27e00
+6809c210
+9846fc00
+20407efd
+18078400
+20600000
+d8400ea6
+9846fc00
+20407efd
+1807fe00
+1ff07e00
+18070400
+98418400
+20600000
+df200003
+20207e9e
+df200002
+20207e9e
+df200006
+ea208000
+1fe20400
+1ff1fe00
+20407eaa
+e1408000
+18427e00
+1fe17e0f
+20407eaa
+e1408000
+1a20a201
+c2007e9e
+20600000
+1fe67c09
+20217eae
+1fe0fe57
+20600000
+1fe0fe30
+20600000
+d8400000
+18422600
+e8608000
+1fe67c2c
+20628000
+20407ec9
+1a620400
+20407f32
+da40000a
+9a4ffe00
+9840fe00
+1fe20400
+20207eb1
+df200002
+20207ec0
+df200006
+e8608000
+20407ec9
+1ff22600
+e8608000
+20407ec9
+9a60fe00
+e0a08000
+c2007ec0
+20600000
+d840003a
+98467c00
+24217ed2
+d8400061
+98467c00
+20217ed5
+d8400037
+98467e00
+20600000
+d8400030
+98467e00
+20600000
+d8400057
+98467e00
+20600000
+18426000
+580001ff
+18002400
+1fe92200
+1a232200
+9a22a200
+2a2ffe00
+7920fe09
+18430400
+2feffe00
+79208407
+1fe37e00
+1a40a401
+2a400e00
+2420fedb
+e0a88000
+c2007edb
+1e020400
+20600000
+1fe6fc0a
+20407efd
+1807fe00
+1feba200
+1a2ba200
+18077e00
+9a21fe00
+20600000
+2a2ffe00
+2020fef7
+98002400
+20600000
+1febfe00
+1febfe00
+9a41fe00
+e0a08000
+18a08bfe
+20600000
+207a8000
+20207efd
+60040161
+18007e20
+18007208
+d8a00028
+e0a08000
+c2007f03
+d8a00028
+18a08a07
+68040161
+1fe6fc0a
+20407efd
+18077e00
+1fe1fe30
+e0a08000
+18a08bfe
+1807fe00
+207a0000
+20207f08
+60040161
+18007e00
+60040028
+d8a00028
+18a08a07
+68040161
+18002200
+1fe6fc0a
+20407efd
+18077e00
+20407ef3
+1a20a201
+1807fe00
+1fe67c09
+24217f18
+20407ef3
+2a2ffe00
+20608000
+e0a08000
+20600000
+ea208000
+ea488000
+98467c00
+24628000
+1a20a201
+1a40a401
+c2007f25
+18007c00
+20600000
+98467c00
+24610000
+18427e00
+20600000
+9840fe00
+98460400
+98467e00
+20600000
+df200200
+d8a04000
+20207e3b
+6802809c
+60028161
+68014210
+e0a10000
+58000000
+7936fe07
+7935fe06
+792c7e05
+79377e04
+e0a08000
+20207f52
+6802809c
+60028161
+68008016
+e0a08000
+680103da
+d8c00fff
+98c17e00
+7936fe0f
+7935fe0e
+792c7e0d
+79377e0c
+e0a10000
+20207f52
+60040161
+6800c16e
+c13f8000
+1fe17e7f
+1fe9fe00
+d8a04c00
+98a08a00
+68040161
+e0a40000
+6800c16e
+2feffe07
+1fe0fe01
+1fe17e7f
+7920fe07
+6000c16e
+68040161
+20600000
+df200800
+d8a00000
+59010101
+20207e3c
+207a0000
+1fe27a00
+6811010e
+243a7f68
+20600000
+68110058
+1fe20600
+20600000
+6811005e
+1fe21400
+20600000
+18c22200
+20407f6e
+1a220c00
+20404976
+204068fa
+20207f68
+70820301
+20600000
+60110205
+68108203
+79207e04
+60108203
+20600000
+60110207
+68108203
+79207e06
+60108203
+20600000
+60110205
+70820330
+20600000
+68108043
+79207e04
+60108043
+20600000
+68108043
+793ffe04
+60108043
+20600000
+6811010e
+d8400200
+98467c00
+20600000
+79200025
+44dec037
+ea2a8000
+18417eff
+243a7f99
+184cfe00
+e2228000
+1a20a204
+ea208000
+243a3bf1
+68008b7d
+e2208000
+20600000
+79200025
+44df4037
+df200005
+ea228000
+207a0000
+ea208000
+243a7fa9
+1a20a201
+c2007fa4
+20203bf1
+d8400000
+e2288000
+20600000
+ea228000
+20600000
+ea208000
+20600000
+ea210000
+20600000
+d8400000
+68008006
+c2007fb3
+18408401
+c2007fb3
+18427e00
+20600000
+98467c00
+24610000
+18427e00
+20600000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00000000
+00008010
Index: btkb/program/app.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/app.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/app.prog	(working copy)
@@ -0,0 +1,525 @@
+app_init:
+	set1 mark_ext_patch,mark
+	bpatch patch39_5,mem_patch39
+	fetch 1,mem_device_option
+	branch app_init,blank				/* wait ram to be initialized */
+	beq dvc_op_ukey,le_ukey_init
+	beq dvc_op_ir,le_ir_init
+	beq dvc_op_dongle,le_dongle_init
+	beq dvc_op_kb,kb_init
+	beq dvc_op_hci,hci_init
+	beq dvc_op_shutter,shutter_init
+	beq dvc_op_module,module_init
+	beq dvc_op_ble_kb,le_kb_init
+	beq dvc_op_ble_prcp,prcp_init
+	beq dvc_op_test,test_init
+	bbit1 dvc_op_mouse,mouse_init
+	rtn
+	
+app_lpm_init:
+	set1 mark_ext_patch,mark
+	bpatch patch39_6,mem_patch39
+	jam 0,mem_tester_emulate
+	jam 0,mem_debug_config
+	jam 0, mem_lch_code
+	setarg 0
+	store 5,mem_sp_state_start
+	fetch 1,mem_device_option
+	branch app_lpm_init,blank				/* wait ram to be initialized */
+	beq dvc_op_module,module_lpm_init
+	rtn
+
+	
+app_process_idle:
+	call ui_dispatch
+	call check_51cmd
+	call app_process_bb_event
+	fetch 2,mem_cb_idle_process
+	branch callback_func
+	
+app_process_bt:
+	fetch 2,mem_cb_bt_process
+	branch callback_func
+	
+app_process_ble:
+	fetch 2,mem_cb_le_process
+	branch callback_func
+
+app_process_bb_event:
+	set1 mark_ext_patch,mark
+	bpatch patch39_7,mem_patch39
+	//return if c51 need to process bb event
+	arg mem_ipc_fifo_bt2c51,rega
+	call fifo_out
+	rtn blank
+	//reaching here mains c51 cannot get bb event.
+	copy pdata,regc
+	call app_event_normal_process
+	branch app_process_bb_event_priority
+	
+app_discard_event:
+	arg 0,regc
+	rtn
+
+//************************************************//
+//*APP BB EVENT NORMAL PROCESS**//
+//************************************************//
+app_event_normal_process:
+	beq BT_EVT_BB_CONNECTED,app_evt_bt_conn
+	beq BT_EVT_BUTTON_LONG_PRESSED,app_evt_button_long_pressed
+	beq BT_EVT_SETUP_COMPLETE,app_evt_setup_complete
+	beq BT_EVT_HID_HANDSHAKE,app_evt_hid_handshake
+	beq BT_EVT_HID_CONNECTED,app_bb_event_hid_connected
+	beq BT_EVT_RECONN_FAILED,app_bb_event_reconn_failed
+	beq BT_EVT_BB_DISCONNECTED,app_bb_event_bb_disconn
+	beq BT_EVT_RECONN_PAGE_TIMEOUT,app_bb_event_reconn_failed	
+	beq BT_EVT_LE_CONNECTED,app_le_event_bb_connected
+	beq BT_EVT_LE_DISCONNECTED,app_le_event_bb_disconn
+	beq BT_EVT_RECONN_STARTED,app_event_reconn_start
+	beq BT_EVT_ENTER_SNIFF,app_event_enter_sniff
+	beq BT_EVT_EXIT_SNIFF,app_event_exit_sniff
+	
+	beq BT_EVT_ML2CAP_CONN_REFUSED,app_event_ml2cap_conn_refused
+	beq BT_EVT_LINKKEY_GENERATE,app_event_linkkey_generate
+	beq BT_EVT_SWITCH_FAIL_MASTER,app_event_switch_fail_master
+	beq BT_EVT_SWITCH_SUCCESS_MASTER,app_event_switch_success
+	
+	and pdata,0x0f,temp
+	and_into BT_EVT_TIMER_MASK,pdata
+	beq BT_EVT_TIMER_INIT,app_evt_timer
+	rtn
+
+app_evt_bt_conn:
+	fetch 2,mem_ui_state_map
+	set1 UI_STATE_BT_CONNECTED,pdata
+	store 2,mem_ui_state_map
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	set0 APP_DISC_BY_BUTTON ,pdata
+	store APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	rtn
+app_event_switch_success:
+	jam 0,mem_switch_fail_master_count
+	rtn	
+
+app_event_switch_fail_master:
+	fetch 1,mem_switch_fail_master_count
+	increase 1,pdata
+	store 1,mem_switch_fail_master_count
+	sub pdata,1,null
+	branch app_bt_role_switch,positive
+	jam 0,mem_switch_fail_master_count
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	set1 APP_DISC_SWITCH_FAIL,pdata
+	store APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	branch app_bt_disconnect
+	
+app_process_bb_event_priority:
+	fetch 2,mem_cb_bb_event_process
+	branch callback_func
+
+app_check_wake_lock:
+	fetch 2,mem_cb_check_wakelock
+	branch callback_func
+	
+app_will_enter_lpm:
+	fetch 2,mem_cb_before_lpm
+	branch callback_func
+
+app_event_linkkey_generate:
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	set1 APP_DISC_AFTER_PAIRING ,pdata
+	store APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	branch app_bt_store_reconn_info
+	
+app_event_reconn_start:
+	fetch 2,mem_ui_state_map
+	set1 UI_STATE_BT_RECONNECT,pdata
+	store 2,mem_ui_state_map
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	set1 APP_DISC_AFTER_RECONN,pdata
+	store APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	rtn
+
+app_evt_setup_complete:
+	fetch 2,mem_ui_state_map
+	set1 UI_STATE_BT_SETUP_COMPLETE,pdata
+	store 2,mem_ui_state_map
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	set1 APP_DISC_AFTER_SETUP_DONE,pdata
+	store APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	rtn
+
+app_evt_hid_handshake:
+	fetch 2,mem_ui_state_map
+	set1 UI_STATE_BT_HID_HANDSHAKE,pdata
+	store 2,mem_ui_state_map
+	rtn
+	
+app_event_enter_sniff:
+	fetch 2,mem_ui_state_map
+	set1 UI_STATE_BT_SNIFF,pdata
+	store 2,mem_ui_state_map
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	set1 APP_DISC_AFTER_SNIFF,pdata
+	store APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	rtn
+	
+app_event_exit_sniff:
+	fetch 2,mem_ui_state_map
+	set0 UI_STATE_BT_SNIFF,pdata
+	store 2,mem_ui_state_map
+	rtn
+
+app_le_event_bb_connected:
+	fetch 2,mem_ui_state_map
+	set1 UI_STATE_BLE_CONNECTED,pdata
+	store 2,mem_ui_state_map
+	rtn
+	
+app_le_event_bb_disconn:
+	fetch 2,mem_ui_state_map
+	set0 UI_STATE_BLE_CONNECTED,pdata
+	store 2,mem_ui_state_map
+	jam 0,mem_le_switch_send_data
+	branch app_lpm_mult_disable
+	
+app_bb_event_hid_connected:
+	fetch 2,mem_ui_state_map
+	set1 UI_STATE_BT_HID_CONN,pdata
+	store 2,mem_ui_state_map
+	rtn
+
+app_evt_button_long_pressed:
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	set1 APP_DISC_BY_BUTTON,pdata
+	store APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	rtn
+	
+app_event_ml2cap_conn_refused:
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	set1 APP_DISC_L2CAP_REFUSED,pdata
+	store APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	branch  app_bt_disconnect
+
+
+app_evt_timer:
+	set1 mark_ext_patch,mark
+	bpatch patch3a_0,mem_patch3a
+	storet 1,mem_app_evt_timer_count
+app_evt_100ms_loop:
+	fetch 1,mem_app_evt_timer_count
+	rtn blank
+	increase -1,pdata
+	store 1,mem_app_evt_timer_count
+	call ui_button_polling
+	call app_lpm_wake_auto_lock_timer
+	call app_unsniff_delay_timer
+	call app_discovery_timer
+	branch app_evt_100ms_loop
+	
+app_unsniff_delay_timer:
+	fetch 1,mem_unsniff2sniff_timer_count
+	rtn blank
+	increase -1,pdata
+	store 1,mem_unsniff2sniff_timer_count
+	nrtn blank
+	call context_check_idle
+	branch app_bt_enter_sniff,zero
+	rtn
+app_discovery_timer:
+	fetch 2,mem_discovery_timeout_timer_count
+	rtn blank
+	increase -1,pdata
+	store 2,mem_discovery_timeout_timer_count
+	nrtn blank
+	call app_bt_stop_discovery
+	call app_led_off
+	fetch 2,mem_cb_discovry_timeout
+	branch callback_func 
+	
+app_bb_event_reconn_failed:
+	call app_disconn_reason_flag_clear
+app_clear_reconnect_flag:
+	fetch 2,mem_ui_state_map
+	set0 UI_STATE_BT_RECONNECT,pdata
+	store 2,mem_ui_state_map
+	rtn
+
+app_bb_event_bb_disconn:
+	jam 0,mem_unsniff2sniff_timer_count
+	fetch 2,mem_ui_state_map
+	bbit1 UI_STATE_BT_RECONNECT,app_bb_event_bb_reconn_disconn
+	isolate0 UI_STATE_BT_SETUP_COMPLETE,pdata
+ 	call app_discard_event,true
+app_bb_event_bb_reconn_disconn:
+	fetch 2,mem_ui_state_map
+	set0 UI_STATE_BT_CONNECTED,pdata
+	set0 UI_STATE_BT_SETUP_COMPLETE,pdata
+	set0 UI_STATE_BT_HID_CONN,pdata
+	set0 UI_STATE_BT_HID_HANDSHAKE,pdata
+	set0 UI_STATE_BT_SPP_CONN,pdata
+	store 2,mem_ui_state_map
+	branch app_lpm_mult_disable
+	
+app_bb_hibernate:
+	call app_disconn_reason_clear
+	branch app_enter_hibernate
+
+	
+app_event_do_nothing:
+app_disconn_reason_clear:
+	setarg 0
+	store APP_DISC_RSN_SIZE,mem_app_disconn_reason
+	rtn
+app_disconn_reason_flag_clear:
+	setarg 0
+	store APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	rtn
+
+	
+app_disconn_reason_collect_bt:
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	store APP_DISC_RSN_SIZE,mem_app_disconn_reason
+	setarg 0
+	store APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	rtn
+	
+app_disconn_reason_collect_ble:
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	set1 APP_DISC_BLE,pdata
+	store APP_DISC_RSN_SIZE,mem_app_disconn_reason
+	setarg 0
+	store APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	rtn
+
+	
+//************************************************//
+//********APP SHARED FUNCSIONS*******//
+//************************************************//
+app_check_reconn_target:
+	call eeprom_load_reconn_info
+	fetch 6,mem_hci_plap
+	rtn
+	
+app_le_check_reconn_target:
+	fetch 1,mem_ltk_exists
+	branch app_le_check_reconn_target_none,blank
+	call app_led_on
+	branch app_ble_start_direct_adv
+app_le_check_reconn_target_none:
+	call app_led_start_blink
+	branch app_ble_start_adv
+
+app_check_plap:
+	set1 mark_ext_patch,mark
+	bpatch patch3a_1,mem_patch3a
+	arg mem_check_plap_temp,regb
+	arg app_check_one_plap,regc
+	branch context_search
+	
+app_check_one_plap:
+	arg 0,temp
+	bbit0 state_inconn,app_check_one_plap_next
+	add rega,coffset_plap,contr
+	ifetcht 6,contr
+app_check_one_plap_next:
+	copy temp,pdata
+	ncall app_check_one_plap_device_exist,blank
+	istoret 6,regb
+	increase 6,regb
+	branch context_search_next
+app_check_one_plap_device_exist:
+	fetch 1,mem_device_nums
+	increase 1,pdata
+	store 1,mem_device_nums
+	rtn
+	
+app_check_conn_device_nums_addr:
+	jam 0,mem_device_nums
+	branch app_check_plap
+
+app_check_sniff:
+	fetch 1,mem_ui_state_map
+	isolate1 UI_STATE_BT_SNIFF,pdata
+	rtn
+
+//*****************************************//
+//*****************API********************//
+//*****************************************//
+app_clearflag_store:
+	setarg 0
+	branch app_flag_store
+app_initflag_store:
+	setarg EEPROM_INIT_FLAG
+app_flag_store:
+	store 2,mem_timeup
+	set1 mark_ext_patch,mark
+	bpatch patch3a_2,mem_patch3a
+	arg 2,temp
+	arg mem_timeup,rega
+	arg eeprom_module_init_flag,regb
+	branch iicd_write_eep_data
+
+//initflag is in eeprom to sure is eeprom nead to init
+app_initflag_check:
+	set1 mark_ext_patch,mark
+	bpatch patch3a_3,mem_patch3a
+	arg 2,temp
+	arg mem_pdatatemp,rega
+	arg eeprom_module_init_flag,regb
+	call iicd_read_eep_data
+	fetch 2,mem_pdatatemp
+	arg EEPROM_INIT_FLAG,temp
+	isub  temp,null
+	rtn
+
+
+app_start_auto_sniff:
+	fetch 1,mem_unsniff2sniff_timer
+	store 1,mem_unsniff2sniff_timer_count
+	rtn	
+	
+app_get_lpm_wake_lock:
+	arg wake_lock_app,queue
+	branch lpm_get_wake_lock
+
+app_put_lpm_wake_lock:
+	arg wake_lock_app,queue
+	branch lpm_put_wake_lock
+	
+app_lpm_wake_auto_lock:
+	jam  LPM_WAKE_UP_DELAY_TIMER,mem_wake_up_delay_timer
+	branch app_get_lpm_wake_lock
+app_lpm_wake_auto_lock_timer:
+	fetch 1,mem_wake_up_delay_timer
+	rtn blank
+	increase -1,pdata
+	store 1,mem_wake_up_delay_timer
+	nrtn blank
+	branch app_put_lpm_wake_lock
+
+app_l2cap_flow_control_enable:
+	jam L2CAP_FLOW_CTRL_ENABLE,mem_l2cap_flow_ctrl_flag
+	rtn
+
+app_l2cap_flow_control_disable:
+	jam L2CAP_FLOW_CTRL_DISABLE,mem_l2cap_flow_ctrl_flag
+	rtn
+	
+app_bt_set_pincode:
+	jam BT_CMD_SET_PIN_CODE,mem_fifo_temp
+	branch ui_ipc_send_cmd
+
+app_bt_role_switch:
+	jam BT_CMD_ROLE_SWITCH,mem_fifo_temp
+	branch ui_ipc_send_cmd
+	
+app_bt_start_reconnect:
+	set1 mark_ext_patch,mark
+	bpatch patch3a_4,mem_patch3a
+	fetch 1,mem_app_connection_options
+	store 1,mem_connection_options
+	jam APP_FLAG_RECONNECT,mem_reconnect_flag
+	jam BT_CMD_RECONNECT,mem_fifo_temp
+	branch ui_ipc_send_cmd	
+	
+app_bt_reconnect_cancel:
+	jam BT_CMD_BB_RECONN_CANCEL,mem_fifo_temp
+	branch ui_ipc_send_cmd
+	
+app_bt_disconnect:
+	jam BT_CMD_DISCONNECT,mem_fifo_temp
+	branch ui_ipc_send_cmd	
+
+app_bt_start_discovery_short:
+	fetch 2,mem_discovery_timeout
+	store 2,mem_discovery_timeout_timer_count
+app_bt_start_discovery_led_blink:
+	call app_led_start_blink
+app_bt_start_discovery:
+	jam BT_CMD_START_DISCOVERY,mem_fifo_temp
+	branch ui_ipc_send_cmd
+
+app_bt_stop_discovery:
+	setarg 0
+	store 2,mem_discovery_timeout_timer_count
+	jam BT_CMD_STOP_DISCOVERY,mem_fifo_temp
+	branch ui_ipc_send_cmd
+	
+app_ble_start_direct_adv:
+	jam BT_CMD_START_DIRECT_ADV,mem_fifo_temp
+	branch ui_ipc_send_cmd
+
+app_ble_stop_direct_adv:
+	jam BT_CMD_STOP_DIRECT_ADV,mem_fifo_temp
+	branch ui_ipc_send_cmd
+	
+app_ble_stop_adv:
+	jam BT_CMD_STOP_ADV,mem_fifo_temp
+	branch ui_ipc_send_cmd
+	
+app_ble_start_adv:	
+	jam BT_CMD_START_ADV,mem_fifo_temp
+	branch ui_ipc_send_cmd
+	
+app_ble_start_scan:
+	jam BT_CMD_LE_START_SCAN,mem_fifo_temp
+	branch ui_ipc_send_cmd
+	
+app_ble_stop_scan:
+	jam BT_CMD_LE_STOP_SCAN,mem_fifo_temp
+	branch ui_ipc_send_cmd
+	
+app_ble_start_conn:
+	jam BT_CMD_LE_START_CONN,mem_fifo_temp
+	branch ui_ipc_send_cmd
+	
+app_ble_disconnect:
+	jam BT_CMD_LE_DISCONNECT,mem_fifo_temp
+	branch ui_ipc_send_cmd
+
+app_ble_start_write:
+	jam BT_CMD_LE_START_WRITE,mem_fifo_temp
+	branch ui_ipc_send_cmd
+	
+app_led_start_blink:	
+	jam BT_CMD_LED_BLINK,mem_fifo_temp
+	branch ui_ipc_send_cmd
+
+app_led_on:
+	jam BT_CMD_LED_ON,mem_fifo_temp
+	branch ui_ipc_send_cmd
+	
+app_led_stop_blink:
+app_led_off:
+	jam BT_CMD_LED_OFF,mem_fifo_temp
+	branch ui_ipc_send_cmd
+	
+app_enter_hibernate:
+	jam BT_CMD_ENTER_HIBERNATE,mem_fifo_temp 
+	branch ui_ipc_send_cmd
+	
+app_bt_sniff_exit:
+	jam BT_CMD_EXIT_SNIFF,mem_fifo_temp
+	branch  ui_ipc_send_cmd
+	
+app_bt_enter_sniff:
+	jam BT_CMD_ENTER_SNIFF,mem_fifo_temp
+	branch ui_ipc_send_cmd
+
+app_ble_store_reconn_info:
+	jam BT_CMD_STORE_RECONN_INFO_LE,mem_fifo_temp
+	branch ui_ipc_send_cmd
+
+app_bt_store_reconn_info:
+	jam BT_CMD_STORE_RECONN_INFO_BT,mem_fifo_temp
+	branch ui_ipc_send_cmd
+	
+app_lpm_mult_enable:
+	set1 mark_lpm_mult_enable,mark
+	rtn
+
+app_lpm_mult_disable:
+	set0 mark_lpm_mult_enable,mark
+	rtn
+	
Index: btkb/program/at.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/at.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/at.prog	(working copy)
@@ -0,0 +1,1103 @@
+
+
+ifdef COMPILE_AT
+at_restore_param:
+	set1 mark_ext_patch,mark
+	bpatch patch32_0,mem_patch32
+	arg 32,temp
+	arg mem_le_name_len,rega
+	arg eeprom_module_ble_name_length,regb
+	call iicd_read_eep_data
+
+
+	arg 32,temp
+	arg mem_local_name_length,rega
+	arg eeprom_module_bt_name_length,regb
+	call iicd_read_eep_data
+
+	arg 6,temp
+	arg mem_lap,rega
+	arg eeprom_module_bt_adss,regb
+	call iicd_read_eep_data
+
+	arg 6,temp
+	arg mem_le_lap,rega
+	arg eeprom_module_le_adss,regb
+	call iicd_read_eep_data
+	call le_modified_name
+
+	arg 2,temp
+	arg mem_baud,rega
+	arg eeprom_module_trans_baud,regb
+	call iicd_read_eep_data
+	call uart_set_baud_by_mem
+
+	branch  at_restore_pin_code
+
+at_restore_pin_code:
+	arg 14,temp
+	arg mem_pin_length,rega
+	arg eeprom_module_pincode_length,regb
+	branch iicd_read_eep_data
+
+init_module_environment:
+	set1 mark_ext_patch,mark
+	bpatch patch32_1,mem_patch32
+	call app_initflag_check
+	branch at_restore_param,zero
+init_module_eeprom:
+	call at_store_bt_name
+	call at_store_le_name
+	call le_modified_name
+	call at_store_le_adss
+	call at_store_bt_adss
+	call pincode_reinit
+	call at_store_bt_pincode
+	call at_store_throughput_uart_baud115200
+	branch app_initflag_store
+
+at_store_bt_name:
+	fetcht 1,mem_local_name_length
+	increase 1,temp
+	arg mem_local_name_length,rega
+	arg eeprom_module_bt_name_length,regb
+	branch iicd_write_eep_data
+
+at_store_le_name:
+	fetcht 1,mem_le_name_len
+	increase 1,temp
+	arg mem_le_name_len,rega
+	arg eeprom_module_ble_name_length,regb
+	branch iicd_write_eep_data
+
+at_store_le_adss:
+	arg 6,temp
+	arg mem_le_lap,rega
+	arg eeprom_module_le_adss,regb
+	branch iicd_write_eep_data
+
+at_store_bt_adss:
+	arg 6,temp
+	arg mem_lap,rega
+	arg eeprom_module_bt_adss,regb
+	branch iicd_write_eep_data
+
+at_store_bt_pincode:
+	fetcht 1,mem_pin_length
+	increase 1,temp
+	arg mem_pin_length,rega
+	arg eeprom_module_pincode_length,regb
+	branch iicd_write_eep_data
+
+at_store_throughput_uart_baud115200:
+	setarg AT_baud_115200
+	store 2,mem_timeup
+at_store_throughput_uart_baud:
+	arg 2,temp
+	arg mem_timeup,rega
+	arg eeprom_module_trans_baud,regb
+	branch iicd_write_eep_data
+
+
+at_process:
+	set1 mark_ext_patch,mark
+	bpatch patch32_2,mem_patch32
+	fetch 2,mem_current_packet_length
+	arg 300,temp
+	isub temp,null
+	branch at_error_rev_end,positive
+	call check_module_disabled
+	call get_uart_rrptr
+	copy contru,rega
+	fetch 2,mem_current_packet_length
+	increase -2,pdata
+	iadd contru,contru
+	ifetch 2,contru
+	arg AT_CMD_END,temp
+	isub temp,null
+	nrtn zero		//the end is not \n
+	copy rega,contru
+	arg mem_prarm_atp,regb
+	arg 3,loopcnt
+	call string_compare_uart_follow
+	nbranch at_error_rev_end,true
+	branch at_dispatch
+	
+at_dispatch:
+	set1 mark_ext_patch,mark
+	bpatch patch32_3,mem_patch32
+/****************name****************/
+	copy contru,rega
+	arg mem_prarm_name,regb
+	force 4,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_name,true
+/****************lename****************/
+	arg mem_prarm_blename,regb
+	force 7,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_le_name,true
+/*****************adss****************/
+	arg mem_prarm_adss,regb
+	force 4,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_adss,true
+/*****************leadss*******************/
+	arg mem_prarm_bleadss,regb
+	force 7,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_leadss,true
+/*****************vers****************/
+	arg mem_prarm_vers,regb
+	force 4,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_vers,true
+/******************uart****************/
+	arg mem_prarm_uart,regb
+	force 4,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_uart,true
+/****************pswd******************/
+	arg mem_prarm_pswd,regb
+	force 4,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_pswd,true
+/****************class*********************/
+	arg mem_prarm_class,regb
+	force 5,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_class,true
+/*******************list******************/
+	arg mem_prarm_list,regb
+	force 4,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_list,true
+/****************role*********************/
+	arg mem_prarm_role,regb
+	force 4,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_role,true
+/****************sniff*********************/
+	arg mem_prarm_sniff,regb
+	force 5,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_sniff,true
+/****************ldev*********************/
+	arg mem_prarm_ldev,regb
+	force 4,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_ldev,true
+/****************rssi*********************/
+	arg mem_prarm_rssi,regb
+	force 4,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_rssi,true
+/****************cdev*********************/
+	arg mem_prarm_cdev,regb
+	force 4,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_cdev,true
+/****************inqr*********************/
+	arg mem_prarm_inqr,regb
+	force 4,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_inqr,true
+/****************leinqr*********************/
+	arg mem_prarm_bleinqr,regb
+	force 7,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_leinqr,true
+/****************cmode*********************/
+	arg mem_prarm_cmode,regb
+	force 5,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_cmode,true
+/****************mode*********************/
+	arg mem_prarm_mode,regb
+	force 4,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_mode,true
+/****************DMstate*********************/
+	arg mem_prarm_dmstate,regb
+	force 7,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_dmstate,true
+/****************reconn*********************/
+	arg mem_prarm_reconn,regb
+	force 6,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_reconn,true
+/***************discov*******************/	
+	arg mem_prarm_discov,regb
+	force 6,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_discov,true
+/****************dis*********************/
+	arg mem_prarm_dis,regb
+	force 3,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_dis,true
+/****************stsn*********************/
+	arg mem_prarm_stsn,regb
+	force 4,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_stsn,true
+/***************clrflg*******************/
+	arg mem_prarm_clrflg,regb
+	force 6,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_clrflg,true
+/*****************OTA******************/
+	arg mem_prarm_ota,regb
+	force 3,loopcnt
+	call string_compare_uart_follow
+	branch at_rev_ota,true
+	branch at_error_rev_end
+
+/****************name****************/
+at_rev_name:
+	ifetch 1,contru
+	beq AT_QUES,at_rev_name_inquiry
+	beq AT_EQU,at_rev_name_set
+	branch at_error_rev_end
+at_rev_name_inquiry:
+	call get_uart_twptr
+	call at_group_name_inquiry
+	branch at_nomal_rev_end
+	
+/****************lename****************/
+at_rev_le_name:
+	ifetch 1,contru
+	beq AT_QUES,at_rev_le_name_inquiry
+	beq AT_EQU,at_rev_le_name_set
+	branch at_error_rev_end
+at_rev_le_name_inquiry:
+	call get_uart_twptr
+	call at_group_le_name_inquiry
+	branch at_nomal_rev_end
+/*****************adss****************/
+at_rev_adss:
+	ifetch 1,contru
+	beq AT_QUES,at_rev_adss_inquiry
+	beq AT_EQU,at_rev_adss_set
+	branch at_error_rev_end
+at_rev_adss_inquiry:
+	call at_group_adss_inquiry
+	branch at_nomal_rev_end
+
+at_rev_leadss:
+	ifetch 1,contru
+	beq AT_QUES,at_rev_leadss_inquiry
+	beq AT_EQU,at_rev_leadss_set
+	branch at_error_rev_end
+at_rev_leadss_inquiry:
+
+	call at_group_leadss_inquiry
+	branch at_nomal_rev_end
+/*****************vers****************/
+at_rev_vers:
+	ifetch 1,contru
+	beq AT_QUES,at_rev_vers_inquiry
+	branch at_error_rev_end
+at_rev_vers_inquiry:
+	call at_group_version_inquiry
+	branch at_nomal_rev_end
+	
+/******************uart****************/
+at_rev_uart:
+	ifetch 1,contru
+	beq AT_EQU,at_rev_uart_set
+	branch at_error_rev_end
+	
+/****************pswd******************/
+at_rev_pswd:
+	ifetch 1,contru
+	beq AT_QUES,at_rev_pswd_inquiry
+	beq AT_EQU,at_rev_pswd_set
+	branch at_error_rev_end
+at_rev_pswd_inquiry:
+	call at_group_pswd_inquiry
+	branch at_nomal_rev_end
+/****************class*********************/
+at_rev_class:
+	ifetch 1,contru
+	beq AT_QUES,at_rev_class_inquiry
+	beq AT_EQU,at_rev_class_set
+	branch at_error_rev_end
+at_rev_class_inquiry:
+	call at_group_class_inquiry
+	branch at_nomal_rev_end
+/****************list*********************/
+at_rev_list:
+	ifetch 1,contru
+	beq AT_QUES,at_rev_list_inquiry
+	beq AT_EQU,at_rev_list_set
+	branch at_error_rev_end
+at_rev_list_inquiry:
+	call at_group_list_inquiry
+	branch at_nomal_rev_end
+/****************role*********************/
+at_rev_role:
+	ifetch 1,contru
+	beq AT_QUES,at_rev_role_inquiry
+	beq AT_EQU,at_rev_role_set
+	branch at_error_rev_end
+
+/****************sniff*********************/
+at_rev_sniff:
+	ifetch 1,contru
+	beq AT_QUES,at_rev_sniff_inquiry
+	beq AT_EQU,at_rev_sniff_set
+	branch at_error_rev_end
+at_rev_sniff_inquiry:
+	call at_group_sniff_inquiry
+	branch at_nomal_rev_end
+/****************ldev*********************/
+at_rev_ldev:
+	ifetch 1,contru
+	beq AT_QUES,at_rev_ldev_inquiry
+	branch at_error_rev_end
+at_rev_ldev_inquiry:
+	call at_group_ldev_inquiry
+	branch at_nomal_rev_end
+/****************rssi*********************/
+at_rev_rssi:
+	ifetch 1,contru
+	beq AT_QUES,at_rev_rssi_inquiry
+	branch at_nomal_rev_end
+at_rev_rssi_inquiry:
+	call context_check_idle
+	nbranch at_error_rev_end,zero
+	call at_group_rssi_inquiry
+	branch at_nomal_rev_end
+/****************cdev*********************/
+at_rev_cdev:
+	ifetch 1,contru
+	beq AT_QUES,at_rev_cdev_inquiry
+	branch at_error_rev_end
+at_rev_cdev_inquiry:
+	fetch 1,mem_context
+	bbit0 state_inconn,at_error_rev_end
+	call get_uart_twptr
+	fetch 1,mem_context+coffset_mode
+	bbit1 mode_le,le_cdev_inquiry
+	branch at_cdev_unle_inq
+le_cdev_inquiry:
+	arg mem_prarm_cdev,rega
+	arg 4,loopcnt
+	call at_group_inquiryhead_common
+	call at_rev_uart_write_62
+	setarg 0x34
+	istore 1,contwu
+	call at_rev_uart_write_44
+	arg mem_le_plap,rega
+	call adss_hex2string_to_uart
+	call uartd_send
+	branch at_nomal_rev_end
+at_cdev_unle_inq:
+	arg mem_prarm_cdev,rega
+	arg 4,loopcnt
+	call at_group_inquiryhead_common
+	call at_rev_uart_write_62
+	setarg 0x33
+	istore 1,contwu
+	call at_rev_uart_write_44
+	arg mem_plap,rega
+	call adss_hex2string_to_uart
+	call uartd_send
+	branch at_nomal_rev_end
+	
+/****************inqr*********************/
+at_rev_inqr:
+	set1 mark_ext_patch,mark
+	bpatch patch32_4,mem_patch32
+	call app_check_conn_device_nums_addr
+	fetch 1,mem_device_nums
+	bne 0,at_error_rev_end
+	call do_at_inquiry
+	branch at_nomal_rev_end
+
+at_rev_leinqr:
+	set1 mark_ext_patch,mark
+	bpatch patch32_5,mem_patch32
+	call do_at_leinquiry
+	branch at_nomal_rev_end
+/****************role*********************/
+at_rev_role_inquiry:
+	arg mem_prarm_role,rega
+	arg 4,loopcnt
+	call at_group_inquiryhead_common
+	call context_check_idle
+	nbranch at_rev_uart_write_N,zero
+	fetch 1,mem_context+coffset_mode
+	bbit1 mode_master,at_rev_uart_write_M
+	call at_rev_uart_write_S
+	call uartd_send
+	branch at_nomal_rev_end
+at_rev_uart_write_M:
+	setarg 0x4d
+	istore 1,contwu
+	call uartd_send
+	branch at_nomal_rev_end
+at_rev_uart_write_S:
+	setarg 0x53
+	istore 1,contwu
+	rtn
+/****************cmode*********************/
+at_rev_cmode:
+	ifetch 1,contru
+	beq AT_QUES,at_rev_cmode_inquiry
+	beq AT_EQU,at_rev_cmode_set
+	branch at_error_rev_end
+at_rev_cmode_inquiry:
+	call at_group_cmode_inquiry
+	branch at_nomal_rev_end
+/****************mode*********************/
+at_rev_mode:
+	ifetch 1,contru
+	beq AT_EQU,at_rev_mode_set
+	branch at_error_rev_end
+/****************dmstate*********************/
+at_rev_dmstate:
+	ifetch 1,contru
+	beq AT_QUES,at_rev_dmstate_inquiry
+	branch at_error_rev_end
+at_rev_dmstate_inquiry:
+	call at_group_dmstate_inquiry
+	branch at_nomal_rev_end
+/**************reconn****************/
+at_rev_reconn:
+	fetch 1,mem_app_connection_options
+	store 1,mem_connection_options
+	call eeprom_load_reconn_info
+	call app_check_conn_device_nums_addr
+	fetch 1,mem_device_nums
+	bne 0,at_error_rev_end
+	fetch 1,mem_xrecord_mode
+	beq REC_3_MODE,at_rev_unle_reconn
+	beq REC_4_MODE,at_rev_lereconn
+	branch at_error_rev_end
+/**************lereconn****************/
+at_rev_lereconn:
+	call app_ble_start_direct_adv
+	branch at_nomal_rev_end
+at_rev_unle_reconn:
+	call app_bt_start_reconnect
+	branch at_nomal_rev_end
+/**************dis****************/
+at_rev_dis:
+	call app_check_conn_device_nums_addr
+	fetch 1,mem_device_nums
+	bne 1,at_error_rev_end
+	fetch 1,mem_context+coffset_mode 
+	bbit1 mode_le,at_rev_ledis
+	call  app_bt_disconnect
+	branch at_nomal_rev_end
+	
+/**************ledis****************/
+at_rev_ledis:
+	call app_ble_disconnect
+	branch at_nomal_rev_end
+	
+/**************stsn****************/
+at_rev_stsn:
+	ifetch 1,contru
+	beq AT_EQU,at_rev_stsn_set
+	branch at_error_rev_end
+at_rev_stsn_set:
+	ifetch 1,contru
+	beq 0x31,at_exit_sniff
+	beq 0x30,at_enter_sniff
+	branch at_error_rev_end
+at_enter_sniff:
+	call app_check_sniff
+	branch at_nomal_rev_end,true
+	call app_bt_enter_sniff
+	branch at_nomal_rev_end
+at_exit_sniff:
+	call app_check_sniff
+	nbranch at_nomal_rev_end,true
+	call module_exit_sniff
+	call at_set_cmd_task_flag
+	branch at_nomal_rev_end
+	
+/***************clrflg*******************/
+at_rev_clrflg:
+	call app_clearflag_store
+	branch at_nomal_rev_end
+
+at_rev_ota:
+	ifetch 1,contru
+	beq AT_EQU,at_rev_ota_process
+	branch at_error_rev_end
+
+at_rev_discov:
+	call app_check_conn_device_nums_addr
+	fetch 1,mem_device_nums
+	bne 0,at_error_rev_end
+	call module_disconn_start
+	branch at_nomal_rev_end
+
+	
+/********************************************at FUNC*****************************************/
+
+/**************at_SET***********/
+at_rev_name_set:
+	arg mem_local_name,rega
+	call at_set_common
+	storet 1,mem_local_name_length
+	call at_store_bt_name
+	branch at_nomal_rev_end
+	
+at_rev_le_name_set:
+	arg  mem_le_name,rega
+	call at_set_common
+	storet 1,mem_le_name_len
+	call at_store_le_name
+ 	call le_modified_name
+	branch at_nomal_rev_end
+
+at_rev_adss_set:
+	arg mem_lap,contw
+	call adss_string2hex_from_uart
+	call at_store_bt_adss
+	branch at_nomal_rev_end
+
+at_rev_leadss_set:
+	arg mem_le_lap,contw
+	call adss_string2hex_from_uart
+	call at_store_le_adss
+	branch at_nomal_rev_end
+
+at_rev_pswd_set:
+	arg mem_pin,rega
+	call at_set_common
+	storet 1,mem_pin_length
+	call at_store_bt_pincode
+	branch at_nomal_rev_end
+
+at_rev_uart_set:
+	call string2dec_from_uart
+	setarg uart_clk
+	idiv temp
+	call wait_div_end
+	quotient pdata
+	store 2,mem_timeup
+	call at_store_throughput_uart_baud
+	branch at_nomal_rev_end
+
+at_rev_mode_set:
+	ifetch 1,contru
+	sub pdata,0x33,null
+	nbranch at_error_rev_end,positive
+	and pdata,0x3,pdata
+	store 1,mem_module_state
+	branch at_nomal_rev_end
+
+at_rev_class_set:
+	ifetch 3,contru
+	store 3,mem_class
+	branch at_nomal_rev_end
+	
+at_rev_role_set:
+	call context_check_idle
+	nbranch at_error_rev_end,zero
+	ifetch 1,contru
+	beq 0x53,at_role_slave
+	beq 0x4D,at_role_master
+	branch at_error_rev_end
+	
+at_role_slave:
+	fetch 1,mem_context+coffset_mode
+	bbit1 mode_master,at_switch_role
+	branch at_error_rev_end
+	
+at_role_master:
+	fetch 1,mem_context+coffset_mode
+	bbit0 mode_master,at_switch_role
+	branch at_error_rev_end
+	
+at_switch_role:
+	fetch 1,mem_module_task
+	set1 AT_TASK_SWITCH,pdata
+	store 1,mem_module_task
+	jam hci_cmd_role_switch,mem_hci_cmd
+	branch at_rev_end
+
+at_rev_sniff_set:
+	arg mem_sniff_param_interval,contw
+	call mem2_string2hex_from_uart
+	arg mem_sniff_param_attempt,contw
+	call mem2_string2hex_from_uart
+	arg  mem_sniff_param_timeout,contw
+	call mem2_string2hex_from_uart
+	branch at_nomal_rev_end
+
+at_rev_list_set:
+	ifetch 1,contru
+	beq 0x31,at_rev_list_set_1
+	beq 0x32,at_rev_list_set_2
+	branch at_error_rev_end
+at_rev_list_set_1:
+	ifetch 1,contru
+	arg mem_temp_lap,contw
+	call adss_string2hex_from_uart
+	call  eeprom_clear_bd_reconn_info
+	nrtn user
+	branch at_nomal_rev_end
+at_rev_list_set_2:
+	call eeprom_clear_all_reconn_info
+	branch at_nomal_rev_end
+	
+at_rev_cmode_set:
+	ifetch 1,contru
+	fetcht 1,mem_module_state
+	nsetflag blank,AT_STATE_CMODE,temp
+	storet 1,mem_module_state
+	branch at_nomal_rev_end,blank
+	ifetch 1,contru
+	arg mem_cmode_addr,contw
+	call adss_string2hex_from_uart
+	branch at_nomal_rev_end
+
+at_rev_ota_process:
+	set1 mark_ext_patch,mark
+	bpatch patch32_6,mem_patch32
+	arg 20,loopcnt
+	arg mem_l2cap_rxbuff1,contw
+	call uart_copy_rx_bytes
+	arg mem_l2cap_rxbuff1,rega
+	fetch 1,mem_l2cap_rxbuff1
+	compare OTA_WRITE_REQ,pdata,0xff
+	call prcp_parse_ota_write_req,true
+	fetch 1,mem_l2cap_rxbuff1
+	compare OTA_END_CMD,pdata,0xff
+	call prcp_parse_ota_end_cmd,true
+	branch at_nomal_rev_end
+	
+
+/***********************************at  INQUIRY******************************/
+/****************name****************/
+at_group_name_inquiry:
+	arg mem_prarm_name,rega
+	arg 4,loopcnt
+	call at_group_inquiryhead_common
+	fetch 1,mem_local_name_length
+	copy pdata,loopcnt
+	arg mem_local_name,contr
+	branch send_mem_to_uart0
+at_group_le_name_inquiry:
+	arg mem_prarm_blename,rega
+	force 7,loopcnt
+	call at_group_inquiryhead_common
+	call le_get_device_name
+	ifetch 1,contr	
+	copy pdata,loopcnt
+	branch send_mem_to_uart0
+	
+/****************adss****************/
+at_group_adss_inquiry:
+	arg mem_prarm_adss,rega
+	arg 4,loopcnt
+	call at_group_inquiryhead_common
+	arg mem_lap,rega
+	call adss_hex2string_to_uart
+	branch uartd_send
+at_group_leadss_inquiry:
+	arg mem_prarm_bleadss,rega
+	arg 7,loopcnt
+	call at_group_inquiryhead_common
+	arg mem_le_lap,rega
+	call adss_hex2string_to_uart
+	branch uartd_send
+
+/****************vers****************/
+at_group_version_inquiry:
+	arg mem_prarm_vers,rega
+	arg 4,loopcnt
+	call at_group_inquiryhead_common
+	arg 6,loopcnt
+	arg mem_module_version,contr
+	branch send_mem_to_uart0
+/****************class****************/
+at_group_class_inquiry:
+	arg mem_prarm_class,rega
+	arg 5,loopcnt
+	call at_group_inquiryhead_common
+	arg 3,loopcnt
+	arg mem_class,contr
+	branch send_mem_to_uart0
+/****************list****************/
+at_group_list_inquiry:
+	arg mem_prarm_list,rega
+	arg 4,loopcnt
+	call at_group_inquiryhead_common
+	call eeprom_load_bdaddr_list
+	call at_group_list_reply
+	branch uartd_send
+
+/****************ldev****************/
+at_group_ldev_inquiry:
+	call eeprom_load_reconn_bdaddr
+	arg mem_prarm_ldev,rega
+	arg 4,loopcnt
+	call at_group_inquiryhead_common
+	fetch 1,mem_record_bt_mode
+	beq REC_3_MODE,at_group_ldev_inquiry0
+	beq REC_4_MODE,at_group_ldev_inquiry0
+	branch uartd_send
+at_group_ldev_inquiry0:	
+	istore 1,contwu
+	call at_rev_uart_write_44
+	arg mem_temp_lap,rega
+	call adss_hex2string_to_uart
+	branch uartd_send
+/****************rssi****************/
+at_group_rssi_inquiry:
+	set1 mark_ext_patch,mark
+	bpatch patch32_7,mem_patch32
+	arg mem_prarm_rssi,rega
+	arg 4,loopcnt
+	call at_group_inquiryhead_common
+	call at_rssi_result
+	branch uartd_send
+at_rssi_result:
+	arg mem_rssi,rega
+	arg 1,loopcnt
+	branch hex2string_to_uart0
+/****************cdev****************/
+at_group_cdev_inquiry:
+	rtn
+
+/****************cmode****************/
+at_group_cmode_inquiry:
+	arg mem_prarm_cmode,rega
+	arg 5,loopcnt
+	call at_group_inquiryhead_common
+	arg mem_cmode_addr,rega
+	call adss_hex2string_to_uart
+	branch uartd_send
+
+/****************dmstate****************/
+at_group_dmstate_inquiry:
+	arg mem_prarm_dmstate,rega
+	arg 7,loopcnt
+	call at_group_inquiryhead_common
+	fetch 1,mem_module_state
+	copy pdata,rega
+	fetch 1,mem_context
+	isolate1 state_inconn,pdata
+	setflag true,AT_STATE_ISCONN,rega
+	isolate1 state_insniff,pdata
+	setflag true,AT_STATE_SNIFF,rega
+	fetch 1,mem_context+coffset_mode
+	isolate1 mode_master,pdata
+	setflag true,AT_STATE_ROLE,rega
+	isolate1 mode_le,pdata
+	setflag true,AT_STATE_LE,rega
+	copy rega,pdata
+	istore 1,contwu
+	branch uartd_send
+
+do_at_inquiry:
+	setarg param_glap
+	store 3,mem_glap
+	fetch 1,mem_at_using_flag
+	set1 AT_FLAG_INQ,pdata
+	store 1,mem_at_using_flag
+	branch do_at_inquiry0
+	
+do_at_leinquiry:
+	call app_check_conn_device_nums_addr
+	fetch 1,mem_device_nums
+	bne 0,at_error_rev_end
+	call app_ble_start_scan
+	fetch 1,mem_at_using_flag
+	set1 AT_FLAG_LEINQ,pdata
+	store 1,mem_at_using_flag
+	setarg 0x200
+	store 2,mem_at_scan_time
+	arg mem_prarm_bleinqr,rega
+	arg 6,loopcnt
+	call at_group_inquiryhead_common
+	call send_mem_to_uart0
+	branch at_rev_end
+
+
+/****************pswd****************/
+at_group_pswd_inquiry:
+	arg mem_prarm_pswd,rega
+	arg 4,loopcnt
+	call at_group_inquiryhead_common
+	fetch 1,mem_pin_length
+	copy pdata,loopcnt
+	arg mem_pin,contr
+	branch send_mem_to_uart0
+
+
+/*****************sniff*********************/
+at_group_sniff_inquiry:
+	arg mem_prarm_sniff,rega
+	arg 5,loopcnt
+	call at_group_inquiryhead_common
+	call at_rev_uart_write_62
+	setarg 84//T
+	istore 1,contwu
+	call at_rev_uart_write_colon
+	arg mem_sniff_param_interval,rega
+	call mem2_hex2string_to_uart
+	call at_rev_uart_write_62
+	setarg 65//A
+	istore 1,contwu
+	call at_rev_uart_write_colon
+	arg mem_sniff_param_attempt,rega
+	call mem2_hex2string_to_uart
+	call at_rev_uart_write_62
+	setarg 79//O
+	istore 1,contwu
+	call at_rev_uart_write_colon
+	arg mem_sniff_param_timeout,rega
+	call mem2_hex2string_to_uart
+	branch send_mem_to_uart0
+at_inquiry_reply:
+	call get_uart_twptr
+	call at_rev_uart_write_62
+	arg extm_lap,rega
+	call adss_hex2string_to_uart
+	call at_rev_uart_write_44
+	arg extm_class,rega
+	call mem3_hex2string_to_uart
+	call at_rev_uart_write_44
+	call at_rssi_result
+	branch uartd_send
+
+/*********************at do*************************/
+
+
+	
+/**************************************at inline*************************************/
+
+//input:rega length:loopcnt 
+//rtn:length:temp
+//note:at_rev_adss_set not use this
+at_set_common:
+	call at_set_setprarm
+	branch uart_copy_rx_bytes
+at_set_setprarm:
+	call uart_get_remain_length
+	copy pdata,temp
+	copy pdata,loopcnt
+	copy rega,contw
+	rtn
+
+//input:loopcnt 	contxt:rega
+at_group_inquiryhead_common:
+	call get_uart_twptr
+	call at_rev_uart_write_plus
+at_group_inquiryhead_common0:
+	copy rega,contr
+	call uart_copy_tx_bytes
+	branch at_rev_uart_write_colon
+
+	
+string_compare_uart_follow:
+	ifetch 1,contru
+	ifetcht 1,regb
+	isub temp,null
+	disable true
+	nbranch string_compare_uart_follow_diff, zero
+	increase 1,regb
+	loop string_compare_uart_follow
+	enable true
+	rtn
+string_compare_uart_follow_diff:
+	branch restore_contru
+
+
+at_rev_uart_write_plus:
+	setarg UI_PLUS
+	istore 1,contwu
+	rtn
+
+at_rev_uart_write_colon:
+	setarg UI_COLON
+	istore 1,contwu
+	rtn
+
+//>
+at_rev_uart_write_62:
+	setarg 62
+	istore 1,contwu
+	rtn
+at_rev_uart_write_N:
+	setarg 78
+	istore 1,contwu
+	call uartd_send
+	branch at_nomal_rev_end
+
+
+//,
+at_rev_uart_write_44:
+	setarg AT_COMMA
+	istore 1,contwu
+	rtn
+	
+restore_contru:
+	copy rega,contru
+	rtn
+
+at_group_list_reply:
+	arg mem_bdaddr_list_buff+7,regc
+	arg 4,loopcnt
+at_group_list_reply_loop:
+	copy loopcnt,pdata
+	store 1,mem_pdatatemp
+	ifetch 1,regc
+	beq REC_3_MODE,at_group_list_isrecord
+	beq REC_4_MODE,at_group_list_isrecord
+	branch at_group_list_notrecord
+at_group_list_isrecord:
+	call at_rev_uart_write_62
+	ifetch 1,regc
+	istore 1,contwu
+	increase 1,regc
+	call at_rev_uart_write_44
+	copy regc,rega
+	call adss_hex2string_to_uart
+at_group_list_notrecord0:
+	increase 6,regc
+	fetch 1,mem_pdatatemp
+	copy pdata,loopcnt
+	loop at_group_list_reply_loop
+	rtn
+at_group_list_notrecord:
+	increase 1,regc
+	branch at_group_list_notrecord0
+	
+	
+//rtn remain length
+uart_get_remain_length:
+	set1 mark_ext_patch,mark
+	bpatch patch33_0,mem_patch33
+	hfetch  2,core_uart_rrptr
+	isub contru,pdata
+	rtn zero
+	branch uart_get_remain_length0,positive
+uart_get_remain_length_common:
+	fetcht 2,mem_current_packet_length
+	iadd temp,pdata
+	increase -2,pdata
+	rtn
+uart_get_remain_length0:
+	call uart_get_rx_buff_length
+	iadd contru,temp
+	hfetch  2,core_uart_rrptr
+	isub temp,pdata
+	branch uart_get_remain_length_common
+
+uart_get_rx_buff_length:
+	arg mem_module_rx_buf_end,pdata
+	increase  1,pdata
+	arg mem_module_rx_buf,temp
+	isub temp,pdata
+	rtn
+
+release_packet:
+	fetcht 2,mem_current_packet_length
+	branch uartd_rxdone_by_len
+
+
+
+/********at_rev_end********/
+at_error_rev_end:
+	set1 mark_ext_patch,mark
+	bpatch patch33_1,mem_patch33
+	call get_uart_twptr
+	setarg 0x525245	//write err
+	istore 3,contwu
+	call uartd_send
+	branch at_rev_end
+	
+at_nomal_rev_end:
+	set1 mark_ext_patch,mark
+	bpatch patch33_2,mem_patch33
+	call get_uart_twptr
+	setarg 0x4b4f	//write ok
+	istore 2,contwu
+	call uartd_send
+spp_send_end:
+at_rev_end:
+	set1 mark_ext_patch,mark
+	bpatch patch33_3,mem_patch33
+	call release_packet
+spp_ipc_end:
+	setarg 0
+	store 2,mem_current_packet_length
+	store 4,mem_last_uart_clock
+	rtn
+else
+
+at_app_dispatch:
+at_check_state:
+at_process:
+at_ble_dispatch:
+at_unble_dispatch:
+at_rev_name:
+at_rev_name_inquiry:
+at_rev_adss:
+at_rev_adss_inquiry:
+at_rev_vers:
+at_rev_vers_inquiry:
+at_rev_uart:
+at_rev_uart_inquiry:
+at_rev_pswd:
+at_rev_pswd_inquiry:
+at_rev_class:
+at_rev_class_inquiry:
+at_rev_clrcfg:
+at_rev_name_set:
+at_ble_name_set:
+at_rev_adss_set:
+at_ble_adss_set:
+at_rev_adss_set_common:
+at_rev_pswd_set:
+at_rev_uart_set:
+at_rev_class_set:
+at_group_name_inquiry:
+at_group_adss_inquiry:
+at_group_version_inquiry:
+at_group_class_inquiry:
+at_group_uart_inquiry:
+at_baud_get:
+at_group_pswd_inquiry:
+at_unknow_command:
+at_reset:
+at_set_common:
+at_set_setprarm:
+	branch assert
+at_group_inquiryhead_common:
+at_group_inquiryhead_common0:
+string_compare_uart_follow:
+string_compare_uart_follow_diff:
+at_rev_uart_write_plus:
+at_rev_uart_write_colon:
+restore_contru:
+uart_Juge_apacket:
+uart_packet_first_char:
+uart_get_remain_length:
+uart_get_remain_length_common:
+uart_get_remain_length0:
+uart_get_rx_buff_length:
+release_packet:
+at_error_rev_end:
+at_nomal_rev_end:
+at_rev_end:
+spp_send_end:
+at_inquiry_reply_eir:
+at_rssi_result:
+at_inquiry_reply:
+	branch assert
+
+ 
+endif
+
Index: btkb/program/bt.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/bt.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/bt.prog	(working copy)
@@ -0,0 +1,4854 @@
+define REVD
+//define FPGA
+define PATCH
+define ROMCODE
+//define RAM_VERSION
+//define CLK6M
+//define DEBUG_MALLOC
+//define DEBUG_H4LOG_ENABLE
+//define DEBUG_LIGHT_STATE
+//define E2_LOG
+//define LMP_DBG
+
+define SIMPLE_PAIRING
+define COMPILE_RFCOMM
+define COMPILE_SHUTTER
+define COMPILE_HCI_BCSP
+define COMPILE_IR
+define COMPILE_KEYBOARD
+define COMPILE_MOUSE
+define COMPILE_MODULE
+define COMPILE_AT
+define COMPILE_PRCP
+define COMPILE_USB
+define COMPILE_DONGLE
+define COMPILE_LE
+
+INCLUDE "bt_format"
+
+org 0x0000		// start from patch ram address start
+ifdef ROMCODE
+ifdef SIM
+include sim.prog
+else
+include patch.prog
+endif
+
+/******************************************/
+/***********   ROM Start   ***************/
+/******************************************/
+
+ifdef RAM_VERSION
+org 0x4000
+else
+org 0x3000		// start from rom address start
+endif
+start:
+	call lpmstate
+else
+
+/******************************************/
+/***********   RAM Start   ***************/
+/******************************************/
+
+start:
+	setarg 0xef21
+	hstore 2,core_clkoff
+	hfetch 8,core_gpio_wakeup_low
+	store 8,mem_gpio_wakeup_low
+	hfetch 1,core_misc_status
+	bbit1 2,soft_reset				// skip wake process if loaded by e
+	fetch 4,mem_sleep_counter
+	arg -1,rega
+	isub rega,null
+	nbranch soft_reset,zero
+	deposit auxcnt
+	branch lpm_hibernate,blank	// continue to hibernate
+	disable wake
+endif
+
+
+soft_reset:
+	set0 mark_ext_patch,mark
+	bpatch patch00_0,mem_patch00
+	clear_stack
+	call initialize_radio
+	call iicd_init_12m
+	call init_param
+	call l2cap_init
+	set0 mark_ext_patch,mark
+	bpatch patch00_1,mem_patch00
+	call rfcomm_init
+	call init_lmp
+	call ui_init
+	call app_init
+	set0 mark_ext_patch,mark
+	bpatch patch00_2,mem_patch00
+	call app_lpm_init,wake
+ifdef SIMPLE_PAIRING
+	call sp_initialize
+else
+	call ssp_disable
+endif
+	call lpm_recover_clk,wake
+main_loop:	
+	set0 mark_ext_patch,mark
+	bpatch patch00_3,mem_patch00
+ifdef SIMPLE_PAIRING
+	call sp_calc_sequence
+endif
+	call le_dispatch
+	call hci_dispatch
+	set0 mark_ext_patch,mark
+	bpatch patch00_4,mem_patch00
+	call idle_dispatch
+	call app_process_idle
+	call inquiry_dispatch
+	set0 mark_ext_patch,mark
+	bpatch patch00_5,mem_patch00
+	call inquiry_scan_dispatch
+	call page_scan_dispatch
+	call connection_dispatch
+	call lpm_dispatch
+	branch main_loop
+
+connection_dispatch:
+	call connection_incontext
+	rtnmark0 mark_context
+	set0 mark_context,mark
+	call context_save
+	branch le_disable
+	
+connection_incontext:
+	set0 mark_ext_patch,mark
+	bpatch patch00_6,mem_patch00
+	call context_search_insniff
+	nbranch connection_nosniff,zero
+	call context_load
+	add rega,coffset_mode,contr
+	ifetch 1,contr
+	bbit1 mode_le,le_conn_dispatch
+	bbit1 mode_master, master_dispatch
+	branch slave_dispatch
+connection_nosniff:
+	set0 mark_ext_patch,mark
+	bpatch patch00_7,mem_patch00
+	call context_get_next
+	copy loopcnt,null
+	rtn zero
+	call context_load
+	fetch 1,mem_state
+	bbit1 state_inpage,master_page
+	fetch 1,mem_mode
+	bbit1 mode_master, master_dispatch
+	branch slave_dispatch
+
+
+
+/**************************************/
+/**************idle dispatch*********/
+/**************************************/
+	
+idle_dispatch:
+	fetch 1,mem_hci_cmd
+	rtn blank
+	beq hci_cmd_inquiry,idle_inquiry
+	beq hci_cmd_inquiry_cancel,idle_inquiry_cancel
+	beq hci_cmd_remote_name_req,idle_remote_name_req
+	beq hci_cmd_create_conn,idle_create_conn
+	beq hci_cmd_le_create_conn,idle_le_create_conn
+	call context_search_conn_handle
+	rtn zero
+	call context_search_plap
+	rtn zero
+idle_exit:
+	jam 0,mem_hci_cmd
+	rtn
+
+idle_le_create_conn:
+	jam hci_cmd_le_create_conn,mem_cmd_le_create_conn
+	jam 0,mem_hci_cmd
+	rtn
+	
+idle_inquiry:
+	set1 mark_inquiry_on,mark
+	set0 mark_inquiry_trainb,mark
+	jam param_ninquiry,mem_ninqy_index
+	jam 31,mem_nfreq_index_inq
+	branch idle_exit
+
+idle_inquiry_cancel:
+	set0 mark_inquiry_on,mark
+	force 0,stop_watch
+	branch idle_exit
+
+idle_remote_name_req:
+	call context_search_plap
+	rtn zero
+	force LMP_NAME_REQ,temp
+	jam 5,mem_nameres_cnt
+	branch idle_start_page
+
+idle_create_conn:
+	set0 mark_ext_patch,mark
+	bpatch patch01_0,mem_patch01
+	fetch 1,mem_device_option
+	beq dvc_op_hci,idle_create_conn_hci
+idle_create_conn_device:
+	fetch 6,mem_hci_plap
+	branch idle_exit,blank
+	jam RECONNECT_HID,memui_reconnect_mode
+	//jam HS_INIT_CALL,mem_hs_mode //init as master
+	jam CONN_SM_WAIT_FEATURES_RES,mem_conn_sm
+	branch idle_create_conn_cont
+	
+idle_create_conn_hci:
+	fetch 6,mem_hci_plap
+	branch idle_exit,blank
+	store 6,mem_plap
+idle_create_conn_cont:
+	force LMP_VERSION_REQ,temp
+idle_start_page:
+	set0 mark_ext_patch,mark
+	bpatch patch01_1,mem_patch01
+	fetch 1,mem_page_mode
+	branch idle_page_mode_r0,blank
+	lshift3 pdata,pdata
+	lshift4 pdata,pdata
+	increase -1,pdata
+idle_page_mode_r0:
+	store 1,mem_npage
+	store 1,mem_npage_index
+	jam 31,mem_nfreq_index_page
+	set0 mark_page_trainb,mark
+	call context_new
+	nbranch idle_page_fail,zero
+	call get_free_amaddr
+	store 1,mem_amaddr
+	storet 1,mem_lmo_opcode2
+	fetch 6,mem_hci_plap
+	store 6,mem_plap
+	set0 mark_ext_patch,mark
+	bpatch patch01_2,mem_patch01
+	force 0,pdata
+	compare LMP_NAME_REQ,temp,0xff
+	nsetflag true,state_init_seq,pdata
+	set1 state_inpage,pdata
+	store 1,mem_state
+	jam BT_EVT_RECONN_STARTED,mem_fifo_temp
+	call ui_ipc_send_event
+	force 0,pdata
+	setflag true,smap_name_req,pdata
+	store 1,mem_state_map
+	setarg 0
+	set1 mode_master,pdata
+	store 1,mem_mode
+	enable master
+	call context_save
+	disable master
+	force page_length_timer,queue
+	fetch 2,mem_page_to
+	call timer_init
+	branch idle_exit
+idle_page_fail:
+	set0 mark_ext_patch,mark
+	bpatch patch01_3,mem_patch01
+	fetch 6,mem_hci_plap
+	store 6,mem_plap
+	compare LMP_NAME_REQ,temp,0xff
+	branch idle_name_fail,true
+	force HCI_ERROR_MEMORY_FULL,temp
+	call hci_send_connection_error
+	branch idle_exit
+idle_name_fail:
+	arg mem_tmp_buffer,contw
+	arg 8,loopcnt
+	call memset0
+	force HCI_ERROR_MEMORY_FULL,queue
+	call hci_send_name
+	jam BT_EVT_RECONN_FAILED,mem_fifo_temp
+	call ui_ipc_send_event
+	branch idle_exit
+	
+
+/******************************************/
+/**************  Inquiry  *****************/
+/******************************************/
+
+inquiry_dispatch:
+	rtnmark0 mark_inquiry_on
+	force inquiry_length_timer,queue
+	call timer_check
+	nsetflag blank,mark_inquiry_on,mark
+	nbranch inquiry_start,blank
+	rtn
+	
+
+
+inquiry_start:
+	set0 mark_ext_patch,mark
+	bpatch patch01_4,mem_patch01
+	fetcht 2,mem_inq_window
+	force 4,queue
+	call sniff_check_window
+	rtn user
+	call afh_clear
+	force 0,freq_mode
+inquiry_restart:
+	rtn timeout
+	set0 mark_fhs_already_good,mark
+	set0 mark_fhs_eir,mark
+inquiry_rx_restart:
+	add clkn_bt,1,bt_clk
+	isolate1 mark_inquiry_trainb,mark
+	setflag true,2,freq_mode
+	compare 0x00,bt_clk,0x02      /* see if this is even slot */
+	nbranch inquiry_receive,true
+
+inquiry_transmit:
+	set0 mark_ext_patch,mark
+	bpatch patch01_5,mem_patch01
+	fetch 1,mem_inquiry_transmit
+	increase 1,pdata
+	store 1,mem_inquiry_transmit
+	call fetch_giac
+	call tx_radio_freq
+	call fetch_diac
+	call start_transmitter	/* get ready for that id packet */
+	call start_tx_native
+	call send_access_word
+	call end_of_packet
+	call inquiry_check_train
+	branch inquiry_restart
+
+inquiry_check_train:
+	set0 mark_ext_patch,mark
+	bpatch patch01_6,mem_patch01
+	fetch 1,mem_nfreq_index_inq
+	increase -1,pdata
+	store 1,mem_nfreq_index_inq
+	rtn positive  /* if it's time to incremnt N */
+	jam 31,mem_nfreq_index_inq
+	fetch 1,mem_ninqy_index
+	increase -1,pdata
+	store 1,mem_ninqy_index
+	rtn positive      /* if it's time to change train */
+	setflip mark_inquiry_trainb,mark
+	jam param_ninquiry,mem_ninqy_index
+	rtn
+
+inquiry_receive:
+	set0 mark_ext_patch,mark
+	bpatch patch01_7,mem_patch01
+	call fetch_giac
+	call rx_radio_freq
+	call fetch_diac
+	call start_rx_native
+	call start_receiver	/* get ready for that id packet */
+	call wait_access_clkn_rt
+	branch inquiry_sync,sync   /* try look for id packet again if not found */
+	call inquiry_check_train
+	branch inquiry_rx_restart
+inquiry_sync:
+	set0 mark_ext_patch,mark
+	bpatch patch02_0,mem_patch02
+	call save_rssi
+	call scan_mode_whiten
+	call receive_packet_whitened
+	set0 mark_rxbuf_inuse,mark
+	rtnmark0 mark_fhs_already_good
+inquiry_receive_rtn:
+	set0 mark_ext_patch,mark
+	bpatch patch02_1,mem_patch02
+	fetch 1,mem_at_using_flag
+	bbit1 AT_FLAG_INQ,at_inquiry_reply
+	call hci_inquiry_reply
+inquiry_receive_eir_rtn:
+	fetch 1,mem_inquiry_rcv
+	increase 1,pdata
+	store 1,mem_inquiry_rcv
+	rtn
+inquiry_receive_eir:
+	set0 mark_fhs_already_good,mark
+	call rf_setup_time_slave_slot_eir
+	call fetch_giac
+	call rx_radio_freq
+	call init_rx_packet_flags
+	call start_rx_native	/* start listening at start_rx time */
+	call start_receiver
+	call wait_access_clkn_rt
+	branch inquiry_receive_eir_packet,sync   /* try look for id packet again if not found */
+	rtn
+inquiry_receive_eir_packet:
+	call scan_mode_whiten
+	call receive_packet_whitened
+	set0 mark_rxbuf_inuse,mark		/*open recive pkt*/
+	branch inquiry_receive_rtn,crc_failed
+	call hci_inquiry_reply_eir
+	branch inquiry_receive_eir_rtn
+	
+rf_setup_time_slave_slot_eir:
+	arg param_rf_setup, timeup
+rf_setup_time_eir:
+	until clkn_rt,meet
+	and clkn_bt,3,pdata
+	bne 1,rf_setup_time_eir
+	rtn
+	
+	
+/******************************************/
+/**************  Master Dispatch  *************/
+/******************************************/
+
+
+
+master_page:
+	set0 mark_ext_patch,mark
+	bpatch patch02_2,mem_patch02
+	enable master
+	enable clknt
+	fetch 2,mem_page_interval
+	branch master_page_no_interval,blank
+	force page_interval_timer,queue
+	call timer_check               
+	nrtn blank
+master_page_no_interval:
+	set0 mark_ext_patch,mark
+	bpatch patch02_3,mem_patch02
+	fetcht 2,mem_page_window
+	force 40,queue
+	call sniff_check_window
+	branch page_exit,user
+	force page_length_timer,queue
+	call timer_check
+	nbranch page_start,blank
+	fetch 1,mem_state_map
+	bbit1 smap_name_req,master_npage_timeout
+	force HCI_ERROR_PAGE_TIMEOUT,temp
+	call hci_send_connection_error
+	branch master_page_timeout
+master_npage_timeout:
+	arg mem_tmp_buffer,contw
+	arg 8,loopcnt
+	call memset0
+	force HCI_ERROR_PAGE_TIMEOUT,queue
+	call hci_send_name
+master_page_timeout:
+	set0 mark_ext_patch,mark
+	bpatch patch02_4,mem_patch02
+	jam 0,mem_state
+	call init_lmp_work
+	jam 0,memui_reconnect_mode
+	jam BT_EVT_RECONN_PAGE_TIMEOUT,mem_fifo_temp
+	call ui_ipc_send_event	
+	branch page_exit
+
+page_start:
+	set0 mark_ext_patch,mark
+	bpatch patch02_5,mem_patch02
+	force 0,timeup
+	until clkn_rt,meet
+	fetch 1,mem_page_clk
+	increase -1,pdata
+	ixor clkn_bt,pdata
+	compare 0,pdata,3
+	nbranch page_start,true
+	deposit am_addr
+	store 1,mem_fhs_am_addr
+	force 0,N_tx_slot
+	force 0,freq_mode
+
+page_restart:
+	set0 mark_ext_patch,mark
+	bpatch patch02_6,mem_patch02
+	branch page_exit,timeout
+	call fetch_page_bt_adr
+	arg param_rf_setup, timeup
+	until clkn_rt,meet         /* wait for the start_receiver time against native real clk  */
+page_rx_restart:
+	set0 mark_ext_patch,mark
+	bpatch patch02_7,mem_patch02
+	fetch 4,mem_page_clk    /* deposit clk_estimate */
+	iforce bt_clk
+	increase 1,pdata
+	store 4,mem_page_clk
+	isolate1 mark_page_trainb,mark
+	setflag true,2,freq_mode
+	compare 0x00,bt_clk,0x02      /* see if this is even slot */
+	nbranch page_receive,true
+	fetch 1, mem_page_transmit
+	increase 1,pdata
+	store 1, mem_page_transmit
+	call tx_radio_freq
+	call start_transmitter	/* get ready for that id packet */
+	call start_tx_native
+	call send_access_word
+	call end_of_packet
+	call page_check_train
+	branch page_restart	
+master_dispatch_exit:
+page_exit:
+	set0 mark_ext_patch,mark
+	bpatch patch03_0,mem_patch03
+	disable master
+	fetch 2,mem_page_interval      
+	rtn blank
+	force page_interval_timer,queue
+	branch timer_init              
+
+page_check_train:
+	set0 mark_ext_patch,mark
+	bpatch patch03_1,mem_patch03
+	fetch 1,mem_nfreq_index_page
+	increase -1,pdata
+	store 1,mem_nfreq_index_page
+	rtn positive
+	jam 31,mem_nfreq_index_page
+	fetch 1,mem_npage_index
+	increase -1,pdata                 /* increment N */
+	store 1,mem_npage_index
+	rtn positive      			/* if it's time to change train */
+	setflip mark_page_trainb,mark             /* change train */
+	fetch 1,mem_npage
+	store 1,mem_npage_index
+	rtn
+	
+page_receive:
+	set0 mark_ext_patch,mark
+	bpatch patch03_2,mem_patch03
+	call rx_radio_freq
+	call start_rx_native
+	call start_receiver	/* get ready for that id packet */
+	call wait_access_clkn_rt	/* try id look for id packet again */
+	branch page_sync,sync         /* restart if didn't receive anything */
+	call page_check_train
+	branch page_rx_restart
+page_sync:
+	call end_of_packet
+	fetch 1, mem_page_rcv
+	increase 1,pdata
+	store 1, mem_page_rcv
+	force 0,stop_watch
+	fetch 4,mem_page_clk
+page_send_fhs:
+	set0 mark_ext_patch,mark
+	bpatch patch03_3,mem_patch03
+	call rf_setup_time_master_slot
+	call fetch_page_bt_adr
+	increase 1,N_tx_slot
+page_send_fhs_continue:
+	and_into 0x1fd,bt_clk
+	and_into 0x1fc,freq_mode               /* master response = x00, even_train settin must remain the same */
+	call tx_radio_freq
+	call start_transmitter	/* get ready for that id packet */
+	call start_tx_native
+	call send_access_word
+	deposit clkn_bt
+	store 4,mem_clkn_bt
+	force 0,am_addr
+	force type_fhs,type
+	call scan_mode_whiten
+	call transmit_packet_whitened
+page_wait_fhs_reply:
+	set0 mark_ext_patch,mark
+	bpatch patch03_4,mem_patch03
+	call rf_setup_time_slave_slot
+	or_into 0x02,bt_clk
+	and_into 0x1fc,freq_mode               /* master response sequence = x00, even train setting must be preserved */
+	call rx_radio_freq
+	call start_rx_native
+	call start_receiver	/* get ready for that id packet */
+	call wait_access_clkn_rt	/* look for that reply */
+	call end_of_packet,sync              /* id reply is enough */
+	branch page_wait_fhs_reply_ok,sync           /* no reply then send fhs again */
+	fetch 1,mem_fhs_wait_counter
+	branch page_restart,blank
+	increase -1,pdata
+	store 1,mem_fhs_wait_counter
+	branch page_send_fhs
+	
+page_wait_fhs_reply_ok:
+	set0 mark_ext_patch,mark
+	bpatch patch03_5,mem_patch03
+	fetch 1, mem_page_rcv_fhs
+	increase 1,pdata
+	store 1, mem_page_rcv_fhs
+	call prepare_newconn
+master_newconn_loop:
+	call master_newconn_once
+	branch newconn_poll_responded,sync
+	call new_conn_timeout
+	nbranch master_newconn_loop,blank
+	branch page_restart
+
+newconn_poll_responded:
+	set0 mark_ext_patch,mark
+	bpatch patch03_6,mem_patch03
+	fetch 1,mem_state
+	set0 state_inpage,pdata
+	store 1,mem_state
+	call newconn_init
+	disable master
+	rtn
+	
+
+master_dispatch:
+	set0 mark_ext_patch,mark
+	bpatch patch03_7,mem_patch03
+	enable master
+	enable clknt
+	call role_switch_master
+	rtn user
+	call check_bt_disabled
+	call rf_setup_time_master_slot
+	add clkn_bt,1,bt_clk
+	call fetch_self_bt_adr
+	force 0x03,freq_mode
+	call load_esco
+	call get_sco_data
+	call scheduler_tx_l2cap_pkt
+	call prepare_tx
+	call tx_radio_freq
+	call start_transmitter
+	call start_tx_native
+	call send_access_word
+	call transmit_packet
+master_loop:
+	set0 mark_ext_patch,mark
+	bpatch patch04_0,mem_patch04
+	call parse_lmp
+	call process_cmd
+	call hci_send_num_complete_packets
+	call master_conn_recv_packet
+	nbranch master_notmatch,match
+	call supervision_flush
+	call parse_l2cap
+	fetch 1,mem_master_rcvcnt
+	increase 1,pdata
+	store 1,mem_master_rcvcnt
+master_notmatch:
+	set0 mark_ext_patch,mark
+	bpatch patch04_1,mem_patch04
+	call scheduler_process
+	call check_master_disconnect
+	nrtn master					/* disconnected */
+	call check_attempt
+	nbranch master_attempt,blank
+master_exit:
+	call process_sco_data
+	call restore_esco
+	disable master
+	rtn
+
+master_attempt:
+	call prepare_tx
+	call master_conn_send_packet
+	branch master_loop
+
+
+check_master_disconnect:
+	branch check_master_match,match
+	call supervision_update
+	branch master_disconnect,positive
+check_master_match:
+	call check_disconnect_timeout
+	nbranch master_disconnect,user
+	fetch 1,mem_state_map
+	rtnbit0 smap_name_req
+	rtnbit1 smap_name_res
+	fetch 1,mem_op
+	rtnbit1 op_disconn
+	call conn_timer_expired
+	nrtn blank
+	fetch 1,mem_nameres_cnt
+	increase -1,pdata
+	store 1,mem_nameres_cnt
+	nrtn blank
+	branch lmp_disconnect
+
+master_disconnect:
+	set0 mark_ext_patch,mark
+	bpatch patch04_2,mem_patch04
+	call quit_connection
+	disable master
+	fetch 1,mem_state_map
+	bbit1 smap_name_req,master_name_disconnect
+	fetch 1,mem_state
+	bbit0 state_conn_comp,master_disconnect_quiet
+	fetcht 1,mem_conn_handle
+	branch hci_send_disconn_complete
+master_disconnect_quiet:
+	force HCI_ERROR_CONNECTION_TIMEOUT,temp
+	branch hci_send_connection_error
+master_name_disconnect:
+	force HCI_SUCCESS,queue
+	fetch 1,mem_state_map
+	bbit1 smap_name_res,hci_send_name
+master_name_error:
+	force HCI_ERROR_PAGE_TIMEOUT,queue
+	arg mem_tmp_buffer,contw
+	arg 8,loopcnt
+	call memset0
+	branch hci_send_name
+	
+disconnect_stop_sco:
+	set0 mark_ext_patch,mark
+	bpatch patch04_3,mem_patch04
+	fetch 1,mem_state
+	rtnbit0 state_insco
+	fetcht 1,mem_conn_handle
+	fetch 1,mem_sco_asso_handle
+	isub temp,null
+	nrtn zero
+	call stop_esco  //include sco
+	branch restore_esco_check_no_mark
+
+check_disconnect_timeout:
+	set0 mark_ext_patch,mark
+	bpatch patch04_4,mem_patch04
+	enable user
+	fetch 1,mem_op
+	rtnbit0 op_disconn
+	call conn_timer_expired
+	nrtn blank
+disable_usr:
+	disable user
+	rtn
+
+conn_timer_expired:
+	fetch 1,mem_conn_timer
+	increase -1,pdata
+	store 1,mem_conn_timer
+	rtn
+
+linkkey_ready:
+	set0 mark_ext_patch,mark
+	bpatch patch04_5,mem_patch04
+	fetch 1,mem_state
+	bbit1 state_linkkey,linkkey_set
+	fetch 1,mem_device_option
+	beq dvc_op_hci,linkkey_send_hci
+	fetch 1,mem_pairing_auth
+	branch linkkey_set,blank
+	jam DEFALT_PAIRING_AUTH,mem_pairing_auth
+	jam BT_EVT_LINKKEY_GENERATE,mem_fifo_temp
+	call ui_ipc_send_event
+	branch linkkey_set
+linkkey_send_hci:
+	call check_localsm
+	ncall hci_send_linkkey_notification,true
+linkkey_set:
+	set0 mark_ext_patch,mark
+	bpatch patch04_6,mem_patch04
+	call context_traverse_linkkey
+	fetch 1,mem_state
+	set1 state_linkkey,pdata
+	store 1,mem_state
+	jam 1,mem_link_key_exists
+	fetch 1,mem_conn_sm
+	bne CONN_SM_PAIRING,linkkey_set_continue
+linkkey_set_continue:
+	rtn
+
+generate_linkkey_continue:
+	jam PAIRING_AUTH,mem_pairing_auth
+clear_linkstate:
+	fetch 1,mem_state
+	set0 state_linkkey,pdata
+	store 1,mem_state
+	rtn
+	
+
+	/* rtn user if switch */
+role_switch_check:
+	set0 mark_ext_patch,mark
+	bpatch patch04_7,mem_patch04
+	disable user
+	fetch 1,mem_state
+	rtnbit0 state_insniff
+	fetch 2,mem_tsniff
+	nrtn blank
+	fetch 4,mem_sniff_anchor
+	branch role_switch_clkn,clknt
+	isub clke_bt,pdata
+	branch role_switch_clke
+role_switch_clkn:
+	isub clkn_bt,pdata
+role_switch_clke:
+	sub pdata,4,null
+	nrtn positive
+	fetch 1,mem_state
+	set0 state_insniff,pdata
+	store 1,mem_state
+	enable user
+	rtn
+
+	/* pdata: switch instant, set tsniff=0 for special sniff */	
+role_switch_prepare:
+	copy pdata,temp
+	set0 mark_ext_patch,mark
+	bpatch patch05_0,mem_patch05
+	store 4,mem_sniff_anchor
+role_switch_prepare0:
+	jam SWITCH_FLAG_ACCEPT,mem_switch_flag
+	fetch 1,mem_state
+	set1 state_insniff,pdata
+	store 1,mem_state
+	force 0,pdata
+	store 2,mem_tsniff
+	jam 10,mem_current_sniff_attempt		// allow 10 more polls or nulls afterwards
+	jam 1,mem_sniff_attempt
+	rtn
+
+
+role_switch_master:
+	set0 mark_ext_patch,mark
+	bpatch patch05_1,mem_patch05
+	call role_switch_check
+	nrtn user
+	disable user
+	jam param_newconnto,mem_newconnto_counter
+	set0 mark_fhs_already_good,mark
+roles_waitfhs_loop:
+	call rf_setup_time_master_slot
+	call master_recv_packet
+	bmark1 mark_fhs_already_good,roles_replyto_fhs
+	call new_conn_timeout
+	nbranch roles_waitfhs_loop,blank
+role_switch_fail_master:
+	set0 mark_ext_patch,mark
+	bpatch patch05_2,mem_patch05
+	disable user
+	deposit clkn_bt
+	store 4,mem_next_btclk
+	enable clknt
+	enable master
+	jam BT_EVT_SWITCH_FAIL_MASTER,mem_fifo_temp
+	branch ui_ipc_send_event
+	
+roles_replyto_fhs:
+	set0 mark_ext_patch,mark
+	bpatch patch05_3,mem_patch05
+	call rf_setup_time_slave_slot
+	call master_send_packet
+	disable clknt
+	disable master
+	call apply_switch_clke
+	call prepare_newconn
+roles_newconns_loop:
+	set0 mark_ext_patch,mark
+	bpatch patch05_4,mem_patch05
+	call slave_newconn_once
+	branch roles_newconns_responded,match
+	call new_conn_timeout
+	nbranch roles_newconns_loop,blank
+	branch role_switch_fail_master
+roles_newconns_responded:
+	force 1,temp
+	call hci_send_role_change
+	fetch 1,mem_mode
+	set0 mode_master,pdata
+	store 1,mem_mode
+	call supervision_flush
+	call calc_clke_offset
+	enable user
+	jam BT_EVT_SWITCH_SUCCESS_MASTER,mem_fifo_temp
+	branch ui_ipc_send_event
+
+	
+load_esco:
+	set0 mark_ext_patch,mark
+	bpatch patch05_5,mem_patch05
+	rtnmark0 mark_esco
+	fetch 1,mem_state
+	rtnbit0 state_insco
+load_esco_do:
+	call init_esco_ibuff
+	fetch 1,mem_esco_arq
+	fetcht 1,mem_arq
+	storet 1,mem_esco_saved_arq
+	store 1,mem_arq
+	deposit am_addr
+	store 1,mem_saved_amaddr
+	fetch 1,mem_esco_addr
+	iforce am_addr
+	set0 mark_esco_rxok,mark	
+	fetch 1,mem_last_type
+	store 1,mem_last_type_saved
+	fetch 1,mem_last_type_esco
+	store 1,mem_last_type
+	rtn
+
+restore_esco:
+	set0 mark_ext_patch,mark
+	bpatch patch05_6,mem_patch05
+	rtnmark0 mark_esco	
+restore_esco_check_no_mark:
+	call check_esco_amaddr
+	nrtn true
+restore_esco_do:
+	call clear_got_tx
+	fetch 1,mem_esco_saved_arq
+	fetcht 1,mem_arq
+	store 1,mem_arq
+	storet 1,mem_esco_arq
+	fetch 1,mem_saved_amaddr
+	iforce am_addr
+	fetch 1,mem_last_type
+	store 1,mem_last_type_esco
+	fetch 1,mem_last_type_saved
+	store 1,mem_last_type
+	setarg 0xffff
+	store 2,mem_retransmission_cnt
+	rtn
+
+
+
+
+context_load:
+	set0 mark_ext_patch,mark
+	bpatch patch05_7,mem_patch05
+	set1 mark_context,mark
+	deposit rega
+	store 2,mem_context_ptr
+	force context_size,loopcnt
+	arg mem_le_state,contw
+	add rega,coffset_mode,contr
+	ifetch 1,contr
+	copy rega,contr
+	bbit1 mode_le,memcpy
+	arg mem_state,contw
+	call memcpy
+	disable attempt
+	fetch 1,mem_amaddr
+	iforce am_addr
+	jam 1,mem_current_sniff_attempt
+	branch context_load_master,master
+	jam 1,mem_current_sniff_attempt
+context_load_master:
+	fetch 1,mem_state
+	rtnbit0 state_insniff
+	fetch 1,mem_sniff_attempt
+	store 1,mem_current_sniff_attempt
+	fetch 1,mem_sniff_timeout
+	store 1,mem_current_sniff_timeout
+	rtn
+	
+context_save:
+	set0 mark_ext_patch,mark
+	bpatch patch06_0,mem_patch06
+	fetch 2,mem_context_ptr
+	iforce contw
+	force context_size,loopcnt
+	arg mem_le_state,contr
+	branch memcpy,le
+	arg mem_state,contr
+	branch memcpy
+
+	
+
+context_get_next:
+	fetcht 1,mem_current_context
+	arg context_num,loopcnt
+context_get_next_loop:
+	increase 1,temp
+	compare context_num,temp,0xff
+	nbranch context_get_next_cont,true
+	arg 0,temp
+context_get_next_cont:
+	storet 1,mem_current_context
+	mul32 temp,context_size,pdata
+	arg mem_context,rega
+	iadd rega,rega
+	ifetch 1,rega
+	bbit1 state_insniff,context_get_next_sniff
+	rtnbit1 state_inconn
+	rtnbit1 state_inpage
+context_get_next_sniff:
+	loop context_get_next_loop
+	rtn
+	
+context_new:
+	set0 mark_ext_patch,mark
+	bpatch patch06_1,mem_patch06
+	arg context_search_empty,regc
+	call context_search
+	nrtn zero					// all occupied
+	deposit rega
+	store 2,mem_context_ptr
+	force 0,null
+	rtn
+	
+	//return zero if anyone's wack is 1.
+	//return nzero if all wack is 0
+context_check_all_wack:
+	call check_esco_amaddr
+	branch context_check_esco_wack,true
+	fetch 2,mem_context_ptr
+	add pdata,coffset_arq,contw
+	fetch 1,mem_arq
+	istore 1,contw
+	arg context_check_a_wack,regc
+	branch context_search
+
+context_check_esco_wack:
+	fetch 1,mem_arq
+	isolate1 wack,pdata
+	branch context_esco_wack,true
+	force 1,null
+	rtn
+context_esco_wack:
+	force 0,null
+	rtn
+	
+	//rtn nzero if idle(no conn)
+context_check_idle:
+	arg context_check_inconn,regc
+	branch context_search
+	
+context_traverse_linkkey:
+	fetcht 2,mem_context_ptr
+	arg context_traverse_clearkey,regc
+	branch context_search
+	
+context_traverse_max_slot:
+	fetcht 2,mem_context_ptr
+	arg context_traverse_mslot,regc
+	branch context_search
+	
+	/* return zero if conn handle is found */
+context_search_conn_handle:
+	fetcht 1,mem_hci_conn_handle
+context_search_conn_handle2:
+	arg context_search_handle,regc
+	branch context_search
+	/* return zero if plap is found */
+context_search_plap:
+	set0 mark_ext_patch,mark
+	bpatch patch06_2,mem_patch06
+	fetcht 6,mem_hci_plap
+context_search_plap2:
+	arg context_search_lap,regc
+	branch context_search
+	/* return zero if sniff anchor is meet and rega pointers to context */
+context_search_insniff:
+	arg context_search_sniff,regc
+	branch context_search
+	/* return zero if sniff window is in content with current transaction */
+context_search_sniff_window:
+	arg context_search_window,regc
+context_search:
+	set0 mark_ext_patch,mark
+	bpatch patch06_3,mem_patch06
+	arg mem_context,rega
+	force context_num,loopcnt
+context_search_loop:
+	ifetch 1,rega
+	copy regc,pc
+context_search_next:
+	increase context_size,rega
+	loop context_search_loop
+	force 1,null
+	rtn
+
+context_search_empty:
+	bbit1 state_inconn,context_search_next
+	bbit1 state_inpage,context_search_next
+	force 0,null
+	rtn
+	
+context_search_lap:
+	bbit1 state_inpage,context_search_lap_cont
+	bbit0 state_inconn,context_search_next
+context_search_lap_cont:
+	add rega,coffset_plap,contr
+	ifetch 6,contr
+	isub temp,null
+	rtn zero
+	branch context_search_next
+
+context_search_handle:
+	bbit0 state_inconn,context_search_next
+	add rega,coffset_conn_handle,contr
+	ifetch 1,contr
+	isub temp,null
+	rtn zero
+	branch context_search_next
+
+context_search_sniff:
+	bbit0 state_insniff,context_search_next
+context_search_sniff_loop:
+	call context_get_anchor
+	bbit1 27,context_search_sniff_cont
+	isolate0 27,temp
+	branch context_search_sniff_cont,true
+	set1 28,pdata								/* case:0 - fffffff */
+context_search_sniff_cont:
+	isub temp,pdata
+	increase 1,pdata
+	branch context_search_sniff_miss,positive
+	increase 5,pdata
+	nbranch context_search_next,positive
+context_search_meet:
+	copy temp,bt_clk
+	call context_next_anchor
+	force 0,null
+	rtn
+
+context_search_sniff_miss:
+	iforce regb
+	add rega,coffset_tsniff,contr
+	ifetch 2,contr
+	branch context_search_meet,blank
+	call context_next_anchor
+	branch context_search_sniff_loop
+
+context_check_inconn:
+	bbit0 state_inconn,context_search_next
+	force 0,null 				// found
+	rtn
+	
+context_check_a_wack:
+	bbit0 state_inconn,context_search_next
+	add rega,coffset_mode,contr
+	ifetch 1,contr
+	bbit1 mode_le,context_search_next
+	add rega,coffset_arq,contr
+	ifetch 1,contr
+	bbit0 wack,context_search_next
+	force 0,null 				// found
+	rtn
+
+context_get_anchor:
+	add rega,coffset_mode,contr
+	ifetcht 1,contr
+	deposit clkn_bt
+	isolate1 mode_master,temp
+	add rega,coffset_sniff_anchor,contr
+	ifetcht 4,contr
+	rtn true
+	add rega,coffset_clk_offset,contr
+	ifetch 6,contr
+	call calc_clke2
+	deposit clke_bt
+	rtn
+
+context_next_anchor:
+	add rega,coffset_tsniff,contr
+	add rega,coffset_sniff_anchor,contw
+	ifetch 2,contr
+	iadd temp,timeup			/* wrap to 28 bits */
+	deposit timeup
+	istore 4,contw
+	branch le_context_nexthop
+	
+
+context_search_window:
+	bbit0 state_insniff,context_search_next
+	call context_get_anchor
+	iadd stop_watch,pdata
+	iadd stop_watch,pdata
+	iadd queue,pdata
+	isub temp,null
+	nbranch context_search_next,positive
+	force 0,null
+	rtn
+
+context_traverse_mslot:
+	bbit0 state_inconn,context_search_next
+	deposit temp
+	isub rega,null
+	branch context_search_next,null
+	add rega,coffset_mode,contr
+	ifetch 1,contr
+	bbit1 mode_le,context_search_next
+	add rega,coffset_lmp_to_send,contw
+	ifetch 1,contw
+	nbranch context_search_next,blank
+	force LMP_MAX_SLOT,pdata
+	istore 1,contw
+	branch context_search_next
+
+context_traverse_clearkey:
+	bbit0 state_inconn,context_search_next
+	deposit temp
+	isub rega,null
+	branch context_search_next,null
+	add rega,coffset_mode,contr
+	ifetch 1,contr
+	bbit1 mode_le,context_search_next
+	ifetch 1,rega
+	set0 state_linkkey,pdata
+	istore 1,rega
+	branch context_search_next
+
+	
+master_conn_send_packet:
+	set0 mark_ext_patch,mark
+	bpatch patch06_4,mem_patch06
+	call rf_setup_time_master_slot
+master_send_packet:
+	add clkn_bt,1,bt_clk          /* master start to use native clock */
+	call fetch_self_bt_adr
+	force 0x03,freq_mode          /* we are in connection!! */
+	call tx_radio_freq
+	call start_transmitter
+	call start_tx_native
+	call send_access_word
+	branch transmit_packet
+
+master_conn_recv_packet:
+	set0 mark_ext_patch,mark
+	bpatch patch06_5,mem_patch06
+	call rf_setup_time_slave_slot
+master_recv_packet:
+	add clkn_bt,1,bt_clk          /* master start to use native clock */
+	call fetch_self_bt_adr
+	force 0x03,freq_mode          /* we are in connection!! */
+	call rx_radio_freq
+	call init_rx_packet_flags
+	call prep_crypt
+	call start_rx_native	/* start listening at start_rx time */
+	call start_receiver
+master_rx_conn_finish_packet:
+	call wait_access_clkn_rt	/* master use native clock */
+	nrtn sync
+	call save_rssi
+	branch receive_packet
+	
+	
+
+master_newconn_once:
+	set0 mark_ext_patch,mark
+	bpatch patch06_6,mem_patch06
+	fetch 1,mem_fhs_am_addr
+	iforce am_addr			//review
+	force type_poll,type
+	call master_conn_send_packet
+	branch master_conn_recv_packet
+
+
+
+
+
+
+/******************************************/
+/************* Inquiry Scan ***************/
+/******************************************/
+
+inquiry_scan_dispatch:
+	fetch 1,mem_scan_mode
+	rtnbit0 inq_scan_mode
+	force iscan_interval_timer,queue
+	call timer_check
+	nrtn blank
+	fetcht 2,mem_iscan_window
+	force 4,queue
+	call sniff_check_window
+	rtn user
+	call inquiry_scan_start
+	force iscan_interval_timer,queue
+	fetch 2,mem_iscan_interval
+	nbranch timer_init,sync
+	random pdata				/* inquiry scan backoff */
+	iand mask3ff,pdata
+	branch timer_init
+	
+
+inquiry_scan_start:
+	set0 mark_ext_patch,mark
+	bpatch patch06_7,mem_patch06
+	jam 0,mem_fhs_am_addr
+	disable clknt
+	disable attempt
+	call afh_clear
+	and clkn_bt,0x1fc,bt_clk      /* freeze the clock, set bit[1] 0, this is version 1.1 */
+	force 0x01,freq_mode     /* slave in inquiry scan, kind of same as inquriy_response, this is version 1.1 */
+	call fetch_giac
+	call rx_radio_freq
+	setflip mark_inquiry_state,mark
+	fetch 1,mem_inquiryscan_waitcnt
+	increase 1,pdata
+	store 1,mem_inquiryscan_waitcnt
+	call fetch_diac
+	call start_receiver	/* get ready for that id packet */
+	call wait_access_forever	/* until there is timeout, or matched (true) */
+	nrtn sync
+	set0 mark_ext_patch,mark
+	bpatch patch07_0,mem_patch07
+	force 0,stop_watch
+	call shutdown_radio	/* must have heard */
+	fetch 1,mem_inquiryscan_rcvcnt
+	increase 1,pdata
+	store 1,mem_inquiryscan_rcvcnt
+	call fetch_giac
+	call rf_setup_time_slave_slot
+	or_into 0x002,bt_clk               /* put clk(1) to 1 */
+	force 0x01,freq_mode               /* slave in inquriy and page, response only */
+	call tx_radio_freq
+	call fetch_diac
+	call start_transmitter	/* get ready for that id packet */
+	call start_tx_external
+	deposit clkn_bt
+	store 4,mem_clkn_bt
+	call send_access_word
+	force type_fhs,type
+	force 0,am_addr                       /* put 0 into am_addr field for fhs */
+	call scan_mode_whiten
+	call transmit_packet_whitened
+	call send_eir
+	and_into 0x1fd,bt_clk                 /* put clk(1) back to 0 */
+	increase 1,N_tx_slot
+	rtn
+
+send_eir:
+	set0 mark_ext_patch,mark
+	bpatch patch07_1,mem_patch07
+	fetch 1,mem_eir_enable
+	rtn blank
+	arg mem_eir,contw
+	fetch 1,mem_local_name_length
+	copy pdata,loopcnt
+	increase 1,pdata
+	istore 1,contw	
+	copy contw,temp
+	increase 1,pdata
+	store 2,mem_tx_len	
+	copy temp,contw
+	setarg 0x09  //type:name
+	istore 1,contw		
+	arg  mem_local_name,contr
+	call memcpy       //name
+	arg mem_all_uuid_128bits,regc
+	arg 4,loopcnt
+	call get_all_uuid
+	arg mem_all_uuid_16bits,regc
+	arg 1,loopcnt
+	call get_all_uuid
+	force type_dm3,type		/* DM3 */
+	jam 2,mem_tx_lch
+	setarg mem_eir
+	store 2,mem_txptr
+	call rf_setup_time_slave_slot
+	call tx_radio_freq
+	call start_transmitter	/* get ready for that id packet */
+	call start_tx_external
+	call send_access_word
+	call scan_mode_whiten
+	call transmit_packet_whitened
+	rtn
+
+
+get_all_uuid:
+	copy contw,temp
+	copy regc,contr
+	ifetch 1,contr
+	rtn blank
+lshift_loop:
+	lshift pdata,pdata
+	loop lshift_loop
+	copy pdata,rega
+	increase 2,pdata
+	copy pdata,queue
+	fetch 2,mem_tx_len
+	iadd queue,pdata
+	store 2,mem_tx_len
+	copy temp,contw
+	copy rega,pdata
+	increase 1,pdata
+	istore 1,contw
+	copy regc,contr
+	ifetch 1,contr
+	ifetch 1,contr	//fetch type
+	istore 1,contw
+	copy rega,loopcnt
+	branch memcpy  //copy uuid
+	
+/******************************************/
+/******** Slave dispatch ***********/
+/******************************************/
+
+page_scan_dispatch:	
+	fetch 1,mem_scan_mode
+	rtnbit0 page_scan_mode
+	force pscan_interval_timer,queue
+	call timer_check
+	nrtn blank
+	fetcht 2,mem_pscan_window
+	force 40,queue
+	call sniff_check_window
+	rtn user
+	force 0,am_addr
+	jam param_pagerespto,mem_fhs_wait_counter
+	set0 mark_fhs_already_good,mark
+	call page_scan_start
+	force pscan_interval_timer,queue
+	fetch 2,mem_pscan_interval
+	branch timer_init
+	
+
+page_scan_start:
+	set0 mark_ext_patch,mark
+	bpatch patch07_2,mem_patch07
+	disable clknt
+	call afh_clear
+	fetch 1,mem_pagescan_waitcnt
+	increase 1,pdata
+	store 1,mem_pagescan_waitcnt
+	force 0,N_tx_slot
+	call fetch_self_bt_adr
+	add clkn_bt,1,bt_clk      /* freeze the clock on native clock until scan window is up */
+	force 0x02, freq_mode     /* slave in inquiry and page, not response */
+	set0 mark_ext_patch,mark
+	bpatch patch07_3,mem_patch07
+	call rx_radio_freq
+	call start_receiver	/* wait for that id packet from master */
+	call wait_access_forever
+	nrtn sync                          /* pscan window timeout occured, back to dispatch */
+	call shutdown_radio	/* got the id packet */
+	fetch 1,mem_pagescan_rcvcnt
+	increase 1,pdata
+	store 1,mem_pagescan_rcvcnt
+	force 0,stop_watch
+	call rf_setup_time_slave_slot
+	or_into 0x002,bt_clk               /* put clk(1) to 1 */
+	force 0x01,freq_mode               /* slave in inquriy and page, response only */
+	call tx_radio_freq
+	call start_transmitter
+	call start_tx_external
+	call send_access_word
+	call end_of_packet
+	force 0,am_addr
+	arg param_rf_setup, timeup
+	until clke_rt,meet
+	or_into 0x03,clke_bt
+	and_into 0x1fd,bt_clk
+page_scan_wait_fhs_restart:
+	set0 mark_ext_patch,mark
+	bpatch patch07_4,mem_patch07
+	increase 1,N_tx_slot
+	call rx_radio_freq
+	call start_receiver
+	call wait_access_mhalfbnd
+	nbranch page_scan_wait_fhs_again,sync	/* go back if didn't find access code */
+	call scan_mode_whiten
+	call receive_packet_whitened
+	bmark1 mark_fhs_already_good,page_scan_reply_to_fhs
+page_scan_wait_fhs_again:
+	set0 mark_ext_patch,mark
+	bpatch patch07_5,mem_patch07
+	fetch 1,mem_fhs_wait_counter
+	rtn blank
+	increase -1,pdata
+	store 1,mem_fhs_wait_counter
+	call rf_setup_time_master_slot	/* set up expiration time */
+	branch page_scan_wait_fhs_restart
+
+
+page_scan_reply_to_fhs:
+	set0 mark_ext_patch,mark
+	bpatch patch07_6,mem_patch07
+	set0 1,clke_bt
+	set1 0,clke_bt
+	fetch 1,mem_pagescan_rcvfhscnt
+	increase 1,pdata
+	store 1,mem_pagescan_rcvfhscnt
+	call rf_setup_time_slave_slot
+	or_into 0x02,bt_clk
+	call tx_radio_freq
+	call start_transmitter
+	call start_tx_external
+	call send_access_word
+	call end_of_packet
+slave_apply_clke_bt:
+	compare 0x03,clke_bt,0x03
+	branch slave_apply_clke_bt_now,true
+	until null,mhalfbnd
+	branch slave_apply_clke_bt
+slave_apply_clke_bt_now:
+	fetch 4,mem_clke_bt
+	or_into 0x03,pdata
+	icopy clke_bt
+
+start_slave_connection:
+	set0 mark_ext_patch,mark
+	bpatch patch07_7,mem_patch07
+	fetch 6,extm_lap
+	store 6,mem_plap
+	call prepare_newconn
+slave_newconn_loop:
+	call slave_newconn_once
+	branch sconn_successful,match     /* we were talked to */
+	call new_conn_timeout
+	nbranch slave_newconn_loop,blank
+	rtn
+
+	
+sconn_successful:
+	set0 mark_ext_patch,mark
+	bpatch patch08_0,mem_patch08
+	call newconn_init
+	call context_new
+	nrtn zero
+	jam 0,mem_mode
+	call calc_clke_offset
+	branch context_save
+
+
+slave_dispatch:
+	set0 mark_ext_patch,mark
+	bpatch patch08_1,mem_patch08
+	call calc_clke
+	call role_switch_slave
+	rtn user
+	call load_esco
+	call get_sco_data
+slave_loop:
+	set0 mark_ext_patch,mark
+	bpatch patch08_2,mem_patch08
+	call check_bt_disabled
+	call scheduler_process
+	call slave_conn_recv_packet	/* go listen for a packet */
+	call slave_savelist
+	nbranch slave_notmatch,match
+	call supervision_flush
+	call parse_l2cap
+	call scheduler_tx_l2cap_pkt
+	call prepare_tx
+	call slave_conn_send_packet
+	call parse_lmp
+	call process_cmd
+	call hci_send_num_complete_packets
+	fetch 1,mem_slave_rcvcnt
+	increase 1,pdata
+	store 1,mem_slave_rcvcnt
+	call calc_clke_offset
+slave_notmatch:
+	set0 mark_ext_patch,mark
+	bpatch patch08_3,mem_patch08
+	call lpm_set_mult
+	call supervision_update
+	branch slave_disconnect,positive
+	call check_disconnect_timeout
+	nbranch slave_disconnect,user
+	call check_attempt
+	nbranch slave_loop,blank
+	call process_sco_data
+	branch restore_esco
+
+
+slave_disconnect:
+	set0 mark_ext_patch,mark
+	bpatch patch08_4,mem_patch08
+	jam 0,mem_tester_emulate
+	jam 0,mem_debug_config
+	call quit_connection
+	set0 mark_testmode,mark
+	call test_enable_white
+	fetch 1,mem_state
+	bbit0 state_conn_comp,slave_connection_fail
+	fetcht 1,mem_conn_handle
+	branch hci_send_disconn_complete
+
+slave_connection_fail:
+	force HCI_ERROR_KEY_MISSING,temp
+	branch hci_send_connection_error
+
+role_switch_slave:
+	set0 mark_ext_patch,mark
+	bpatch patch08_5,mem_patch08
+	call role_switch_check
+	nrtn user
+	copy am_addr,temp
+	call get_free_amaddr
+	store 1,mem_fhs_am_addr
+	copy temp,am_addr
+	jam param_newconnto,mem_newconnto_counter
+roles_sendfhs_loop:
+	set0 mark_ext_patch,mark
+	bpatch patch08_6,mem_patch08
+	call rf_setup_time_master_slot
+	force type_fhs,type
+	call slave_send_access
+	deposit clkn_bt
+	store 4,mem_clkn_bt
+	call transmit_packet
+	call rf_setup_time_slave_slot
+	enable user3
+	call slave_receive_access
+	branch roles_got_fhs_reply,sync
+	call shutdown_radio
+	call new_conn_timeout
+	nbranch roles_sendfhs_loop,blank
+	rtnmark0 mark_accept_switch
+	jam LMP_SLOT_OFFSET,mem_lmo_opcode2
+	set1 mark_switch_initiated,mark
+	rtn
+roles_got_fhs_reply:
+	enable clknt
+	call prepare_newconn
+	call afh_clear
+roles_newconn_loop:
+	set0 mark_ext_patch,mark
+	bpatch patch08_7,mem_patch08
+	call master_newconn_once
+	branch roles_newconn_responded,sync
+	call new_conn_timeout
+	nbranch roles_newconn_loop,blank
+	disable clknt
+	deposit clke_bt
+	store 4,mem_next_btclk
+	rtn
+roles_newconn_responded:
+	force 0,temp
+	call hci_send_role_change
+	enable master
+	bmark0 mark_accept_switch,roles_newconn_nolmp
+	set0 mark_accept_switch,mark
+	jam LMP_ACCEPTED,mem_lmo_opcode2
+	jam LMP_HOST_CONNECTION_REQ,mem_lmi_opcode2
+	call tid_set_reply
+roles_newconn_nolmp:
+	deposit am_addr
+	store 1,mem_amaddr
+	force 0,pdata
+	store 6,mem_clk_offset
+	fetch 1,mem_mode
+	set1 mode_master,pdata
+	store 1,mem_mode
+	call supervision_flush
+	disable master
+enable_user:
+	enable user
+	rtn
+
+	
+
+init_rx_packet_flags:
+	set0 mark_ext_patch,mark
+	bpatch patch09_0,mem_patch09
+	disable match
+	set0 mark_loopback,mark
+	set0 mark_am_addr_broadcast,mark          /* initialize slave flags */
+	set0 mark_longpacket,mark
+	set0 mark_old_packet,mark
+	fetch 1,mem_arq    /* mem_arq + am_addr */
+	set0 arqnx,pdata
+	set1 flowx,pdata
+	store 1,mem_arq
+	rtn
+
+prepare_newconn:
+	set0 mark_ext_patch,mark
+	bpatch patch09_1,mem_patch09
+	jam param_newconnto,mem_newconnto_counter
+	jam param_newconn_arq,mem_arq
+	fetch 2,mem_rx_window_init
+	store 2,mem_rx_window
+	deposit clkn_bt
+	store 4,mem_next_btclk
+	rtn clknt
+	deposit clke_bt
+	store 4,mem_next_btclk
+	rtn
+
+newconn_init:
+	set0 mark_ext_patch,mark
+	bpatch patch09_2,mem_patch09
+	call init_lmp_reinit
+	call new_conn_handle
+	store 1,mem_conn_handle
+	setarg param_supervision_to
+	store 2,mem_supervision_to
+	fetch 1,mem_state
+	set1 state_inconn,pdata
+	store 1,mem_state
+	jam 0,mem_op
+	jam 0,mem_state_map
+	jam 0,mem_lpm_current_mult
+	branch supervision_flush
+	
+
+clear_linkkey:
+	set0 mark_ext_patch,mark
+	bpatch patch09_3,mem_patch09
+	force 0,pdata
+	store 8,mem_link_key
+	istore 8,contw
+	call clear_linkstate
+	branch context_traverse_linkkey
+	
+new_conn_timeout:
+	fetch 1,mem_newconnto_counter
+	increase -1,pdata
+	store 1,mem_newconnto_counter
+	rtn
+
+new_conn_handle:
+	fetch 1,mem_handle_num
+	increase 1,pdata
+	store 1,mem_handle_num
+	rtn
+
+
+quit_connection:
+	set0 mark_ext_patch,mark
+	bpatch patch09_4,mem_patch09
+	call disconnect_stop_sco
+	fetch 1,mem_hci_cmd
+	beq hci_cmd_remote_name_req,quit_connection_name
+	fetch 1,mem_lmp_to_send
+	bne LMP_NAME_REQ,quit_connection_cont
+quit_connection_name:
+	call cmd_check_plap
+	nbranch quit_connection_cont,zero
+	call master_name_error
+	jam 0,mem_hci_cmd
+quit_connection_cont:
+	set0 mark_ext_patch,mark
+	bpatch patch09_5,mem_patch09
+	call app_disconn_reason_collect_bt
+	call process_cmd				/* clear pending command */
+	call sniff_exit
+	jam BT_EVT_BB_DISCONNECTED,mem_fifo_temp
+	call ui_ipc_send_event
+	call init_lmp_work
+	call l2cap_init_work
+ifdef SIMPLE_PAIRING
+	call sp_initialize
+endif
+	fetch 1,mem_state
+	set0 state_inconn
+	store 1,mem_state
+	jam 0,memui_reconnect_mode
+
+	fetch 1,mem_state_map
+	compare 0x0,pdata,0xc0
+	branch quit_connection_not_clear_mark,true
+	set0 mark_rxbuf_inuse,mark
+quit_connection_not_clear_mark:
+	fetch 1,mem_arq
+	bbit0 wack,quit_connection_not_clear_tx
+quit_connection_not_clear_tx:
+	fetch 1,mem_op
+	rtnbit0 op_txl2cap
+	set0 mark_tx_l2cap,mark
+	rtn
+
+slave_newconn_once:
+	set0 mark_ext_patch,mark
+	bpatch patch09_6,mem_patch09
+	fetch 1,extm_newconn_am_addr
+	rtn blank     
+	icopy am_addr
+	call slave_conn_recv_packet
+	nrtn match
+	force type_null,type
+	call slave_conn_send_packet
+	deposit am_addr
+	store 1,mem_amaddr                 /* now the new am_addr is official */
+	force 0,pdata
+	store 1,extm_newconn_am_addr
+	rtn
+
+
+/******************************************/
+/********  Time consuming task  ***********/
+/******************************************/
+prepare_tx:
+	set0 mark_ext_patch,mark
+	bpatch patch09_7,mem_patch09
+	fetch 1,mem_state
+	bbit0 state_insco,prepare_tx_not_sco
+	force type_hv3,type
+	bmark0 mark_esco,prepare_tx_not_esco
+	call check_esco_amaddr
+	nbranch prepare_tx_not_sco,true
+	branch prepare_tx_not_sco,attempt	
+	call set_wait_ack					/* send esco only at the first attempt */
+	setarg 2		/* esco only has 1 retry */
+	store 2,mem_retransmission_cnt
+	rtn
+prepare_tx_not_esco:
+	nrtn attempt						/* send sco only at the first attempt */
+prepare_tx_not_sco:
+	set0 mark_ext_patch,mark
+	bpatch patch0a_0,mem_patch0a
+	call context_check_all_wack			 //abandon mark_retransmit, use context_check_all_wack instead.
+	nbranch prepare_tx_no_retransmit,zero
+	fetch 1,mem_arq
+	bbit0 wack,prepare_tx_pollnull		/* other wack, tx buffer in use, but not me */
+prepare_tx_retransmit:
+	bmark1 mark_loopback,prepare_tx_loopback
+	fetch 1,mem_debug_config
+	bbit1 debug_tx_pattern,prepare_tx_txpat
+	fetch 2,mem_retransmission_cnt
+	increase -1,pdata
+	store 2,mem_retransmission_cnt
+	branch prepare_tx_nomore_retransmit,blank
+	fetch 1,mem_last_type
+	iforce type
+	rtn
+
+prepare_tx_nomore_retransmit:
+	set0 mark_ext_patch,mark
+	bpatch patch0a_1,mem_patch0a
+	call clear_got_tx
+prepare_tx_no_retransmit:
+	call check_esco_amaddr
+	branch prepare_tx_pollnull,true
+	call send_lmp
+	branch prepare_tx_sendlmp,user
+	fetch 1,mem_op
+	bbit1 op_txl2cap,prepare_tx_sendl2cap
+	bmark1 mark_loopback,prepare_tx_loopback
+	fetch 1,mem_debug_config
+	bbit1 debug_tx_pattern,prepare_tx_txpat
+prepare_tx_pollnull:
+	force type_poll,type				/* POLL for master */
+	rtn master
+	force type_null,type				/* default is NULL */
+	rtn
+prepare_tx_loopback:
+	set0 mark_ext_patch,mark
+	bpatch patch0a_2,mem_patch0a
+	fetch 1,mem_rx_type
+	iforce type
+	rtnne 1
+	force type_null,type
+	rtn
+prepare_tx_txpat:
+	fetch 1,test_mode_packet_type
+	and pdata,0xf,type
+	set1 mark_loopback,mark
+	rtn
+prepare_tx_sendlmp:
+	force type_lmp,type
+	branch set_wait_ack
+prepare_tx_sendl2cap:
+	call tx_l2cap_type
+
+set_wait_ack:
+	set0 mark_ext_patch,mark
+	bpatch patch0a_3,mem_patch0a
+	fetcht 1,mem_arq
+	set1 wack,temp
+	storet 1,mem_arq
+	deposit type
+	store 1,mem_last_type
+	setarg 0xffff
+	store 2,mem_retransmission_cnt
+	rtn
+
+tx_l2cap_type:
+	set0 mark_ext_patch,mark
+	bpatch patch0a_4,mem_patch0a
+	fetch 1,mem_state_map
+	isolate1 smap_edr,pdata
+	fetch 2,mem_tx_len
+	branch tx_l2cap_type_edr,true
+	force type_dm1,type		/* DM1 */
+	sub pdata,17,null			
+	rtn positive
+	force type_dh1,type		/* DH1 */
+	sub pdata,27,null				
+	rtn positive
+	force type_dm3,type		/* DM3 */
+	sub pdata,121,null
+	rtn positive
+	force type_dm5,type		/* DM5 */
+	sub pdata,224,null
+	rtn positive
+	force type_dh5,type		/* DH5 */
+	rtn
+tx_l2cap_type_edr:
+	force type_dm1,type
+	sub pdata,17,null
+	rtn positive
+	force type_dh1,type		/*2-DH1*/
+	sub pdata,54,null
+	rtn positive
+	force type_dm3,type		/*2-DH3*/
+	arg 367,temp
+	isub temp,null
+	nrtn positive
+	force type_dm5,type		/*2-DH5*/
+	arg 679,temp
+	isub temp,null
+	nrtn positive
+	force type_dh5,type		/*3-DH5*/
+	rtn
+
+
+/******************************************/
+/***********  Receive Packet  *************/
+/******************************************/
+
+
+
+slave_receive_master_slot:
+	fetch 1,mem_state
+	bbit0 state_insniff,slave_receive_notsniff
+	fetch 2,mem_tsniff
+	branch slave_receive_notsniff,blank		/* role switch */
+	nbranch slave_receive_sniff,attempt
+slave_receive_notsniff:
+	call rf_setup_time_master_slot
+slave_receive_access:
+	add clke_bt,1,bt_clk
+slave_receive_sniff:
+	enable swfine
+	fetch 2,mem_rx_window
+	rshift pdata,pdata
+	arg param_pll_setup,temp
+	iadd temp,pdata
+	call ahead_window
+	call fetch_extm_bt_adr
+	force 0x03,freq_mode          /* connection hop */
+	call rx_radio_freq
+	call init_rx_packet_flags
+	call prep_crypt
+	set0 mark_ext_patch,mark
+	bpatch patch0a_5,mem_patch0a
+	fetch 2,mem_rx_window
+	rshift pdata,pdata
+	call ahead_window
+	call start_receiver
+	enable decode_fec0
+	fetch 2,mem_rx_window
+	arg param_clke_cal,temp
+	iadd temp,stop_watch
+	correlate null,timeout
+	copy clke,temp
+	storet 6,mem_sync_clke
+	disable decode_fec0
+	nrtn sync
+	arg param_clke_cal,clke_rt
+	copy bt_clk,clke_bt
+	branch lpm_adjust_clk,wake
+	rtn
+	
+
+slave_conn_recv_packet:
+	set0 mark_ext_patch,mark
+	bpatch patch0a_6,mem_patch0a
+	call slave_receive_master_slot
+	nbranch shutdown_radio,sync
+	call save_rssi
+	bmark0 mark_testmode,receive_packet
+	fetch 2,mem_tst_pktcnt_sync
+	increase 1,pdata
+	store 2,mem_tst_pktcnt_sync
+receive_packet:
+	rshift bt_clk,temp
+	or temp,0x40,white_init
+receive_packet_whitened:
+	set0 mark_ext_patch,mark
+	bpatch patch0a_7,mem_patch0a
+	enable enable_white
+	enable enable_hec
+	enable decode_fec1
+	parse demod,bucket,3  /* get am_addr */
+	rshift8 pwindow,pdata
+	store 1,mem_temp_am_addr
+	parse demod,bucket,4  /* get type */
+	inject bucket,7       /* align up to pwindow */
+	copy pwindow,pdata
+	store 1,mem_rx_type
+	parse demod,bucket,3  /* get arq */
+	rshift8 pwindow,pdata
+	store 1,mem_temp_arq
+	fetch 1,mem_rx_type
+	sub pdata,3,null
+	branch receive_packet_noedr,positive
+	beq 7,receive_packet_noedr		/* esco packet */
+	fetch 1,mem_state_map
+	isolate1 smap_edr,pdata
+	setflag true,PSK,radio_ctrl
+receive_packet_noedr:
+	set0 mark_ext_patch,mark
+	bpatch patch0b_0,mem_patch0b
+	parse demod,bucket,8   /* cycle thru hec */
+	disable decode_fec1
+	disable enable_hec   /* at this moment, 1 seqn + 8 hec is in shift */
+	branch error_header,crc_failed  /* if hec error, nothing is valid */
+	bmark0 mark_testmode,receive_packet_amchk
+	fetch 2,mem_tst_pktcnt_hec
+	increase 1,pdata
+	store 2,mem_tst_pktcnt_hec
+receive_packet_amchk:	
+	set0 mark_ext_patch,mark
+	bpatch patch0b_1,mem_patch0b
+	fetch 1,mem_temp_am_addr
+	compare 0,pdata,0x07           /* check for broadcast */
+	setflag true,mark_am_addr_broadcast,mark   /* received a broadcast message, can fire ar_addr if during unpark_req */
+	branch am_addr_ok,true
+	icompare 0x07,am_addr
+	branch am_addr_match,true
+	bmark0 mark_esco,end_of_packet
+	fetcht 1,mem_saved_amaddr
+	icompare 0x7,temp
+	nbranch end_of_packet,true
+	call restore_esco
+	fetch 1,mem_arq    /* mem_arq + am_addr */
+	set0 arqnx,pdata
+	set1 flowx,pdata
+	store 1,mem_arq
+am_addr_match:
+	enable match
+am_addr_ok:
+	set0 mark_ext_patch,mark
+	bpatch patch0b_2,mem_patch0b
+	fetch 1,mem_rx_type
+	icopy type
+	bmark1 mark_am_addr_broadcast,arqn_bypass        /* arqn doesn't make sense */
+	fetcht 1,mem_temp_arq
+	fetch 1,mem_arq
+	set0 flow,pdata
+	isolate1 flow,temp
+	setflag true,flow,pdata
+	isolate1 arqn,temp
+	setflag true,arqn,pdata
+	store 1,mem_arq
+	isolate0 arqn,temp
+	branch arqn_bypass,true
+	call clear_got_tx
+arqn_bypass:
+	set0 mark_ext_patch,mark
+	bpatch patch0b_3,mem_patch0b
+	arg 0,temp
+	call reserve_slot
+	and type,0xf,pdata
+	beq type_poll,process_poll
+	beq type_null,end_of_packet	/* null */
+	beq type_fhs,process_fhs
+	fetcht 1,mem_temp_arq
+	fetch 1,mem_arq
+	icompare 0x04,temp    /* bit 2 is seqn */
+	nbranch rx_type_dispatch,true   /* different then it's new */
+	bmark0 mark_am_addr_broadcast,failed_seqn         /* seqn failed, and not broadcast */
+	bbit0 bcast1,rx_type_dispatch           /* first broadcast never fail seqn */
+failed_seqn:
+	set1 mark_old_packet,mark
+rx_type_dispatch:
+	set0 mark_ext_patch,mark
+	bpatch patch0b_4,mem_patch0b
+	deposit type
+	beq type_dm1, process_dm1
+	beq type_dh1, process_dh1
+	beq type_hv3, process_hev
+	beq type_3dh1, process_3dh1
+	arg 4,temp
+	call reserve_slot
+	beq type_dm3, process_dm3
+	beq type_dh3, process_dh3
+	arg 8,temp
+	call reserve_slot
+	beq type_dm5, process_dm5
+	beq type_dh5, process_dh5
+	rtn
+
+
+process_hev:
+	set0 mark_ext_patch,mark
+	bpatch patch0b_5,mem_patch0b
+	enable decode_fec0
+	enable enable_crc
+	enable encrypt
+	arg mem_sco_ibuf,contw
+	force 30,loopcnt
+process_hev_loop:	
+	parse demod,bucket,8
+	rshift3 pwindow,pdata
+	istore 1,contw
+	loop process_hev_loop
+	bmark0 mark_esco,end_of_packet
+	parse demod,bucket,16  /* cycle through the crc */
+	nsetflag crc_failed,mark_esco_rxok,mark
+	call test_esco,crc_failed
+	branch error_payload,crc_failed
+	branch ack_payload
+
+test_esco:
+	deposit clke
+	store 6,mem_display
+	rtn
+
+process_poll:
+	branch end_of_packet
+
+process_dm3:
+process_dm5:
+	set1 mark_longpacket,mark
+process_dm1:
+	enable decode_fec2
+	branch process_dmh
+	
+process_dh3:
+process_dh5:
+	set1 mark_longpacket,mark
+process_3dh1:
+	set1 PSK3M,radio_ctrl
+process_dh1:
+	enable decode_fec0
+process_dmh:
+	set0 mark_ext_patch,mark
+	bpatch patch0b_6,mem_patch0b
+	bmark1 mark_rxbuf_inuse,end_of_packet			/* buffer in use, nack */
+	isolate0 PSK,radio_ctrl
+	branch process_dmh_noedr,true
+	disable enable_white
+	enable decode_fec0
+	disable decode_fec2
+	add clkn_bt,2,timeup
+	correlate clkn_bt,meet
+	nbranch error_payload,sync
+	set1 mark_longpacket,mark
+	enable enable_white
+process_dmh_noedr:
+	set0 mark_ext_patch,mark
+	bpatch patch0b_7,mem_patch0b
+	enable encrypt
+	enable enable_crc
+	parse demod,bucket,3  /* parse in lch+l2cap flow */
+	rshift8 pwindow,pdata
+	store 1,mem_lch_code		/* for loopback */
+	parse demod,bucket,5  /* parse in 5 bit packetlength */
+	bmark1 mark_longpacket,process_dmh_long
+	rshift3 pwindow,loopcnt
+	rshift3 loopcnt,loopcnt
+	branch process_dmh_common
+process_dmh_long:
+	parse demod,bucket,5		/* multi slot packet length of dh3 dh5 dm3 dm5 */
+	rshift pwindow,loopcnt
+	parse demod,bucket,3  /* undefined+bit 9 of length */
+process_dmh_common:	
+	set0 mark_ext_patch,mark
+	bpatch patch0c_0,mem_patch0c
+	deposit loopcnt
+	store 2,mem_len
+	branch process_dmh_data_end,blank
+	isub mask3ff,null
+	branch error_payload,positive	/* packet too large, discard */
+	set0 mark_ext_patch,mark
+	bpatch patch0c_1,mem_patch0c
+	set0 mark_fhs_eir,mark
+	fetch 1,mem_lch_code
+	and_into 0x03,pdata
+	arg mem_rxbuf,contw //lmp_data or test packet
+	beq LLID_LMP,process_lmp
+	bmark1 mark_testmode,process_dmh_data
+	fetch 1,mem_device_option
+	beq dvc_op_hci,process_dmh_acl	//HCI mode
+	//non-HCI mode
+	fetch 1,mem_lch_code
+	and_into 0x03,pdata
+	beq LLID_L2CAP_START,process_dmh_data_l2cap_start_pkt
+	beq LLID_L2CAP_CONT,process_dmh_data_l2cap_continue_pkt
+	branch error_payload
+
+process_lmp:
+	fetch 2,mem_len
+	sub pdata,0x70,null		//lmp buffer size
+	nbranch error_payload,positive
+	bmark1 mark_old_packet,ack_payload
+	branch process_dmh_data
+
+process_dmh_acl: //HCI
+	set0 mark_ext_patch,mark
+	bpatch patch0c_2,mem_patch0c
+	bmark1 mark_old_packet,ack_payload
+	fetch 2,mem_len
+	branch error_payload,blank
+	call hci_check_bcsp_protocol
+	nbranch process_dmh_acl_check_h4_buff,true
+process_dmh_acl_bcsp:
+	fetcht 2,mem_h5tx_free
+	increase 10,pdata
+	isub temp,null
+	nbranch process_dmh_acl_packet,positive// nbranch if no free buff
+	call hci_dispatch
+	branch process_dmh_acl_bcsp// loop and wait for tx buff
+process_dmh_acl_check_h4_buff:
+	hfetch 2,core_uart_txitems
+	arg 300,temp
+	isub temp,null
+	branch error_payload,positive
+	fetch 2,mem_acl_credits
+	branch error_payload,blank
+process_dmh_acl_packet: // packaging
+	set0 mark_ext_patch,mark
+	bpatch patch0c_3,mem_patch0c
+	call hci_get_packet_ptr
+	fetch 1,mem_conn_handle
+	fetcht 1,mem_lch_code
+	and_into 3,temp
+	lshift8 temp,temp
+	lshift4 temp,temp
+	ior temp,pdata
+	istore 2,contwu
+	fetcht 2,mem_len
+	copy temp,loopcnt
+	istoret 2,contwu //length in temp
+process_dmh_acl_copy:
+	set0 mark_ext_patch,mark
+	bpatch patch0c_4,mem_patch0c
+	parse demod,bucket,8
+	rshift3 pwindow,pdata
+	istore 1,contwu
+	loop process_dmh_acl_copy
+	add temp,4,loopcnt
+ifdef ACL_DEBUG
+	setarg 4
+	iadd temp,pdata
+	isub loopcnt,null
+	ncall ice_break,zero
+	//copy pdata,loopcnt
+endif
+	call hci_check_bcsp_protocol
+	nbranch process_dmh_acl_send_h4,true
+	set1 mark_h5tx_rp,mark
+	force 6,queue
+	call bcsp_send_packet
+	branch process_dmh_data_end
+process_dmh_acl_send_h4:
+	call h4_send_packet_acl
+	branch process_dmh_data_end
+	
+process_dmh_data_l2cap_start_pkt:
+	set0 mark_ext_patch,mark
+	bpatch patch0c_5,mem_patch0c
+	bmark1 mark_old_packet,ack_payload
+	fetch 2,mem_len
+	arg 0x2e0,temp //l2cap buffer size
+	isub temp,null
+	branch error_payload,positive
+	fetch 1,mem_l2cap_rxbuff_inuse
+	bbit0 L2CAP_INUSE_BUFF1,process_dmh_data_into_buff1
+	bbit0 L2CAP_INUSE_BUFF2,process_dmh_data_into_buff2
+	branch end_of_packet
+process_dmh_data_into_buff1:
+	jam 1,mem_l2cap_rxbuff_new //new data in buff 1
+	fetch 2,mem_l2cap_rxbuff1_len
+	bne 0,end_of_packet			//baseband head error
+	arg mem_l2cap_rxbuff1,contw
+	branch process_dmh_data
+process_dmh_data_into_buff2:
+	jam 2,mem_l2cap_rxbuff_new //new data in buff 2
+	fetch 2,mem_l2cap_rxbuff2_len
+	bne 0,end_of_packet
+	arg mem_l2cap_rxbuff2,contw
+	branch process_dmh_data
+	
+process_dmh_data_l2cap_continue_pkt:
+	set0 mark_ext_patch,mark
+	bpatch patch0c_6,mem_patch0c
+	bmark1 mark_old_packet,ack_payload
+	fetch 2,mem_len
+	arg 0x2e0,temp //l2cap buffer size
+	isub temp,null
+	branch error_payload,positive
+	fetch 1,mem_l2cap_rxbuff_new
+	beq 1,process_dmh_data_l2cap_continue_pkt1
+	beq 2,process_dmh_data_l2cap_continue_pkt2
+	branch end_of_packet
+process_dmh_data_l2cap_continue_pkt1:
+	arg mem_l2cap_rxbuff1,contw
+	fetch 2,mem_l2cap_rxbuff1_len
+	iadd contw,contw
+	branch process_dmh_data
+process_dmh_data_l2cap_continue_pkt2:
+	arg mem_l2cap_rxbuff2,contw
+	fetch 2,mem_l2cap_rxbuff2_len
+	iadd contw,contw
+process_dmh_data:	
+	parse demod,bucket,8
+	rshift3 pwindow,pdata
+	istore 1,contw
+	loop process_dmh_data
+process_dmh_data_end:	
+	set0 mark_ext_patch,mark
+	bpatch patch0c_7,mem_patch0c
+	parse demod,bucket,16  /* cycle through the crc */
+	branch error_payload_crc,crc_failed
+	call lpm_hci_wake_dispatch
+	fetch 1,mem_l2cap_flow_ctrl_flag
+	beq L2CAP_FLOW_CTRL_ENABLE,end_of_packet
+	bmark1 mark_testmode,process_dmh_cont
+	bmark1 mark_old_packet,redundant_payload
+	fetch 1,mem_lch_code
+	compare 3,pdata,3
+	branch process_dmh_cont,true
+	fetch 2,mem_len
+	branch process_dmh_cont,blank
+	fetch 1,mem_device_option
+	beq dvc_op_hci,process_dmh_cont
+	set0 mark_ext_patch,mark
+	bpatch patch0d_0,mem_patch0d
+	fetch 1,mem_l2cap_rxbuff_new
+	beq 1,process_l2cap_pass_crc_buff1
+	beq 2,process_l2cap_pass_crc_buff2
+	branch assert
+process_l2cap_pass_crc_buff1:
+	fetch 2,mem_l2cap_rxbuff1_len
+	fetcht 2,mem_len
+	iadd temp,pdata
+	store 2,mem_l2cap_rxbuff1_len
+	beq 0,assert
+	fetcht 2,mem_l2cap_rxbuff1// l2cap payload length
+	increase 4,temp
+	isub temp,null
+	call l2cap_buff1_inuse,zero //l2cap pkts not ended
+	branch process_dmh_cont
+process_l2cap_pass_crc_buff2:
+	fetch 2,mem_l2cap_rxbuff2_len
+	fetcht 2,mem_len
+	iadd temp,pdata
+	store 2,mem_l2cap_rxbuff2_len
+	beq 0,assert
+	fetcht 2,mem_l2cap_rxbuff2// l2cap payload length 
+	add temp,4,temp
+	isub temp,null
+	call l2cap_buff2_inuse,zero //l2cap pkts not ended
+	branch process_dmh_cont
+process_dmh_cont:
+	set0 mark_ext_patch,mark
+	bpatch patch0d_1,mem_patch0d
+	fetcht 1,mem_state_map
+	fetch 1,mem_lch_code
+	compare 3,pdata,0x03
+	setflag true,smap_rxlmp,temp
+	nsetflag true,smap_rxl2cap,temp
+	storet 1,mem_state_map
+	nbranch process_dmh_cont_rxbuf_not_use,true
+	set1 mark_rxbuf_inuse,mark
+process_dmh_cont_rxbuf_not_use:
+	bmark0 mark_testmode,ack_payload
+	isolate1 smap_rxlmp,temp
+	branch ack_payload,true
+	fetch 2,mem_tst_pktcnt_crc
+	increase 1,pdata
+	store 2,mem_tst_pktcnt_crc
+	set1 mark_loopback,mark
+	set0 smap_rxl2cap,temp
+	set0 mark_rxbuf_inuse,mark
+	storet 1,mem_state_map
+ack_payload:
+	set0 mark_ext_patch,mark
+	bpatch patch0d_2,mem_patch0d
+	fetcht 1,mem_temp_arq
+	fetch 1,mem_arq
+	set1 arqnx,pdata
+	isolate1 seqn,temp            /* if accept, seqn always copies from the header */
+	setflag true,seqn,pdata
+	isolate1 mark_am_addr_broadcast,mark
+	setflag true,bcast1,pdata
+	store 1,mem_arq
+	fetch 2,mem_len
+	nbranch end_of_packet,blank
+	fetch 1,mem_state_map
+	set0 smap_rxl2cap,pdata//better to do this in l2cap_flow_ctrl_stop
+	store 1,mem_state_map
+	fetch 1,mem_lch_code
+	compare 0x01,pdata,0x07
+	//call l2cap_flow_ctrl_stop,true
+	branch end_of_packet
+	
+error_header:
+	set0 mark_ext_patch,mark
+	bpatch patch0d_3,mem_patch0d
+	disable match
+	fetch 2,mem_rx_hec_err
+	increase 1,pdata
+	store 2,mem_rx_hec_err
+	branch end_of_packet
+error_payload_crc:
+	fetch 2,mem_rx_crc_err
+	increase 1,pdata
+	store 2,mem_rx_crc_err
+	call discard_pkt
+	bmark0 mark_testmode,error_payload
+	set1 mark_loopback,mark
+error_payload:
+	branch end_of_packet
+	
+discard_pkt:
+	set0 mark_ext_patch,mark
+	bpatch patch0d_4,mem_patch0d
+	fetch 1,mem_lch_code
+	compare 3,pdata,0x03
+	nbranch discard_pkt_l2cap,true
+discard_pkt_lmp:	
+	fetcht 1,mem_state_map
+	set0 smap_rxlmp,temp
+	storet 1,mem_state_map
+	rtn
+discard_pkt_l2cap:
+//	isolate1 mark_testmode,mark
+//	setflag true,mark_loopback,mark
+	fetcht 1,mem_state_map
+	set0 smap_rxl2cap,temp
+	storet 1,mem_state_map
+	branch  h4_send_acl_trigger_clear
+
+redundant_payload:
+	fetch 1,mem_arq
+	set1 arqnx,pdata
+	store 1,mem_arq
+end_of_packet:
+	set0 mark_ext_patch,mark
+	bpatch patch0d_5,mem_patch0d
+	disable encode_fec0
+	disable encode_fec2
+	disable decode_fec0
+	disable decode_fec2
+	disable enable_crc
+	disable encrypt
+	disable enable_white
+	branch shutdown_radio,is_rx
+	until null,tx_clear
+	nop 100          /* flush out the last bit */
+	branch shutdown_radio
+	
+process_fhs:
+	set0 mark_ext_patch,mark
+	bpatch patch0d_6,mem_patch0d
+	enable enable_crc
+	enable decode_fec2
+	parse demod,bucket,72
+	isolate1 58,pdata
+	setflag true,mark_fhs_eir,mark
+	copy bt_adr,temp             /* save current address to aside */
+	ialigned bt_adr            /* send it to access gen */
+	ialigned fhs0			/* get fhs_misc */
+	pulse recalc                /* calc the lap just received from the other guy */
+	setsect 2,0xfffff             /* preset ms of shift reg as big mask */
+	setsect 3,0x0ffff             /* preset ms of shift reg as big mask */
+	nop 32                       /* 30 cycles after recalc */
+	iverify fhs_parity             /* check fhs_parity against ls 34 bits at shift reg, with msb 36 bits as mask */
+	deposit lap
+	store 3,extm_lap
+	deposit uap
+	store 1,extm_uap
+	copy temp,bt_adr             /* put the address back */
+	branch fhs_parity_ok,true     /* fhs parity failed */
+	branch error_payload
+fhs_parity_ok:
+	set0 mark_ext_patch,mark
+	bpatch patch0d_7,mem_patch0d
+	parse demod,bucket,72
+	ialigned fhs1                   /* give host the information on class and fhs_misc */
+	ialigned am_addr                /* store the am_addr the master assigned us */
+	ialigned nap
+	ialigned regb                   /* store external clock in regb according to clock format */
+	force 0,pdata
+	parse demod,bucket,16  /* cycle through the crc */
+	branch error_payload,crc_failed
+	setarg 0x0ffffffc
+	iand regb,pdata
+	store 4,mem_clke_bt
+	deposit fhs_class
+	store 3,extm_class
+	deposit fhs_misc
+	store 1,extm_fhs_misc
+	deposit am_addr
+	store 1,extm_newconn_am_addr
+	deposit nap
+	store 2,extm_nap
+	deposit bt_clk
+	inject rxf,32
+	compare type_fhs,type,0x0f         /* see if this was fhs packet */
+	setflag true,mark_fhs_already_good,mark
+	branch end_of_packet
+
+clear_got_tx:
+	set0 mark_ext_patch,mark
+	bpatch patch0e_0,mem_patch0e
+	fetch 1,mem_arq
+	rtnbit0 wack
+	set0 wack,pdata
+	setflip seqnx,pdata
+	store 1,mem_arq
+	fetch 1,mem_last_type
+	beq type_lmp,clear_got_txlmp
+	rtneq type_hv3
+	fetch 1,mem_op
+	rtnbit0 op_txl2cap,pdata
+	set0 op_txl2cap,pdata
+	set1 op_pkt_comp,pdata
+	store 1,mem_op
+	set0 mark_tx_l2cap,mark
+	fetch 1,mem_device_option
+	rtneq dvc_op_hci
+	fetch 2,mem_l2cap_tx_multi_offset
+	nrtn blank
+	fetch 1,mem_op
+	set0 op_pkt_comp,pdata
+	store 1,mem_op
+	branch l2cap_malloc_free
+
+clear_got_txlmp:
+	set0 mark_ext_patch,mark
+	bpatch patch0e_1,mem_patch0e
+	fetch 1,mem_lmo_header_opcode
+	rshift pdata,pdata
+	beq LMP_START_ENCRYPTION_REQ,start_encryption
+	beq LMP_STOP_ENCRYPTION_REQ,stop_encryption
+	beq LMP_UNSNIFF_REQ, sniff_exit
+	beq LMP_ESCAPE,clear_lmp_escape
+	beq LMP_REMOVE_SCO_LINK_REQ,stop_sco
+	rtnne LMP_ACCEPTED
+	fetch 1,mem_lmo_payload
+	beq LMP_SCO_LINK_REQ,sco_link_req_by_slave
+	beq LMP_START_ENCRYPTION_REQ,clear_send_setup_complete
+	rtn
+
+clear_lmp_escape:
+	fetch 1,mem_lmo_payload
+	set1 7,pdata
+	beq LMP_EXT_REMOVE_ESCO_REQ,stop_sco
+	rtn
+clear_send_setup_complete:
+	rtn master
+	fetch 1,mem_state
+	rtnbit1 state_conn_comp
+	jam LMP_SETUP_COMPLETE,mem_lmo_opcode2
+	rtn
+	
+// nokia BH-105  CALLING when reconnection
+sco_link_req_by_slave:
+	rtn master
+	fetch 1,mem_mode
+	isolate1 send_sco_when_slave,pdata
+	branch clean_mem_mode,true
+	//jam LMP_REMOVE_SCO_LINK_REQ,mem_lmo_opcode2
+	rtn
+clean_mem_mode:
+	set0 send_sco_when_slave,pdata
+	store 1,mem_mode
+	rtn
+	
+start_encryption:
+	set0 mark_ext_patch,mark
+	bpatch patch0e_2,mem_patch0e
+	fetch 1,mem_state_map
+	set1 smap_encryption,pdata
+	store 1,mem_state_map
+	hjam 1,core_encrypt
+	fetch 1,mem_state
+	isolate1 state_conn_comp,pdata
+	branch hci_send_encryption_change,true
+	rtn
+
+stop_encryption:
+	set0 mark_ext_patch,mark
+	bpatch patch0e_3,mem_patch0e
+	fetch 1,mem_state_map
+	set0 smap_encryption,pdata
+	store 1,mem_state_map
+	hjam 0,core_encrypt
+	rtn
+
+
+sniff_init:
+	set0 mark_ext_patch,mark
+	bpatch patch0e_4,mem_patch0e
+	copy clkn_bt,pdata
+	store 4,mem_lpm_delay_after_sniff
+	add clkn_bt,3,rega
+	branch sniff_init_master,master
+	add clke_bt,3,rega
+sniff_init_master:
+	fetcht 2,mem_tsniff
+	deposit rega
+	set0 27,pdata
+	idiv temp
+	fetch 2,mem_dsniff
+	call wait_div_end
+	remainder regc
+	isub regc,pdata
+	branch sniff_init_nowrap,positive
+	iadd temp,pdata
+sniff_init_nowrap:
+	iadd rega,pdata
+	store 4,mem_sniff_anchor
+	jam SWITCH_FLAG_INIT,mem_switch_flag
+	fetch 1,mem_state
+	set1 state_insniff,pdata
+	store 1,mem_state
+	fetch 1,mem_sniff_attempt
+	store 1,mem_current_sniff_attempt
+	jam 0x80,mem_seqi
+	setarg 0
+	store 3,mem_sniff_rcv
+	store 3,mem_sniff_lost
+	store 1,mem_sniff_unint_lost
+	jam BT_EVT_ENTER_SNIFF,mem_fifo_temp
+	call ui_ipc_send_event
+	fetch 2,mem_rx_window_sniff
+	store 2,mem_rx_window
+	nrtn master
+	add am_addr,-1,queue
+	rtn
+
+sniff_exit:
+	set0 mark_ext_patch,mark
+	bpatch patch0e_5,mem_patch0e
+	fetch 1,mem_state
+	rtnbit0 state_insniff
+	set0 state_insniff,pdata
+	store 1,mem_state
+	jam 0x7f,mem_seqi
+	fetch 2,mem_rx_window_init
+	store 2,mem_rx_window
+	disable wake
+	jam BT_EVT_EXIT_SNIFF,mem_fifo_temp
+	branch ui_ipc_send_event
+
+
+check_attempt:
+	set0 mark_ext_patch,mark
+	bpatch patch0e_6,mem_patch0e
+	enable attempt
+	fetch 1,mem_state
+	bbit1 state_insniff,check_attempt_sniff
+	rtnmark1 mark_testmode						/* pdata won't be blank now, try attempt */
+	fetch 1,mem_arq
+	rtnbit1 wack
+	fetch 1,mem_lmp_to_send
+	nrtn blank
+	fetch 1,mem_op
+	rtnbit1 op_txl2cap
+check_attempt_nomore:
+	force 0,pdata
+	rtn
+
+check_attempt_sniff:
+	bbit0 state_insco,check_attempt_not_sco
+	fetch 1,mem_current_sniff_attempt
+	beq 2,check_attempt_sniff_restore_sco
+	fetch 1,mem_arq
+	bbit1 wack,check_attempt_notimeout
+	bmark0 mark_esco_rxok,check_attempt_notimeout
+check_attempt_sniff_restore_sco:
+	call restore_esco
+	nbranch check_attempt_notimeout,master
+	fetch 1,mem_lmp_to_send
+	nbranch check_attempt_notimeout,blank
+check_attempt_sco_master:
+	fetch 1,mem_sco_poll
+	increase -1,pdata
+	store 1,mem_sco_poll
+	nbranch check_attempt_nomore,blank
+	jam param_sco_poll,mem_sco_poll
+	branch check_attempt_notimeout
+	
+check_attempt_not_sco:
+	fetch 1,mem_current_sniff_attempt
+	bne 1,check_attempt_notimeout
+	fetch 1,mem_current_sniff_timeout
+	branch check_attempt_notimeout,blank
+	increase -1,pdata
+	store 1,mem_current_sniff_timeout
+	fetch 1,mem_arq
+	rtnbit1 wack						// waiting for next ack
+	nrtn match						// waiting for next poll
+check_attempt_notimeout:
+	fetch 1,mem_current_sniff_attempt
+	increase -1,pdata
+	store 1,mem_current_sniff_attempt
+	rtn
+
+	/* enable user if sniff window vialation, queue is extra overhead */
+sniff_check_window:
+	set0 mark_ext_patch,mark
+	bpatch patch0e_7,mem_patch0e
+	disable swfine
+	copy temp,stop_watch
+	call context_search_sniff_window
+	disable user
+	nrtn zero
+	force 0,stop_watch
+	enable user
+	rtn
+
+	//return true if it is esco context
+check_esco_amaddr:
+	fetch 1,mem_esco_addr
+	icompare 0xff,am_addr
+	rtn
+	
+play_sco:
+	set0 mark_ext_patch,mark
+	bpatch patch0f_0,mem_patch0f
+	jam 1,mem_max_slot
+	//call context_traverse_max_slot
+	call enable_pcm
+	force 12,pdata
+	store 2,mem_tsniff
+	fetch 1,mem_esco_desco
+	lshift pdata,pdata
+	store 2,mem_dsniff
+	fetch 1,mem_state
+	set1 state_insco,pdata
+	store 1,mem_state
+	jam 3,mem_sniff_attempt
+	jam 3,mem_current_sniff_attempt
+	call sniff_init
+	force 0,temp //sco chn
+	call hci_send_sco_complete
+	jam 0x50,mem_esco_arq
+	jam param_sco_poll,mem_sco_poll
+	rtn
+	
+stop_sco:
+	set0 mark_ext_patch,mark
+	bpatch patch0f_1,mem_patch0f
+	call sniff_exit
+	jam 5,mem_max_slot
+	//call context_traverse_max_slot
+	call disable_pcm	
+	fetch 1,mem_state
+	set0 state_insco,pdata
+	store 1,mem_state
+stop_sco_hci:
+	arg 0xe00,temp
+	jam HCI_ERROR_REMOTE_USER_ENDED_CONNECTION,mem_hci_disconn_reason
+	branch hci_send_disconn_complete
+
+stop_esco:
+	set0 mark_ext_patch,mark
+	bpatch patch0f_2,mem_patch0f
+	jam default_neogotiation_state,mem_neogotiation_state
+	call stop_sco
+	call restore_esco
+	set0 mark_esco,mark
+	rtn	
+
+parse_l2cap:	
+	set0 mark_ext_patch,mark
+	bpatch patch0f_3,mem_patch0f
+	fetch 1,mem_device_option
+	beq dvc_op_hci,parse_l2cap_hci
+	set0 mark_rxbuf_inuse,mark 
+parse_l2cap_cont:
+	jam L2CAP_RX_CLEAR,mem_l2cap_rx_done
+	fetch 1,mem_l2cap_rxbuff_inuse
+	rtn blank
+	isolate1 L2CAP_INUSE_BUFF1,pdata
+	arg mem_l2cap_rxbuff1,contr
+	call process_rx_l2cap_pkt,true
+	set0 mark_ext_patch,mark
+	bpatch patch0f_4,mem_patch0f
+	fetch 1,mem_l2cap_rx_done
+	beq L2CAP_RX_DONE,parse_l2cap_release_buff1
+	
+	jam L2CAP_RX_CLEAR,mem_l2cap_rx_done
+	fetch 1,mem_l2cap_rxbuff_inuse
+	rtnbit0 L2CAP_INUSE_BUFF2
+	arg mem_l2cap_rxbuff2,contr	
+	call process_rx_l2cap_pkt
+	fetch 1,mem_l2cap_rx_done
+	beq L2CAP_RX_DONE,parse_l2cap_release_buff2
+	rtn
+	
+parse_l2cap_exit:
+	fetch 1,mem_state_map
+	set0 smap_rxl2cap,pdata
+	store 1,mem_state_map
+	set0 mark_rxbuf_inuse,mark
+	branch h4_send_acl_trigger_clear
+	
+parse_l2cap_release_buff1:
+	fetch 1,mem_l2cap_rxbuff_inuse
+	set0 L2CAP_INUSE_BUFF1,pdata
+	store 1,mem_l2cap_rxbuff_inuse
+	setarg 0
+	store 2,mem_l2cap_rxbuff1_len
+	rtn
+parse_l2cap_release_buff2:
+	fetch 1,mem_l2cap_rxbuff_inuse
+	set0 L2CAP_INUSE_BUFF2,pdata
+	store 1,mem_l2cap_rxbuff_inuse
+	setarg 0
+	store 2,mem_l2cap_rxbuff2_len
+	rtn
+
+parse_l2cap_hci:
+	fetch 1,mem_state_map
+	rtnbit0 smap_rxl2cap,pdata
+	call h4_send_acl_trigger
+	fetch 2,mem_acl_credits
+	branch assert,blank
+	increase -1,pdata
+	store 2,mem_acl_credits
+	branch parse_l2cap_exit
+
+l2cap_buff1_inuse:
+	fetch 1,mem_l2cap_rxbuff_inuse
+	set1 L2CAP_INUSE_BUFF1,pdata
+	store 1,mem_l2cap_rxbuff_inuse
+	rtn
+
+l2cap_buff2_inuse:
+	fetch 1,mem_l2cap_rxbuff_inuse
+	set1 L2CAP_INUSE_BUFF2,pdata
+	store 1,mem_l2cap_rxbuff_inuse
+	rtn
+
+/******************************************/
+/**********  Transmit Packet  *************/
+/******************************************/
+
+slave_send_access:
+	set0 mark_ext_patch,mark
+	bpatch patch0f_5,mem_patch0f
+	add clke_bt,1,bt_clk          /* slave start to use native clock */
+	call fetch_extm_bt_adr
+	force 0x03,freq_mode          /* connection frequency */
+	call tx_radio_freq
+	call start_transmitter
+	call start_tx_external
+	branch send_access_word
+	
+
+slave_conn_send_packet:
+	set0 mark_ext_patch,mark
+	bpatch patch0f_6,mem_patch0f
+	call rf_setup_time_slave_slot
+	deposit clke_bt
+	fetcht 4,mem_next_btclk
+	isub temp,pdata
+	rtnne 1					/* missed slave slot */
+	compare type_null,type,0x1f
+	nbranch slave_conn_send_access,true
+	fetch 1,mem_rx_type
+	rtn blank					/* null packet, do nothing */
+slave_conn_send_access:
+	call slave_send_access
+	compare type_id,type,0x1f        /* is this id only ? */
+	branch end_of_packet,true
+transmit_packet:
+	rshift bt_clk,temp
+	or temp,0x40,white_init
+transmit_packet_whitened:
+	set0 mark_ext_patch,mark
+	bpatch patch0f_7,mem_patch0f
+	enable enable_white
+	enable enable_hec
+	enable encode_fec1
+	set0 mark_longpacket,mark
+	deposit am_addr
+	inject mod,3             /* am_addr, temp is disabled */
+	deposit type
+	inject mod,4
+	fetch 1,mem_arq   /* aka mem_arq */
+	inject bucket,4  /* align up to flowx, arqnx, seqnx */
+	inject mod,3
+	enable enable_parity
+	inject mod,8   /* transmit parity */
+	disable encode_fec1
+	disable enable_parity
+	disable enable_hec
+	set0 PSK3M,radio_ctrl
+	arg 0,temp
+	call reserve_slot
+	set0 mark_ext_patch,mark
+	bpatch patch10_0,mem_patch10
+	and type,0x1f,pdata
+	beq type_lmp, transmit_lmp
+	beq type_null, end_of_packet
+	beq type_poll, end_of_packet
+	beq type_fhs, transmit_fhs  /* master mode fhs need got_tx and ack */
+	beq type_dm1, transmit_dm1
+	beq type_dh1, transmit_dh1
+	beq type_hv3, transmit_hev
+	beq type_3dh1, transmit_3dh1
+	arg 4,temp
+	call reserve_slot
+	beq type_dm3, transmit_dm3
+	beq type_dh3, transmit_dh3
+	arg 8,temp
+	call reserve_slot
+	beq type_dh5, transmit_dh5
+	branch transmit_dm5	/* must be 14, dm5 */
+
+
+transmit_hev:
+	set0 mark_ext_patch,mark
+	bpatch patch10_1,mem_patch10
+	enable encode_fec0
+	enable enable_crc
+	enable encrypt
+	force 30,loopcnt
+	arg mem_sco_obuf,contr
+transmit_ev_loop:
+	ifetch 1,contr
+	inject mod,8
+	loop transmit_ev_loop
+	bmark1 mark_esco,transmit_end
+	branch end_of_packet
+	
+transmit_fhs:
+	set0 mark_ext_patch,mark
+	bpatch patch10_2,mem_patch10
+	fetch 1,mem_fhs_am_addr            /* this is the am_addr to assign to slave */
+	icopy am_addr
+	fetch 1,mem_fhs_misc
+	icopy fhs_misc    /* [7:6]SR [5:4]SP [3:1]PS [0]undef  */
+	fetch 3,mem_class   /* store away class */
+	icopy fhs_class
+	fetch 2,mem_nap
+	icopy nap
+	enable enable_crc
+	enable encode_fec2
+	copy bt_adr,rega
+	call fetch_self_bt_adr
+	pulse recalc
+	nop 32                    /* 30 cycles after recalc for sync word generation */
+	copy bt_clk,timeup
+	fetch 4,mem_clkn_bt
+	icopy bt_clk
+	preload fhs0
+	set1 58,pdata		/* eir */
+	inject mod,72
+	preload fhs1
+	inject mod,72
+	copy timeup,bt_clk
+	copy rega,bt_adr
+	enable enable_parity
+	inject mod,16   /* generate CRC */
+	disable enable_parity
+	branch end_of_packet
+
+transmit_lmp:    /* expect the payload ready as in bb spec */
+	set0 mark_ext_patch,mark
+	bpatch patch10_3,mem_patch10
+	enable encrypt
+	enable enable_crc
+	enable encode_fec2
+	fetch 1,mem_lmo_header_length   /* this is the payload header */
+	and pdata,0x1f8,temp       /* temp is number of bits, check payload header format */
+	arg mem_lmo_header_length,contr
+	increase 8,temp   /* temp is in bits */
+transmit_lmp_loop:
+	add temp,-72,regc   /* regc is remainder */
+	nbranch transmit_lmp_finish,positive
+	ifetch 9,contr
+	inject mod,72
+	copy regc,temp
+	branch transmit_lmp_loop
+transmit_lmp_finish:
+	ifetch 9,contr
+	iinject mod,temp
+	branch transmit_end
+
+transmit_dm1:
+	enable encode_fec2
+	branch transmit_dmh
+transmit_dm3:
+transmit_dm5:
+	enable encode_fec2
+	set1 mark_longpacket,mark
+	branch transmit_dmh
+
+transmit_3dh1:
+	set1 PSK3M,radio_ctrl
+transmit_dh1:
+	enable encode_fec0
+	branch transmit_dmh
+	
+transmit_dh3:
+transmit_dh5:
+	set1 PSK3M,radio_ctrl
+	enable encode_fec0
+	set1 mark_longpacket,mark
+
+transmit_dmh:
+	set0 mark_ext_patch,mark
+	bpatch patch10_4,mem_patch10
+	fetch 1,mem_state_map
+	bbit0 smap_edr,transmit_noedr
+	sub type,3,null
+	branch transmit_noedr,positive
+	disable encrypt
+	disable encode_fec2
+	enable encode_fec0
+	disable enable_white
+	set1 PSK,radio_ctrl
+	isolate1 PSK3M,radio_ctrl
+	branch transmit_edr3m,true
+	setarg 0xabeee
+	inject mod,20
+	branch transmit_edr_sync_end
+transmit_edr3m:
+	setarg 0x5faeba
+	inject mod,24
+	setarg 0x12
+	inject mod,6
+transmit_edr_sync_end:	
+	enable enable_white
+	set1 mark_longpacket,mark
+transmit_noedr:
+	enable encrypt
+	enable enable_crc
+	bmark1 mark_loopback,transmit_loopback
+	fetch 1,mem_tx_lch
+	inject mod,3
+	fetch 2,mem_tx_len
+	iforce loopcnt
+	bmark1 mark_longpacket,transmit_long
+	inject mod,5
+	branch transmit_stuff
+transmit_long:	
+	inject mod,13
+transmit_stuff:
+	fetch 1,mem_device_option
+	beq dvc_op_hci,transmit_stuff_hci
+	deposit loopcnt
+	branch transmit_end,blank
+	fetch 2,mem_txptr
+	iforce contr
+transmit_stuff_loop:
+	ifetch 1,contr
+	inject mod,8
+	loop transmit_stuff_loop
+	branch transmit_end
+transmit_stuff_hci:
+	fetch 2,mem_txptr
+	iforce contru
+transmit_stuff_hci_loop:
+	ifetch 1,contru
+	inject mod,8
+	loop transmit_stuff_hci_loop
+transmit_end:
+	enable enable_parity
+	inject mod,16
+	disable enable_parity
+	call set_wait_ack
+	fetch 1,mem_state_map
+	bbit0 smap_edr,end_of_packet
+	force 0,pdata
+	inject mod,6				/* edr trailer */
+	branch end_of_packet
+
+
+transmit_loopback:
+	set0 mark_ext_patch,mark
+	bpatch patch10_5,mem_patch10
+	bmark1 mark_longpacket,transmit_loopback_long
+transmit_loopback_short:
+	fetch 1,mem_lch_code
+	inject mod,3						/* LLID and FLOW */
+	fetch 1,mem_len	/* take packet length */
+	iforce regc
+	inject mod,5
+	branch transmit_loopback_cont
+transmit_loopback_long:
+	fetch 1,mem_lch_code
+	inject mod,3						/* LLID and FLOW */
+	fetch 2,mem_len	/* take packet length */
+	iforce regc
+	inject mod,13
+transmit_loopback_cont:
+	arg mem_rxbuf,contr
+transmit_loopback_loop:	
+	copy regc,null
+	branch transmit_loopback_end,zero
+	ifetch 1,contr
+	inject mod,8
+	increase -1,regc
+	branch transmit_loopback_loop
+transmit_loopback_end:
+	fetch 2,mem_tst_pktcnt_dmh
+	increase 1,pdata
+	store 2,mem_tst_pktcnt_dmh
+	branch transmit_end
+	
+
+apply_switch_clke:
+	fetch 4,mem_clke_bt
+	add pdata,7,rega
+	fetch 2,mem_slot_offset
+	nbranch apply_switch_nozero,blank
+	increase -3,rega
+	branch apply_switch_wait_loop
+apply_switch_nozero:
+	mul32 pdata,12,pdata
+	hfetcht 2,core_halfslot
+	increase 1,temp
+apply_switch_loop:
+	isub temp,pdata
+	nbranch apply_switch_bt,positive
+	increase -1,rega
+	branch apply_switch_loop
+apply_switch_bt:
+	sub pdata,0,pdata
+apply_switch_wait_loop:
+	until null,oneslot
+	compare 0,clkn_bt,3
+	nbranch apply_switch_wait_loop,true
+	iforce clke_rt
+	copy rega,clke_bt
+	iforce clke_rt
+	rtn
+	
+
+calc_slot_offset:
+	set0 mark_ext_patch,mark
+	bpatch patch10_6,mem_patch10
+	until null,halfslot
+	deposit clke
+	iforce contr
+	rshift16,pdata,pdata
+	isub clkn_bt,loopcnt
+	and_into 3,loopcnt			/* bt portion */
+	nbranch calc_bt_portion,zero
+	force 0,pdata
+	branch calc_skip_bt
+calc_bt_portion:
+	arg 3750,temp
+	force 0,pdata
+calc_slot_offset_loop:
+	iadd temp,pdata
+	loop calc_slot_offset_loop
+calc_skip_bt:
+	iadd contr,pdata			/* add rt portion */
+	div pdata,12
+	call wait_div_end
+	quotient pdata
+	store 2,mem_slot_offset
+	rtn
+
+calc_clke_offset:
+	set0 mark_ext_patch,mark
+	bpatch patch10_7,mem_patch10
+	deposit clke
+	copy clkn,temp
+	isub temp,null
+	nsetflag positive,44,pdata
+	isub temp,temp
+	setarg 3750
+	isolate0 15,temp
+	branch calc_clke_pos,true
+	setarg -61786
+	iadd temp,temp
+calc_clke_pos:
+	storet 6,mem_le_clk_offset
+	rtn le
+	storet 6,mem_clk_offset
+	rtn
+
+calc_clke:
+	disable clknt
+	fetch 6,mem_le_clk_offset
+	branch calc_clke2,le
+	fetch 6,mem_clk_offset
+calc_clke2:
+	iadd clkn,alarm
+	increase 10,alarm
+	setarg 3750
+	isub alarm,pdata
+	isolate0 15,pdata
+	branch calc_clke_pos_adj,true
+	setarg 0xf15a
+	iadd alarm,alarm
+calc_clke_pos2:
+	copy alarm,clke
+	rtn
+calc_clke_pos_adj:		/* add 2 clock */
+	force 0,null
+	branch calc_clke_pos2
+	
+/******************************************/
+/********* RF related functions ***********/
+/******************************************/
+
+
+calc_radio_freq:
+	set0 mark_ext_patch,mark
+	bpatch patch11_0,mem_patch11
+	call set_sync_on
+	copy bt_clk,pdata
+	and_into 0x180,pdata
+	compare 3,freq_mode,0x07
+	nbranch freq_not_connection,true    /* don't do the hack if not in connection */
+	rshift3 pdata,pdata
+	iadd freq_index,pdata
+	branch do_hop_mod_now
+freq_not_connection:	
+	copy freq_index,pdata
+do_hop_mod_now:
+	div pdata,79
+	pulse recalc         /* now is good time to recalc id */
+	call wait_div_end
+	remainder rega
+	add rega,-40,temp
+	branch odd_half,positive
+	lshift rega,temp
+	branch freq_result
+odd_half:
+	lshift temp,temp
+	increase 1,temp
+freq_result:	
+	set0 mark_ext_patch,mark
+	bpatch patch11_1,mem_patch11
+	fetch 1,mem_mode
+	bbit0 afh_change,afh_process_con
+afh_process_0:	
+	fetch 4, mem_afh_instant   
+	isub bt_clk, null
+	branch afh_process_con,positive
+	call afh_clear
+	fetch 1,mem_afh_new_mod
+	rtn blank
+	fetch 1,mem_mode
+	set1 afh_enable,pdata
+	store 1,mem_mode
+	fetch 5,mem_afh_map_new
+	store 5,mem_afh_map_lo
+	ifetch 5,contr
+	store 5,mem_afh_map_hi
+	call afh_process_freq_map
+afh_process_con:
+	fetch 1,mem_mode
+	rtnbit0 afh_enable
+	isolate1 1,bt_clk
+	branch afh_same_channel,true	/* at odd slot, use the same as last even */
+	rshift3 temp,rega
+	and temp,7,queue
+	setarg mem_afh_map_lo  
+	iadd rega, rega
+	ifetch 1, rega
+	qisolate0 pdata
+	branch afh_process_1,true		/* not in map, do afh */
+	deposit temp
+	branch afh_process_end
+afh_process_1:
+	fetch 1, mem_afh_used
+	iforce regb                     
+	deposit bt_clk
+	and_into 0x180, pdata
+	rshift3 pdata,pdata
+	iadd freq_index,pdata
+	idiv regb
+	setarg mem_afh_map     
+	call wait_div_end
+	remainder rega
+	iadd rega,contr
+	ifetch 1,contr
+afh_process_end:	
+	store 1,mem_afh_index
+	iforce temp  
+  	rtn
+
+afh_same_channel:
+	fetch 1, mem_afh_index           /* last afh index  */
+	iforce temp
+	rtn
+
+afh_clear:
+	fetch 1,mem_mode
+	set0 afh_enable,pdata
+	set0 afh_change,pdata
+	store 1,mem_mode
+	rtn
+/*
+fixed_frequency:
+	fetcht 1,mem_fixed_freq
+	rtn
+*/
+afh_process_freq_map:
+	set0 mark_ext_patch,mark
+	bpatch patch11_2,mem_patch11
+	arg mem_afh_map,contw
+	force 10,loopcnt
+	call memset0
+	arg mem_afh_map,contw
+	force 0,regc
+	force 2,queue
+process_freq_3:	
+	fetch 5,mem_afh_map_lo
+	iforce temp
+	compare 2,queue,0xff
+	branch process_freq_1,true
+	rshift temp,temp
+process_freq_1:	
+	isolate0 0,temp
+	branch process_freq_0,true
+	deposit regc
+	istore 1,contw
+process_freq_0:
+	rshift2 temp,temp
+	increase 2,regc
+	compare 40,regc,0xfe
+	nbranch process_freq_2,true
+	fetch 5,mem_afh_map_hi
+	iforce temp
+	compare 2,queue,0xff
+	branch process_freq_2,true
+	rshift temp,temp
+process_freq_2:	
+	sub regc,78,null
+	branch process_freq_1,positive
+	force 1,regc
+	increase -1,queue
+	nbranch process_freq_3,zero
+	arg mem_afh_map,rega
+	deposit contw
+	isub rega,pdata
+	store 1,mem_afh_used
+	rtn
+
+rx_radio_freq:
+	set0 mark_ext_patch,mark
+	bpatch patch11_3,mem_patch11
+	call calc_radio_freq
+	fetch 1,mem_debug_config
+	bbit0 debug_rx_fixed_freq,rx_radio_freq_now
+	fetcht 1,mem_rx_fixed_freq
+rx_radio_freq_now:
+	branch set_freq_rx
+	
+
+tx_radio_freq:
+	set0 mark_ext_patch,mark
+	bpatch patch11_4,mem_patch11
+	call calc_radio_freq
+	fetch 1,mem_debug_config
+	bbit0 debug_tx_fixed_freq,tx_radio_freq_now
+	fetcht 1,mem_tx_fixed_freq
+tx_radio_freq_now:
+	branch set_freq_tx
+	
+
+fetch_giac:
+	force 0,uap
+	fetch 3,mem_glap
+	iforce lap
+	rtn
+
+fetch_page_bt_adr:
+	set0 mark_ext_patch,mark
+	bpatch patch11_5,mem_patch11
+	fetch 1,mem_hci_puap
+	icopy uap
+	fetch 3,mem_hci_plap
+	icopy lap
+	rtn
+
+fetch_self_bt_adr:
+	set0 mark_ext_patch,mark
+	bpatch patch11_6,mem_patch11
+	fetch 2,mem_nap
+	icopy nap
+	fetch 1,mem_uap
+	icopy uap
+	fetch 3,mem_lap
+	icopy lap                 /* copy self_adr,bt_adr */      /* use own address */
+	rtn
+
+fetch_extm_bt_adr:
+	set0 mark_ext_patch,mark
+	bpatch patch11_7,mem_patch11
+	fetch 2,mem_pnap
+	icopy nap
+	fetch 1,mem_puap
+	icopy uap
+	fetch 3,mem_plap
+	icopy lap         
+	rtn
+
+
+fetch_diac:
+	bmark1 mark_all_diac,fetch_diac_do
+	rtnmark0 mark_inquiry_state
+	rtnmark0 mark_periodical_diac
+fetch_diac_do:
+	and_into -256,lap
+	pulse recalc
+	nop 32
+	rtn
+
+
+shutdown_radio:
+	set0 mark_ext_patch,mark
+	bpatch patch12_0,mem_patch12
+ifdef FPGA
+ifndef ROMCODE
+	setarg 0x003f
+	call fpga_write_radio
+	setarg 0x017f
+	call fpga_write_radio
+endif
+endif
+	force 0,radio_ctrl
+	disable is_rx
+	disable is_tx
+	pulse packet_end
+	hjam 0x0,rfen_mdm
+	hjam 0x0,rfen_tx
+	hjam 0x0,rfen_rx
+	hjam 0,rfen_sn
+	hjam 0x70,rfen_msc
+	hjam 0x0,rfen_adc
+	rtn	
+
+set_sync_on:
+	set0 mark_ext_patch,mark
+	bpatch patch12_1,mem_patch12
+ifdef FPGA
+ifndef ROMCODE
+	setarg 0x000f
+	call fpga_write_radio
+	setarg 0x016f
+	call fpga_write_radio
+endif
+endif
+	hjam 0x0,rfen_mdm					/* if called from tx or rx */
+	hjam 0x0,rfen_tx
+	hjam 0x18,rfen_rx
+	hjam 0xa7,rfen_sn
+	hjam 0x7f,rfen_msc
+	rtn
+
+
+set_freq_rx:
+	set0 mark_ext_patch,mark
+	bpatch patch12_2,mem_patch12
+		/* IF is +2MHz */
+	storet 1,mem_last_freq
+	add temp,rx_freq_offset,rega			/* index to frequency */
+	branch rf_write_freq
+rf_rx_enable:
+	set0 mark_ext_patch,mark
+	bpatch patch12_3,mem_patch12
+ifdef FPGA
+ifndef ROMCODE
+	setarg 0x0004
+	call fpga_write_radio
+	setarg 0x016f
+	call fpga_write_radio
+endif
+endif
+	hjam 0xcf,rfen_tx
+	nop 10					/* wait adc clk48 ready */
+	hjam 0xff,rfen_rx
+	hjam 0xaf,rfen_sn
+	hjam 0xff,rfen_msc
+	nop 10
+	hjam 0xa0,rfen_mdm
+	rtn
+
+
+set_freq_tx:
+	set0 mark_ext_patch,mark
+	bpatch patch12_4,mem_patch12
+	storet 1,mem_last_freq
+	add temp,tx_freq_offset,rega			/* index to frequency */
+	call rf_write_freq
+	setarg param_pll_setup
+	call sleep
+txon:	
+ifdef FPGA
+ifndef ROMCODE
+	setarg 0x000f
+	call fpga_write_radio
+	setarg 0x01e1
+	call fpga_write_radio
+	hjam 0x0, 0x901
+endif
+endif
+	hjam 0x1,rfen_adc
+	hjam 0x3c,rfen_rx
+	hjam 0xe0,rfen_tx
+	hjam 0xb7,rfen_sn
+	hjam 0x7f, rfen_mdm
+	rtn
+
+initialize_radio:
+ifdef FPGA
+ifndef ROMCODE
+	branch fpga_init
+endif
+endif
+	hjam clksel_rc,core_clksel
+	call init_rf_regs
+	call init_agc_table
+initialize_radio_wait:
+	fetch 2,mem_rf_init_ptr
+	bbit0 14,initialize_radio_wait
+	iforce contr
+	arg 0x8900,temp
+initialize_radio_loop:
+	ifetch 1,contr
+	beq 0xff,initialize_radio_cont
+	ior temp,contw
+	ifetch 1,contr
+	istore 1,contw
+	branch initialize_radio_loop
+initialize_radio_cont:
+	set0 mark_ext_patch,mark
+	bpatch patch12_5,mem_patch12
+	call lpm_cal_xtal_startup
+	call switchto_dpllclk
+//	ncall check_dpll,wake
+	setarg param_dpll_start_delay
+	iadd clkn_bt,pdata
+	store 4,mem_dpll_clkn
+	set1 RESET,radio_ctrl
+	force 0,radio_ctrl
+	ncall do_rccal,wake
+	branch set_rccal
+
+	/* rega is frequency, 00=2400Mhz */
+rf_write_freq:
+	set0 mark_ext_patch,mark
+	bpatch patch12_6,mem_patch12
+ifdef FPGA
+ifndef ROMCODE
+	copy rega,regc
+	setarg 0x1a6c	
+	call fpga_write_radio
+	copy regc,rega
+	add rega,0x18,pdata
+	arg 0x1a80,temp
+	ior temp,pdata
+	branch fpga_write_radio
+endif
+endif
+	setarg 2400
+	iadd rega,temp
+	fetch 1,mem_fcomp_mul
+	hjam 0x04,rf_pll_rstn
+	imul32 temp,pdata
+	fetcht 1,mem_fcomp_div
+	idiv temp
+	call wait_div_end
+	quotient rega			/* rega is FLOOR(FVCO/fcomp) */
+	remainder pdata		
+	lshift16 pdata,pdata
+	lshift4 pdata,pdata		/* pdata is frac * 2^20 */
+	idiv temp
+	call wait_div_end
+	quotient pdata		/* pdata is frac *2^20/fcomp */
+	lshift8 pdata,pdata
+	lshift pdata,pdata
+	ior rega,pdata
+	hstore 4,rf_pll_intg
+	hjam 0x44,rf_pll_rstn
+	hjam 0xc4,rf_pll_rstn
+	rtn
+
+	
+do_rccal:
+	set0 mark_ext_patch,mark
+	bpatch patch12_7,mem_patch12
+	hjam 0x02,rfen_adc
+	setarg 250000
+	call sleep					/* wait clkpll&xtal stable */
+	hjam 0x7f,rfen_rx
+	nop 130
+	hjam 0x30,rf_rccal_ctrl
+	hjam 0xd0,rfen_tx
+	hjam 0x70,rf_rccal_ctrl
+	hjam 0xf0,rf_rccal_ctrl
+	force 50,loopcnt
+do_rccal_loop:
+	hfetch 1,rf_rccal_result
+	bbit1 5,do_rccal_end
+	loop do_rccal_loop
+do_rccal_end:
+	store 1,mem_rf_rccal
+	hjam 0,rfen_tx
+	hjam 0,rfen_rx
+	hjam 0x00,rfen_adc
+ifndef ROMCODE
+	jam 0x30,mem_rf_rccal
+endif
+	rtn
+
+set_rccal:
+	set0 mark_ext_patch,mark
+	bpatch patch13_0,mem_patch13
+	fetch 1,mem_rf_rccal
+	set1 5,pdata
+	hstore 1,rf_rccal_ctrl
+	hfetcht 1,rf_bpf_ctrim
+	and_into 7,temp
+	lshift3 pdata,pdata
+	ior temp,pdata
+	hstore 1,rf_bpf_ctrim
+	hfetch 1,rf_bpf_ib
+	set0 bpf_rccal,pdata
+	hstore 1,rf_bpf_ib
+	hfetch 1,rf_adc_rccal
+	set0 adc_rccal,pdata
+	hstore 1,rf_adc_rccal
+	rtn
+
+save_rssi:
+	set0 mark_ext_patch,mark
+	bpatch patch13_1,mem_patch13
+	hfetch 2,rf_afc_d2a
+	rshift4 pdata,pdata
+	rshift3 pdata,pdata
+	sub pdata,0,pdata
+	and_into 0xff,pdata
+	div pdata,10
+	call wait_div_end
+	quotient pdata
+	lshift4 pdata,pdata
+	remainder temp
+	ior temp,pdata
+	store 1,mem_rssi			/* bcd value */
+	rtn
+
+switchto_rcclk:
+	hjam 0xa,core_clksel
+	hjam 0,rfen_ck
+	hfetch 3,core_lpm_ctrl
+	hstore 3,core_lpm_reg
+	hjam 0xfc,core_lpm_reg
+	call lpm_write_ctrl
+	nop 1000
+	rtn
+	
+switchto_dpllclk:
+	hjam clksel_rc,core_clksel
+	hfetch 1,rf_clkpll_frac+2
+	set0 4,pdata
+	set0 5,pdata
+	hstore 1,rf_clkpll_frac+2
+	hjam 0x00,rfen_ck
+	hjam 0x00,rfen_msc
+	hjam 0x70,rfen_msc
+	hjam 0xff,rfen_ck
+	hfetch 1,rf_clkpll_frac+2
+	set1 4,pdata
+	set1 5,pdata
+	hstore 1,rf_clkpll_frac+2
+	call init_lpm_ctrl
+	hfetch 1,rf_clkpll_int
+	set1 7,pdata
+	hstore 1,rf_clkpll_int
+	set0 7,pdata
+	hstore 1,rf_clkpll_int
+	set1 7,pdata
+	hstore 1,rf_clkpll_int
+	hjam clksel_dpll,core_clksel
+	rtn
+
+check_dpll:
+	nop 1000
+	hjam clksel_xtal,core_clksel
+	nop 10
+	hjam 0x00,core_bist_ctrl
+	hjam ccnt_start,core_misc_ctrl
+check_dpll_loop:
+	hfetch 1,core_perf_status
+	bbit0 1,check_dpll_loop
+	hfetcht 3,core_clk_counter
+	hjam clksel_dpll,core_clksel
+	nop 10
+	hjam ccnt_start,core_misc_ctrl
+check_dpll_loop2:
+	hfetch 1,core_perf_status
+	bbit0 1,check_dpll_loop2
+	hfetch 3,core_clk_counter
+	isub temp,pdata
+	branch check_dpll_pos,positive
+	sub pdata,0,pdata
+check_dpll_pos:
+	store 2,mem_dpll_error
+	sub pdata,70,null
+check_dpll_assert:
+	nbranch check_dpll_assert,positive
+	rtn
+	
+xtal_fast_wake:
+	setarg 0xf0f
+	branch lpm_write_config
+
+init_lpm_ctrl:
+	setarg 0x80f
+	branch lpm_write_config
+
+
+
+start_receiver:
+	set0 mark_ext_patch,mark
+	bpatch patch13_2,mem_patch13
+	call rf_rx_enable
+	disable is_tx
+	enable is_rx
+	pulse init_encrypt
+	rtn
+
+prep_crypt:
+	set0 mark_ext_patch,mark
+	bpatch patch13_3,mem_patch13
+	fetch 1,mem_state_map
+	isolate1 smap_encryption,pdata
+	setflag true,0,pdata
+	hstore 1,core_encrypt
+	arg mem_kc,contr
+	ifetch 9,contr
+	iforce kc_ls
+	ifetch 7,contr
+	iforce kc_ms
+	fetch 1,mem_key_size
+	add pdata,-1,g1l
+	pulse kc_p_activate               /* immediately start calculating primary Key */
+	rtn
+	
+wait_access_clke_rt:
+	set0 mark_ext_patch,mark
+	bpatch patch13_4,mem_patch13
+	enable decode_fec0
+	arg param_conn_access,timeup
+	correlate clke_rt,meet    /* keep correlating until sync is found, stop on no other condition */
+wait_access_end:
+	deposit clke
+	store 6,mem_sync_clke
+	disable decode_fec0
+	nbranch shutdown_radio,sync
+	arg param_clke_cal,clke_rt
+	increase 1,clke_bt
+	and_into 0x1fc,clke_bt
+	rtn
+
+
+
+wait_access_mhalfbnd:
+	enable decode_fec0
+wait_access_mhalfbnd_correlate:
+	correlate null,mhalfbnd    /* keep correlating until sync is found, or clke half */
+	branch wait_access_end,sync
+	compare 0x02,clke_bt,0x02
+	nbranch wait_access_mhalfbnd_correlate,true
+	branch wait_access_end
+
+wait_access_clkn_rt:
+	set0 mark_ext_patch,mark
+	bpatch patch13_5,mem_patch13
+	arg param_conn_access,timeup	/* found sync must occur within this time */
+	enable decode_fec0
+	correlate clkn_rt,meet    /* keep correlating until sync is found, or until clkn_rt timeup */
+	disable decode_fec0
+	nbranch shutdown_radio,sync
+	rtn
+
+wait_access_forever:
+	set0 mark_ext_patch,mark
+	bpatch patch13_6,mem_patch13
+	enable decode_fec0
+	correlate null,timeout    /* keep correlating until sync is found, or timeout */
+	disable decode_fec0
+	nbranch shutdown_radio,sync
+	arg param_clke_cal,clke_rt
+	and_into 0x1fc,clke_bt
+	rtn
+
+	/* reserve slots for mult-slot packet */
+reserve_slot:
+	set0 mark_ext_patch,mark
+	bpatch patch13_7,mem_patch13
+	iforce rega
+	deposit bt_clk
+	iadd temp,timeup
+	copy timeup,pdata
+	store 4,mem_next_btclk
+	deposit rega
+	rtn
+
+	/* pdata = clks ahead of bt_clk */
+ahead_window:
+	copy pdata,temp
+	set0 mark_ext_patch,mark
+	bpatch patch14_0,mem_patch14
+	copy temp,pdata
+	call clk2bt
+	lshift16 bt_clk,pdata
+	set1 44,pdata
+	call clk_diff
+	set0 44,pdata
+	call get_clk
+	call clk_diff
+	rtn user
+	call clk2rt
+	iforce stop_watch
+	until null,timeout
+	rtn
+
+
+setup_clk:
+	set0 mark_ext_patch,mark
+	bpatch patch14_1,mem_patch14
+	branch setup_clkn,clknt
+	until clke_rt,meet
+skip_setup_clke:
+	copy clke_bt,temp
+	branch setup_clknbt
+setup_clkn:
+	branch skip_setup_clkn,attempt
+	until clkn_rt,meet
+skip_setup_clkn:
+	copy clkn_bt,temp
+setup_clknbt:
+	branch setup_clk11,user
+	compare 1,temp,3
+	nbranch setup_clk,true
+setup_complete:
+	set0 mark_ext_patch,mark
+	bpatch patch14_2,mem_patch14
+	fetch 1,mem_state
+	rtnbit0 state_inconn
+	fetch 4,mem_next_btclk
+	isub temp,pdata
+	nrtn positive
+	sub pdata,0xff,null
+	branch setup_clk,positive
+	rtn
+setup_clk11:
+	compare 3,temp,3
+	nbranch setup_clk,true
+	branch setup_complete
+
+rf_setup_time:
+	set0 mark_ext_patch,mark
+	bpatch patch14_3,mem_patch14
+	arg param_rf_setup,timeup
+	branch setup_clk
+	
+rf_setup_time_slave_slot:
+	disable user
+	branch rf_setup_time
+
+rf_setup_time_master_slot:
+	enable user
+	branch rf_setup_time
+	
+start_transmitter:
+	set0 mark_ext_patch,mark
+	bpatch patch14_4,mem_patch14
+	call prep_crypt
+	disable is_rx
+	enable is_tx
+	rtn
+
+
+
+start_tx_native:
+	set0 mark_ext_patch,mark
+	bpatch patch14_5,mem_patch14
+	arg param_tx_setup,timeup
+	until clkn_rt,meet         /* wait until start_tx time */
+	pulse init_encrypt
+	rtn
+
+start_rx_native:
+	set0 mark_ext_patch,mark
+	bpatch patch14_6,mem_patch14
+	arg param_rx_setup,timeup
+	until clkn_rt,meet
+	rtn
+
+
+start_tx_external:
+	set0 mark_ext_patch,mark
+	bpatch patch14_7,mem_patch14
+	arg param_tx_setup,timeup
+	until clke_rt,meet         /* wait until start_tx time */
+	pulse init_encrypt
+	rtn
+
+send_access_word:
+	set0 mark_ext_patch,mark
+	bpatch patch15_0,mem_patch15
+	preload access          /* load in access word ready to be sent */
+	enable encode_fec0
+	set1 TXGFSK,radio_ctrl
+	inject mod,72
+	disable encode_fec0
+	rtn
+
+
+scan_mode_whiten:
+	copy xin,temp
+	or_into 0x60,temp                /* extend xin with 5->1, 6->1 */
+	copy temp,white_init
+	rtn
+
+
+
+	/* return blank if free amaddr is found */
+get_free_amaddr:
+	set0 mark_ext_patch,mark
+	bpatch patch15_1,mem_patch15
+	fetch 1,mem_current_amaddr
+	increase 1,pdata
+	bne param_esco_addr,get_free_amaddr_cont
+	force 1,pdata
+get_free_amaddr_cont:
+	store 1,mem_current_amaddr
+	iforce am_addr
+	rtn
+
+get_clk:
+	copy clkn,temp
+	rtn master
+	copy clke,temp
+	rtn
+
+get_clkbt:
+	deposit clkn_bt
+	rtn master
+	deposit clke_bt
+	rtn
+
+
+supervision_update:
+	set0 mark_ext_patch,mark
+	bpatch patch15_2,mem_patch15
+	fetcht 4,mem_supervision_timer
+	call get_clkbt
+	isub temp,timeup					/* and to 28 bits */
+	deposit timeup
+	fetcht 2,mem_supervision_to
+	lshift temp,temp
+	isub temp,pdata
+	rtn
+	
+supervision_flush:
+	set0 mark_ext_patch,mark
+	bpatch patch15_3,mem_patch15
+	call get_clkbt
+	store 4,mem_supervision_timer
+	rtn
+
+assert:
+	branch assert
+	
+loop:
+	branch loop
+
+sleep:	
+	rtn blank
+	/* sleep pdata clocks, only even clocks are accurate */
+	rshift pdata,pdata
+	increase -3,pdata
+sleep_loop:	
+	increase -1,pdata
+	nbranch sleep_loop,zero
+	force 0,pdata
+	rtn
+
+
+
+init_param:
+	/* clear specified sched ram */
+	arg 0x10,loopcnt
+	arg 0,contw
+	call memset0
+	arg mem_le_state,contw
+	arg 10,loopcnt
+	call memset0
+	jam 0,mem_sp_calc
+	jam 0,mem_fifo_temp
+	jam 0,mem_le_testtype
+	jam 0,mem_debug_config
+	jam 0,mem_lmp_conn_state
+	set0 mark_ext_patch,mark
+	bpatch patch15_4,mem_patch15
+	jam 0,mem_connection_options
+	jam 0,mem_tester_emulate
+	jam 0,mem_tester_cnt
+	setarg param_glap
+	store 3,mem_glap
+	setarg param_acl_pktlen
+	store 2,mem_acl_pktlen
+	jam param_sco_pktlen,mem_sco_pktlen
+	jam param_acl_pktcnt,mem_acl_pktcnt
+	jam param_sco_pktcnt,mem_sco_pktcnt
+	setarg param_hci_version
+	store 3,mem_hci_version
+	setarg param_lmp_version
+	store 3,mem_lmp_version
+	setarg param_lmp_subversion
+	store 2,mem_lmp_subversion
+	jam 0x60,mem_fhs_misc		/* R1 for 1.28s ps interval,P2 */
+	jam param_max_slot,mem_max_slot
+	jam 0x02,mem_fw_ver		/* set firmware version */
+ifdef SIMPLE_PAIRING
+	call init_memp
+endif
+	set0 mark_ext_patch,mark
+	bpatch patch15_5,mem_patch15
+	rtn wake
+	setarg 0
+	store 2,mem_tx_len
+	rshift clkn_bt,pdata
+	store 4,mem_last_clkn
+	rtn
+	
+
+//clear esco ibuff
+init_esco_ibuff:
+	setarg 0xaa,pdata
+	arg mem_sco_ibuf,contw
+	force 30,loopcnt
+init_esco_ibuff_loop:
+	istore 1,contw
+	loop init_esco_ibuff_loop
+	rtn
+
+init_rf_regs:
+	hjam 0x02,0x907
+	hjam 0x1f,0x908
+	hjam 0x1f,0x909
+	hjam 0xe0,0x90a
+	hjam 0x4e,0x90b			/* EVM */
+	hjam 0x45,rf_agc_ctrl		/* invert demod */
+	hjam 0x00,0x953			/* rccal */
+
+	hjam 0xfb,0x94c			/* rx sensitivity */
+	hjam 0xef,0x94d
+	hjam 0x0c,0x94e
+	
+	hjam 0x88,0x96f
+	hjam 0x30,0x973			/* turn off charge pump */
+
+	// tx power up to -3dBm
+	hjam 0x00,0x953
+	hjam 0xc9,0x956
+	hjam 0x6c,0x958
+	hjam 0x50,0x959
+	rtn
+
+init_agc_table:
+//AGC Table Setting Conservative, Based on 8PSK_sen, Max added
+	hjam 0xa9,0x930 //hjam 0x9D,0x930	
+	hjam 0xb1,0x92f //hjam 0xA1,0x92f	
+	hjam 0xb9,0x92e //hjam 0xA9,0x92e	
+	hjam 0xAD,0x92d	
+	hjam 0xB1,0x92c	
+	hjam 0xB5,0x92b	
+	hjam 0xBA,0x92a	
+	hjam 0xBE,0x929	
+	hjam 0xC2,0x928	
+	hjam 0xC6,0x927	
+	hjam 0xCA,0x926	
+	hjam 0xCE,0x925	
+	hjam 0xD2,0x924	
+	hjam 0xD6,0x923	
+	hjam 0xDA,0x922	
+	hjam 0xDE,0x921	
+	hjam 0xE2,0x920	
+	hjam 0xE6,0x91f	
+	hjam 0xEA,0x91e	
+	hjam 0xEE,0x91d	
+	hjam 0xF2,0x91c	
+	hjam 0xF6,0x91b	
+	hjam 0xFB,0x91a
+	
+	hjam 0xf5,0x947 //hjam 0xF8,0x947	
+	hjam 0xe5,0x946 //hjam 0xE9,0x946	
+	hjam 0xd5,0x945 //hjam 0xD9,0x945	
+	hjam 0xD8,0x944	
+	hjam 0xC9,0x943	
+	hjam 0xC8,0x942	
+	hjam 0x89,0x941	
+	hjam 0x88,0x940	
+	hjam 0x87,0x93f	
+	hjam 0x48,0x93e	
+	hjam 0x09,0x93d	
+	hjam 0x08,0x93c	
+	hjam 0xC9,0x93b	
+	hjam 0xC8,0x93a	
+	hjam 0xC7,0x939	
+	hjam 0xC6,0x938	
+	hjam 0xC5,0x937	
+	hjam 0xC4,0x936	
+	hjam 0xC3,0x935	
+	hjam 0xC2,0x934	
+	hjam 0xC1,0x933	
+	hjam 0xC0,0x932	
+	hjam 0x80,0x931
+	rtn	
+
+
+ifdef FPGA
+ifndef ROMCODE
+fpga_init:
+	hjam 5,core_clksel
+	hjam 1,core_config			// uart use 48M
+	hjam 1,rf_rx_lna_ctrim
+	hjam 0x2,0x908
+	hjam 0xb1,0x90e
+	hjam 0,0x912
+
+	hjam 0xF7,0x91A
+	hjam 0xF4,0x91B
+	hjam 0xF0,0x91C
+	hjam 0xEB,0x91D
+	hjam 0xE7,0x91E
+	hjam 0xE4,0x91F
+	hjam 0xE0,0x920
+	hjam 0xDB,0x921
+	hjam 0xD7,0x922
+	hjam 0xD5,0x923
+	hjam 0xD1,0x924
+	hjam 0xCC,0x925
+	hjam 0xC8,0x926
+	hjam 0xC2,0x927
+	hjam 0xBE,0x928
+	hjam 0xBA,0x929
+	hjam 0xBA,0x92A
+	hjam 0xB3,0x92B
+	hjam 0xB3,0x92C
+	hjam 0xAB,0x92D
+	hjam 0xAB,0x92E
+	hjam 0xA2,0x92F
+	hjam 0x9F,0x930
+
+	hjam 0x30,0x931
+	hjam 0x20,0x932
+	hjam 0x10,0x933
+	hjam 0x50,0x934
+	hjam 0x64,0x935
+	hjam 0x54,0x936
+	hjam 0x68,0x937
+	hjam 0xa8,0x938
+	hjam 0xe8,0x939
+	hjam 0xfC,0x93A
+	hjam 0xeC,0x93B
+	hjam 0xd9,0x93C
+	hjam 0x19,0x93D
+	hjam 0x8D,0x93E
+	hjam 0xcD,0x93F
+	hjam 0x1E,0x940
+	hjam 0x9E,0x941
+	hjam 0x9E,0x942
+	hjam 0x9E,0x943
+	hjam 0x9F,0x944
+	hjam 0x9F,0x945
+	hjam 0x8F,0x946
+	hjam 0xcF,0x947
+
+	hjam 0x00,0x948
+	hjam 0x90,0x949
+	hjam 0x7f,0x94a
+
+	rtn wake
+	call fpga_init_jtag
+	setarg 0x1c38	
+	call fpga_write_radio
+	setarg 0x1c28	
+	call fpga_write_radio
+	setarg 0x185e	
+	call fpga_write_radio
+	setarg 0x24ff	
+	call fpga_write_radio
+	setarg 0x2894
+	call fpga_write_radio
+	setarg 0x2922	
+	call fpga_write_radio
+	setarg 0x2a1c	
+	call fpga_write_radio
+	setarg 0x2c00
+	call fpga_write_radio
+
+	setarg 0x2050
+	call fpga_write_radio
+	setarg 0x1580
+	call fpga_write_radio
+	hjam 0x70,core_bist_ctrl
+	hjam ccnt_start,core_misc_ctrl
+
+	hjam 1,rf_rx_lna_ctrim+1
+	force 0,clkn
+	force 0,clke
+	hjam 0,rf_rx_lna_ctrim+1
+	rtn
+
+fpga_init_jtag:
+	hjam 0,rf_rx_vctrl_reg2
+	hjam 0x9,core_clksel 
+	nop 100
+	hjam 2,rf_rx_lna_ctrim
+	hjam 0,rf_rx_lna_ctrim
+	arg 0x800c,rega
+	arg 2,regb
+	call fpga_write_reg
+	nop 0x5000
+	hjam 1,rf_rx_lna_ctrim
+	nop 0x5000
+	hjam 5,core_clksel
+	rtn
+
+fpga_write:
+	hstore 1,rf_rx_vctrl_reg1
+	hjam 1,rf_rx_vctrl_reg2
+	hjam 0,rf_rx_vctrl_reg2
+	rtn
+
+
+fpga_read:
+	hfetch 1,rf_rccal_result
+	hjam 2,rf_rx_vctrl_reg2
+	hjam 0,rf_rx_vctrl_reg2
+	rtn
+
+	
+fpga_write_reg:
+	setarg 0xb
+	call fpga_write
+	rshift8 rega,pdata
+	call fpga_write
+	setarg 0x3
+	call fpga_write
+	and rega,0xff,pdata
+	call fpga_write
+	setarg 5
+	call fpga_write
+	deposit regb
+	branch fpga_write
+	
+
+fpga_read_reg:
+	setarg 0xb
+	call fpga_write
+	rshift8 rega,pdata
+	call fpga_write
+	setarg 0x3
+	call fpga_write
+	and rega,0xff,pdata
+	call fpga_write
+	setarg 6
+	call fpga_write
+	branch fpga_read
+	
+
+fpga_write_radio:
+	and pdata,0xff,regb
+	rshift8 pdata,rega
+	setarg 0x8900
+	ior rega,rega
+	branch fpga_write_reg
+
+endif
+endif
+
+init_250k:
+	enable le
+	setarg 0x8e89be
+	lshift8 pdata,pdata
+	or_into 0xd6,pdata
+	iforce access
+	hjam 7,0x914			// enable ble
+	hjam 0xa0,0x90a
+	hjam 0x8f,0x90d		// enable 250k
+	hjam 0x0f,0x911		
+	hjam 0x87,0x912		// disable agc
+	rtn
+
+
+/*****************************************LPO************************************************/
+
+lpmstate:
+	setarg 0xee21
+	hstore 2,core_clkoff			// disable unused peripherals
+	hfetch 1,core_lpm_ldocnt
+	bbit0 gpio_latch,loadcode		// power up boot
+	enable wake
+	bbit0 cold_wake,lpmwake		
+	disable wake
+	deposit auxcnt
+	nbranch lpmwake,blank		// sleep interrupted, wakeup
+	arg param_hibernate_clks,temp
+	branch lpm_enter_sleep
+lpmwake:
+	hfetch 3,core_lpm_xtalcnt
+	hstore 3,core_lpm_reg
+	ifetch 1,contr
+	or_into isogate_mask,pdata		// open all isolation gate&power switch
+	istore 1,contw
+	call lpm_write_ctrl2
+	hfetch 1,core_lpm_isogate
+	set1 enable_retmem,pdata
+	hstore 1,core_lpm_isogate
+	call lpm_write_ctrl2
+	call lpm_load_context,wake
+	hfetch 1,core_lpm_reg+2
+	set0 gpio_latch,pdata			// enable gpio fuction
+	hstore 1,core_lpm_reg+2
+	call lpm_write_ctrl2
+	rtn wake
+	branch loadcode				// wakeup from hibernate
+
+lpm_load_context:
+	fetch 1,mem_saved_spidctrl
+	hstore 1,core_spid_ctrl
+	fetch 3,mem_saved_gsel
+	hstore 3,core_gpio_sel
+	fetch 4,mem_saved_gpio+4
+	hstore 4,core_gpio_out0
+	fetch 4,mem_saved_gpio
+	hstore 4,core_gpio_oe0
+	fetch 8,mem_saved_gpio+8
+	hstore 8,core_gpio_pu0	
+	fetch 8,mem_saved_mark
+	iforce mark
+	hfetch 8,core_gpio_wakeup_low
+	store 8,mem_gpio_wakeup_low
+	call load_ucode
+	rtn
+
+lpm_save_context:
+	deposit mark
+	store 8,mem_saved_mark
+	hfetch 8,core_gpio_oe0
+	store 8,mem_saved_gpio
+	ifetch 8,contr
+	istore 8,contw
+	hfetch 3,core_gpio_sel
+	store 3,mem_saved_gsel
+	hfetch 1,core_spid_ctrl
+	store 1,mem_saved_spidctrl
+	branch lpm_write_gpio_wakeup
+
+lpo_calibration:
+	hfetch 1,core_bist_ctrl
+	nbranch lpo_cal_inited,blank
+	fetch 3,mem_clks_per_lpo
+	nrtn blank
+	hjam 0xc0,core_bist_ctrl
+	hjam ccnt_start,core_misc_ctrl
+lpo_cal_inited:
+	hfetch 1,core_perf_status
+	rtnbit0 1
+	hfetch 3,core_clk_counter
+	store 3,mem_clks_per_lpo
+	rtn
+
+
+	/* temp is synced clke */
+lpm_adjust_clk:
+	set0 mark_ext_patch,mark
+	bpatch patch15_6,mem_patch15
+	deposit clke
+	call clk_diff_rt
+	fetcht 4,mem_sleep_counter_all
+	sub temp,0xff,null
+	rtn positive				// interval too small
+	lshift8 pdata,pdata
+	lshift4 pdata,pdata
+	idiv temp
+	call wait_div_end
+	quotient pdata
+	arg param_lpm_adjmax,temp
+	call ceiling
+	store 1,mem_lpm_adjust
+	nbranch lpm_adjust_positive,user
+	sub pdata,0,pdata
+lpm_adjust_positive:
+	fetcht 3,mem_clks_per_lpo
+	iadd temp,pdata
+	store 3,mem_clks_per_lpo
+lpm_clear_counter:
+	setarg 0
+	store 4,mem_sleep_counter_all
+	rtn
+
+	/* no retention memory at all */
+lpm_hibernate:
+	set0 mark_ext_patch,mark
+	bpatch patch15_7,mem_patch15
+	call lpm_write_gpio_wakeup
+	hfetch 4,core_lpm_ctrl
+	set0 15,pdata						/* lowest lpo */
+	hstore 4,core_lpm_reg
+	call lpm_write_ctrl
+lpm_hibernate_normal:
+	arg param_hibernate_clks,temp
+	fetch 1,mem_lpm_hibernate_switch
+	store 1,mem_lpm_xtalcnt + 4
+ifdef ROMCODE
+	fetch 1,mem_lpm_xtalcnt + 2
+	set1 cold_wake,pdata
+	store 1,mem_lpm_xtalcnt + 2
+else
+	branch rom_lpm_sleep
+endif
+
+	/* temp is lpo clocks to sleep */
+lpm_sleep:
+	set0 mark_ext_patch,mark
+	bpatch patch16_0,mem_patch16
+	fetch 4,mem_sleep_counter_all
+	iadd temp,pdata
+	store 4,mem_sleep_counter_all
+	call lpm_save_context
+	fetch 5,mem_lpm_xtalcnt
+	hstore 4,core_lpm_reg
+	rshift32 pdata,rega
+	until null,lpo_edge
+	deposit clkn
+	store 6,mem_sleep_clkn
+	hjam lpmreg_sel_ctrl2,core_lpm_wr
+	until null,lpo_edge
+	until null,lpo_edge
+	deposit rega
+	hstore 1,core_lpm_isogate
+	hjam lpmreg_sel_ctrl2,core_lpm_wr
+lpm_enter_sleep:
+	until null,lpo_edge
+	until null,lpo_edge
+	hstoret 4,core_lpm_reg
+	hjam lpmreg_sel_counter,core_lpm_wr
+	until null,never
+
+
+
+
+lpm_recover_clk:
+	set0 mark_ext_patch,mark
+	bpatch patch16_1,mem_patch16
+	setarg 0
+	copy auxcnt,null
+	branch lpm_recover_timeout,zero
+	hfetch 1,core_lpm_xtalcnt
+	hfetcht 1,core_lpm_buckcnt
+	isub temp,null
+	branch lpm_recover_xtal,positive
+	deposit temp
+lpm_recover_xtal:
+	isub auxcnt,pdata
+	increase 1,pdata
+lpm_recover_timeout:
+	increase 8,pdata
+	until null,lpo_edge
+	iadd lpo_time,pdata
+	fetcht 4,mem_sleep_counter
+	iadd temp,pdata
+	fetcht 3,mem_clks_per_lpo
+	imul32 temp,pdata
+	rshift8 pdata,pdata
+	rshift4 pdata,pdata
+	increase param_lpm_fix,pdata
+	arg 3750,temp
+	idiv temp
+	call wait_div_end
+	quotient pdata
+	lshift16 pdata,pdata
+	remainder temp
+	ior temp,pdata
+	fetcht 6,mem_sleep_clkn
+	call clk_add
+	copy temp,clkn
+	fetch 6,mem_context + coffset_clk_offset
+	call calc_clke2
+	deposit clke
+	store 6,mem_pdatatemp
+	deposit auxcnt
+	istore 1,contw
+	hfetch 1,core_gpio_in1
+	or_into 0xf0,pdata
+	istore 1,contw
+	call savelist_2
+	rtn
+	
+lpm_dispatch:
+	set0 mark_ext_patch,mark
+	bpatch patch16_2,mem_patch16
+	call lpo_calibration
+	fetch 3,mem_clks_per_lpo
+	rtn blank
+	fetch 1,mem_lpm_mode
+	rtn blank
+	call lpm_check_wake_lock
+	nrtn blank
+lpm_dispatch0:
+	fetch 1,mem_context
+	compare 3,pdata,0x7							/* sco won't sleep */
+	nbranch lpm_dispatch_unconn,true
+	fetch 2,mem_context + coffset_tsniff
+	rtn blank										/* role switch */
+	rtn wake
+	set0 mark_ext_patch,mark
+	bpatch patch16_3,mem_patch16
+lpm_dispatch1:
+	fetcht 1,mem_lpm_current_mult
+	fetch 2,mem_context + coffset_tsniff
+	imul32 temp,pdata
+	rshift4 temp,temp
+	rshift2 temp,temp
+	isub temp,pdata
+	fetcht 4,mem_context + coffset_sniff_anchor
+	iadd temp,pdata
+	fetcht 1,mem_lpm_overhead
+	isub temp,pdata
+	lshift16 pdata,alarm
+	set0 mark_ext_patch,mark
+	bpatch patch16_4,mem_patch16
+	fetch 2,mem_context + coffset_rx_window
+	rshift pdata,pdata
+	call clk2bt
+	deposit alarm
+	call clk_diff
+	copy clke,temp
+	call clk_diff_rt
+	rtn user
+lpm_dispatch_sleep:
+	call clk2lpo
+lpm_dispatch_lpo:
+	set0 mark_ext_patch,mark
+	bpatch patch16_5,mem_patch16
+	fetch 1,mem_lpm_xtalcnt
+	isub temp,null
+	branch lpm_clear_counter,positive
+	storet 4,mem_sleep_counter
+	call app_will_enter_lpm
+	call l2cap_lpm_save_txbuf
+	fetcht 4,mem_sleep_counter
+ifdef ROMCODE
+	branch lpm_sleep
+else
+	call lpm_write_gpio_wakeup
+	jam 1,mem_patch00
+	branch rom_lpm_sleep
+endif
+	
+lpm_dispatch_unconn:
+	set0 mark_ext_patch,mark
+	bpatch patch16_6,mem_patch16
+	fetch 1,mem_context
+	rtnbit1 state_inconn					// wont sleep in connection
+	rtnbit1 state_inpage					// wont sleep when paging
+	fetch 1,mem_ssp_enable
+	branch lpm_unconn_nossp,blank
+	fetch 1,mem_sp_local_key_invalid	// simple pairing is not ready
+	rtn blank
+lpm_unconn_nossp:
+	fetch 1,mem_le_adv_enable
+	nbranch lpm_unconn_cont,blank
+	fetch 1,mem_scan_mode
+	rtn blank
+lpm_unconn_cont:
+	fetch 2,mem_lpm_interval
+	rtn blank
+lpm_sleep_btclk:
+	fetcht 1,mem_lpm_overhead
+	isub temp,pdata
+	arg 7500,temp				/* 1.25ms */
+	imul32 temp,pdata
+	branch lpm_dispatch_sleep
+
+lpm_set_mult:
+	set0 mark_ext_patch,mark
+	bpatch patch16_7,mem_patch16
+	disable wake
+	fetch 1,mem_state
+	rtnbit0 state_insniff
+	nbranch lpm_not_match,match
+	call lpm_match
+	fetch 2,mem_rx_window_sniff
+	store 2,mem_rx_window
+	fetch 1,mem_arq
+	bbit1 wack,lpm_mult_short
+	bmark0 mark_lpm_mult_enable,lpm_mult_short
+	call l2cap_malloc_is_fifo_empty
+	nbranch lpm_mult_short,blank
+lpm_mult_wait_timeout:
+	jam 0,mem_lpm_current_mult
+	bmark0 mark_lpm_mult_enable,lpm_mult_short
+	fetch 1,mem_lpm_mult_cnt
+	branch lpm_mult_long,blank
+	increase -1,pdata
+	store 1,mem_lpm_mult_cnt
+	rtn
+
+lpm_match:
+	jam 0,mem_sniff_unint_lost
+	fetch 3,mem_sniff_rcv
+	increase 1,pdata
+	store 3,mem_sniff_rcv
+	rtn
+
+lpm_not_match:
+	set0 mark_ext_patch,mark
+	bpatch patch17_0,mem_patch17
+	fetcht 2,mem_rx_window_sniff
+	rshift temp,temp
+	fetch 2,mem_rx_window
+	iadd temp,pdata
+	store 2,mem_rx_window
+lpm_lost:
+	jam 0,mem_lpm_current_mult
+	fetch 3,mem_sniff_lost
+	increase 1,pdata
+	store 3,mem_sniff_lost
+	fetch 1,mem_sniff_unint_lost
+	increase 1,pdata
+	store 1,mem_sniff_unint_lost
+	rtn
+
+lpm_mult_short:
+	jam 0,mem_lpm_current_mult
+	fetch 1,mem_lpm_mult_timeout
+	store 1,mem_lpm_mult_cnt
+	rtn
+
+lpm_mult_long:
+	fetcht 1,mem_lpm_mult
+	storet 1,mem_lpm_current_mult
+	rtn
+
+lpm_cal_xtal_startup:
+	set0 mark_ext_patch,mark
+	bpatch patch17_1,mem_patch17
+	fetch 1,mem_lpm_xtalcnt
+	nrtn blank
+	hjam clksel_rc,core_clksel
+	setarg 0xf0c
+	call lpm_write_config
+	setarg 200000
+	call sleep
+	until null,lpo_edge
+	copy lpo_time,alarm
+	call xtal_fast_wake
+	hjam clksel_xtal,core_clksel
+	nop 10
+	until null,lpo_edge
+	deposit lpo_time
+	isub alarm,pdata
+	increase 0x30,pdata
+	arg 0xff,temp
+	call ceiling
+	store 1,mem_lpm_xtalcnt
+	rtn
+
+
+
+	/* pdata is lpm_reg[11:0] */
+lpm_write_config:
+	arg 0xfff,contw
+	iand contw,contw
+	fetch 1,mem_lpm_config
+	and_into 0xf0,pdata
+	lshift8 pdata,pdata
+	ior contw,pdata
+	hstore 2,core_lpm_reg
+	ifetch 2,contr
+	istore 2,contw
+
+lpm_write_ctrl:
+	setarg lpmreg_sel_ctrl
+	branch lpm_write
+
+lpm_write_ctrl2:
+	setarg lpmreg_sel_ctrl2
+lpm_write:
+	until null,lpo_edge
+	hstore 1,core_lpm_wr
+	until null,lpo_edge
+	until null,lpo_edge
+	rtn
+
+
+lpm_write_gpio_wakeup:
+	set0 mark_ext_patch,mark
+	bpatch patch17_2,mem_patch17
+	fetch 4,mem_gpio_wakeup_low
+	hstore 4,core_lpm_reg
+	setarg lpmreg_sel_gpiolow
+	call lpm_write
+	fetch 4,mem_gpio_wakeup_high
+	hstore 4,core_lpm_reg
+	setarg lpmreg_sel_gpiohigh
+	branch lpm_write
+
+lpm_get_wake_lock:
+	fetch 2,mem_lpm_wake_lock
+	qset1 pdata
+	store 2,mem_lpm_wake_lock
+	rtn
+
+lpm_put_wake_lock:
+	fetch 2,mem_lpm_wake_lock
+	qset0 pdata
+	store 2,mem_lpm_wake_lock
+	rtn
+
+
+
+lpm_check_wake_lock:
+	set0 mark_ext_patch,mark
+	bpatch patch17_3,mem_patch17
+	call app_check_wake_lock
+	fetch 2,mem_lpm_wake_lock
+	copy pdata,rega
+	fetch 1,mem_state_map
+	isolate1 smap_rxlmp,pdata
+	setflag true,wake_lock_lmp_rx,rega
+	fetch 1,mem_lmo_opcode1
+	fetcht 1,mem_lmo_opcode2
+	iadd temp,pdata
+	fetcht 1,mem_lmp_to_send
+	iadd temp,pdata
+	nsetflag blank,wake_lock_lmp_tx,rega
+	set0 mark_ext_patch,mark
+	bpatch patch17_4,mem_patch17
+	fetch 2,mem_l2cap_rxbuff1_len
+	fetcht 2,mem_l2cap_rxbuff2_len
+	iadd temp,pdata
+	nsetflag blank,wake_lock_l2cap_rx,rega
+	fetch 5,mem_ipc_fifo_bt2c51
+	nsetflag blank,wake_lock_ipc_bt2c51,rega
+	fetch 5,mem_ipc_fifo_c512bt
+	nsetflag blank,wake_lock_ipc_c512bt,rega
+	fetch 1,mem_hci_cmd
+	nsetflag blank,wake_lock_cmd,rega
+	fetch 1,mem_device_option
+	compare dvc_op_module,pdata,0xff
+	call lpm_uart_wake_lock,true
+	set0 mark_ext_patch,mark
+	bpatch patch17_5,mem_patch17
+	fetch 1,mem_device_option
+	bne dvc_op_hci,lpm_check_wake_lock_nothci
+	call lpm_uart_wake_lock
+	fetch 1,mem_link_key_exists
+	setflag blank,wake_link_key_exists,rega
+	fetch 4,mem_lpm_delay_after_sniff
+	arg 0x1710,temp
+	iadd temp,temp
+	copy clkn_bt,pdata
+	isub temp,null
+	nsetflag positive,wake_lock_delay,rega
+	branch lpm_check_wake_lock_end
+
+lpm_uart_wake_lock:
+	hfetch 2,core_uart_rxitems
+	nsetflag blank,wake_lock_uart_rx ,rega
+	hfetch 2,core_uart_txitems
+	nsetflag blank,wake_lock_uart_tx ,rega
+	rtn
+
+lpm_check_wake_lock_nothci:
+	setarg -8
+	iand rega,rega
+lpm_check_wake_lock_end:
+	copy rega,pdata
+	store 2,mem_lpm_wake_lock
+	rtn blank
+	rtn match
+	enable wake
+	rtn
+
+lpm_shut_down:
+	hfetch 4,core_lpm_ctrl
+	set0 27,pdata
+	hstore 4,core_lpm_reg
+	call  lpm_write_ctrl
+	branch assert
+
+lpm_enable_exen_output:
+	hfetch 4,core_lpm_xtalcnt
+	set1 20,pdata
+	hstore 4,core_lpm_reg
+	branch lpm_write_ctrl2
+	
+lpm_disable_exen_output:
+	hfetch 4,core_lpm_xtalcnt
+	set0 20,pdata
+	hstore 4,core_lpm_reg
+	branch lpm_write_ctrl2
+
+lpm_hci_wake_dispatch:
+	set0 mark_ext_patch,mark
+	bpatch patch17_6,mem_patch17
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	call gpio_check_uart_state
+	rtn true
+	fetch 4,mem_hci_wake_clk
+	nbranch lpm_hci_check_wake_time,blank
+	copy clkn_bt,pdata
+	store 4,mem_hci_wake_clk
+	branch gpio_pd_uart_tx
+lpm_hci_check_wake_time:
+	set0 mark_ext_patch,mark
+	bpatch patch17_7,mem_patch17
+	copy clkn_bt,pdata
+	fetcht 4,mem_hci_wake_clk
+	isub temp,pdata
+	arg HOST_WAKE_TIME,temp
+	isub temp,null
+	nrtn positive
+	setarg 0
+	store 4,mem_hci_wake_clk
+	branch hci_exit_lpm
+
+check_bt_disabled:
+	fetch 2,mem_chip_functions
+	bbit1 bt_disabled,assert
+	rtn
+check_ble_disabled:
+	fetch 2,mem_chip_functions
+	bbit1 ble_disabled,assert
+	rtn
+check_module_disabled:
+	fetch 2,mem_chip_functions
+	bbit1 module_disable,assert
+	rtn
+	
+test_init:
+	setarg test_proc
+	store 2,mem_cb_bt_process
+	setarg test_sleep
+	store 2,mem_cb_bb_event_process
+	setarg test_proc
+	store 2,mem_cb_idle_process
+	rtn wake
+	jam ui_led_start,mem_led_switch
+	rtn
+
+test_proc:
+	fetch 1,mem_state
+	bbit0 state_insniff,check_test_cond
+	set1 mark_lpm_mult_enable,mark
+	fetch 6,mem_sniff_rcv
+	store 6,mem_local_name
+	branch ui_led_blink_stop
+	
+
+test_sleep:
+	deposit regc
+	rtnne BT_EVT_BUTTON_LONG_PRESSED
+test_sleep_loop:
+	call ui_button_polling
+	fetch 1,mem_ui_button_last_state
+	beq 1,test_sleep_loop
+	call ui_led_off
+	branch lpm_hibernate
+
+
+test_tx:
+	force 2,temp
+	increase -2,temp
+	call set_sync_on
+	call set_freq_tx
+	disable enable_white
+	enable encode_fec0
+	set1 TXGFSK,radio_ctrl
+	call start_transmitter
+test_tx_loop:
+	fetch 1,0
+	inject mod,8
+	branch test_tx_loop
+
+
+	
+
+
Index: btkb/program/dongle.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/dongle.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/dongle.prog	(working copy)
@@ -0,0 +1,125 @@
+ifdef COMPILE_DONGLE
+
+le_dongle_init:
+	call usb_init
+	call app_led_start_blink
+	setarg le_dongle
+	store 2,mem_cb_le_process
+	setarg dongle_process_bb_event
+	store 2,mem_cb_bb_event_process
+	setarg usb_isr
+	store 2,mem_cb_idle_process
+	jam 5,mem_dongle_count
+	jam 0,mem_dongle_peers
+	jam hci_cmd_le_create_conn,mem_hci_cmd
+	rtn	
+
+
+le_dongle:
+	disable true
+	call app_check_conn_device_nums_addr
+	//jam 1,mem_le_scan_enable
+	jam 0x1b,mem_cmd_le_create_conn
+	fetch 1,mem_device_nums
+	compare 2,pdata,0x3
+	nrtn true
+	jam 0,mem_le_scan_enable
+	rtn
+
+le_scan_dongle:
+	fetch 1,mem_le_rxbuf
+	bbit0 0,dongle_add_peer
+	fetch 6,mem_le_rxbuf+2			// direct ind, for me?
+	fetcht 6,mem_le_plap
+	isub temp,null
+	nrtn zero
+dongle_peer_paired:
+	fetch 6,mem_le_plap
+	store 6,mem_le_conn_peer_addr
+	rtn
+	
+dongle_add_peer:
+	arg 0xff,rega
+	call le_search_adtype
+	nrtn zero
+	ifetch 2,contr
+	fetcht 2,mem_dongle_signature
+	isub temp,null
+	nrtn zero
+	fetch 1,mem_dongle_peers
+	increase 1,pdata
+	store 1,mem_dongle_peers
+	fetcht 1,mem_dongle_pairing_cnt
+	isub temp,null
+	branch dongle_peer_paired,positive
+	rtn
+
+dongle_process_bb_event:
+	copy regc,pdata
+	beq BT_EVT_LE_DISCONNECTED,dongle_le_event_bb_disconnected
+	beq BT_EVT_LE_CONNECTED,dongle_bb_event_connected
+	and pdata,0x0f,temp
+	and_into BT_EVT_TIMER_MASK,pdata
+	beq BT_EVT_TIMER_INIT,dongle_bb_event_100ms
+	rtn
+	
+dongle_le_event_bb_disconnected:
+	setarg 0
+	store 6,mem_le_conn_peer_addr
+	jam 0,mem_dongle_peers
+	setarg 0
+	store 5,mem_mouse_data
+	jam SEND_MOUSE_DATA_CMD,mem_mcmd
+	call usb_isr
+	branch app_ble_start_scan
+ 	
+dongle_bb_event_100ms:
+	rtn
+	fetch 1,mem_le_scan_enable
+	rtn blank
+	fetch 1,mem_dongle_count
+	rtn blank
+	increase -1,pdata
+	store 1,mem_dongle_count
+	nrtn blank
+	call le_change_peer_addr
+	branch app_ble_start_conn
+	
+	
+dongle_bb_event_connected:
+	branch app_ble_stop_scan
+
+le_change_peer_addr:
+
+	jam 5,mem_dongle_count
+	fetch 1,mem_le_peer_state
+	beq LE_CONTEXT_STATE_KB,addr_slave2
+	beq LE_CONTEXT_STATE_MOUSE,addr_slave1
+	rtn
+addr_slave1:
+	fetch 6,mem_le_addr_slave1
+	store 6,mem_app_peer_addr
+	jam LE_CONTEXT_STATE_KB,mem_le_peer_state
+	rtn
+addr_slave2:
+  	fetch 6,mem_le_addr_slave2
+  	store 6,mem_app_peer_addr
+  	jam LE_CONTEXT_STATE_MOUSE,mem_le_peer_state
+  	rtn
+  	
+else
+
+le_scan_dongle:
+	rtn
+le_dongle_init:
+check_usb_desc:
+le_dongle:
+dongle_process_bb_event:
+dongle_le_event_bb_disconnected:
+dongle_bb_event_100ms:
+dongle_bb_event_connected:
+le_change_peer_addr:
+addr_slave1:
+addr_slave2:
+	branch assert
+endif
Index: btkb/program/hci_bcsp.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/hci_bcsp.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/hci_bcsp.prog	(working copy)
@@ -0,0 +1,368 @@
+
+ifdef COMPILE_HCI_BCSP
+hci_rx_bcsp:
+	ifetch 2,contru
+	branch hci_reset_uart,blank		//length = 0
+	iforce regc						/* regc is byte count */
+	ifetch 1,contru
+	store 1,mem_h5rx_tmp
+	iforce rega						/* rega is checksum */
+	bbit0 6,hci_rx_bcsp_nocrc
+	increase -2,regc
+hci_rx_bcsp_nocrc:
+	ifetch 2,contru
+	rshift4 pdata,loopcnt				/* loopcnt is packet length */
+	and pdata,0xf,debug				/* debug is packet type */
+	iadd rega,rega
+	rshift8 pdata,pdata
+	iadd rega,rega
+	ifetch 1,contru
+	iadd rega,pdata
+	bne 0xff,hci_rx_bcsp_discard_packet		/* checksum error */
+	add regc,-4,pdata
+	isub loopcnt,null
+	nbranch hci_rx_bcsp_discard_packet_err,zero	/* received byte not equal length */
+	fetch 1,mem_h5rx_tmp
+	isolate0 7,pdata
+	branch hci_rx_bcsp_check_ack_skip,true
+	set0 mark_h5_reset,mark
+	bmark1 mark_h5_reset,hci_rx_bcsp_check_ack_skip
+	and_into 7,pdata
+	fetcht 1,mem_h5tx_ack
+	isub temp,null
+	nbranch hci_rx_bcsp_discard_packet_err,zero	/*ack  number err*/
+hci_rx_bcsp_check_ack_skip:
+	setarg 1600
+	force lpo_delay_timer,queue
+	call timer_init
+	deposit debug
+	call hci_bcsp_parse_packet
+	rtn user							/* delaying parse packet */
+	fetch 1,mem_h5rx_tmp
+	iforce rega						/* saved in rega */
+	rshift3 pdata,temp
+	and_into 7,temp					/* temp is ack no */
+	fetch 1,mem_h5rx_ack
+	isub temp,pdata
+	sub pdata,0,pdata
+	and_into 7,pdata
+	bne 1,hci_rx_bcsp_discard_packet_err		/* should only ack 1 packet! */
+	storet 1,mem_h5rx_ack
+	fetch 1,mem_h5rx_ackcnt
+	increase 1,pdata
+	store 1,mem_h5rx_ackcnt
+	branch hci_rx_bcsp_discard_packet
+	
+hci_rx_bcsp_discard_packet_err:
+	fetch 1,mem_check_err_acl_cont
+	increase 1,pdata
+	store 1,mem_check_err_acl_cont
+hci_rx_bcsp_discard_packet:
+	hfetch 2,core_uart_rrptr
+	iforce contru
+	ifetch 2,contru
+	iadd contru,contru
+	deposit contru
+	hstore 2,core_uart_rrptr
+	rtn
+
+hci_bcsp_parse_packet:
+	disable user
+	rtn blank					/* ack packet, do nothing */
+	beq 1,parse_bcsp_link_establish
+	beq 2,parse_bcsp_bccmd
+	beq 5,process_hci_cmd
+	beq 6,process_acl
+	beq 8,process_hci_patch
+	rtn
+
+parse_bcsp_link_establish:
+	set0 mark_h5_reinit,mark
+	ifetch 1,contru
+	beq 0xda,parse_bcsp_link_establish_sync
+	beq 0xac,parse_bcsp_link_establish_syncrsp
+	beq 0xad,parse_bcsp_link_establish_conf
+	beq 0xde,parse_bcsp_link_establish_confrsp
+	rtn
+parse_bcsp_link_establish_sync:
+	bmark1 mark_h5_sync,parse_bcsp_link_establish_send_syncrsp
+	force 0xda,temp
+	setarg 0xededdc
+	call parse_bcsp_link_establish_send
+parse_bcsp_link_establish_send_syncrsp:	
+	force 0xac,temp
+	setarg 0xeeefaf
+	branch parse_bcsp_link_establish_send
+parse_bcsp_link_establish_syncrsp:
+	set1 mark_h5_sync,mark
+	force 0xad,temp
+	setarg 0xedacef
+	branch parse_bcsp_link_establish_send
+parse_bcsp_link_establish_conf:
+	force 0xde,temp
+	setarg 0xd0d0ad
+parse_bcsp_link_establish_send:	
+	lshift8 pdata,pdata
+	ior temp,temp
+	call hci_get_packet_ptr
+	istoret 4,contwu
+	force 1,queue				/* queue is packet type */
+	force 4,loopcnt
+	set0 mark_h5tx_rp,mark
+	branch bcsp_send_packet
+parse_bcsp_link_establish_confrsp:
+	force 0,alarm
+	branch hci_command_status
+	
+parse_bcsp_bccmd:
+	copy loopcnt,alarm
+	call bcsp_send_ack
+	force 0,regb
+	call hci_get_packet_ptr
+	copy alarm,loopcnt
+	ifetch 1,contru
+	setarg 1
+	istore 1,contwu
+	set0 mark_temp,mark
+parse_bcsp_bccmd_loop:
+	ifetch 1,contru
+	increase 1,regb
+	beq 0x1c,parse_bcsp_bccmd_sco_link		/*sco link patch by csr*/
+	compare 4,regb,0xff
+	nbranch parse_bcsp_bccmd_next,true
+	setflag blank,mark_temp,mark
+	bne 0x3a,parse_bcsp_bccmd_next
+	setarg 2000
+	force h5_reinit_timer,queue
+	call timer_init
+	set1 mark_h5_reinit,mark
+	rtn
+	
+parse_bcsp_bccmd_sco_link:
+	compare 6,regb,0xff
+	branch parse_bcsp_bccmd_next_ok,true	
+parse_bcsp_bccmd_next:
+	isolate1 mark_temp,mark
+	call parse_bcsp_bccmd_replace,true
+	istore 1,contwu
+	loop parse_bcsp_bccmd_loop
+	set0 mark_bccmd_patch,mark
+	copy alarm,loopcnt
+	set1 mark_h5tx_rp,mark
+	force 2,queue
+	branch bcsp_send_packet
+parse_bcsp_bccmd_next_ok:
+	set1 mark_bccmd_patch,mark
+	branch parse_bcsp_bccmd_next
+	
+parse_bcsp_bccmd_replace:
+	rtnmark1 mark_bccmd_patch
+	compare 10,regb,0xff
+	branch parse_bcsp_bccmd_replace1,true
+	compare 11,regb,0xff
+	nrtn true
+	setarg 0x12
+	rtn
+parse_bcsp_bccmd_replace1:
+	setarg 0xe9
+	rtn
+	
+bcsp_send_ack:
+	fetch 1,mem_h5rx_tmp
+	increase 1,pdata
+	and_into 7,pdata
+	store 1,mem_h5tx_ack		/* our ack is got seq + 1 */
+	force 0,loopcnt
+	force 0,queue
+	set0 mark_h5tx_rp,mark
+bcsp_send_packet:
+//	set1 mark_h5tx_crc,mark
+	add loopcnt,4,regb				/* regb is total packet length */
+	fetch 1,mem_h5tx_ack
+	lshift3 pdata,regc
+	isolate0 mark_h5tx_crc,mark
+	nsetflag true,6,regc
+	branch bcsp_send_packet_nocrc,true	
+	increase 2,regb
+bcsp_send_packet_nocrc:
+	bmark0 mark_h5tx_rp,bcsp_send_packet_form_nonrp
+	set1 7,regc
+	fetch 1,mem_h5tx_seq
+	ior regc,regc
+	increase 1,pdata
+	and_into 7,pdata
+	store 1,mem_h5tx_seq
+	fetch 1,mem_rp_packets
+	increase 1,pdata
+	store 1,mem_rp_packets
+bcsp_send_packet_form_nonrp:
+	fetch 2,mem_h5tx_wptr
+	iforce contwu
+	deposit regb
+	isolate1 mark_h5tx_rp,mark
+	setflag true,hci_flag_rp,pdata
+	istore 2,contwu
+	copy contwu,rega		/* rega is packet pointer */
+	deposit regc
+	istore 1,contwu
+	lshift4 loopcnt,pdata
+	ior queue,pdata
+	iadd regc,regc
+	istore 2,contwu
+	rshift8 pdata,pdata
+	iadd regc,pdata
+	sub pdata,0xff,pdata
+	istore 1,contwu
+	bmark0 mark_h5tx_crc,bcsp_send_packet_form_nocrc
+	increase 4,loopcnt		/* crc includes header 4 bytes */
+	copy rega,contwu
+	call calc_tx_crc16
+	istore 2,contwu
+bcsp_send_packet_form_nocrc:
+	fetch 2,mem_h5tx_wptr
+	iadd regb,contwu
+	increase 2,contwu
+	deposit contwu
+	store 2,mem_h5tx_wptr
+	hstore 2,core_uart_twptr
+	fetcht 2,mem_h5tx_rptr
+	call bcsp_update_free
+	call bcsp_init_retransmit
+	setarg 1600
+	force lpo_delay_timer,queue
+	branch timer_init
+	
+bcsp_init_retransmit:
+	setarg 400				/* retransmit timeout : 250ms */
+	force hci_retransmit_timer,queue
+	call timer_init
+	set1 mark_h5tx_retransmit,mark
+	rtn
+
+bcsp_retransmit:
+	rtnmark0 mark_h5tx_retransmit
+	force hci_retransmit_timer,queue
+	call timer_check
+	nrtn blank
+	fetch 2,mem_h5tx_rptr
+	hstore 2,core_uart_trptrp
+	branch bcsp_init_retransmit
+
+bcsp_freepacket:
+	fetch 2,mem_h5tx_wptr
+	fetcht 2,mem_h5tx_rptr
+	isub temp,null
+	branch bcsp_noretransmit,zero			/* no more packet to free */
+	copy temp,contwu
+	ifetch 2,contwu
+	iforce rega							/* rega is length+flag */
+	iand mask3ff,pdata
+	iadd contwu,contwu					/* contwu is new rptr */
+	hfetch 2,core_uart_trptr
+	isub contwu,pdata
+	iand mask3ff,regb						/* regb is trptr - new rptr */
+	fetch 2,mem_h5tx_wptr
+	isub contwu,pdata
+	iand mask3ff,pdata						/* pdata is wptr - new rptr */
+	isub regb,pdata
+	nrtn positive							/* packet not transmitted yet */
+	isolate0 hci_flag_rp,rega
+	branch bcsp_discardnrp,true
+	fetch 1,mem_h5rx_ackcnt
+	rtn blank								/* not acked yet */
+	increase -1,pdata
+	store 1,mem_h5rx_ackcnt
+	fetch 1,mem_rp_packets
+	increase -1,pdata
+	store 1,mem_rp_packets
+bcsp_discardnrp:
+	copy contwu,temp
+	storet 2,mem_h5tx_rptr
+	fetch 2,mem_h5tx_wptr
+	call bcsp_update_free
+	branch bcsp_freepacket
+bcsp_noretransmit:
+	set0 mark_h5tx_retransmit,mark
+	rtn	
+
+bcsp_update_free:
+	isub temp,pdata
+	iand mask3ff,pdata
+	isub mask3ff,pdata
+	sub pdata,0,pdata
+	store 2,mem_h5tx_free
+	rtn
+	
+bcsp_get_tx_ptr:	/* contwu is offset to packet start */
+	fetch 2,mem_h5tx_wptr
+	iadd contwu,contwu
+	rtn
+	
+else
+
+hci_rx_bcsp:
+	branch assert
+hci_rx_bcsp_nocrc:
+	branch assert
+hci_rx_bcsp_check_ack_skip:
+	branch assert
+hci_rx_bcsp_discard_packet_err:
+	branch assert
+hci_rx_bcsp_discard_packet:
+	branch assert
+hci_bcsp_parse_packet:
+	branch assert
+parse_bcsp_link_establish:
+	branch assert
+parse_bcsp_link_establish_sync:
+	branch assert
+parse_bcsp_link_establish_send_syncrsp:	
+	branch assert
+parse_bcsp_link_establish_syncrsp:
+	branch assert
+parse_bcsp_link_establish_conf:
+	branch assert
+parse_bcsp_link_establish_send:	
+	branch assert
+parse_bcsp_link_establish_confrsp:
+	branch assert
+parse_bcsp_bccmd:
+	branch assert
+parse_bcsp_bccmd_loop:
+	branch assert
+parse_bcsp_bccmd_sco_link:
+	branch assert
+parse_bcsp_bccmd_next:
+	branch assert
+parse_bcsp_bccmd_next_ok:
+	branch assert
+parse_bcsp_bccmd_replace:
+	branch assert
+parse_bcsp_bccmd_replace1:
+	branch assert
+bcsp_send_ack:
+	branch assert
+bcsp_send_packet:
+	branch assert
+bcsp_send_packet_nocrc:
+	branch assert
+bcsp_send_packet_form_nonrp:
+	branch assert
+bcsp_send_packet_form_nocrc:
+	branch assert
+bcsp_init_retransmit:
+	branch assert
+bcsp_retransmit:
+	branch assert
+bcsp_freepacket:
+	branch assert
+bcsp_discardnrp:
+	branch assert
+bcsp_noretransmit:
+	branch assert
+bcsp_update_free:
+	branch assert
+bcsp_get_tx_ptr:
+	branch assert
+endif
+
Index: btkb/program/hci_h4.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/hci_h4.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/hci_h4.prog	(working copy)
@@ -0,0 +1,188 @@
+
+ifdef DEBUG_H4LOG_ENABLE
+hci_log:
+	copy regc,pdata
+	rtneq 0x11
+	fetch 1,mem_hci_log
+	increase 1,pdata
+	sub pdata,hci_log_cnt,null
+	branch hci_log_calc_ptr,positive
+	setarg 0
+hci_log_calc_ptr:
+	store 1,mem_hci_log
+	arg hci_log_size,temp
+	imul32 temp,pdata
+	arg mem_hci_log+hci_log_size,contw
+	iadd contw,contw
+hci_log_write_content:
+	fetch 1,mem_hci_log
+	istore 1,contw//counter
+	copy regb,pdata
+	istore 1,contw
+	fetch 2,mem_le_event_count
+	istore 1,contw
+	copy clke_bt,pdata
+	istore 3,contw
+	fetch 1,mem_last_freq
+	istore 1,contw
+	fetch 1,mem_le_rxbuf
+	istore 1,contw
+	rtn
+else
+hci_log:
+	rtn
+endif
+
+hci_rx_h4:
+	set1 mark_ext_patch,mark
+	bpatch patch3d_4,mem_patch3d
+	fetch 1,mem_hci_cmd
+	nrtn blank
+hci_rx_h4_1:
+	call hci_h4_parse_packet
+	ncall h4_rx_discard_packet,user
+	rtn
+	
+hci_h4_parse_packet:
+	set1 mark_ext_patch,mark
+	bpatch patch3d_5,mem_patch3d
+	copy contru,rega
+	arg 4,temp
+	ifetch 1,contru //type
+	beq HCI_H4_TYPE_CMD,hci_h4_parse_packet_wait_len
+	increase 1,temp //acl packet has 2 bytes for length
+	beq HCI_H4_TYPE_ACL,hci_h4_parse_packet_wait_len
+	copy contru,pdata
+	hstore 2,core_uart_rrptr
+	rtn
+hci_h4_parse_packet_wait_len:
+	hfetch 2,core_uart_rxitems
+	isub temp,null
+	nbranch hci_h4_parse_packet_wait_len,positive // while(rxitems >= 4 or 5);
+	//Make sure length has been recieved.
+	disable user
+	copy rega,contru
+	call h4_get_rx_payload_len
+	iadd temp,temp
+hci_h4_parse_packet_wait:
+	hfetch 2,core_uart_rxitems
+	isub temp,null
+	nbranch hci_h4_parse_packet_wait,positive//wait for rcv a complete packet
+	copy rega,contru
+	ifetch 1,contru //HCI packet type
+	beq  HCI_H4_TYPE_CMD,process_hci_cmd
+	beq HCI_H4_TYPE_ACL,hci_h4_parse_packet_acl
+	branch assert
+hci_h4_parse_packet_acl: //downgoing ACL
+	set1 mark_ext_patch,mark
+	bpatch patch3d_6,mem_patch3d
+	copy contru,rega
+	ifetch 2,contru // handle
+	copy rega,contru
+	fetcht 1,mem_conn_handle
+	icompare 0xff,temp
+	branch process_acl,true// traditional BT handle
+	branch le_acl_downgoing,le //BLE handle
+	enable user
+	rtn
+h4_rx_discard_packet:
+	set1 mark_ext_patch,mark
+	bpatch patch3d_7,mem_patch3d
+	hfetch 2,core_uart_rrptr
+	iforce contru
+	call h4_get_rx_payload_len
+	iadd contru,contru
+	deposit contru
+	hstore 2,core_uart_rrptr
+	rtn
+
+
+//contru = pointer to packet start
+//return len via pdata
+h4_get_rx_payload_len:
+	ifetch 1,contru
+	increase 2,contru
+	beq HCI_H4_TYPE_ACL,h4_get_rx_payload_len_acl
+	ifetch 1,contru
+	rtn
+h4_get_rx_payload_len_acl:
+	ifetch 2,contru
+	rtn
+
+h4_get_tx_ptr:
+	hfetch 2,core_uart_twptr
+	increase -5,contwu
+	iadd contwu,contwu
+	rtn
+
+h4_send_packet_event:
+	arg HCI_H4_TYPE_EVENT,temp //type
+	branch h4_send_packet
+h4_send_packet_acl: //upgoing ACL
+	arg HCI_H4_TYPE_ACL,temp //type
+h4_send_packet:
+	set1 mark_ext_patch,mark
+	bpatch patch3e_0,mem_patch3e
+	increase 1,loopcnt
+	hfetch 2,core_uart_twptr
+	copy pdata,contwu
+	copy loopcnt,pdata //length
+	istoret 1,contwu //packet type in temp
+	increase -1,pdata
+	iadd contwu,contwu
+	copy contwu,pdata
+	store 2,mem_hci_acl_tx_trigger_wptr
+	copy temp,pdata
+ifdef ACL_DEBUG
+	beq HCI_H4_TYPE_EVENT,h4_send_packet0
+	hfetch 1,core_uart_txitems
+	ncall ice_break,blank
+	
+h4_send_packet0:	
+	copy temp,pdata
+endif
+	rtneq HCI_H4_TYPE_ACL //not send acl packet immediately
+	fetch 2,mem_hci_acl_tx_trigger_wptr
+	hstore 2,core_uart_twptr
+	branch h4_send_acl_trigger_clear
+	
+h4_send_acl_trigger:
+	set1 mark_ext_patch,mark
+	bpatch patch3e_1,mem_patch3e
+	fetch 2,mem_hci_acl_tx_trigger_wptr
+	branch assert,blank
+	hstore 2,core_uart_twptr
+ifdef ACL_DEBUG
+	hfetcht 2,core_uart_trptr
+	isub temp,rega
+	branch h4_send_acl_trigger0,positive
+	arg 0x400,rega
+	iadd rega,pdata
+	isub temp,rega
+h4_send_acl_trigger0:	
+	fetch 2,mem_len
+	increase 5,pdata
+	isub rega,null
+	ncall ice_break,zero
+endif
+	branch h4_send_acl_trigger_clear
+	
+h4_send_acl_trigger_clear:
+	setarg 0
+	store 2,mem_hci_acl_tx_trigger_wptr
+	rtn
+
+h4_tx_buffer_remain:
+	hfetcht 2,core_uart_trptr
+	hfetch 2,core_uart_twptr
+	isub temp,rega
+	nbranch h4_tx_buffer_remain_negative,positive
+	hfetcht 2,core_uart_tsaddr
+	hfetch 2,core_uart_teaddr
+	isub temp,pdata
+	isub rega,temp
+	rtn
+h4_tx_buffer_remain_negative:
+	sub rega,-1,temp
+	rtn
+	
Index: btkb/program/hci_main.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/hci_main.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/hci_main.prog	(working copy)
@@ -0,0 +1,2236 @@
+/*********************************/
+/**********   HCI  *****************/
+/*********************************/
+hci_dispatch:
+	set0 mark_ext_patch,mark
+	bpatch patch19_5,mem_patch19
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	call hci_rx_packet
+ifdef COMPILE_HCI_BCSP	
+	call hci_check_bcsp_protocol
+	call bcsp_retransmit,true
+	call hci_check_bcsp_protocol
+	call bcsp_freepacket,true
+endif
+	branch  process_send_acl
+ifdef COMPILE_HCI_BCSP
+	rtnmark0 mark_h5_reinit
+	force h5_reinit_timer,queue
+	call timer_check
+	nrtn blank
+	call hci_reinit
+	call hci_check_bcsp_protocol
+	nrtn true
+	set0 mark_h5_sync,mark
+	force 0xda,temp
+	setarg 0xededdc
+	call parse_bcsp_link_establish_send
+	setarg 2000
+	force h5_reinit_timer,queue
+	branch timer_init
+endif
+
+
+hci_init:
+	set0 mark_ext_patch,mark
+	bpatch patch19_6,mem_patch19
+	rtn wake
+	setarg hci_idle_dispatch
+	store 2,mem_cb_idle_process
+
+	setarg uart_baud_115200
+	store uart_baud_len,mem_baud
+hci_lpm_init:
+	set0 mark_ext_patch,mark
+	bpatch patch19_7,mem_patch19
+	call init_filter_ram
+	setarg mem_h5rx_buf
+	hstore 2,core_uart_rsaddr
+	setarg mem_h5rx_buf_end
+	hstore 2,core_uart_readdr
+	setarg mem_h5tx_buf
+	hstore 2,core_uart_tsaddr
+	call hci_sel_init
+hci_reinit:
+	set0 mark_ext_patch,mark
+	bpatch patch1a_0,mem_patch1a
+	hjam 0x0,core_uart_ctrl
+ifdef COMPILE_HCI_BCSP
+	jam 0,mem_h5rx_ack
+	jam 0,mem_h5tx_ack
+	jam 0,mem_h5tx_seq
+endif
+ 	setarg mem_h5tx_buf
+ifdef COMPILE_HCI_BCSP
+	store 2,mem_h5tx_wptr
+	store 2,mem_h5tx_rptr
+endif
+	hstore 2,core_uart_twptr
+	hstore 2,core_uart_trptrp
+	setarg mem_h5rx_buf
+	hstore 2,core_uart_rrptr
+	store 2,mem_h5rx_rptr
+hci_init_common:
+	set0 mark_ext_patch,mark
+	bpatch patch1a_1,mem_patch1a
+	hfetch 2,core_clkoff
+	set0 CLOCK_OFF_UART,pdata
+	hstore 2,core_clkoff
+	call uart_set_baud_by_mem
+	hjam uartclk_dpll,core_uart_clksel
+	hjam uart_ctrl_h4,core_uart_ctrl
+	branch hci_init_queue_ack
+
+hci_sel_init:
+	setarg mem_h5tx_buf_end
+	hstore 2,core_uart_teaddr
+	hfetch 1,core_gpio_sel1
+	or_into 0x07,pdata
+	hstore 1,core_gpio_sel1
+	jam 0xff,mem_ucode_id_local
+	rtn
+	
+hci_reset_uart:
+	hfetch 2,core_uart_rwptr
+	hstore 2,core_uart_rrptr
+	set1 mark_h5_reset,mark
+	rtn
+
+	
+hci_check_bcsp_protocol:
+	hfetch 1,core_uart_ctrl
+	isolate1 uart_ctrl_bit_slip_protocol,pdata
+	rtn// set true if it is bcsp protocol
+	
+hci_init_queue_ack:
+	setarg mem_hci_acl_queue_start
+	store 2,mem_hci_acl_queue_wptr
+	store 2,mem_hci_acl_queue_rptr
+	force param_acl_pktcnt,temp
+	iadd temp,pdata
+	iadd temp,pdata
+	increase 2,pdata		/*add one pkt more*/
+	store 2,mem_hci_acl_queue_end
+	setarg 0x00
+	store 1,mem_hci_acl_cnt
+	store 1,mem_hci_acl_queue_wcnt
+	rtn
+
+hci_rx_packet:
+	set0 mark_ext_patch,mark
+	bpatch patch1a_2,mem_patch1a
+	hfetch 1,core_uart_status
+	iforce regb
+	bbit0 uart_status_rx_fifo_empty,hci_rx_packet_cont
+	hfetch 2,core_uart_rxitems
+	iforce regc
+	arg 0x44f,temp
+	isub temp,null
+	nrtn zero
+hci_rx_packet_cont:
+	hfetch 2,core_uart_rrptr
+	iforce contru
+	call hci_check_bcsp_protocol
+	branch hci_rx_bcsp,true
+	branch hci_rx_h4
+
+hci_send_ack:
+	call hci_check_bcsp_protocol
+	branch bcsp_send_ack,true
+	rtn
+	
+uart_send_byte:
+	hfetcht 1,core_uart_status
+	isolate1 6,temp
+	branch uart_send_byte,true
+	hstore 1,core_uart_txd
+	rtn
+
+
+process_acl_into_queue:
+	fetcht 2,mem_hci_acl_queue_end
+	fetch 2,mem_hci_acl_queue_wptr
+	iforce contw
+	deposit contru
+	istore 2,contw
+	deposit contw
+	store 2,mem_hci_acl_queue_wptr
+	icompare 0xff,temp
+	call process_acl_into_queue_loop,true
+	fetch 1,mem_hci_acl_queue_wcnt
+	increase 1,pdata
+	store 1,mem_hci_acl_queue_wcnt
+	rtn	
+process_acl_into_queue_loop:
+	setarg mem_hci_acl_queue_start
+	store 2,mem_hci_acl_queue_wptr
+	rtn
+	
+	
+process_acl_dequeue:
+	fetch 1,mem_hci_acl_queue_wcnt
+	rtn blank
+	fetcht 2,mem_hci_acl_queue_end
+	fetch 2,mem_hci_acl_queue_rptr
+	iforce contr
+	ifetch 2,contr
+	iforce contru
+	deposit contr
+	store 2,mem_hci_acl_queue_rptr
+	icompare 0xff,temp
+	call process_acl_dequeue_loop,true
+	fetch 1,mem_hci_acl_queue_wcnt
+	increase -1,pdata
+	store 1,mem_hci_acl_queue_wcnt
+	force 1,pdata
+	rtn	
+process_acl_dequeue_loop:
+	setarg mem_hci_acl_queue_start
+	store 2,mem_hci_acl_queue_rptr
+	rtn
+
+process_acl: // traditional BT downgoing ACL
+	set0 mark_ext_patch,mark
+	bpatch patch1a_3,mem_patch1a
+	fetch 1,mem_hci_acl_queue_wcnt
+	sub pdata,2,null
+	branch process_acl_queue_check_ok,positive
+	enable user
+	branch process_send_acl
+process_acl_queue_check_ok:
+	call hci_send_ack
+	call process_acl_into_queue
+process_send_acl: //downgoing ACL
+	set0 mark_ext_patch,mark
+	bpatch patch1a_4,mem_patch1a
+	rtnmark1 mark_tx_l2cap		
+	call process_acl_dequeue
+	rtn blank
+	ifetcht 1,contru
+	call context_search_conn_handle2
+	nrtn zero						/* cannot find conn handle */
+	ifetch 1,contru
+	rshift4 pdata,pdata
+	and pdata,0x3,pdata //low 2 bits
+	nbranch process_send_acl_good_lch,blank
+	set1 1,pdata //BT2.0device donot know '00' lch
+process_send_acl_good_lch:
+	set1 2,pdata
+	store 1,mem_tx_lch
+	ifetch 2,contru
+	store 2,mem_tx_len				/* length */
+	deposit contru
+	store 2,mem_txptr
+	set1 mark_tx_l2cap,mark
+	bmark0 mark_context,process_acl_ncontext
+	fetch 1,mem_conn_handle
+	isub temp,null
+	nbranch process_acl_ncontext,zero
+	fetch 1,mem_op
+	set1 op_txl2cap,pdata
+	store 1,mem_op
+	rtn
+
+process_acl_ncontext:
+        increase coffset_op,rega                             
+        ifetch 1,rega
+        set1 op_txl2cap,pdata
+        istore 1,rega
+        rtn
+
+
+
+	
+process_hci_cmd:
+	set0 mark_ext_patch,mark
+	bpatch patch1a_5,mem_patch1a
+	fetch 1,mem_hci_cmd
+	branch process_hci_cmd_cont,blank
+	enable user					/* last command still there */
+	rtn
+process_hci_cmd_cont:
+	call hci_send_ack
+	ifetch 2,contru
+	iforce alarm				/* alarm is used for sending */
+	iforce queue				/* queue is OCF */
+	ifetch 1,contru		/* skip hci length */
+	iforce temp			/* temp has the length */
+	rshift2 alarm,pdata
+	rshift8 pdata,pdata
+	beq HCI_OGF_LINK_CONTROL,phci_grp_link_control
+	beq HCI_OGF_LINK_POLICY,phci_grp_link_policy
+	beq HCI_OGF_BASEBAND,phci_grp_baseband
+	beq HCI_OGF_INFO,phci_grp_info
+	beq HCI_OGF_STATUS,phci_grp_status
+	beq HCI_OGF_TEST,phci_grp_test
+	beq HCI_OGF_VENDOR_SPECIFIC,phci_grp_vendor_specific
+	beq HCI_OGF_LOW_ENERGY,phci_grp_low_energy
+	rtn
+
+
+phci_grp_link_control:
+	set0 mark_ext_patch,mark
+	bpatch patch1a_6,mem_patch1a
+	deposit queue
+	beq HCI_INQUIRY,phci_inquiry 
+	beq HCI_INQUIRY_CANCEL,phci_inquiry_cancel 
+	beq HCI_PERIODIC_INQUIRY_MODE,hci_normal_reply
+	beq HCI_EXIT_PERIODIC_INQUIRY_MODE,hci_normal_reply
+	beq HCI_CREATE_CONNECTION,phci_create_connection 
+	beq HCI_DISCONNECT,phci_disconnect 
+	beq HCI_ADD_SCO_CONNECTION,hci_normal_reply
+	beq HCI_CREATE_CONNECTION_CANCEL,phci_create_connection_cancel
+	beq HCI_ACCEPT_CONNECTION,phci_accept_connection
+	beq HCI_REJECT_CONNECTION,phci_reject_connection
+	beq HCI_LINK_KEY_REQUEST_REPLY,phci_link_key_request_reply 
+	beq HCI_LINK_KEY_REQUEST_NEGATIVE_REPLY,phci_link_key_request_negative_reply 
+	beq HCI_PIN_CODE_REQUEST_REPLY,phci_pin_code_request_reply
+	beq HCI_PIN_CODE_REQUEST_NEGATIVE_REPLY,phci_pin_code_request_negative_reply
+	beq HCI_CHANGE_CONNECTION_PACKET_TYPE,phci_change_connection_packet_type
+	beq HCI_AUTHENTICATION_REQUESTED,phci_authentication_requested
+	beq HCI_SET_CONNECTION_ENCRYPTION,phci_set_connection_encryption
+	beq HCI_CHANGE_CONNECTION_LINK_KEY,hci_normal_reply
+	beq HCI_MASTER_LINK_KEY,hci_normal_reply
+	beq HCI_REMOTE_NAME_REQUEST,phci_remote_name_request 
+	beq HCI_READ_REMOTE_SUPPORTED_FEATURES,phci_read_remote_supported_features 
+	beq HCI_READ_REMOTE_EXT_FEATURES,phci_read_remote_ext_features 
+	beq HCI_READ_REMOTE_VERSION_INFORMATION,phci_read_remote_version_information
+	beq HCI_READ_CLOCK_OFFSET,phci_read_clock_offset
+	beq HCI_SETUP_SCO_CONNECTION,phci_setup_sco_connection
+	beq HCI_ACCEPT_SCO_CONNECTION,phci_accept_sco_connection
+	beq HCI_IO_CAP_REQUEST_REPLY,phci_io_cap_request_reply
+	branch phci_unknown_command
+
+
+phci_grp_link_policy:
+	set0 mark_ext_patch,mark
+	bpatch patch1a_7,mem_patch1a
+	deposit queue
+	beq HCI_ROLE_DISCOVERY,phci_role_discovery 
+	beq HCI_WRITE_LINK_POLICY_SETTINGS,phci_write_link_policy_settings
+	beq HCI_HOLD_MODE,hci_normal_reply
+	beq HCI_SNIFF_MODE,phci_sniff_mode
+	beq HCI_EXIT_SNIFF_MODE,phci_exit_sniff_mode
+	beq HCI_PARK_MODE,hci_normal_reply
+	beq HCI_EXIT_PARK_MODE,hci_normal_reply
+	beq HCI_QOS_SETUP,hci_normal_reply
+	beq HCI_SWITCH_ROLE,phci_switch_role
+	beq HCI_READ_LINK_POLICY_SETTINGS,hci_normal_reply
+	beq HCI_READ_DEFAULT_LINK_POLICY_SETTINGS,hci_normal_reply
+	beq HCI_WRITE_DEFAULT_LINK_POLICY_SETTINGS,hci_normal_reply
+	beq HCI_FLOW_SPECIFICATION,hci_normal_reply
+	beq HCI_SNIFF_SUBRATING,phci_sniff_subrating
+	branch phci_unknown_command
+
+phci_grp_baseband:
+	set0 mark_ext_patch,mark
+	bpatch patch1b_0,mem_patch1b
+	deposit queue
+	beq HCI_SET_EVENT_MASK ,phci_set_event_mask
+	beq HCI_RESET ,hci_normal_reply
+	beq HCI_DELETE_STORED_LINK_KEY,phci_delete_stored_link_key 
+	beq HCI_WRITE_LOCAL_NAME,phci_change_local_name 
+	beq HCI_READ_LOCAL_NAME,phci_read_local_name 
+	beq HCI_WRITE_PAGE_TIMEOUT,phci_write_page_timeout 
+	beq HCI_READ_SCAN_ENABLE,phci_read_scan_enable 
+	beq HCI_WRITE_SCAN_ENABLE,phci_write_scan_enable 
+	beq HCI_WRITE_PAGE_SCAN_ACTIVITY,phci_write_page_scan_activity 
+	beq HCI_WRITE_INQUIRY_SCAN_ACTIVITY,phci_write_inquiry_scan_activity 
+	beq HCI_WRITE_AUTHENTICATION_ENABLE,phci_write_authentication_enable 
+	beq HCI_WRITE_ENCRYPTION_MODE,phci_write_encryption_mode
+	beq HCI_WRITE_CLASS_OF_DEVICE,phci_write_class_of_device 
+	beq HCI_WRITE_VOICE_SETTING,hci_normal_reply 
+	beq HCI_SET_CONTROLLER_TO_HOST_FLOW_CONTROL ,hci_normal_reply
+	beq HCI_HOST_BUFFER_SIZE,hci_normal_reply 
+	beq HCI_HOST_NUM_COMPLETED_PACKETS,phci_host_num_completed
+	beq HCI_WRITE_INQUIRY_SCAN_TYPE,hci_normal_reply 
+	beq HCI_WRITE_INQUIRY_MODE,hci_normal_reply 
+	beq HCI_WRITE_PAGE_SCAN_TYPE,hci_normal_reply 
+	beq HCI_READ_EXTENDED_INQUIRY_RESPONSE,phci_read_ext_inquiry_response
+	beq HCI_WRITE_SIMPLE_PAIRING_MODE,phci_write_ssp_mode 
+	branch phci_unknown_command
+
+phci_grp_info:
+	set0 mark_ext_patch,mark
+	bpatch patch1b_1,mem_patch1b
+	deposit queue
+	beq HCI_READ_LOCAL_VERSION_INFORMATION,phci_read_local_version_information 
+	beq HCI_READ_LOCAL_SUPPORTED_FEATURES,phci_read_local_supported_features 
+	beq HCI_READ_LOCAL_EXT_FEATURES,phci_read_local_ext_features 
+	beq HCI_READ_BUFFER_SIZE,phci_read_buffer_size
+	beq HCI_READ_BD_ADDR,phci_read_bd_addr
+	branch phci_unknown_command
+
+phci_grp_status:
+	set0 mark_ext_patch,mark
+	bpatch patch1b_2,mem_patch1b
+	deposit queue
+	beq HCI_READ_FAILED_CONTACT_COUNTER,hci_normal_reply
+	beq HCI_RESET_FAILED_CONTACT_COUNTER,phci_reset_failed_contact_counter
+	beq HCI_GET_LINK_QUALITY,phci_get_link_quality
+	beq HCI_READ_RSSI,phci_read_rssi
+	beq HCI_READ_AFH_CHANNEL_MAP,phci_read_afh_channel_map
+	beq HCI_READ_BD_CLOCK,phci_read_bd_clock
+	branch phci_unknown_command
+
+phci_grp_test:
+	set0 mark_ext_patch,mark
+	bpatch patch1b_3,mem_patch1b
+	deposit queue
+	beq HCI_READ_LOOPBACK_MODE,hci_normal_reply
+	beq HCI_WRITE_LOOPBACK_MODE,hci_normal_reply
+	beq HCI_ENABLE_DEVICE_UNDER_TEST_MODE,hci_normal_reply
+	beq HCI_WRITE_SIMPLE_PAIRING_DEBUG_MODE,hci_normal_reply
+	branch phci_unknown_command
+	rtn
+
+phci_grp_vendor_specific:
+	set0 mark_ext_patch,mark
+	bpatch patch1b_4,mem_patch1b
+	deposit queue
+	beq HCI_VENDOR_CMD_RESET,hci_normal_reply
+	beq HCI_VENDOR_CMD_CHIPID,phci_grp_vendor_chipid
+	beq HCI_VENDOR_CMD_BAUD,phci_grp_vendor_baud
+	beq HCI_VENDOR_CMD_PATCH,phci_grp_vendor_patch
+	beq HCI_VENDOR_CMD_PATCH_DONE,phci_grp_vendor_done
+	beq HCI_VENDOR_CMD_ECHO,hci_normal_reply
+	beq HCI_VENDOR_CMD_BDADDR,phci_grp_vendor_bdaddr
+	beq HCI_VENDOR_CMD_ENTER_LPM,phci_grp_vendor_enter_lpm
+	
+	beq HCI_VENDOR_CMD_MEM,phci_grp_vendor_mem
+	beq HCI_VENDOR_CMD_EEP,phci_grp_vendor_eep
+	branch hci_normal_reply
+
+phci_grp_vendor_enter_lpm:
+	call hci_normal_reply
+	call wait_uarttx
+	call gpio_pu_uart_tx
+hci_enter_lpm:
+	call app_put_lpm_wake_lock
+	call app_l2cap_flow_control_enable
+	branch gpio_rx_config_input_with_pu
+
+hci_exit_lpm:
+	jam HCI_RX_READY,mem_hci_lt_rx_state
+	call app_get_lpm_wake_lock
+	call hci_lpm_init
+	branch app_l2cap_flow_control_disable
+	
+phci_grp_vendor_chipid:
+	call hci_get_cmd_complete_ptr
+	hfetch 2,core_chipid
+	istore 2,contwu
+	force 6,loopcnt
+	branch hci_command_complete
+	
+phci_grp_vendor_baud:
+	ifetch 2,contru
+	store 2,mem_baud
+	hstore 2,core_uart_baud
+	rtn
+	
+phci_grp_vendor_patch:
+	//hjam 0x80,core_ucode_ctrl
+	ifetch 1,contru
+	copy pdata,temp //check sum via temp
+	hstore 1,core_ucode_low
+	ifetch 1,contru
+	iadd temp,temp
+	set1 7,pdata
+	hstore 1,core_ucode_ctrl
+	ifetch 1,contru
+	iadd temp,temp
+	copy pdata,loopcnt
+phci_grp_vendor_patch_loop:
+	ifetch 1,contru
+	hstore 1,core_ucode_data
+	iadd temp,temp
+	loop phci_grp_vendor_patch_loop
+	and temp,0xff,temp
+	ifetch 1,contru
+	isub temp,null
+	nbranch phci_grp_vendor_patch_bad,zero
+	branch hci_normal_reply
+
+phci_grp_vendor_done:
+	arg 0x20,loopcnt    //patch switch length
+	arg mem_patch00,contw
+	arg 0,temp //checksum
+phci_grp_vendor_done_loop:
+	ifetch 1,contru
+	istore 1,contw
+	iadd temp,temp
+	loop phci_grp_vendor_done_loop
+	and temp,0xff,temp
+	ifetch 1,contru
+	isub temp,null
+	nbranch phci_grp_vendor_patch_bad,zero
+	hjam 0,core_ucode_ctrl
+	call hci_normal_reply
+	call h4_rx_discard_packet
+	branch soft_reset
+
+phci_grp_vendor_patch_bad:
+	hjam 0,core_ucode_ctrl
+	branch start
+	
+phci_grp_vendor_bdaddr:
+	ifetch 6,contru
+	store 6,mem_lap
+	branch hci_normal_reply
+
+
+phci_grp_vendor_mem:
+	ifetch 1,contru
+	store 1,mem_hci_curr_len
+	copy pdata,loopcnt
+	ifetch 2,contru
+	store 2,mem_hci_curr_target
+	copy pdata,contw
+	call uart_copy_rx_bytes
+	branch hci_normal_reply
+
+
+phci_grp_vendor_eep:
+	ifetch 1,contru
+	store 1,mem_hci_curr_len
+	copy pdata,loopcnt
+	ifetch 2,contru
+	store 2,mem_hci_curr_target
+	arg mem_l2cap_rxbuff1,contw
+	call uart_copy_rx_bytes
+	fetcht 1,mem_hci_curr_len
+	arg mem_l2cap_rxbuff1,rega
+	fetch 2,mem_hci_curr_target
+	branch iicd_write_ota_data
+	
+
+
+
+
+phci_grp_low_energy:
+	set0 mark_ext_patch,mark
+	bpatch patch1b_5,mem_patch1b
+	deposit queue
+	beq HCI_LE_SET_EVENT_MASK,hci_normal_reply
+	beq HCI_LE_READ_BUFFER_SIZE,phci_le_read_buffer_size
+	beq HCI_LE_READ_LOCAL_SUPPORTED_FEATURES,phci_le_read_local_supported_features
+	beq HCI_LE_SET_ADVERTISING_PARAMETERS,phci_le_set_adv_param
+	beq HCI_LE_SET_ADVERTISING_DATA, phci_le_set_adv_data
+	beq HCI_LE_SET_SCAN_RESPONSE_DATA,phci_le_set_scan_response_data
+	beq HCI_LE_SET_ADVERTISE_ENABLE,phci_le_set_adv_enable
+	beq HCI_LE_SET_SCAN_PARAMETERS,phci_le_set_scan_param
+	beq HCI_LE_SET_SCAN_ENABLE,phci_le_set_scan_enable
+	beq HCI_LE_CREATE_CONNECTION,phci_le_create_conn
+	beq HCI_LE_CREATE_CONNECTION_CANCEL,phci_le_create_conn_cancel
+	beq HCI_LE_READ_CHANNEL_MAP,phci_le_read_channel_map
+	beq HCI_LE_READ_REMOTE_USED_FEATURES,hci_command_status
+	beq HCI_LE_CONNECTION_UPDATE,hci_normal_reply
+	branch phci_unknown_command
+	rtn
+phci_le_read_buffer_size:
+	call hci_get_cmd_complete_ptr
+	setarg 0
+	istore 3,contwu
+	force 0x07,loopcnt
+	branch hci_command_complete
+
+phci_le_read_local_supported_features:
+	call hci_get_cmd_complete_ptr
+	setarg 1
+	istore 2,contwu
+	setarg 0
+	istore 6,contwu
+	force 0x0c,loopcnt
+	branch hci_command_complete
+
+phci_le_set_adv_param:
+	arg 15,loopcnt
+	arg mem_le_adv_param,contw
+	call uart_copy_rx_bytes
+	branch hci_normal_reply
+
+phci_le_set_adv_data:
+	arg 32,loopcnt
+	arg mem_le_adv_data_len,contw
+	call uart_copy_rx_bytes
+	branch hci_normal_reply
+
+phci_le_set_scan_response_data:
+	arg 32,loopcnt
+	arg mem_le_scan_data_len,contw
+	call uart_copy_rx_bytes
+	branch hci_normal_reply
+
+phci_le_set_adv_enable:
+	ifetch 1,contru
+	store 1,mem_le_adv_enable
+	branch hci_normal_reply
+	
+phci_le_set_scan_param:
+	ifetch 7,contru
+	store 7,mem_le_scan_params
+	branch hci_normal_reply
+	
+phci_le_set_scan_enable:
+	ifetch 1,contru
+	store 1,mem_le_scan_enable
+	branch hci_normal_reply
+
+phci_le_create_conn:
+	ifetch 4,contru //interval & window
+	store 4,mem_le_scan_interval
+	ifetch 1,contru
+	store 1,mem_le_scan_filter_policy
+	arg 20,loopcnt
+	arg mem_le_conn_param,contw
+	call uart_copy_rx_bytes
+	jam 1,mem_le_scan_enable
+	fetch 1,mem_le_conn_own_addr_type
+	store 1,mem_le_scan_own_addr_type
+	fetch 2,mem_le_conn_interval_max 
+	store 2,mem_le_conn_interval
+	fetch 2,mem_le_conn_latency
+	store 2,mem_le_slave_latency
+	fetch 2,mem_le_conn_superto
+	store 2,mem_le_superto
+	jam hci_cmd_le_create_conn,mem_hci_cmd
+	branch hci_command_status
+
+phci_le_create_conn_cancel:
+
+	branch hci_normal_reply
+	
+phci_le_read_channel_map:
+	call hci_get_cmd_complete_ptr
+	ifetch 2,contru
+	istore 2,contwu
+	setarg 0x1fffff
+	istore 5,contwu
+	force 0x0b,loopcnt
+	branch hci_command_complete
+	
+
+
+
+phci_host_num_completed:
+	ifetch 3,contru
+	ifetcht 3,contru
+	fetch 2,mem_acl_credits
+	iadd temp,pdata  
+	store 2,mem_acl_credits
+	rtn
+
+phci_inquiry:
+	ifetch 3,contru
+	store 3,mem_glap
+do_at_inquiry0:
+	jam hci_cmd_inquiry,mem_hci_cmd
+	ifetch 1,contru
+	arg 1600,temp
+	imul32 temp,pdata
+	arg 0xffff,temp
+	isub temp,null
+	nbranch phci_inquiry_nowrap,positive
+	deposit temp
+phci_inquiry_nowrap:
+	force inquiry_length_timer,queue
+	call timer_init
+	fetch 1,mem_at_using_flag
+	bbit1 AT_FLAG_INQ,at_rev_end
+	branch hci_command_status
+	
+	
+phci_inquiry_cancel:
+	jam hci_cmd_inquiry_cancel,mem_hci_cmd
+	branch hci_normal_reply
+
+phci_create_connection:
+	call phci_read_plap
+	ifetch 2,contru
+	store 2,mem_packet_type
+	ifetch 2,contru
+	store 1,mem_page_mode
+	call phci_read_clock
+	ifetch 1,contru
+	store 1,mem_allow_switch
+	jam hci_cmd_create_conn,mem_hci_cmd
+	branch hci_command_status
+
+
+phci_disconnect:
+	jam hci_cmd_disconn,mem_hci_cmd
+	ifetch 2,contru
+	store 1,mem_hci_conn_handle
+	ifetch 1,contru
+	store 1,mem_disconn_reason_send
+	jam HCI_ERROR_CONNECTION_TERMINATED_BY_LOCAL_HOST,mem_hci_disconn_reason
+	fetch 1,mem_hci_conn_handle
+	fetcht 1,mem_sco_handle
+	isub temp,null
+	nbranch hci_command_status,zero
+	jam hci_cmd_disconn_sco,mem_hci_cmd
+	fetch 1,mem_sco_asso_handle
+	store 1,mem_hci_conn_handle
+	branch hci_command_status
+	
+phci_create_connection_cancel:
+	call hci_get_cmd_complete_ptr
+	call hci_write_plap
+	force 10,loopcnt
+	call hci_command_complete
+	//connection cancel 
+	jam hci_cmd_detach,mem_hci_cmd
+	force HCI_ERROR_NO_CONNECTION,temp
+	branch hci_send_connection_error
+
+phci_link_key_request_reply:
+	call phci_read_plap
+	arg mem_link_key,contw
+	force 16,loopcnt
+	call uart_copy_rx_bytes
+	jam hci_cmd_linkkey,mem_hci_cmd
+	branch phci_pin_code_reply
+
+phci_link_key_request_negative_reply:
+	call phci_read_plap
+	jam hci_cmd_nokey,mem_hci_cmd
+	branch phci_pin_code_reply
+
+phci_pin_code_request_reply:
+	call phci_read_plap
+	ifetch 1,contru
+	store 1,mem_pin_length
+	iforce loopcnt
+	arg mem_pin,contw
+	call uart_copy_rx_bytes
+	jam hci_cmd_pair,mem_hci_cmd
+	branch phci_pin_code_reply
+
+phci_pin_code_request_negative_reply:
+	call phci_read_plap
+	jam hci_cmd_nopair,mem_hci_cmd
+phci_pin_code_reply:
+	call hci_get_cmd_complete_ptr
+	call hci_write_plap
+	force 10,loopcnt
+	branch hci_command_complete
+
+phci_io_cap_request_reply:
+	//BD_ADDR, IO_Capability, 
+	increase 6,contru
+	ifetch 3,contru
+	store 3,mem_sp_iocap_local
+	fetch 1,mem_master_sp_state
+	beq SP_MASTER_STAT_START_DONE,phci_io_cap_request_reply_master
+	beq SP_STAT_KEY_SEND,phci_io_cap_request_reply_master
+	jam hci_cmd_io_cap,mem_hci_cmd
+	branch phci_io_cap_request_reply_commom
+phci_io_cap_request_reply_master:
+	jam SP_FLAG_COMMIT,mem_master_sp_flag
+phci_io_cap_request_reply_commom:
+	call hci_get_cmd_complete_ptr
+	call hci_write_plap
+	force 10,loopcnt
+	branch hci_command_complete
+	
+
+phci_authentication_requested:
+	call phci_read_handle
+	jam hci_cmd_auth,mem_hci_cmd
+	branch hci_command_status
+
+phci_set_connection_encryption:
+	call phci_read_handle
+	ifetch 1,contru
+	increase hci_cmd_stopencrypt,pdata
+	store 1,mem_hci_cmd
+	branch hci_command_status
+
+phci_remote_name_request:
+	call phci_read_plap
+	ifetch 2,contru
+	store 1,mem_page_mode
+	call phci_read_clock
+	jam hci_cmd_remote_name_req,mem_hci_cmd
+	branch hci_command_status
+	
+phci_read_remote_ext_features:
+	ifetch 2,contru
+	ifetch 1,contru
+	store 1, mem_ext_features_page
+	jam hci_cmd_remote_ext_features_req,mem_hci_cmd
+	branch hci_command_status
+
+phci_read_remote_supported_features:
+	//if no handle,need send err status
+	fetch 1,mem_conn_handle
+	force HCI_ERROR_NO_CONNECTION,rega
+	branch hci_command_status_err,blank
+	call phci_read_handle
+	jam hci_cmd_remote_feature_req,mem_hci_cmd
+	branch hci_command_status
+
+
+phci_read_remote_version_information:
+	//if no handle,need send err status
+	fetch 1,mem_conn_handle
+	force HCI_ERROR_NO_CONNECTION,rega
+	branch hci_command_status_err,blank
+	call phci_read_handle
+	jam hci_cmd_remote_version_req,mem_hci_cmd
+	branch hci_command_status
+
+
+phci_read_clock_offset:
+	call phci_status_reply_temp
+	force HCI_EVENT_READ_CLOCK_OFFSET_COMPLETE,queue
+	force 5,loopcnt
+	branch hci_send_event
+
+phci_setup_sco_connection:
+	call phci_read_handle
+	increase 10,contru
+	ifetch 2,contru
+	store 2,mem_voice_setting
+	ifetch 1,contru
+	store 1,mem_retransmission_effort
+	ifetch 2,contru
+	store 2,mem_sco_ptype
+	jam 2,mem_air_mode				/* cvsd */
+	jam hci_cmd_setup_sco,mem_hci_cmd
+	branch hci_command_status
+
+phci_accept_sco_connection:
+	jam hci_cmd_accept_sco_conn,mem_hci_cmd
+	branch hci_command_status	
+	
+	
+	
+phci_read_local_name:
+	call hci_get_cmd_complete_ptr
+	arg mem_local_name,contr
+	sub contr,0xff,loopcnt
+	call uart_copy_tx_bytes
+	force 0,pdata
+	sub contr,mem_local_name,loopcnt
+	increase 0xf8,loopcnt
+	call uart_write_bytes
+	force 0xfc,loopcnt
+	branch hci_command_complete
+	
+phci_change_local_name:
+	arg mem_local_name,contw
+	sub contw,0xff,loopcnt
+phci_change_local_name_loop:
+	ifetch 1,contru
+	istore 1,contw
+	branch phci_write_local_name_end,blank
+	loop phci_change_local_name_loop
+phci_write_local_name_end:
+	sub contw,mem_local_name,pdata
+	sub pdata,0,pdata
+	store 1,mem_local_name_length
+	branch hci_normal_reply
+
+phci_role_discovery:
+	call hci_get_cmd_complete_ptr
+	call hci_write_handle
+	force 0,pdata
+	nsetflag master,0,pdata
+	istore 1,contwu
+	force 7,loopcnt
+	arg 0x809,alarm				/* role discovery */
+	call hci_command_complete
+	branch cmd_exit
+	jam hci_cmd_role_discovery,mem_hci_cmd
+	rtn
+
+
+phci_write_link_policy_settings:
+	call phci_copy_handle
+	force 6,loopcnt
+	branch hci_command_complete
+
+
+phci_delete_stored_link_key:
+	branch hci_normal_reply
+
+phci_write_page_timeout:
+	ifetch 2,contru
+	store 2,mem_page_to
+	branch hci_normal_reply
+
+	
+phci_write_scan_enable:
+	ifetch 1,contru
+	store 1,mem_scan_mode
+	branch hci_normal_reply
+
+phci_write_page_scan_activity:
+	ifetch 2,contru
+	store 2,mem_pscan_interval
+	ifetch 2,contru
+	store 2,mem_pscan_window
+	branch hci_normal_reply
+
+phci_write_inquiry_scan_activity:
+	ifetch 2,contru
+	store 2,mem_iscan_interval
+	ifetch 2,contru
+	store 2,mem_iscan_window
+	branch hci_normal_reply
+
+phci_write_encryption_mode:
+	branch hci_normal_reply
+
+	
+phci_write_authentication_enable:
+	ifetch 1,contru
+	store 1,mem_auth_enable
+	branch hci_normal_reply
+
+phci_write_class_of_device:
+	ifetch 3,contru
+	store 3,mem_class
+	branch hci_normal_reply
+
+
+
+
+phci_read_ext_inquiry_response:
+	deposit temp
+	branch hci_normal_reply,blank
+	call hci_get_payload_ptr
+	force 0x1,pdata
+	istore 1,contwu
+	deposit alarm
+	istore 2,contwu
+	force HCI_ERROR_INVALID_HCI_COMMAND_PARAMETERS,pdata
+	istore 1,contwu
+	setarg 0
+	increase 0xf1,loopcnt
+	call uart_write_bytes
+	
+	force HCI_EVENT_COMMAND_COMPLETE,queue
+	force 0xf5,loopcnt
+	branch hci_send_event
+
+
+	
+phci_write_ssp_mode:
+	ifetch 1,contru
+	ncall ssp_enable,blank
+	call ssp_disable,blank
+	branch hci_normal_reply
+
+phci_read_scan_enable:
+	call hci_get_cmd_complete_ptr
+	fetch 1,mem_scan_mode
+	istore 1,contwu
+	force 5,loopcnt
+	branch hci_command_complete
+
+phci_read_local_version_information:
+	call hci_get_cmd_complete_ptr
+	fetch 8,mem_hci_version
+	istore 8,contwu
+	force 12,loopcnt
+	branch hci_command_complete
+
+phci_read_local_supported_features:
+	call hci_get_cmd_complete_ptr
+	fetch 8,mem_features
+	istore 8,contwu
+	force 12,loopcnt
+	branch hci_command_complete
+	
+phci_read_local_ext_features:
+	call hci_get_cmd_complete_ptr
+	setarg 0x0101	// page 1, and max page is 1
+	istore 2,contwu
+	setarg 0x01		// only support ssp
+	istore 8,contwu
+	force 14,loopcnt
+	branch hci_command_complete
+
+phci_read_buffer_size:
+	call hci_get_cmd_complete_ptr
+	fetch 7,mem_acl_pktlen
+	istore 7,contwu
+	force 11,loopcnt
+	branch hci_command_complete
+	
+phci_read_bd_addr:
+	call hci_get_cmd_complete_ptr
+	fetch 6,mem_lap
+	istore 6,contwu
+	force 10,loopcnt
+	branch hci_command_complete
+
+phci_set_event_mask:
+	branch hci_normal_reply
+
+//NO SUPPUT
+phci_reset_failed_contact_counter:
+	branch hci_normal_reply
+phci_get_link_quality:
+	call hci_get_cmd_complete_ptr
+	call hci_write_handle
+	setarg 0xff
+	istore 1,contwu
+	force 7,loopcnt
+	branch hci_command_complete
+	
+phci_read_rssi:
+	call hci_get_cmd_complete_ptr
+	call hci_write_handle
+	setarg 0x00
+	istore 1,contwu
+	force 7,loopcnt
+	branch hci_command_complete
+	
+phci_read_afh_channel_map:
+	set0 mark_ext_patch,mark
+	bpatch patch1b_6,mem_patch1b
+	branch hci_normal_reply
+phci_read_bd_clock:
+	set0 mark_ext_patch,mark
+	bpatch patch1b_7,mem_patch1b
+	branch hci_normal_reply
+
+
+
+
+phci_accept_connection:
+	call phci_read_plap
+	jam hci_cmd_accept_conn,mem_hci_cmd
+	ifetch 1,contru
+	beq 1,hci_command_status	//1 role slave
+	jam hci_cmd_accept_with_switch,mem_hci_cmd
+	branch hci_command_status
+		
+phci_reject_connection:
+	branch phci_accept_connection
+	call phci_read_plap
+	jam hci_cmd_reject_conn,mem_hci_cmd
+	branch hci_normal_reply
+	
+phci_change_connection_packet_type:
+	call hci_command_status
+	call hci_get_payload_ptr
+	setarg 0
+	istore 1,contwu
+	ifetch 4,contru
+	istore 4,contwu
+	force 8,loopcnt
+	arg HCI_EVENT_CONNECTION_PACKET_TYPE_CHANGED,queue
+	arg 5,loopcnt
+	branch hci_send_event
+
+phci_unknown_command:
+	force HCI_ERROR_UNKNOWN_HCI_COMMAND,rega
+	branch hci_command_status_err
+	
+phci_sniff_mode:
+//	force HCI_ERROR_COMMAND_DISALLOWED,rega
+//	branch hci_command_status_err
+	call phci_read_handle
+	ifetch 2,contru
+	store 2,mem_sniff_param_interval
+	ifetch 2,contru
+	store 2,mem_hci_sniff_min_interval
+	ifetch 2,contru
+	store 2,mem_sniff_param_attempt
+	ifetch 2,contru
+	store 2,mem_sniff_param_timeout
+	jam hci_cmd_in_sniff,mem_hci_cmd
+	branch hci_command_status
+	
+phci_exit_sniff_mode:
+	call phci_read_handle
+	call exit_sniff
+	branch hci_command_status
+
+exit_sniff:
+	jam hci_cmd_exit_sniff,mem_hci_cmd
+	rtn
+
+phci_sniff_subrating:
+	branch hci_normal_reply
+	
+phci_switch_role:
+	call phci_read_plap
+	jam hci_cmd_role_switch,mem_hci_cmd
+	branch hci_command_status
+
+phci_read_plap:
+	ifetch 6,contru
+	store 6,mem_hci_plap
+	rtn
+
+phci_read_handle:
+	ifetch 2,contru
+	store 1,mem_hci_conn_handle
+	rtn
+
+phci_copy_handle:
+	call phci_read_handle
+	call hci_get_cmd_complete_ptr
+	fetch 1,mem_hci_conn_handle
+	istore 2,contwu
+	rtn
+
+
+	/* TODO: should be replaced with real job */
+phci_status_reply_temp:
+	call phci_read_handle
+	call hci_command_status
+	call hci_get_payload_ptr
+	force 0,pdata
+	istore 1,contwu
+	fetch 1,mem_hci_conn_handle
+	istore 2,contwu
+	rtn
+	
+phci_read_clock:
+	ifetch 2,contru
+	iadd clkn_bt,pdata
+	and_into 0x1fc,pdata
+	store 4,mem_page_clk
+	rtn
+
+hci_inquiry_reply:
+	set0 mark_ext_patch,mark
+	bpatch patch1c_0,mem_patch1c
+	fetch 1,mem_rp_packets
+	sub pdata,2,null
+	nrtn positive
+	fetcht 6,extm_lap
+	call context_search_plap2
+	rtn zero
+	call hci_get_packet_ptr
+	setarg 0x10f22
+	istore 3,contwu
+	fetch 6,extm_lap
+	istore 6,contwu
+	fetch 1, extm_fhs_misc
+	copy pdata, temp
+	rshift3 pdata, pdata
+	rshift3 pdata, pdata
+	istore 1,contwu
+	copy temp, pdata
+	and pdata,0x30,pdata
+	rshift3 pdata, pdata
+	rshift pdata, pdata
+	istore 1,contwu
+	fetch 3, extm_class
+	istore 3,contwu
+	fetch 4,mem_clke_bt
+	isub clkn_bt,pdata
+	istore 2,contwu
+	setarg 0xc8
+	istore 1,contwu
+	force 15,loopcnt
+	branch hci_send_event_raw
+	
+hci_inquiry_reply_eir:
+	set0 mark_ext_patch,mark
+	bpatch patch1c_1,mem_patch1c
+	force 540,temp
+	fetch 2,mem_h5tx_free
+	isub temp,null
+	nrtn positive
+	fetcht 3,mem_extm_uap_restore
+	fetch 3,extm_uap
+	isub temp,null
+	rtn zero
+	rtn blank
+	store 3,mem_extm_uap_restore
+	fetch 1,mem_rp_packets
+	sub pdata,2,null
+	nrtn positive
+	fetcht 6,extm_lap
+	call context_search_plap2
+	rtn zero
+	call hci_eir_reply
+	force 15,temp
+	fetch 1,mem_rxbuf+1
+	bne 0x09,hci_inquiry_reply_eir_end
+	fetch 1,mem_rxbuf
+	branch hci_inquiry_reply_eir_end,blank
+	iforce loopcnt
+	istore 1,contwu
+	iadd temp,temp
+	increase 1,temp
+	arg mem_rxbuf+1,contr
+	//increase 1,contr
+hci_inquiry_name_loop:
+	ifetch 1,contr
+	istore 1,contwu
+	loop hci_inquiry_name_loop
+hci_inquiry_other_rtn_loop:
+	ifetch 1,contr
+	branch hci_inquiry_reply_eir_end,blank
+	iforce loopcnt
+	istore 1,contwu
+	iadd temp,temp
+	increase 1,temp
+hci_inquiry_other_loop:
+	ifetch 1,contr
+	istore 1,contwu
+	loop hci_inquiry_other_loop
+	branch hci_inquiry_other_rtn_loop	
+hci_inquiry_reply_eir_end:
+	sub temp,0xff,pdata
+	iforce loopcnt
+hci_inquiry_fill_zero:
+	setarg 0x00
+	istore 1,contwu
+	loop hci_inquiry_fill_zero
+	force 0xff,loopcnt
+	branch hci_send_event_raw
+	
+hci_eir_reply:
+	set0 mark_ext_patch,mark
+	bpatch patch1c_2,mem_patch1c
+	call hci_get_packet_ptr
+	setarg 0x1ff2f
+	istore 3,contwu
+	fetch 6,extm_lap
+	istore 6,contwu
+	fetch 1, extm_fhs_misc
+	copy pdata, temp
+	rshift3 pdata, pdata
+	rshift3 pdata, pdata
+	istore 1,contwu
+	copy temp, pdata
+	and pdata,0x30,pdata
+	rshift3 pdata, pdata
+	rshift pdata, pdata
+	istore 1,contwu
+	fetch 3, extm_class
+	istore 3,contwu
+	fetch 4,mem_clke_bt
+	isub clkn_bt,pdata
+	istore 2,contwu
+	setarg 0xc8
+	istore 1,contwu
+	rtn
+	/* temp is features */
+hci_send_remote_features:
+	set0 mark_ext_patch,mark
+	bpatch patch1c_3,mem_patch1c
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	call hci_write_handle3
+	istoret 8,contwu
+	force 11,loopcnt
+	force HCI_EVENT_READ_REMOTE_FEATURES_COMPLETE,queue
+	branch hci_send_event
+
+hci_send_remote_ext_features_notification:
+	set0 mark_ext_patch,mark
+	bpatch patch1c_4,mem_patch1c
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	// BDaddr, Extended_LMP_Features
+	call hci_get_payload_ptr
+	fetch 6,mem_plap
+	istore 6,contwu
+	istoret 8,contwu// 8 bytes remote ext feature saved in temp reg
+	force 14,loopcnt
+	force HCI_EVENT_REMOTE_HOST_SUPPORTED_FEATURES_NOTIFICATION,queue
+	branch hci_send_event	
+	
+hci_send_remote_ext_features_event:
+	set0 mark_ext_patch,mark
+	bpatch patch1c_5,mem_patch1c
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	//Status, Connection_Handle, Page_Number, Maximum page number, Extended_LMP_Features
+	call hci_write_handle3
+	fetch 1,mem_ext_features_page
+	istore 1,contwu
+	setarg 1
+	istore 1,contwu
+	istoret 8,contwu// 8 bytes remote ext feature saved in temp reg
+	force 13,loopcnt
+	force HCI_EVENT_READ_REMOTE_EXT_FEATURES_COMPLETE,queue
+	branch hci_send_event	
+
+	/* temp is version */
+hci_send_version_information:
+	set0 mark_ext_patch,mark
+	bpatch patch1c_6,mem_patch1c
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	call hci_write_handle3
+	istoret 5,contwu
+	force 8,loopcnt
+	force HCI_EVENT_READ_REMOTE_VERSION_INFORMATION_COMPLETE,queue
+	branch hci_send_event
+
+hci_send_io_cap_response_event:
+	set0 mark_ext_patch,mark
+	bpatch patch1c_7,mem_patch1c
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	// BD_ADDR, IO_Capability,
+	call hci_get_payload_ptr
+	fetch 6,mem_plap
+	istore 6,contwu
+	fetch 3,mem_sp_iocap_remote
+	istore 3,contwu
+	force 9,loopcnt
+	force HCI_EVENT_IO_CAP_RESPONSE,queue
+	branch hci_send_event	
+
+hci_send_io_cap_req_event:
+	set0 mark_ext_patch,mark
+	bpatch patch1d_0,mem_patch1d
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	// BD_ADDR
+	call hci_get_payload_ptr
+	fetch 6,mem_plap
+	istore 6,contwu
+	force 6,loopcnt
+	force HCI_EVENT_IO_CAP_REQ,queue
+	branch hci_send_event	
+
+	
+hci_send_connection_complete:
+	force 0,temp
+hci_send_connection_error:
+	set0 mark_ext_patch,mark
+	bpatch patch1d_1,mem_patch1d
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	force HCI_EVENT_CONNECTION_COMPLETE,queue
+	jam 5,mem_acl_credits
+	call hci_get_payload_ptr
+	istoret 1,contwu
+	call hci_write_handle
+	call hci_write_plap
+	force 1,pdata				/* connection type=1:ACL */
+	istore 1,contwu
+	force 0,pdata
+	fetcht 1,mem_state_map
+	isolate1 smap_encryption,temp
+	setflag true,0,pdata
+	istore 1,contwu
+	force 11,loopcnt
+	branch hci_send_event
+
+	/* temp is connection type 0=sco,1=acl */
+hci_send_conn_req_event:
+	set0 mark_ext_patch,mark
+	bpatch patch1d_2,mem_patch1d
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	force HCI_EVENT_CONNECTION_REQUEST,queue
+	call hci_get_payload_ptr
+	call hci_write_plap
+	// class of device
+	fetch 3,extm_class
+	istore 3,contwu
+	istoret 1,contwu
+	force 10,loopcnt
+	branch hci_send_event
+
+hci_send_encryption_change:
+	set0 mark_ext_patch,mark
+	bpatch patch1d_3,mem_patch1d
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	call hci_write_handle3
+	force 0,pdata
+	fetcht 1,mem_state_map
+	isolate1 smap_encryption,temp
+	setflag true,0,pdata
+	istore 1,contwu
+	force HCI_EVENT_ENCRYPTION_CHANGE_COMPLETE,queue
+	force 4,loopcnt
+	branch hci_send_event
+
+
+hci_send_linkkey_notification:
+	set0 mark_ext_patch,mark
+	bpatch patch1d_4,mem_patch1d
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	force HCI_EVENT_LINK_KEY_NOTIFICATION,queue
+	call hci_get_payload_ptr
+	call hci_write_plap
+	arg mem_link_key,contr
+	force 16,loopcnt
+	call uart_copy_tx_bytes
+	force 0x05,pdata
+	istore 1,contwu
+	force 0x17,loopcnt
+	branch hci_send_event
+
+hci_send_user_confirmation_req:
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	force HCI_EVENT_USER_CONFIRMATION_REQUEST,queue
+	call hci_get_payload_ptr
+	call hci_write_plap
+	fetch 4,mem_sp_gkey
+	istore 4,contwu
+	force 0xa,loopcnt
+	branch hci_send_event
+
+hci_send_ssp_complete:
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	force HCI_EVENT_SIMPLE_PAIRING_COMPLETE,queue
+	call hci_get_payload_ptr
+	setarg 0
+	istore 1,contwu
+	call hci_write_plap
+	force 0x7,loopcnt
+	branch hci_send_event
+
+
+hci_send_linkkey_req:
+	set0 mark_ext_patch,mark
+	bpatch patch1d_5,mem_patch1d
+	force HCI_EVENT_LINK_KEY_REQUEST,queue
+hci_send_sec_req:	/* used by linkkey and pin req */
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	call hci_get_payload_ptr
+	call hci_write_plap
+	force 6,loopcnt
+	branch hci_send_event
+
+hci_send_pincode_req:
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	force HCI_EVENT_PIN_CODE_REQUEST,queue
+	branch hci_send_sec_req
+
+	/* temp=role */
+hci_send_role_change:
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	force HCI_EVENT_ROLE_CHANGE,queue
+	call hci_get_payload_ptr
+	force 0,pdata
+	istore 1,contwu
+	call hci_write_plap
+	istoret 1,contwu
+	force 8,loopcnt
+	branch hci_send_event
+
+hci_send_role_change_err:
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	force 0,temp
+	nbranch hci_send_role_change_err_slave,master
+	force 1,temp
+hci_send_role_change_err_slave:
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	force HCI_EVENT_ROLE_CHANGE,queue
+	call hci_get_payload_ptr
+	force 0x35,pdata
+	istore 1,contwu
+	call hci_write_plap
+	istoret 1,contwu
+	force 8,loopcnt
+	branch hci_send_event
+
+hci_send_name:	/* queue is error code */
+	set0 mark_ext_patch,mark
+	bpatch patch1d_6,mem_patch1d
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	call hci_get_packet_ptr
+	setarg 0xff07
+	istore 2,contwu
+	deposit queue
+	istore 1,contwu
+	call hci_write_plap
+	arg mem_tmp_buffer,contr
+	force 248,loopcnt
+hci_read_remote_name_loop:
+	ifetch 1,contr
+	istore 1,contwu
+	loop hci_read_remote_name_loop
+	force 0xff,loopcnt
+	branch hci_send_event_raw
+
+hci_send_num_complete_packets:
+	set0 mark_ext_patch,mark
+	bpatch patch1d_7,mem_patch1d
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	hfetch 1,core_uart_txitems
+	nrtn blank
+	fetch 1,mem_op
+	rtnbit0 op_pkt_comp
+	set0 op_pkt_comp,pdata
+	store 1,mem_op
+	call hci_get_payload_ptr
+	force 1,pdata
+	istore 1,contwu
+	call hci_write_handle
+	force 1,pdata
+	istore 2,contwu
+	force HCI_EVENT_NUM_COMPLETED_PACKETS,queue
+	force 5,loopcnt
+	branch hci_send_event
+
+
+
+hci_send_auth_complete:
+	set0 mark_ext_patch,mark
+	bpatch patch1e_0,mem_patch1e
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	call hci_write_handle3
+	force HCI_EVENT_AUTHENTICATION_COMPLETE,queue
+	force 3,loopcnt
+	branch hci_send_event
+
+
+	/* temp is connection handle */
+hci_send_disconn_complete:
+	set0 mark_ext_patch,mark
+	bpatch patch1e_1,mem_patch1e
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	call hci_get_payload_ptr
+	force 0,pdata
+	istore 1,contwu
+	istoret 2,contwu
+	fetch 1,mem_hci_disconn_reason
+	istore 1,contwu
+	force HCI_EVENT_DISCONNECTION_COMPLETE,queue
+	force 4,loopcnt
+	branch hci_send_event
+
+
+hci_send_le_adv_report_event:
+	set0 mark_ext_patch,mark
+	bpatch patch1e_2,mem_patch1e
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci,pdata
+	call hci_get_payload_ptr
+	setarg 0x0102//HCI_LE_SUBEVENT_ADV_REPORT + report number
+	istore 2,contwu
+	fetcht 1,mem_le_rxbuf
+	and temp,0xf,pdata//PDU type
+	istore 1,contwu
+	copy rega,pdata//advertiser address type
+	istore 1,contwu
+	fetcht 1,mem_le_rxbuf+1//payload length
+	increase -6,temp//data_len = payload length -6;
+	fetch 6,mem_le_rxbuf+2 //advertiser address
+	istore 6,contwu
+	istoret 1,contwu//data_len
+	copy temp,loopcnt 
+	call uart_copy_tx_bytes //copy adv data
+	setarg 127// RSSI not available
+	istore 1,contwu
+	copy temp,loopcnt
+	add loopcnt,12,loopcnt //payload_len = data_len + 12;
+	force HCI_EVENT_LE_META_EVENT,queue
+	branch hci_send_event
+	
+hci_send_le_conn_complete:
+	set0 mark_ext_patch,mark
+	bpatch patch1e_3,mem_patch1e
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci,pdata
+	call hci_get_payload_ptr
+	setarg HCI_LE_SUBEVENT_CONN_COMPLETE
+	istore 1,contwu
+	istoret 1,contwu //status
+	fetch 1,mem_le_conn_handle
+	istore 2,contwu//handle
+	fetch 1,mem_le_mode
+	rshift pdata,pdata
+	setflip 0,pdata
+	istore 1,contwu//role:0 master,1 slave
+	fetch 1,mem_le_conn_peer_addr_type
+	istore 1,contwu//peer addr & type
+	fetch 6,mem_le_plap
+	istore 6,contwu
+	fetch 2,mem_le_conn_interval// interval & latency & super to
+	istore 2,contwu// interval & latency & super to
+	fetch 2,mem_le_slave_latency
+	istore 2,contwu
+	fetch 2,mem_le_superto
+	istore 2,contwu
+	fetch 1,mem_le_peer_sca
+	istore 1,contwu//Master_Clock_Accuracy
+	force HCI_EVENT_LE_META_EVENT,queue
+	arg 19,loopcnt
+	branch hci_send_event
+
+
+	/* temp is mode */	
+hci_send_mode_change:
+	set0 mark_ext_patch,mark
+	bpatch patch1e_4,mem_patch1e
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	//storet 1,mem_lpm_mode
+	call hci_get_payload_ptr
+	call hci_write_handle3
+	istoret 1,contwu
+	fetch 2,mem_tsniff
+	rshift pdata,pdata
+	istore 2,contwu
+	force 6,loopcnt
+	force HCI_EVENT_MODE_CHANGE,queue
+	branch hci_send_event
+	
+	/* temp is status,hansdle of sco on hci is 0xe00 */
+hci_send_sco_complete:
+	set0 mark_ext_patch,mark
+	bpatch patch1e_5,mem_patch1e
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	set0 mark_ext_patch,mark
+	bpatch patch1e_6,mem_patch1e
+	call hci_get_payload_ptr
+	istoret 1,contwu
+	setarg 0xe00
+	istore 2,contwu
+	call hci_write_plap
+	force 0,pdata
+	bmark1 mark_esco,hci_send_esco
+	force 0,pdata
+	istore 7,contwu
+	branch hci_send_sco_cont
+hci_send_esco:
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	setarg 0x020602
+	istore 3,contwu
+	setarg 30
+	istore 2,contwu
+	setarg 30
+	istore 2,contwu
+hci_send_sco_cont:	
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci
+	fetch 1,mem_air_mode
+	istore 1,contwu
+	force HCI_EVENT_SCO_CONNECTION_COMPLETE,queue
+	force 17,loopcnt
+	branch hci_send_event
+
+
+hci_command_status:
+	set0 mark_ext_patch,mark
+	bpatch patch1e_7,mem_patch1e
+	call hci_get_payload_ptr
+	setarg 0x100
+	istore 2,contwu
+	deposit alarm
+	istore 2,contwu
+	force 4,loopcnt
+	force HCI_EVENT_COMMAND_STATUS,queue
+	branch hci_send_event
+	
+hci_command_status_err:
+	set0 mark_ext_patch,mark
+	bpatch patch1f_0,mem_patch1f
+	call hci_get_payload_ptr
+	deposit rega	/*err type in rega*/
+	istore 1,contwu
+	setarg 0x01
+	istore 1,contwu
+	deposit alarm
+	istore 2,contwu
+	force 4,loopcnt
+	force HCI_EVENT_COMMAND_STATUS,queue
+	branch hci_send_event
+	
+hci_normal_reply:
+	set0 mark_ext_patch,mark
+	bpatch patch1f_1,mem_patch1f
+	force 4,loopcnt
+hci_command_complete:	/* loopcnt is hci length */
+	call hci_get_payload_ptr
+	force 0x1,pdata
+	istore 1,contwu
+	deposit alarm
+	istore 3,contwu
+	force HCI_EVENT_COMMAND_COMPLETE,queue
+hci_send_event:		/* queue:event code, loopcnt: length */
+	set0 mark_ext_patch,mark
+	bpatch patch1f_2,mem_patch1f
+	call hci_get_packet_ptr
+	deposit queue
+	istore 1,contwu
+	deposit loopcnt
+	istore 1,contwu
+hci_send_event_raw:
+	set1 mark_h5tx_rp,mark
+	force 5,queue
+	increase 2,loopcnt
+hci_send_packet:
+	call hci_check_bcsp_protocol
+	branch bcsp_send_packet,true
+	branch h4_send_packet_event
+
+hci_send_commu_ready_event:
+	force HCI_EVENT_VENDOR_SPECIFIC,queue
+	call hci_get_payload_ptr
+	setarg HCI_VENDOR_EVENT_COMMU_READY
+	istore 1,contwu
+	force 1,loopcnt
+	branch hci_send_event
+
+
+hci_write_plap:
+	fetch 6,mem_plap
+	istore 6,contwu
+	rtn
+
+hci_write_handle3:
+	call hci_get_payload_ptr
+	force 0,pdata
+	istore 1,contwu
+hci_write_handle:
+	fetch 1,mem_conn_handle
+	istore 2,contwu
+	rtn
+
+hci_get_cmd_complete_ptr:
+	force 12,contwu
+	branch hci_get_tx_ptr
+
+hci_get_payload_ptr:
+	force 8,contwu
+	branch hci_get_tx_ptr
+
+hci_get_packet_ptr:
+	force 6,contwu
+hci_get_tx_ptr:
+	call hci_check_bcsp_protocol
+	branch bcsp_get_tx_ptr,true
+	branch h4_get_tx_ptr
+
+uart_copy_tx_bytes:
+	deposit loopcnt
+	rtn blank
+uart_copy_tx_bytes_loop:
+	ifetch 1,contr
+	istore 1,contwu
+	loop uart_copy_tx_bytes_loop
+	rtn
+
+uart_copy_rx_bytes:
+	deposit loopcnt
+	rtn blank
+uart_copy_rx_bytes_loop:
+	ifetch 1,contru
+	istore 1,contw
+	loop uart_copy_rx_bytes_loop
+	rtn
+
+uart_write_bytes:
+	istore 1,contwu
+	rshift8 pdata,pdata
+	loop uart_write_bytes
+	rtn
+	
+
+calc_tx_crc16:
+	pulse crc16
+	enable enable_crc
+crcloop:
+	ifetch 1,contwu
+	inject bucket,8
+	loop crcloop
+	enable enable_parity
+	inject bucket,16
+	disable enable_parity
+	disable enable_crc
+	disable crc16
+	byteswap pdata,pdata
+	rtn
+
+stop_loop:
+	nop 1
+	hjam 1,0x8203
+	branch stop_loop
+
+
+
+process_cmd:
+	set0 mark_ext_patch,mark
+	bpatch patch1f_3,mem_patch1f
+	fetch 1,mem_hci_cmd
+	rtn blank
+	fetch 1,mem_lmo_opcode2
+	nrtn blank
+	call cmd_check_plap
+	nbranch process_cmd_conn_handle,zero
+	fetch 1,mem_hci_cmd
+	beq hci_cmd_remote_name_req,cmd_namereq
+	beq hci_cmd_pair,cmd_pair
+	beq hci_cmd_nopair,cmd_nopair
+	beq hci_cmd_linkkey,cmd_has_key
+	beq hci_cmd_nokey,cmd_no_key
+	beq hci_cmd_reject_conn,cmd_disconn
+	beq hci_cmd_role_switch,cmd_role_switch
+	beq hci_cmd_accept_conn,cmd_accept_conn
+	beq hci_cmd_accept_with_switch,cmd_accept_with_switch
+	beq hci_cmd_detach,cmd_detach
+	beq hci_cmd_in_sniff,cmd_in_sniff
+	beq hci_cmd_exit_sniff,cmd_exit_sniff
+process_cmd_conn_handle:
+	set0 mark_ext_patch,mark
+	bpatch patch1f_4,mem_patch1f
+	call cmd_check_handle
+	nrtn blank
+	fetch 1,mem_hci_cmd
+	beq hci_cmd_auth,cmd_auth
+	beq hci_cmd_startencrypt,cmd_start_encrypt
+	beq hci_cmd_stopencrypt,cmd_stop_encrypt
+	beq hci_cmd_setup_sco,cmd_setup_sco
+	beq hci_cmd_disconn_sco,cmd_disconn_sco
+	beq hci_cmd_accept_sco_conn,cmd_accept_sco_conn
+	beq hci_cmd_remote_feature_req,cmd_feature_req
+	beq hci_cmd_remote_ext_features_req,cmd_ext_feature_req
+	beq hci_cmd_remote_version_req,cmd_version_req
+	beq hci_cmd_role_discovery,cmd_role_discovery
+	beq hci_cmd_io_cap,cmd_io_cap
+	rtnne hci_cmd_disconn
+	call lmp_disconnect
+cmd_exit:
+	jam 0,mem_hci_cmd
+	rtn
+
+cmd_check_plap:
+	fetch 6,mem_hci_plap
+	fetcht 6,mem_plap
+	isub temp,null
+	rtn
+
+	/* return pdata=0 if handle match */
+cmd_check_handle:
+	fetch 1,mem_hci_conn_handle
+	fetcht 1,mem_conn_handle
+	isub temp,pdata
+	rtn
+
+cmd_accept_conn:
+	jam LMP_ACCEPTED,mem_lmo_opcode2
+	jam LMP_HOST_CONNECTION_REQ,mem_lmi_opcode2
+	call tid_set_reply
+	branch cmd_exit
+
+cmd_accept_with_switch:
+	branch cmd_accept_sco_conn,master
+	set1 mark_accept_switch,mark
+cmd_role_switch:
+	jam LMP_SLOT_OFFSET,mem_lmo_opcode2
+	set1 mark_switch_initiated,mark
+	nbranch cmd_exit,master
+	jam LMP_SWITCH_REQ ,mem_lmo_opcode2
+	fetch 1,mem_connection_options
+	set0 CONNECTION_SWITCH,pdata
+	store 1,mem_connection_options
+	branch cmd_exit
+
+	
+cmd_namereq:
+	jam LMP_NAME_REQ,mem_lmo_opcode2
+	jam 0,mem_name_offset
+	branch cmd_exit
+	
+//enable ssp master sm
+cmd_ssp:
+	jam SP_FLAG_COMMIT,mem_master_sp_flag
+	jam SP_MASTER_STAT_START_SKIP,mem_master_sp_state
+	branch cmd_exit
+	
+cmd_pair:
+	fetch 1,mem_op
+	bbit1 op_inrand_req,cmd_pair_passive
+	call tid_initiate
+	jam LMP_IN_RAND,mem_lmo_opcode2
+	branch cmd_exit
+cmd_pair_passive:
+	set0 op_inrand_req,pdata
+	store 1,mem_op
+	call lmp_accept_inrand
+	setarg 0
+	setflag master,smap_lmptid,pdata		
+	store 1,mem_lmo_tid2
+	branch cmd_exit
+	
+cmd_nopair:
+	jam PAIRING_NOT_ALLOWED,mem_disconn_reason_send
+	jam LMP_DETACH,mem_lmo_opcode2
+	fetch 1,mem_state
+	bbit1 state_inconn,cmd_exit
+	force HCI_ERROR_PAIRING_NOT_ALLOWED,temp
+	call hci_send_connection_error
+	branch cmd_exit
+
+	
+cmd_has_key:
+	call linkkey_set
+	fetch 1,mem_op
+	bbit1 op_auth_req,cmd_send_aurand
+	bbit1 op_send_sres,cmd_send_sres
+	bbit1 op_inrand_req,cmd_pair_passive
+	branch cmd_exit
+cmd_send_sres:
+	set0 op_send_sres,pdata
+	store 1,mem_op
+	jam LMP_SRES,mem_lmo_opcode2
+	branch cmd_exit
+
+cmd_no_key:
+	fetch 1,mem_op
+	bbit1 op_send_sres,cmd_no_key_reject
+	call hci_send_pincode_req
+	branch cmd_exit
+cmd_no_key_reject:
+	set0 op_send_sres,pdata
+	store 1,mem_op
+	jam LMP_NOT_ACCEPTED,mem_lmo_opcode2
+	jam LMP_AU_RAND,mem_lmi_opcode2
+	jam KEY_MISSING,mem_lmo_reason2
+	branch cmd_exit
+	
+
+cmd_auth:
+	fetch 1,mem_op
+	set1 op_auth_req,pdata
+	store 1,mem_op
+	fetch 1,mem_state
+	bbit1 state_linkkey,cmd_auth_sendaurand
+	call hci_send_linkkey_req
+	branch cmd_exit
+
+cmd_send_aurand:
+cmd_auth_sendaurand:
+	call tid_initiate
+	jam LMP_AU_RAND,mem_lmo_opcode2
+	branch cmd_exit
+
+cmd_start_encrypt:
+	jam LMP_ENCRYPTION_MODE_REQ,mem_lmo_opcode2
+	branch cmd_exit
+
+cmd_stop_encrypt:
+	jam LMP_ENCRYPTION_MODE_REQ ,mem_lmo_opcode2
+	branch cmd_exit
+
+cmd_feature_req:
+	set0 mark_ext_patch,mark
+	bpatch patch1f_5,mem_patch1f
+	jam LMP_FEATURES_REQ,mem_lmo_opcode2
+	jam hci_cmd_wait_remote_feature,mem_hci_cmd
+	rtn
+	
+cmd_ext_feature_req:	
+	jam LMP_EXT_FEATURES_REQ,mem_lmo_opcode2
+	jam hci_cmd_wait_remote_ext_feature,mem_hci_cmd
+	rtn
+	
+cmd_version_req:
+	jam LMP_VERSION_REQ,mem_lmo_opcode2
+	branch cmd_exit
+	
+cmd_in_sniff:
+	jam LMP_SNIFF_REQ,mem_lmo_opcode2
+	arg mem_sniff_payload,contw
+	setarg 0
+	isolate1 27,clke_bt
+	setflag true,1,pdata		/* use init 2 if bit27 of clke is 1 */
+	istore 1,contw	
+	setarg 0	/* dsniff */
+	istore 2,contw
+	fetch 2,mem_sniff_param_interval	/* tsniff */
+	istore 2,contw
+	fetch 1,mem_sniff_param_attempt	/* attempt */
+	istore 2,contw
+	fetch 1,mem_sniff_param_timeout	/* timeout */
+	istore 2,contw
+	branch cmd_exit
+	
+cmd_exit_sniff:
+	jam LMP_UNSNIFF_REQ,mem_lmo_opcode2
+	branch cmd_exit
+	
+cmd_setup_sco:
+	call new_conn_handle
+	store 1,mem_sco_handle
+	fetch 1,mem_conn_handle
+	store 1,mem_sco_asso_handle
+	jam LMP_SCO_LINK_REQ,mem_lmo_opcode2
+	set1 mark_esco,mark
+	jam LMP_EXT_ESCO_LINK_REQ,mem_lmo_opcode2
+	branch cmd_exit
+
+cmd_disconn:
+	call lmp_disconnect
+	branch cmd_exit
+	
+cmd_disconn_sco:
+	jam LMP_REMOVE_SCO_LINK_REQ,mem_lmo_opcode2
+	bmark0 mark_esco,cmd_exit
+	jam LMP_EXT_REMOVE_ESCO_REQ,mem_lmo_opcode2
+	branch cmd_exit
+	
+cmd_accept_sco_conn:
+	branch cmd_accept_sco_conn_master,master
+	jam LMP_ACCEPTED,mem_lmo_opcode2
+	jam LMP_SCO_LINK_REQ,mem_lmi_opcode2
+	bmark0 mark_esco,cmd_exit
+	fetch 1,mem_esco_type
+	bne type_hv3,parse_lmpext_esco_link_req_change_param //ev3 only
+	jam LMP_EXT_ACCEPTED ,mem_lmo_opcode2
+	jam LMP_EXT_ESCO_LINK_REQ,mem_lmi_opcode2
+	branch cmd_exit	
+cmd_accept_sco_conn_master:
+	call new_conn_handle
+	store 1,mem_sco_handle
+	fetch 1,mem_conn_handle
+	store 1,mem_sco_asso_handle
+	jam LMP_SCO_LINK_REQ,mem_lmo_opcode2
+	bmark0 mark_esco,cmd_exit
+	branch parse_lmpext_esco_link_req_change_param	
+
+
+cmd_role_discovery:
+	call hci_get_cmd_complete_ptr
+	call hci_write_handle
+	force 0,pdata
+	nsetflag master,0,pdata
+	istore 1,contwu
+	force 7,loopcnt
+	arg 0x809,alarm				/* role discovery */
+	call hci_command_complete
+	branch cmd_exit
+	
+cmd_io_cap:
+	jam LMP_IO_CAP_RES,mem_lmo_opcode2 
+	branch cmd_exit
+	
+cmd_detach:
+	jam LMP_DETACH,mem_lmo_opcode2
+	jam OTHER_END_TERMINATED,mem_disconn_reason_send
+	branch cmd_exit
+
+
+
+// below  merged from bt_hci_patch
+process_hci_patch:
+	jam 0, mem_check_sum
+	//check the packet id
+	//if the packid is not mem_ucode_id_local + 1 then send nak with packe number
+	ifetch 1,contru
+	store 1, mem_ucode_id_remote
+	call hci_ucode_checksum_add
+	
+	call push_stack
+	fetch 1, mem_ucode_id_remote
+	copy pdata, temp
+	fetch 1, mem_ucode_id_local
+	increase 1,pdata
+	icompare 0xff,temp
+	nbranch hci_nak_ucode_with_stack, true
+	store 1, mem_ucode_id_local
+	call pop_stack
+	
+	ifetch 1,contru
+	beq 0x01,hci_enable_ucode_load
+	beq 0x02,process_hci_ucode
+	beq 0x03,hci_disable_ucode_load
+	beq 0x05,process_hci_n_sched_data
+	beq 0x06,hci_write_register
+	beq 0x07,hci_read_register
+	beq 0x08,hci_enable_ucode
+	beq 0x09,hci_soft_branch
+	rtn
+hci_ucode_checksum_add:
+	copy pdata, temp
+	call push_stack
+	fetch 1, mem_check_sum
+	iadd temp,pdata
+	store 1, mem_check_sum
+	branch pop_stack
+
+
+hci_ack_ucode:
+	force 1,pdata
+	call uart_send_byte
+	fetch 1, mem_ucode_id_local
+	branch uart_send_byte
+	
+hci_nak_ucode_with_stack:
+	call pop_stack
+	branch hci_nak_ucode_ucode_id
+hci_nak_ucode:
+	fetch 1, mem_ucode_id_local
+	increase -1,pdata
+	store 1, mem_ucode_id_local
+hci_nak_ucode_ucode_id:	
+	force 0,pdata
+	call uart_send_byte
+	fetch 1, mem_ucode_id_local
+	branch uart_send_byte
+	
+hci_write_register:
+	call hci_ucode_checksum_add
+	ifetch 1,contru
+	store 1, mem_ucode_temp
+	call hci_ucode_checksum_add
+	ifetch 1,contru
+	lshift8 pdata, contw
+	call hci_ucode_checksum_add
+	fetch 1, mem_ucode_temp
+	iadd contw, contw
+	ifetch 1,contru //data in pdata
+	istore 1, contw //store the data in register
+	call hci_ucode_checksum_add
+	ifetch 1,contru
+	call hci_ucode_checksum_add
+	fetch 1, mem_check_sum
+	bne 0xff, hci_nak_ucode
+	branch hci_ack_ucode
+	
+hci_read_register:
+	call hci_ucode_checksum_add
+	ifetch 1,contru
+	store 1, mem_ucode_temp
+	call hci_ucode_checksum_add
+	ifetch 1,contru
+	store 1, mem_ucode_temp1
+	call hci_ucode_checksum_add
+	ifetch 1,contru
+	call hci_ucode_checksum_add
+	fetch 1, mem_check_sum
+	bne 0xff, hci_nak_ucode
+	
+	fetch 1, mem_ucode_temp1
+	lshift8 pdata, temp
+	fetch 1, mem_ucode_temp
+	iadd temp,contru
+	ifetch 1, contru
+	store 1, mem_ucode_temp
+hci_read_register_ack:	
+	force 1,pdata
+	call uart_send_byte
+	fetch 1, mem_ucode_temp //hardware register
+	call uart_send_byte
+	jam 0xff, mem_ucode_id_local
+	rtn
+	
+hci_enable_ucode:
+	call hci_ucode_checksum_add
+	ifetch 1,contru
+	call hci_ucode_checksum_add
+	fetch 1, mem_check_sum
+	bne 0xff, hci_nak_ucode
+	branch hci_ack_ucode
+
+process_hci_ucode:
+	call hci_ucode_checksum_add
+	ifetch 1,contru
+	hstore 1,core_ucode_low
+	call hci_ucode_checksum_add
+	ifetch 1,contru
+	set1 7,pdata
+	hstore 1,core_ucode_ctrl
+	set0 7,pdata
+	call hci_ucode_checksum_add
+	ifetch 1,contru //length
+	copy pdata,loopcnt
+	call hci_ucode_checksum_add
+write_ucode_loop:
+	ifetch 1,contru
+	hstore 1, core_ucode_data
+	call hci_ucode_checksum_add
+	loop write_ucode_loop
+	ifetch 1,contru
+	call hci_ucode_checksum_add
+	fetch 1, mem_check_sum
+	bne 0xff, hci_nak_ucode
+	branch hci_ack_ucode
+		
+process_hci_n_sched_data:
+	call hci_ucode_checksum_add
+	ifetch 1,contru
+	store 1, mem_ucode_temp
+	call hci_ucode_checksum_add
+	ifetch 1,contru
+	lshift8 pdata, contw
+	call hci_ucode_checksum_add
+	fetch 1, mem_ucode_temp
+	iadd contw, contw
+	ifetch 1,contru
+	iforce loopcnt
+	call hci_ucode_checksum_add
+process_hci_n_sched_loop:
+	ifetch 1,contru
+	istore 1,contw
+	call hci_ucode_checksum_add
+	loop process_hci_n_sched_loop
+	ifetch 1,contru
+	call hci_ucode_checksum_add
+	fetch 1, mem_check_sum
+	bne 0xff, hci_nak_ucode
+	branch hci_ack_ucode
+
+
+
+hci_enable_ucode_load:
+	call hci_ucode_checksum_add
+	ifetch 1,contru
+	call hci_ucode_checksum_add
+	fetch 1, mem_check_sum
+	bne 0xff, hci_nak_ucode
+	hjam 0x80,core_ucode_ctrl
+	branch hci_ack_ucode
+
+hci_disable_ucode_load:
+	call hci_ucode_checksum_add
+	ifetch 1,contru
+	call hci_ucode_checksum_add
+	fetch 1, mem_check_sum
+	bne 0xff, hci_nak_ucode
+	hjam 0,core_ucode_ctrl
+	branch hci_ack_ucode
+	
+hci_soft_branch:
+	call hci_ucode_checksum_add
+	ifetch 1,contru
+	call hci_ucode_checksum_add
+	fetch 1, mem_check_sum
+	bne 0xff, hci_nak_ucode
+	call hci_ack_ucode
+	branch soft_reset
+
+
+hci_idle_dispatch:
+	call gpio_check_uart_state
+	rtn true
+	arg UART_WAKEUP_RX,temp
+	call gpio_get_bit
+	nbranch uart_wake_up,true
+	jam HCI_RX_WAKE,mem_hci_lt_rx_state
+	rtn
+uart_wake_up:
+	fetch 1,mem_hci_lt_rx_state
+	rtnne HCI_RX_WAKE
+	call hci_exit_lpm
+	branch hci_send_commu_ready_event
+	
+	
Index: btkb/program/hid.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/hid.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/hid.prog	(working copy)
@@ -0,0 +1,88 @@
+/**
+* the following API is to send the HID data
+* 
+*/
+
+/**
+* the following API is to process the hid  rx data
+* 
+*/
+//handle the hid data
+
+hid_rx_process:
+	set1 mark_ext_patch,mark
+	bpatch patch33_4,mem_patch33
+	fetch 2,mem_l2cap_payload_ptr
+	copy pdata,contr
+	ifetch 1,contr
+	and pdata,0x0f,temp
+	rshift4 pdata,pdata //hidtype
+	beq HID_TYPE_SET_IDLE,hid_rx_process_handshake
+	beq HID_TYPE_SET_PROTOCOL,hid_rx_process_handshake
+	beq HID_TYPE_DATA,hid_rx_process_data
+	beq HID_TYPE_SET_REPORT,hid_rx_process_set_report
+	beq HID_TYPE_CONTROL,hid_rx_process_hid_control
+	rtn
+
+hid_rx_process_hid_control:
+	copy temp,pdata
+	beq HID_CONTROL_P_VIRTUALCABLEUNPLUG,hid_rx_process_virtual_cable_unplug
+	beq HID_CONTROL_P_SUSPEND,hid_rx_process_suspend
+	rtn
+	
+hid_rx_process_virtual_cable_unplug:
+	jam BT_EVT_VIRTUAL_CABLE_UNPLUG,mem_fifo_temp
+	call ui_ipc_send_event
+	fetch 1,mem_device_option
+	rtnne dvc_op_mouse,pdata
+	copy temp,pdata
+	beq HID_CONTROL_P_VIRTUALCABLEUNPLUG,eeprom_erase_reconn_info
+	rtn
+hid_rx_process_suspend:
+	rtn
+
+hid_rx_process_set_report:
+	arg 0x01,rega
+	call hid_malloc_tx_buff
+	fetch 2,mem_hid_ctrl_remote_cid
+	istore 2,contw
+	setarg 0x00
+	istore 1,contw
+	rtn
+
+hid_rx_process_handshake:
+	arg 1,rega//payload length
+	call hid_malloc_tx_buff
+	fetch 2,mem_hid_ctrl_remote_cid
+	istore 2,contw
+	setarg 0
+	istore 1,contw
+	jam 1,mem_ui_data_txbuff_length
+	fetch 1,mem_hid_control_state
+	set1 l2cap_channel_hid_handshake_done
+	store 1,mem_hid_control_state
+hid_handshake_event:
+	jam BT_EVT_HID_HANDSHAKE,mem_fifo_temp
+	branch ui_ipc_send_event
+
+hid_rx_process_data:
+	ifetch 1,contr
+	beq HID_REPORT_ID_KB,hid_rx_process_data_hid_kb
+	rtn
+
+hid_rx_process_data_hid_kb:
+	copy contr,rega
+	fetch 1,mem_device_option
+	rtnne dvc_op_kb,pdata
+	copy rega,contr
+	branch kb_process_kb_report
+	
+hid_malloc_tx_buff:
+	call l2cap_malloc
+	copy rega,temp
+	storet 1,mem_ui_data_txbuff_length
+	copy pdata,contw
+	copy rega,pdata
+	istore 2,contw //hid payload length
+	rtn
+
Index: btkb/program/ir.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/ir.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/ir.prog	(working copy)
@@ -0,0 +1,293 @@
+
+ifdef COMPILE_IR
+le_ir_init:
+	setarg le_ir
+	store 2,mem_cb_le_process	
+	setarg le_ir_wcb
+	store 2,mem_cb_att_write
+	call eeprom_load_reconn_info
+	call le_init_att
+	hjam 158,core_pwm_ncnt0
+	hjam 8,core_gpio_sel1
+	hjam 5,core_gpio_out1
+	setarg -1
+	set0 1,pdata
+	set0 21,pdata
+	hstore 4,core_gpio_oe0
+	hjam 2,core_gpio_pu0
+	rtn wake
+	jam 1,mem_le_adv_enable
+	rtn
+
+
+le_ir_wcb:
+	ifetch 1,rega
+	store 1,mem_ir_cmd
+	beq ircmd_write_pulse,le_ir_write_pulse
+	beq ircmd_write_seq,le_ir_write_seq
+	beq ircmd_write_next,le_ir_write_next
+	beq ircmd_screen_on,le_ir_screen_on
+	beq ircmd_screen_off,le_ir_screen_off
+	rtnne ircmd_play
+	ifetch 1,contr
+	store 1,mem_ir_play_count
+	rtn
+
+le_ir_write_pulse:
+	arg mem_ir_pulse_zero,contw
+	branch le_ir_write
+	
+le_ir_write_seq:
+	arg mem_ir_sequence_len,contw
+	branch le_ir_write
+
+le_ir_write_next:
+	fetch 2,mem_ir_ptr
+	iforce contw
+
+le_ir_write:
+	arg 19,loopcnt
+	call memcpy
+	deposit contw
+	store 2,mem_ir_ptr
+	jam 0,mem_ir_cmd
+	rtn
+
+
+	
+le_ir:
+	fetch 1,mem_ir_cmd
+	beq ircmd_record,le_ir_start_record
+	beq ircmd_play,le_ir_play
+	beq ircmd_report_pulse,le_ir_report
+	beq ircmd_report_seq,le_ir_report
+	beq ircmd_report_raw,le_ir_report
+	beq ircmd_test_play,le_ir_play
+	beq ircmd_test_rec,le_ir_rec
+	rtn
+
+le_ir_screen_on:
+	jam 0,mem_lpm_mult
+	jam 0,mem_ir_cmd
+	rtn
+le_ir_screen_off:
+	jam 30,mem_lpm_mult
+	jam 0,mem_ir_cmd
+	rtn
+
+	
+
+le_ir_rec:
+	jam 0,mem_ir_cmd
+	arg 0xfffff,stop_watch
+	call ir_record
+	rtn
+	
+le_ir_next_anchor:
+	fetcht 2,mem_le_tsniff
+	iadd temp,pdata
+	store 4,mem_le_anchor
+le_ir_start_record:
+	fetch 4,mem_le_anchor
+	isub clke_bt,pdata
+	nbranch le_ir_next_anchor,positive
+	rshift pdata,stop_watch
+	call ir_record
+	rtn blank
+	jam ircmd_report_raw,mem_ir_cmd
+	arg mem_ir_record,temp
+	storet 2,mem_ir_ptr
+	
+le_ir_report:
+	call le_xtype_fifo_is_full
+	nrtn blank
+	jam notify_handle,mem_le_notify_handle
+	jam ATTOP_HANDLE_VALUE_NOTIFICATION,mem_fifo_temp
+	call le_xtype_fifo_in
+	fetch 2,mem_le_notify_attr_start
+	iforce contw
+	fetch 2,mem_ir_ptr
+	iforce contr
+	arg 20,loopcnt
+	call memcpy
+	deposit contr
+	store 2,mem_ir_ptr
+	fetch 2,mem_ir_report_len
+	increase -20,pdata
+	store 2,mem_ir_report_len
+	rtn positive
+	jam 0,mem_ir_cmd
+	rtn
+
+
+le_ir_play:
+	fetch 1,mem_ir_play_count
+	call ir_play
+	jam 0,mem_ir_cmd
+	rtn
+
+
+ir_record:
+	call ir_receive
+	setarg mem_ir_record
+	isub contw,pdata
+	sub pdata,0,pdata
+	store 2,mem_ir_report_len
+	rtn
+
+
+	/* stop_watch is sync timeout */
+ir_receive:
+	disable swfine
+	arg mem_ir_record,contw
+ir_receive_waitsync:
+	rtn timeout
+	hfetch 1,core_gpio_in+2
+	bbit0 5,ir_receive_waitsync
+	copy clkn,temp
+	arg 0x80,loopcnt
+	call memset0
+	arg mem_ir_record,contw
+	arg 0x0,regc
+ir_receive_loop:
+	arg 180,stop_watch
+ir_receive_waitedge:
+	rtn timeout
+	hfetch 1,core_gpio_in+2
+	ixor regc,pdata
+	bbit1 5,ir_receive_waitedge
+	copy clkn,pdata
+	iforce alarm
+	call clk_diff_rt
+	sub pdata,0xff,null
+	branch ir_receive_waitedge,positive
+	isolate0 5,regc
+	setflag true,23,pdata
+	istore 3,contw
+	rshift8 contw,pdata
+	rtneq mem_ir_record_max
+	copy alarm,temp
+	xor_into 0x20,regc	
+	branch ir_receive_loop
+
+
+	/* return 0xff if all sequence is sent */
+ir_get_next_seq:
+	branch ir_get_next_seq_saved,user
+	branch ir_get_next_encoded,user2
+ir_get_next_seq_fetch:
+	arg mem_ir_sequence,temp
+	fetch 1,mem_ir_sequence_len
+	iadd temp,pdata
+	isub rega,null
+	branch ir_get_next_seq_exit,zero
+	ifetch 1,rega
+	copy contr,rega
+	bbit0 7,ir_get_next_cont
+	enable user2
+	and pdata,0x7f,regb
+	lshift3 rega,rega
+	branch ir_get_next_encoded
+ir_get_next_cont:
+	rshift4 pdata,debug
+	and_into 0xf,pdata
+	isub debug,null
+	rtn zero
+	enable user
+	rtn
+ir_get_next_seq_saved:
+	deposit debug
+	disable user
+	rtn
+ir_get_next_encoded:
+	deposit regb
+	branch ir_get_next_encoded_end,blank
+	and rega,0x7,queue
+	rshift3 rega,contr
+	ifetch 1,contr
+	increase 1,rega
+	increase -1,regb
+	qisolate0 pdata
+	fetch 1,mem_ir_pulse_zero
+	branch ir_get_next_cont,true
+	fetch 1,mem_ir_pulse_one
+	branch ir_get_next_cont
+ir_get_next_encoded_end:
+	disable user2
+	increase 7,rega
+	rshift3 rega,rega
+	branch ir_get_next_seq_fetch
+ir_get_next_seq_exit:
+	setarg 0xff
+	rtn
+	
+	/* pdata=index of pulse */
+ir_get_pulse:
+	lshift pdata,contr
+	iadd contr,pdata
+	arg mem_ir_pulses,contr
+	iadd contr,contr
+	ifetch 3,contr
+	rtn
+	
+	/* pdata=number of seqs to send */
+ir_play:
+	enable swfine
+	iforce loopcnt
+ir_play_nloop:
+	disable user
+	disable user2
+	arg mem_ir_sequence,rega
+ir_play_loop:
+	call ir_get_next_seq
+	beq 0xff,ir_play_end
+	call ir_get_pulse
+	bbit0 23,ir_play_silence
+	set0 23,pdata
+	hjam 158,core_pwm_pcnt0
+ir_play_silence:
+	iforce stop_watch
+	until null,timeout
+	hjam 0,core_pwm_pcnt0
+	branch ir_play_loop
+ir_play_end:
+	loop ir_play_nloop
+	rtn
+
+
+
+else
+le_ir_init:
+le_ir_wcb:
+le_ir_write_pulse:
+le_ir_write_seq:
+le_ir_write_next:
+le_ir_write:
+le_ir:
+le_ir_screen_on:
+le_ir_screen_off:
+le_ir_rec:
+le_ir_next_anchor:
+le_ir_start_record:
+le_ir_report:
+le_ir_play:
+ir_record:
+ir_receive:
+ir_receive_waitsync:
+ir_receive_loop:
+ir_receive_waitedge:
+ir_get_next_seq:
+ir_get_next_seq_fetch:
+ir_get_next_cont:
+ir_get_next_seq_saved:
+ir_get_next_encoded:
+ir_get_next_encoded_end:
+ir_get_next_seq_exit:
+ir_get_pulse:
+ir_play:
+ir_play_nloop:
+ir_play_loop:
+ir_play_silence:
+ir_play_end:
+	branch assert
+endif
Index: btkb/program/keyboard.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/keyboard.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/keyboard.prog	(working copy)
@@ -0,0 +1,591 @@
+
+ifdef COMPILE_KEYBOARD
+
+le_kb_init:
+	call kb_init_common
+	setarg kb_process_idle
+	store 2,mem_cb_idle_process
+	setarg kb_send_process
+	store 2,mem_cb_bt_process
+	setarg kb_process_bb_event
+	store 2,mem_cb_bb_event_process
+	setarg kb_process_lpm_before
+	store 2,mem_cb_before_lpm
+	setarg kb_discovery_timeout_sleep
+	store 2,mem_cb_discovry_timeout
+    	setarg kb_before_hibernate
+	store 2,mem_cb_before_hibernate
+	setarg kb_wakeup_check
+	store 2,mem_cb_check_wakelock
+	rtn wake	
+	
+	fetch 2,mem_ui_state_map
+	bbit1 UI_STATE_BTN_DOWN,app_bt_start_discovery_short
+	call app_check_reconn_target
+	branch kb_start_discovery,blank
+	call app_bt_stop_discovery
+	branch app_bt_start_reconnect
+
+	
+kb_init:	
+	call kb_init_common
+	setarg kb_process_idle
+	store 2,mem_cb_idle_process
+	setarg kb_send_process
+	store 2,mem_cb_bt_process
+	setarg kb_process_bb_event
+	store 2,mem_cb_bb_event_process
+	setarg kb_process_lpm_before
+	store 2,mem_cb_before_lpm
+	setarg kb_discovery_timeout_sleep
+	store 2,mem_cb_discovry_timeout
+    	setarg kb_before_hibernate
+	store 2,mem_cb_before_hibernate
+	setarg kb_wakeup_check
+	store 2,mem_cb_check_wakelock
+	rtn wake	
+		
+	jam 0,mem_sp_flag
+	jam 0,mem_master_sp_flag
+
+	fetch 2,mem_ui_state_map
+	bbit1 UI_STATE_BTN_DOWN,app_bt_start_discovery_short
+	call app_check_reconn_target
+	branch kb_start_discovery,blank
+	call app_bt_stop_discovery
+	branch app_bt_start_reconnect
+
+	
+	
+kb_init_common:
+	set1 mark_ext_patch,mark
+	bpatch patch36_6,mem_patch36
+//	call kb_init_before_hibernate
+	fetch 1,0x8140
+	branch assert,blank
+	hjam 0,core_gpio_oe0
+	hjam 0xff,core_gpio_pu0
+
+	hjam 0xff,core_gpio_oe1
+	hjam 0xff,core_gpio_oe2
+	hfetch 1,core_gpio_oe3
+	or_into 0x0f,pdata
+	hstore 1,core_gpio_oe3
+
+	hjam 0x00,core_gpio_sel
+	hjam 0x00,core_gpio_sel1
+	hjam 0xff,core_gpio_key0
+	hjam 0xFf,core_gpio_key1
+	hfetch 1,core_gpio_key2
+	or_into 0x03,pdata
+	hstore 1,core_gpio_key2
+	hjam 0x00,core_kscn_rowmask
+	setarg KB_KSCAN_COL_1
+	lshift3 pdata,pdata
+	add pdata,KB_KSCAN_ROW_1,pdata
+	hstore 1,core_kscn_rctc
+
+	hfetch 1,core_config
+	set1 2,pdata //set keyscan clk source
+	hstore 1,core_config
+	hfetch 1, core_clkoff+1
+	set0 1,pdata
+	hstore 1,core_clkoff+1
+	hjam 0xd,core_kscn_ksctrl
+	hjam 0xd3,core_kscn_m_debounce
+	hjam 0,core_kscn_scancycle_timer_l
+	hjam 0x31,core_kscn_scancycle_timer_h
+	call lpm_disable_exen_output
+	fetcht 1,mem_led_cap_gpio
+ 	call gpio_config_output
+	fetcht 1,mem_led_num_gpio
+ 	call gpio_config_output
+	fetcht 1,mem_led_scl_gpio
+ 	call gpio_config_output
+	rtn
+
+kb_process_kb_report:
+	set1 mark_ext_patch,mark
+	bpatch patch36_7,mem_patch36
+	ifetch 1,contr
+	copy pdata,rega
+	fetcht 1,mem_led_num_gpio
+	isolate1 KB_NUM_LOCK_SELECTED,rega
+	call gpio_out_flag
+	fetcht 1,mem_led_cap_gpio
+	isolate1 KB_CAPS_LOCK_SELECTED,rega
+	call gpio_out_flag
+	fetcht 1,mem_led_scl_gpio
+	isolate1 KB_SCROLL_LOCK_SELECTED ,rega
+	call gpio_out_flag
+	jam 1,mem_kb_rcv_led_data
+	rtn
+
+
+kb_send_process:
+//	call kb_wakeup_check
+	call kb_kscan_check_if_empty
+	nrtn user
+	nrtn user2
+//	call app_lpm_wake_auto_lock
+	fetch 1,mem_pincode_state
+	beq pincode_state_wait_pincode,kb_pincode
+	fetch 1,mem_hid_interrupt_state
+	rtnne 0x3f
+
+	arg 10,rega
+	call hid_malloc_tx_buff
+	fetch 2,mem_hid_int_remote_cid
+	istore 2,contw
+	setarg 0x01a1
+	istore 2,contw
+	fetch 8,mem_kb_state
+	istore 8,contw
+	rtn
+	
+kb_pincode:
+	fetcht 1,mem_pin_length
+	setarg mem_pin
+	iadd temp,contw
+	fetch 1,mem_kb_report_data
+	branch kb_pincode_rtn,blank
+	beq KB_KCODE_BKSP,kb_pincode_bksp
+	bne KB_KCODE_ENTER,kb_pincode_data
+	storet 1,mem_pin_length
+	branch app_bt_set_pincode
+	
+kb_pincode_rtn:
+	storet 1,mem_pin_length
+	rtn
+kb_pincode_bksp:
+	fetch 1,mem_pin_length
+	rtn blank
+	increase -1,pdata
+	store 1,mem_pin_length
+	arg mem_pin,contw
+	iadd contw,contw
+	setarg 0
+	istore 1,contw
+	enable user2
+	branch kb_send_pin
+kb_pincode_data:
+	sub pdata,KB_KCODE_1_M1,null
+	rtn positive
+	arg 0x30,temp
+	sub pdata,KB_KCODE_0,null
+	nrtn positive
+	branch kb_pincode_0,zero
+	arg KB_KCODE_1_M1,temp
+	isub temp,temp
+	or_into 0x30,temp
+kb_pincode_0:
+	istoret 1,contw
+	fetch 1,mem_pin_length
+	increase 1,pdata
+	store 1,mem_pin_length
+	disable user2
+	branch kb_send_pin
+
+kb_send_pin:
+	fetch 2,mem_hid_int_remote_cid
+	rtn blank
+	arg 3,rega
+	call hid_malloc_tx_buff
+	fetch 2,mem_hid_int_remote_cid
+	istore 2,contw
+	setarg 0xffa1
+	istore 2,contw
+	setarg 0
+	setflag user2,0,pdata
+	istore 1,contw
+	rtn
+
+
+	
+kb_kscan_check_if_empty:
+	disable user
+	disable user2
+	hfetch 1,core_kscn_kstat
+	rtnbit1 KB_KSCAN_STAT_EMPTY
+
+kb_kscan_check_ghost:
+	hfetch 1,core_kscn_event_num
+	bbit1 KB_KSCAN_KEY_EVENT_STAT,kb_kscan_process_event
+	hfetch 1,core_kscn_kstat
+	bbit0 KB_KSCAN_STAT_GHOST,kb_kscan_process_event
+	hfetch 1,core_kscn_event
+	branch kb_kscan_check_if_empty
+		
+kb_kscan_process_event:
+	enable user
+	enable user2
+	hfetch 1,core_kscn_event_num
+	isolate0 kb_KSCAN_KEY_EVENT_STAT,pdata
+	hfetch 1,core_kscn_event
+	arg mem_kb_map,contr
+	iadd contr,contr
+	ifetch 1,contr
+	bbit1 7,kb_kscan_read_statekey
+	nbranch kb_kscan_release_a_key_data,true	
+	disable user2
+	iforce temp
+	fetch 1,mem_kb_keys
+	sub pdata,4,null
+	nrtn positive
+	copy pdata,rega
+	arg 3,loopcnt
+	arg mem_kb_report_data,contr
+kb_kscan_check_report_data:
+	ifetch 1,contr
+	isub temp,null
+	branch kb_kscan_check_if_empty,zero
+	loop kb_kscan_check_report_data
+kb_kscan_store_a_key_data:
+	copy rega,pdata
+	arg mem_kb_report_data,contw
+	iadd contw,contw
+	istoret 1,contw
+	increase 1,pdata
+	store 1,mem_kb_keys
+ 	hfetch 1,core_kscn_event_num
+	rshift3 pdata,pdata
+	nbranch kb_kscan_check_nextevent, blank
+	branch kb_kscan_prepare_send
+
+kb_kscan_check_nextevent:
+	increase -1,pdata
+	branch kb_kscan_prepare_send,zero
+	hfetch 1,core_kscn_event_num
+	and_into 0x01,pdata
+	beq KB_KSCAN_KEY_PRESS,kb_kscan_check_if_empty                 // key pressed
+	beq KB_KSCAN_KEY_RELEASE,kb_kscan_prepare_send              // key release
+	rtn
+kb_kscan_prepare_send:	
+	enable user2
+	rtn
+	
+kb_kscan_release_a_key_data:
+	and pdata,0xff,temp
+	fetch 1,mem_kb_keys
+	rtn blank
+	iforce loopcnt
+	arg mem_kb_report_data,contr
+kb_kscan_find_same_key_data:
+	ifetch 1,contr
+	isub temp,null
+	branch kb_kscan_release_foundkey,zero
+	loop kb_kscan_find_same_key_data
+	rtn
+kb_kscan_release_foundkey:
+	add contr,-1,contw
+	call memcpy
+	fetch 1,mem_kb_keys
+	increase -1,pdata
+	store 1,mem_kb_keys
+	hfetch 1,core_kscn_event_num
+	rshift3 pdata,pdata
+	nbranch kb_kscan_check_nextevent2, blank
+	rtn
+
+kb_kscan_check_nextevent2:
+ 	hfetch 1,core_kscn_event_num
+	and_into 0x01,pdata
+	beq KB_KSCAN_KEY_PRESS,kb_kscan_prepare_send
+	beq KB_KSCAN_KEY_RELEASE,kb_kscan_check_if_empty
+	rtn
+	
+kb_kscan_read_statekey:
+	and pdata,7,queue
+	fetch 1,mem_kb_state
+	qsetflag true,pdata
+	store 1,mem_kb_state
+	rtn
+
+kb_clear_keys:
+	setarg 0
+	store 8,mem_kb_state
+	store 1,mem_kb_keys
+	rtn
+	
+kb_clean_kscan_fifo:
+	hfetch 1,core_kscn_event_num
+	hfetch 1,core_kscn_event
+	hfetch 1,core_kscn_kstat
+	bbit0 KB_KSCAN_STAT_EMPTY,kb_clean_kscan_fifo
+	setarg 0xff
+	enable user
+	rtn
+	
+le_keyboard:
+	fetcht 2,mem_le_notify_handle
+	call le_att_check_notification_enable
+	rtnbit0 0
+	fetch 1,mem_le_switch_send_data
+	rtnbit0 0
+	call le_xtype_fifo_is_full
+	nrtn blank
+	call kb_kscan_check_if_empty
+	nrtn user
+	nrtn user2
+le_slave_keyboard_send_data:
+	call app_lpm_wake_auto_lock
+	jam 2,mem_lpm_mult
+	fetcht 2,mem_le_notify_handle
+	call le_att_get_handle_ptr
+	add contr,1,contw
+	fetch 8,mem_kb_state
+	istore 8,contw
+	jam ATTOP_HANDLE_VALUE_NOTIFICATION,mem_fifo_temp
+	call le_xtype_fifo_in
+	fetch 1,mem_le_op
+	bbit1 op_disconn,loop
+	rtn
+le_keyboard_process_bb_event:
+	copy regc,pdata
+	beq BT_EVT_BUTTON_LONG_PRESSED,le_keyboard_bb_event_discovery_btn
+	//beq BT_EVT_100MS_TIMER,le_keyboard_bb_event_hud_ms
+	beq BT_EVT_LE_CONNECTED,le_kb_connected
+	beq BT_EVT_LE_WRITE_REQUEST,le_kb_bb_event_write_request
+	beq BT_EVT_LE_ENC_INFO,le_kb_bb_event_enc_info
+	beq BT_EVT_REMOTE_UNSNIFF,app_start_auto_sniff
+	rtn
+le_kb_bb_event_enc_info:
+le_kb_bb_event_write_request:
+	call app_lpm_mult_enable
+	branch app_ble_start_write
+le_kb_connected:
+	call kb_clean_kscan_fifo
+	branch kb_clear_keys
+
+le_keyboard_bb_event_discovery_btn:
+	call le_clean_att_list_handle_enable
+	call app_ble_disconnect
+	call app_ble_start_adv
+	branch app_led_start_blink
+
+le_keyboard_bb_event_hud_ms:
+	fetch 1,mem_le_led_on_time
+	rtn blank
+	increase -1,pdata
+	store 1,mem_le_led_on_time
+	nrtn blank
+	fetch 1,mem_le_adv_type
+	rtn blank
+	branch app_led_off
+
+
+kb_process_idle:
+	branch kb_pairing_button_check
+
+
+kb_wakeup_check:	
+	hfetch 3,core_gpio_in
+	copy pdata,regb
+	hfetch 1,core_gpio_in+3
+	and_into 0x0f,pdata
+	lshift16 pdata,pdata
+	lshift8 pdata,pdata
+	ior regb,pdata
+	fetcht 4,mem_kb_fast_wake_last
+	isub temp,pdata
+	rtn blank
+	arg 0xbb,regb
+ 	branch app_lpm_wake_auto_lock
+
+
+kb_pairing_button_check:
+	fetch 1,mem_scan_mode// rtn when scan_mode =03 
+	nrtn blank
+	fetch 1,mem_app_handshake_flag//rtn when handshake success 
+	nrtn blank
+	fetch 1,mem_ui_button_timer// rtn when timer >3s
+	rtn blank
+	fetch 1,mem_ui_button_last_state//rtn when pairing button press
+	nrtn blank
+	branch app_enter_hibernate
+	
+kb_process_bb_event:
+	copy regc,pdata
+	beq BT_EVT_HID_CONNECTED,kb_hid_connected
+	beq BT_EVT_PINCODE_REQ,kb_process_pincode
+	beq BT_EVT_HID_CONNECTED,kb_bt_hid_handshake
+	beq BT_EVT_BUTTON_LONG_PRESSED,kb_bb_event_discovery_btn
+	beq BT_EVT_REMOTE_UNSNIFF,app_start_auto_sniff
+	beq BT_EVT_BB_CONNECTED,kb_stop_discovery
+	beq BT_EVT_BB_DISCONNECTED,kb_bb_disconnected
+//	beq BT_EVT_100MS_TIMER,kb_bb_event_100ms
+	beq BT_EVT_RECONN_FAILED,kb_bb_event_reconn_failed
+	beq BT_EVT_RECONN_PAGE_TIMEOUT,kb_bb_event_reconn_failed
+	and pdata,0x0f,temp
+	and_into BT_EVT_TIMER_MASK,pdata
+	beq BT_EVT_TIMER_INIT,kb_bb_event_timer
+	rtn
+
+kb_bb_event_timer:
+	set1 mark_ext_patch,mark
+	bpatch patch37_0,mem_patch37
+	storet 1,mem_app_evt_timer_count
+kb_bb_event_100ms_loop:
+	fetch 1,mem_app_evt_timer_count
+	rtn blank
+	increase -1,pdata
+	store 1,mem_app_evt_timer_count
+//	call app_lpm_wake_auto_lock_timer
+	call kb_check_hid_handshake_timer	
+	branch kb_bb_event_100ms_loop
+
+kb_bb_event_reconn_failed:
+	fetch 2,mem_ui_state_map
+	bbit1 UI_STATE_BTN_DOWN,kb_start_discovery
+	branch app_bb_hibernate
+
+
+kb_bb_disconnected:
+	set1 mark_ext_patch,mark
+	bpatch patch37_1,mem_patch37
+	call kb_bb_discon_clear_stack
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason
+ifdef DEBUG_LIGHT_STATE
+	store 1,0x4800
+endif
+//	bbit1 APP_DISC_BLE,mouse4_0_event_bb_disconn
+	bbit1 APP_DISC_BY_BUTTON,app_disconn_reason_clear
+	bbit1 APP_DISC_AFTER_PAIRING,kb_event_light_state_pairing
+	bbit1 APP_DISC_AFTER_RECONN,kb_event_light_state_reconn
+	branch kb_start_discovery
+kb_bb_discon_clear_stack:
+	jam 0,mem_link_key_exists
+	jam 0,mem_ltk_exists
+	rtn
+
+kb_event_light_state_pairing:
+	bbit1 APP_DISC_AFTER_HANDSHAKE,app_bb_hibernate
+	bbit1 APP_DISC_AFTER_SNIFF,app_bb_hibernate
+	branch kb_start_discovery
+kb_event_light_state_reconn:
+	fetch 2,mem_ui_state_map
+	bbit1 UI_STATE_BTN_DOWN,kb_start_discovery
+	branch app_bb_hibernate
+
+
+	
+kb_check_hid_handshake_timer:
+	fetch 1,mem_hid_handshake_timer_count
+	rtn blank
+	increase -1,pdata
+	store 1,mem_hid_handshake_timer_count
+	nrtn blank
+	branch kb_bt_hid_handshake
+
+
+kb_bb_event_discovery_btn:
+	call kb_3_0_bb_event_discovery_btn
+	branch kb_start_discovery
+
+kb_3_0_bb_event_discovery_btn:
+	set1 mark_ext_patch,mark
+	bpatch patch37_2,mem_patch37
+	fetch 2,mem_ui_state_map
+	isolate1 UI_STATE_BT_RECONNECT,pdata
+	call app_bt_reconnect_cancel,true
+	fetch 2,mem_discovery_timeout
+	store 2,mem_discovery_timeout_timer_count	
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	set1 APP_DISC_BY_BUTTON,pdata
+	store APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	fetch 2,mem_ui_state_map
+	bbit1 UI_STATE_BT_CONNECTED,app_bt_disconnect
+	rtn
+
+	
+kb_stop_discovery:
+	call app_bt_stop_discovery
+	branch app_led_stop_blink
+
+kb_start_discovery:
+	call app_bt_start_discovery
+	branch app_led_start_blink
+	
+kb_discovery_timeout_sleep:	
+	branch app_enter_hibernate
+	
+kb_process_pincode:
+	jam 0,mem_pin_length
+	rtn
+
+
+kb_before_hibernate:
+
+kb_process_lpm_before:
+	hjam 0x00,core_gpio_key0
+	hjam 0x00,core_gpio_key1
+	hfetch 1,core_gpio_key2
+	and_into 0xf0,pdata
+	hstore 1,core_gpio_key2
+	setarg 0x00
+	store 4,mem_gpio_wakeup_high
+	setarg 0xff
+	fetcht 1,mem_ui_button_gpio
+	copy temp,queue
+	qset1 pdata
+	store 4,mem_gpio_wakeup_low
+	rtn
+
+kb_hid_connected:
+ 	setarg HID_HANDSHAKE_TIMEOUT
+	store 1,mem_hid_handshake_timer_count
+	call kb_clean_kscan_fifo
+	//fetch 1,core_kscn_ksctrl
+	//set1 5,pdata
+	//store 1,core_kscn_ksctrl
+	branch kb_clear_keys
+kb_bt_hid_handshake:
+	set1 mark_ext_patch,mark
+	bpatch patch37_3,mem_patch37
+	jam APP_HANDSHAKE_DONE,mem_app_handshake_flag
+	call app_lpm_mult_enable
+	call app_bt_store_reconn_info
+//	jam BT_KB_MODE_STATE,mem_mouse_mode_state
+	setarg 0
+	store 2,mem_discovery_timeout_timer_count
+	store 1,mem_hid_handshake_timer_count
+	branch app_bt_enter_sniff
+
+
+	
+else
+kb_init:
+kb_process_kb_report:
+kb_send_process:
+kb_pincode:
+kb_pincode_rtn:
+kb_pincode_bksp:
+kb_pincode_data:
+kb_pincode_0:
+kb_send_pin:
+kb_check_num:
+kb_read_a_key:
+kb_read_a_key2:
+kb_read_a_key3:
+kb_read_release:
+kb_read_loop:
+kb_read_foundkey:
+kb_read_statekey:
+kb_clean_kscan_fifo:
+le_keyboard:
+le_slave_keyboard_send_data:
+kb_process_idle:
+kb_process_bb_event:
+kb_bb_event_discovery_off:
+kb_wakeup_int:
+kb_wakeup_check:
+kb_discovery_timeout_sleep:
+le_keyboard_process_bb_event:
+le_kb_connected:
+le_keyboard_bb_event_discovery_btn:
+le_keyboard_bb_event_hud_ms:
+le_kb_init:
+le_kb_bb_event_write_request:
+le_kb_bb_event_enc_info:
+	branch assert
+endif
Index: btkb/program/l2cap.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/l2cap.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/l2cap.prog	(working copy)
@@ -0,0 +1,1878 @@
+/************************************/
+/*initialize L2CAP related variables*/
+/************************************/
+l2cap_init:
+	branch l2cap_init_wake,wake
+l2cap_init_work:
+	setarg mem_l2cap_xmem_end
+	arg mem_l2cap_xmem_start,contw
+	isub contw,loopcnt
+	call clear_mem
+l2cap_init_wake:	
+	set1 mark_ext_patch,mark
+	bpatch patch22_6,mem_patch22
+	setarg mem_sdp_mem_end
+	arg mem_sdp_mem_start,contw
+	isub contw,loopcnt
+	call clear_mem
+	setarg mem_l2cap_mem_end
+	arg mem_l2cap_mem_start,contw
+	isub contw,loopcnt
+	call clear_mem
+	branch l2cap_lpm_load_txbuf
+	
+process_rx_l2cap_pkt:
+	set1 mark_ext_patch,mark
+	bpatch patch22_7,mem_patch22
+	copy contr,temp
+	//call l2cap_malloc_is_fifo_full
+	//nrtn blank
+	copy temp,contr
+	ifetch 2,contr
+	store 2,mem_l2cap_rx_pkt_length
+	ifetch 2,contr
+	store 2,mem_l2cap_rx_cid
+	deposit contr
+	store 2,mem_l2cap_payload_ptr
+	fetch 1,memui_reconnect_mode
+	beq NO_RECONNECTION,l2cap_rx_multiplexing
+	branch ml2cap_rx_multiplexing
+
+l2cap_rx_multiplexing:
+	set1 mark_ext_patch,mark
+	bpatch patch23_0,mem_patch23
+	fetch 2, mem_l2cap_rx_pkt_length
+	branch l2cap_rx_reset_state,blank
+	fetch 1,mem_l2cap_rx_cid
+	beq L2CAP_signal_channel,l2cap_call_proc_signal
+l2cap_rx_multiplexing0:
+	beq L2CAP_SDP_channel,l2cap_call_proc_sdp
+	beq L2CAP_RFCOMM_channel,l2cap_call_proc_rfcomm
+	beq L2CAP_HID_Control_channel,l2cap_call_proc_hid
+	beq L2CAP_HID_Interrupt_channel,l2cap_call_proc_hid
+	branch l2cap_rx_reset_state
+
+l2cap_call_proc_signal:
+	call l2cap_malloc_is_fifo_full
+	nrtn blank
+	jam 0,mem_l2cap_pending_item
+l2cap_call_proc_signal0:
+	call l2cap_malloc_signal_channel
+	call l2cap_process_signal_pkt
+	fetcht 2,mem_l2cap_signal_tx_length
+	branch l2cap_call_proc_no_reply,blank
+	call l2cap_get_signal_tx_buff
+	fetch 2,mem_l2cap_signal_tx_length
+	istore 2,contw
+	force L2CAP_signal_channel,pdata
+	istore 2,contw
+	branch l2cap_rx_reset_state
+	
+l2cap_call_proc_sigal_pending:
+	fetch 1,mem_device_option
+	rtneq dvc_op_hci
+	fetch 1,mem_l2cap_pending_item
+	rtn blank
+	copy pdata,rega
+	fetch 4,mem_l2cap_sdpres_delay_time
+	arg 0x100,temp
+	iadd temp,temp
+	copy clkn_bt,pdata
+	isub temp,null
+	nrtn positive
+	jam 0,mem_l2cap_pending_item
+	copy rega,pdata
+	beq L2CAP_SDP_channel,l2cap_sdp_conn_succ
+	branch assert
+l2cap_sdp_conn_succ:
+	call l2cap_malloc_signal_channel
+	call restore_l2cap_req_param
+	call l2cap_get_signal_tx_payload
+	call save_cont_pointers
+	call send_connection_sdp_res
+	call l2cap_get_signal_tx_buff
+	//fetch 2,mem_l2cap_signal_tx_length
+	setarg 0x000c
+	istore 2,contw
+	force L2CAP_signal_channel,pdata
+	istore 2,contw
+	branch l2cap_rx_reset_state
+	
+l2cap_call_proc_sdp:
+	call l2cap_malloc_is_fifo_empty
+	nrtn blank// not process this packet until fifo empty
+	call l2cap_malloc_sdp_channel
+	call sdp_process
+	call l2cap_get_sdp_tx_buff
+	fetch 2,mem_sdp_tx_pkt_length
+	branch l2cap_call_proc_no_reply,blank
+	istore 2,contw
+	fetch 2,mem_sdp_remote_cid
+	istore 2,contw
+	branch l2cap_rx_reset_state
+
+l2cap_call_proc_hid:
+	call hid_rx_process
+	branch l2cap_rx_reset_state
+
+l2cap_call_proc_rfcomm:
+	set1 mark_ext_patch,mark
+	bpatch patch23_1,mem_patch23
+	jam RFCOMM_MALLOC_SUCCEED,mem_rfcomm_malloc_fail_flag
+	call rfcomm_rx_process
+	fetch 1,mem_rfcomm_malloc_fail_flag
+	rtneq RFCOMM_MALLOC_FAIL
+	branch l2cap_rx_reset_state
+l2cap_call_proc_no_reply:
+	call l2cap_malloc_discard
+	//fall through
+l2cap_rx_reset_state:
+	setarg 0
+	store 2,mem_l2cap_rx_pkt_length
+	store 2,mem_l2cap_rx_cid
+	jam L2CAP_RX_DONE,mem_l2cap_rx_done
+	rtn
+/* To process one L2CAP signalling pkt consisting of 1 or more signalling commands.	*/
+l2cap_process_signal_pkt:
+	set1 mark_ext_patch,mark
+	bpatch patch23_2,mem_patch23
+	call l2cap_get_signal_tx_payload
+	force 0,regb
+	fetch 2,mem_l2cap_rx_pkt_length
+	copy pdata,regc
+	fetch 2,mem_l2cap_payload_ptr
+	iforce contr
+l2cap_process_signal_pkt_loop:
+	call l2cap_process_one_signal
+	deposit regc
+	increase -4,regc
+	increase -4,pdata
+	nbranch l2cap_process_signal_pkt_loop,blank
+	copy regb,pdata
+	store 2,mem_l2cap_signal_tx_length
+	rtn
+
+l2cap_process_one_signal:
+	set1 mark_ext_patch,mark
+	bpatch patch23_3,mem_patch23
+	ifetch 1,contr
+	beq signal_cmd_reject,l2cap_proc_signal_cmd_reject
+	beq signal_connect_req,l2cap_proc_signal_connect_req
+	beq signal_connect_rsp,l2cap_proc_signal_connect_rsp
+	beq signal_config_req,l2cap_proc_signal_config_req
+	beq signal_config_rsp,l2cap_proc_signal_config_rsp
+	beq signal_disconnect_req,l2cap_proc_signal_disconnect_req
+	beq signal_disconnect_rsp,l2cap_proc_signal_disconnect_rsp
+	beq signal_echo_req,l2cap_proc_signal_echo_req
+	beq signal_echo_rsp,l2cap_proc_signal_echo_rsp
+	beq signal_info_req,l2cap_proc_signal_info_req
+	beq signal_info_rsp,l2cap_proc_signal_info_rsp
+	call l2cap_reject_command
+l2cap_process_one_signal_rtn:
+	rtn
+
+l2cap_proc_signal_info_req:
+	ifetch 1,contr //IDs
+	copy pdata,queue
+	ifetch 2,contr //length
+	copy pdata,rega
+	copy regc,pdata
+	isub rega,regc
+	copy rega,pdata
+	iadd contr,contr
+	setarg 0x0b
+	istore 1,contw
+	copy queue,pdata
+	istore 1, contw
+	force 0x0008, pdata
+	istore 2, contw
+	force 0x0002, pdata
+	istore 2, contw
+	force 0x0000, pdata
+	istore 2, contw
+	force 0x0400,pdata
+	istore 2,contw
+	force 0x0000,pdata
+	istore 2,contw
+	force 12,pdata
+	iadd regb,regb
+	branch l2cap_process_one_signal_rtn
+
+ml2cap_proc_signal_info_req:
+	ifetch 1,contr //IDs
+	copy pdata,queue
+	ifetch 2,contr //length
+	copy pdata,rega
+	copy regc,pdata
+	isub rega,regc
+	copy rega,pdata
+	iadd contr,contr
+	call l2cap_get_signal_tx_payload
+	setarg 0x0b
+	istore 1,contw
+	copy queue,pdata
+	istore 1, contw
+	force 0x0008, pdata
+	istore 2, contw
+	force 0x0002, pdata
+	istore 2, contw
+	force 0x0000, pdata
+	istore 2, contw
+	force 0x0400,pdata
+	istore 2,contw
+	force 0x0000,pdata
+	istore 2,contw
+	force 12,pdata
+	iadd regb,regb
+	//call scheduler_start_upper_sm
+	branch l2cap_process_one_signal_rtn
+
+
+/*  Respond to the command reject signal sent from the remote BD.   */
+l2cap_proc_signal_cmd_reject:
+	ifetch 1,contr
+	copy pdata,queue
+	ifetch 2,contr
+	copy pdata,rega
+	iadd contr,contr
+	copy regc,pdata
+	isub rega,regc
+l2cap_proc_signal_cmd_reject_rtn:
+	branch l2cap_process_one_signal_rtn
+/* Respond to an L2CAP connection request from remote BD. (generate a connection_rsp)	*/
+l2cap_proc_signal_connect_req:
+	call save_cont_pointers
+	//fetch 6,mem_inquiry_bd_addr
+  	//store 6,mem_master_paged_bd_addr
+  	call load_cont_pointers
+	arg 0,debug
+	ifetch 1,contr
+	copy pdata,queue
+	ifetch 2,contr
+	copy pdata,rega
+	ifetch 2,contr
+	copy pdata,temp //PSM
+	ifetch 2,contr
+	copy pdata,timeup
+	copy temp,pdata
+	beq PSM_SDP,l2cap_proc_signal_connect_req_sdp
+	beq PSM_RFCOMM,l2cap_proc_signal_connect_req_rfcomm
+	beq PSM_HID_control,l2cap_proc_signal_connect_req_hid_ctrl
+	beq PSM_HID_interrupt,l2cap_proc_signal_connect_req_hid_int
+	call l2cap_reject_command
+	branch l2cap_proc_signal_connect_req_rtn
+
+l2cap_proc_signal_connect_req_sdp:
+	call save_cont_pointers
+	arg L2CAP_SDP_channel,temp
+	fetch 2,mem_sdp_remote_cid
+	nbranch already_connected,blank
+	copy timeup,pdata
+	store 2,mem_sdp_remote_cid
+	copy clkn_bt,pdata
+	store 4,mem_l2cap_sdpres_delay_time
+	call store_l2cap_req_param
+	branch  send_connection_pending
+
+store_l2cap_req_param:
+	storet 2,mem_psm
+	deposit timeup
+	store 2,mem_scid
+	deposit rega
+	store 2,mem_cmd_length
+	deposit regb
+	store 2,mem_tt2
+	deposit regc
+	store 2,mem_tt3
+	deposit queue
+	store 2,mem_id
+	rtn
+
+restore_l2cap_req_param:
+	fetcht 2,mem_psm
+	fetch 2,mem_scid
+	copy pdata,timeup
+	fetch 2,mem_cmd_length
+	copy pdata,rega
+	fetch 2,mem_tt2
+	copy pdata,regb
+	fetch 2,mem_tt3
+	copy pdata,regc
+	fetch 2,mem_id
+	copy pdata,queue
+	rtn
+
+l2cap_proc_signal_connect_req_rfcomm:
+	call save_cont_pointers
+	setarg L2CAP_RFCOMM_channel
+	arg L2CAP_RFCOMM_channel,temp
+	fetch 2,mem_RFCOMM_remote_CID
+	nbranch already_connected,blank
+	copy timeup,pdata
+	store 2,mem_RFCOMM_remote_CID
+	fetch 1,mem_rfcomm_state
+	set1 L2CAP_CHANNEL_STATE_CONN_REQ,pdata
+	set1 L2CAP_CHANNEL_STATE_CONN_RES,pdata
+	store 1,mem_rfcomm_state
+	branch send_connection_res
+l2cap_proc_signal_connect_req_hid_ctrl:
+	call save_cont_pointers
+	arg L2CAP_HID_Control_channel,temp
+	fetch 2,mem_hid_ctrl_remote_cid
+	nbranch already_connected,blank
+	copy timeup,pdata
+	store 2,mem_hid_ctrl_remote_cid
+	fetch 1,mem_hid_control_state
+	set1 L2CAP_CHANNEL_STATE_CONN_REQ,pdata
+	set1 L2CAP_CHANNEL_STATE_CONN_RES,pdata
+	store 1,mem_hid_control_state
+	branch send_connection_res
+l2cap_proc_signal_connect_req_hid_int:
+	call save_cont_pointers
+	deposit clke
+	arg L2CAP_HID_Interrupt_channel,temp
+	fetch 2,mem_hid_int_remote_cid
+	nbranch already_connected,blank
+	copy timeup,pdata
+	store 2,mem_hid_int_remote_cid
+	fetch 1,mem_hid_interrupt_state
+	set1 L2CAP_CHANNEL_STATE_CONN_REQ,pdata
+	set1 L2CAP_CHANNEL_STATE_CONN_RES,pdata
+	store 1,mem_hid_interrupt_state
+	branch send_connection_res
+
+send_connection_pending:
+	setarg L2CAP_connect_pending
+	store 2,memL2CAP_T1
+	jam L2CAP_SDP_channel,mem_l2cap_pending_item
+	branch send_connection_res0
+send_connection_sdp_res:
+	fetch 1,mem_sdp_state
+	set1 L2CAP_CHANNEL_STATE_CONN_REQ,pdata
+	set1 L2CAP_CHANNEL_STATE_CONN_RES,pdata
+	store 1,mem_sdp_state
+send_connection_res:
+	setarg L2CAP_connect_successful
+	store 2,memL2CAP_T1
+send_connection_res0:
+	set1 mark_ext_patch,mark
+	bpatch patch23_4,mem_patch23
+	call load_cont_pointers
+	setarg signal_connect_rsp
+	istore 1,contw
+	copy queue,pdata
+	istore 1,contw
+	setarg 0x0008
+	istore 2,contw
+	copy temp,pdata
+	istore 2,contw
+	copy timeup,pdata
+	istore 2,contw
+	fetch 2,memL2CAP_T1
+	beq L2CAP_connect_pending,connect_pending
+	isolate0 0,debug
+	branch connect_suc,true
+	setarg L2CAP_connect_refused_no_resources
+connect_suc:
+	istore 2,contw
+	force 0x0000,pdata
+	istore 2,contw
+	setarg 12
+	branch connect_req_update_byte_counts
+connect_pending:
+	istore 2,contw
+	force 0x0002,pdata
+	istore 2,contw
+	setarg 12
+	branch connect_req_update_byte_counts
+	
+already_connected:
+	set1 0,debug
+	branch send_connection_res
+connect_req_update_byte_counts:
+	iadd regb,regb
+	copy regc,pdata
+	isub rega,regc
+	branch l2cap_proc_signal_connect_req_rtn
+l2cap_proc_signal_connect_req_rtn:
+	branch l2cap_process_one_signal_rtn
+
+l2cap_proc_signal_connect_rsp:
+	ifetch 1,contr //identifier
+	copy pdata,queue
+	ifetch 2,contr //length
+	copy pdata,rega
+	copy regc,pdata
+	isub rega,regc
+	ifetch 2,contr //remote cid
+	copy pdata,timeup
+	ifetch 2,contr //local cid
+	copy pdata,temp
+	setarg L2CAP_SDP_channel
+	isub temp,null
+	branch l2cap_proc_signal_connect_rsp_sdp,zero
+	setarg L2CAP_RFCOMM_channel
+	isub temp,null
+	branch l2cap_proc_signal_connect_rsp_rfcomm,zero
+	setarg L2CAP_HID_Control_channel
+	isub temp,null
+	branch l2cap_proc_signal_connect_rsp_hid_ctrl,zero
+	setarg L2CAP_HID_Interrupt_channel
+	isub temp,null
+	branch l2cap_proc_signal_connect_rsp_hid_int,zero
+	rtn
+
+l2cap_proc_signal_connect_rsp_sdp:
+	copy timeup,pdata
+	store 2,mem_sdp_remote_cid
+	fetch 1,mem_sdp_state
+	set1 L2CAP_CHANNEL_STATE_CONN_RES,pdata
+	store 1,mem_sdp_state
+	branch l2cap_process_one_signal_rtn
+l2cap_proc_signal_connect_rsp_rfcomm:
+	copy timeup,pdata
+	store 2,mem_rfcomm_remote_CID
+	fetch 1,mem_rfcomm_state
+	set1 L2CAP_CHANNEL_STATE_CONN_RES,pdata
+	store 1,mem_rfcomm_state
+	rtn
+l2cap_proc_signal_connect_rsp_hid_int:
+	copy timeup,pdata
+	store 2,mem_hid_ctrl_remote_cid
+	fetch 1,mem_hid_interrupt_state
+	set1 L2CAP_CHANNEL_STATE_CONN_RES,pdata
+	store 1,mem_hid_interrupt_state
+	rtn
+l2cap_proc_signal_connect_rsp_hid_ctrl:
+	copy timeup,pdata
+	store 2,mem_hid_int_remote_cid
+	fetch 1,mem_hid_control_state
+	set1 L2CAP_CHANNEL_STATE_CONN_RES,pdata
+	store 1,mem_hid_control_state
+	rtn
+
+l2cap_proc_signal_config_req:
+	ifetch 1,contr//identifier
+	copy pdata,queue
+	ifetch 2,contr//length
+	copy pdata,rega
+	copy regc,pdata
+	isub rega,regc
+	ifetch 2,contr//dest cid
+	copy pdata,temp
+	copy temp,rega
+	setarg L2CAP_SDP_channel
+	isub temp,null
+	branch l2cap_proc_signal_config_req_sdp,zero
+	setarg L2CAP_RFCOMM_channel
+	isub temp,null
+	branch l2cap_proc_signal_config_req_rfcomm,zero
+	setarg L2CAP_HID_Control_channel
+	isub temp,null
+	branch l2cap_proc_signal_config_req_hid_ctrl,zero
+	setarg L2CAP_HID_Interrupt_channel
+	isub temp,null
+	branch l2cap_proc_signal_config_req_hid_int,zero
+	branch l2cap_reject_command
+	//branch L2CAP_proc_signal_config_req_rtn
+l2cap_proc_signal_config_req_sdp:
+	copy contw, timeup
+	fetch 1,mem_sdp_state
+	set1 L2CAP_CHANNEL_STATE_RCV_CFG_REQ,pdata
+	set1 L2CAP_CHANNEL_STATE_SND_CFG_RES,pdata
+	//set1 L2CAP_CHANNEL_STATE_SND_CFG_REQ,pdata
+	store 1,mem_sdp_state
+	copy timeup,contw
+	arg L2CAP_SDP_channel,timeup
+	fetch 2,mem_sdp_remote_cid
+	copy pdata,temp
+	branch l2cap_send_config_rsp
+l2cap_proc_signal_config_req_hid_ctrl:
+	copy contw, timeup
+	fetch 1,mem_hid_control_state
+	set1 L2CAP_CHANNEL_STATE_RCV_CFG_REQ,pdata
+	set1 L2CAP_CHANNEL_STATE_SND_CFG_RES,pdata
+	//set1 L2CAP_CHANNEL_STATE_SND_CFG_REQ,pdata
+	store 1,mem_hid_control_state
+	copy timeup,contw
+	arg L2CAP_HID_Control_channel,timeup
+	fetch 2,mem_hid_ctrl_remote_cid
+	copy pdata,temp
+	branch l2cap_send_config_rsp
+l2cap_proc_signal_config_req_hid_int:
+	copy contw, timeup
+	fetch 1,mem_hid_interrupt_state
+	set1 L2CAP_CHANNEL_STATE_RCV_CFG_REQ,pdata
+	set1 L2CAP_CHANNEL_STATE_SND_CFG_RES,pdata
+	//set1 L2CAP_CHANNEL_STATE_SND_CFG_REQ,pdata
+	store 1,mem_hid_interrupt_state
+	copy timeup,contw
+	arg L2CAP_HID_Interrupt_channel,timeup
+	fetch 2,mem_hid_int_remote_cid
+	copy pdata,temp
+	branch l2cap_send_config_rsp
+l2cap_proc_signal_config_req_rfcomm:
+	copy contw, timeup
+	fetch 1,mem_rfcomm_state
+	set1 L2CAP_CHANNEL_STATE_RCV_CFG_REQ,pdata
+	set1 L2CAP_CHANNEL_STATE_SND_CFG_RES,pdata
+	//set1 L2CAP_CHANNEL_STATE_SND_CFG_REQ,pdata
+	store 1,mem_rfcomm_state
+//	jam UPPERSM_RP_SDP_CONN,mem_upper_sm_remote_page
+	copy timeup,contw
+	arg L2CAP_RFCOMM_channel,timeup
+	fetch 2,mem_RFCOMM_remote_CID
+	copy pdata,temp
+l2cap_send_config_rsp:
+	set1 mark_ext_patch,mark
+	bpatch patch23_5,mem_patch23
+	setarg  signal_config_rsp
+	istore 1,contw
+	copy queue,pdata
+	istore 1,contw
+	setarg 0x0006
+	istore 2,contw
+	copy temp,pdata
+	istore 2,contw
+	force 0x00,pdata
+	istore 2,contw
+	force L2CAP_config_success,pdata
+	istore 2,contw
+	force 10,pdata
+	iadd regb,regb
+	//copy temp,pdata
+	storet 2,mem_config_req_dest_CID
+	copy queue,pdata
+	store 1,mem_config_identifier
+	force L2CAP_SDP_channel,pdata
+	icompare 0xff,timeup
+	branch l2cap_send_config_rsp_is_sdp,true
+	increase 1,pdata
+l2cap_send_config_rsp_is_sdp:
+	//store 1,mem_send_config_req
+	rtn
+l2cap_check_channel_state:
+	disable user
+	rtnbit1 L2CAP_CHANNEL_STATE_SND_CFG_REQ,pdata
+	rtnbit0 L2CAP_CHANNEL_STATE_CONN_REQ,pdata
+	rtnbit0 L2CAP_CHANNEL_STATE_CONN_RES,pdata
+	set1 L2CAP_CHANNEL_STATE_SND_CFG_REQ,pdata
+	copy contr,contw
+	increase -1,contw
+	istore 1,contw
+	enable user
+	rtn
+l2cap_send_config_req:
+l2cap_send_config_req_sdp:
+	fetch 1,mem_sdp_state
+	call l2cap_check_channel_state
+	nbranch l2cap_send_config_req_rfcomm,user
+	jam L2CAP_SDP_channel,mem_send_config_req
+	fetch 2,mem_sdp_remote_cid
+	store 2,mem_config_req_dest_CID
+	branch l2cap_generate_config_req
+l2cap_send_config_req_rfcomm:
+	fetch 1,mem_rfcomm_state
+	call l2cap_check_channel_state
+	nbranch l2cap_send_config_req_hid_ctrl,user
+	jam L2CAP_RFCOMM_channel,mem_send_config_req
+	fetch 2,mem_RFCOMM_remote_CID
+	store 2,mem_config_req_dest_CID
+	branch l2cap_generate_config_req
+l2cap_send_config_req_hid_ctrl:
+	fetch 1,mem_hid_control_state
+	call l2cap_check_channel_state
+	nbranch l2cap_send_config_req_hid_int,user
+	jam L2CAP_HID_Control_channel,mem_send_config_req
+	fetch 2,mem_hid_ctrl_remote_cid
+	store 2,mem_config_req_dest_CID
+	branch l2cap_generate_config_req
+l2cap_send_config_req_hid_int:
+	fetch 1,mem_hid_interrupt_state
+	call l2cap_check_channel_state
+	nrtn user//End of sending config req
+	jam L2CAP_HID_Interrupt_channel,mem_send_config_req
+	fetch 2,mem_hid_int_remote_cid
+	store 2,mem_config_req_dest_CID
+	//branch L2CAP_generate_config_req
+
+l2cap_generate_config_req:
+	set1 mark_ext_patch,mark
+	bpatch patch23_6,mem_patch23
+	call l2cap_get_req_id
+	call l2cap_malloc_signal_channel
+	force 0,regb
+	call l2cap_get_signal_tx_payload
+	force signal_config_req,pdata
+	istore 1,contw
+	fetch 1,mem_ML2CAP_comm_id
+	istore 1,contw
+	setarg 0x0008
+	istore 2,contw
+	fetch 2,mem_config_req_dest_CID
+	istore 2,contw
+	setarg 0x0000
+	istore 2,contw
+	force 1,pdata
+	istore 1,contw
+	force 2,pdata
+	istore 1,contw
+	fetch 1,mem_send_config_req
+	beq L2CAP_RFCOMM_channel,l2cap_generate_config_req_rfcomm
+	setarg L2CAP_config_MTU_SDP
+	istore 2,contw
+	branch l2cap_generate_config_req_done
+l2cap_generate_config_req_rfcomm:
+	setarg L2CAP_config_MTU_RFCOMM
+	istore 2,contw
+l2cap_generate_config_req_done:
+	arg 0x0c,temp
+	storet 2,mem_l2cap_signal_tx_length
+	call l2cap_get_signal_tx_buff
+	fetch 2,mem_l2cap_signal_tx_length
+	istore 2,contw
+	force L2CAP_signal_channel,pdata
+	istore 2,contw
+	jam 0,mem_send_config_req
+l2cap_proc_signal_config_req_rtn:
+	branch l2cap_process_one_signal_rtn
+
+l2cap_proc_signal_config_rsp:
+	increase 1,contr
+	ifetch 2,contr
+	copy pdata,rega
+	copy regc,pdata
+	isub rega,regc
+	ifetch 2,contr //source cid
+	copy pdata,rega
+	setarg L2CAP_SDP_channel
+	isub rega,null
+	branch l2cap_proc_signal_config_rsp_sdp,zero
+	setarg L2CAP_RFCOMM_channel
+	isub rega,null
+	branch l2cap_proc_signal_config_rsp_rfcomm,zero
+	setarg L2CAP_HID_Control_channel
+	isub rega,null
+	branch l2cap_proc_signal_config_rsp_hid_ctrl,zero
+	setarg L2CAP_HID_Interrupt_channel
+	isub rega,null
+	branch l2cap_proc_signal_config_rsp_hid_int,zero
+	increase 2,contr
+	ifetch 2,contr
+	iforce null
+	branch l2cap_process_one_signal_rtn
+l2cap_proc_signal_config_rsp_sdp:
+	fetch 1,mem_sdp_state
+	set1 L2CAP_CHANNEL_STATE_RCV_CFG_RES,pdata
+	store 1,mem_sdp_state
+	branch l2cap_process_one_signal_rtn
+l2cap_proc_signal_config_rsp_rfcomm:
+	fetch 1,mem_rfcomm_state
+	set1 L2CAP_CHANNEL_STATE_RCV_CFG_RES,pdata
+	store 1,mem_rfcomm_state
+	branch l2cap_process_one_signal_rtn
+l2cap_proc_signal_config_rsp_hid_ctrl:
+	fetch 1,mem_hid_control_state
+	set1 L2CAP_CHANNEL_STATE_RCV_CFG_RES,pdata
+	store 1,mem_hid_control_state
+	branch l2cap_process_one_signal_rtn
+l2cap_proc_signal_config_rsp_hid_int:
+	fetch 1,mem_hid_interrupt_state
+	set1 L2CAP_CHANNEL_STATE_RCV_CFG_RES,pdata
+	store 1,mem_hid_interrupt_state
+	jam BT_EVT_HID_CONNECTED,mem_fifo_temp
+	branch ui_ipc_send_event
+	
+
+
+l2cap_proc_signal_disconnect_req:
+	ifetch 1,contr
+	copy pdata,queue
+	ifetch 2,contr
+	copy pdata,rega
+	copy regc,pdata
+	isub rega,regc
+	ifetch 2,contr
+	copy pdata,rega
+	ifetch 2,contr
+	copy pdata,timeup
+	copy rega,temp
+	call save_cont_pointers
+	setarg L2CAP_SDP_channel
+	isub temp,null
+	branch l2cap_proc_signal_disconnect_req_sdp,zero
+	setarg L2CAP_RFCOMM_channel
+	isub temp,null
+	branch l2cap_proc_signal_disconnect_req_rfcomm,zero
+	setarg L2CAP_HID_Control_channel
+	isub temp,null
+	branch l2cap_proc_signal_disconnect_req_hid_ctrl,zero
+	setarg L2CAP_HID_Interrupt_channel
+	isub temp,null
+	branch l2cap_proc_signal_disconnect_req_hid_int,zero
+	call l2cap_reject_command
+	branch l2cap_proc_signal_disconnect_req_err_rtn
+l2cap_proc_signal_disconnect_req_hid_ctrl:
+	copy timeup,temp
+	fetch 2,mem_hid_ctrl_remote_cid
+	isub temp,null
+	branch l2cap_disconnect_hid_control_now,zero
+	call l2cap_reject_command
+	branch l2cap_proc_signal_disconnect_req_err_rtn
+l2cap_proc_signal_disconnect_req_hid_int:
+	copy timeup,temp
+	fetch 2,mem_hid_int_remote_cid
+	isub temp,null
+	branch l2cap_disconnect_hid_interrupt_now,zero
+	call l2cap_reject_command
+	branch l2cap_proc_signal_disconnect_req_err_rtn
+
+l2cap_proc_signal_disconnect_req_sdp:
+	copy timeup,temp
+	fetch 2,mem_sdp_remote_cid
+	isub temp,null
+	branch l2cap_disconnect_sdp_now,zero
+	call l2cap_reject_command
+	branch l2cap_proc_signal_disconnect_req_err_rtn
+l2cap_disconnect_hid_control_now:
+	call l2cap_reset_hid_ctrl_state
+	branch l2cap_send_disconnect_rsp_pkt
+l2cap_disconnect_hid_interrupt_now:
+	call l2cap_reset_hid_int_state
+	fetch 2, mem_hid_ctrl_remote_cid
+	branch l2cap_send_disconnect_rsp_pkt, blank
+	//set the flag,hid channel close
+	//should we set here?
+	//call HID_mem_lock
+	//fetch 1, mem_hid_cb1
+	//set1 HID_CB_APP_HID_DISCONNECTED,pdata
+	//store 1, mem_hid_cb1
+	//call HID_mem_unlock
+	branch l2cap_send_disconnect_rsp_pkt
+
+l2cap_disconnect_sdp_now:
+	call l2cap_reset_sdp_channel_state
+	fetch 1,mem_upper_sm_ss
+	nbranch l2cap_send_disconnect_rsp_pkt,blank
+	//jam LMP_ENCRYPTION_MODE_REQ,mem_lmo_opcode2
+	//jam UPPERSM_RP_SDP_CONN,mem_upper_sm_remote_page
+	branch l2cap_send_disconnect_rsp_pkt
+l2cap_proc_signal_disconnect_req_rfcomm:
+	copy timeup,temp
+	fetch 2, mem_RFCOMM_remote_CID
+	isub temp,null
+	branch l2cap_disconnect_rfcomm_now,zero
+	call l2cap_reject_command
+	branch l2cap_proc_signal_disconnect_req_err_rtn
+l2cap_disconnect_rfcomm_now:
+	call l2cap_reset_rfcomm_channel_state
+	branch l2cap_send_disconnect_rsp_pkt
+l2cap_send_disconnect_rsp_pkt:
+	call load_cont_pointers
+	setarg signal_disconnect_rsp
+	istore 1,contw
+	copy queue,pdata
+	istore 1,contw
+	setarg 0x0004
+	istore 2,contw
+	copy rega,pdata
+	istore 2,contw
+	copy timeup,pdata
+	istore 2,contw
+	force 8,pdata
+	branch l2cap_proc_signal_disconnect_req_rtn
+l2cap_proc_signal_disconnect_req_err_rtn:
+	call load_cont_pointers
+	branch l2cap_proc_signal_disconnect_req_rtn
+l2cap_proc_signal_disconnect_req_rtn:
+	iadd regb,regb
+	branch l2cap_process_one_signal_rtn
+l2cap_proc_signal_disconnect_rsp:
+	ifetch 1,contr
+	copy pdata,queue
+	ifetch 2,contr
+	copy pdata,rega
+	copy regc,pdata
+	isub rega,regc
+	ifetch 2,contr
+	copy pdata,timeup
+	ifetch 2,contr
+	copy pdata,temp
+	call save_cont_pointers
+	setarg L2CAP_SDP_channel
+	isub temp,null
+	branch l2cap_proc_signal_disconnect_rsp_sdp,zero
+	setarg L2CAP_RFCOMM_channel
+	isub temp,null
+	branch l2cap_proc_signal_disconnect_rsp_rfcomm,zero
+	setarg L2CAP_HID_Control_channel
+	isub temp,null
+	branch l2cap_proc_signal_disconnect_rsp_hid_ctrl,zero
+	setarg L2CAP_HID_Interrupt_channel
+	isub temp,null
+	branch l2cap_proc_signal_disconnect_rsp_hid_int,zero
+	call l2cap_reject_command
+	branch l2cap_proc_signal_disconnect_rsp_err_rtn
+l2cap_proc_signal_disconnect_rsp_sdp:
+	copy temp,rega
+	copy timeup,temp
+	fetch 2,mem_sdp_remote_cid
+	isub temp,null
+	call l2cap_reset_sdp_channel_state,zero
+	branch l2cap_proc_signal_disconnect_rsp_rtn
+l2cap_proc_signal_disconnect_rsp_rfcomm:
+	copy temp,rega
+	copy timeup,temp
+	fetch 2,mem_rfcomm_remote_CID
+	isub temp,null
+	call l2cap_reset_rfcomm_channel_state,zero
+	branch l2cap_proc_signal_disconnect_rsp_rtn
+l2cap_proc_signal_disconnect_rsp_hid_ctrl:
+	copy temp,rega
+	copy timeup,temp
+	fetch 2,mem_hid_ctrl_remote_cid
+	isub temp,null
+	call  l2cap_reset_hid_ctrl_state,zero
+	branch l2cap_proc_signal_disconnect_rsp_rtn
+l2cap_proc_signal_disconnect_rsp_hid_int:
+	copy temp,rega
+	copy timeup,temp
+	fetch 2,mem_hid_int_remote_cid
+	isub temp,null
+	call l2cap_reset_hid_int_state,zero
+	branch l2cap_proc_signal_disconnect_rsp_rtn
+l2cap_proc_signal_disconnect_rsp_rtn:
+	call load_cont_pointers
+	branch l2cap_process_one_signal_rtn
+l2cap_proc_signal_disconnect_rsp_err_rtn:
+	branch l2cap_process_one_signal_rtn
+
+/* received an echo request from remote BD.  Will echo the 1st 1 byte back,		*/
+l2cap_proc_signal_echo_req:
+	ifetch 1,contr
+	copy pdata,queue
+	ifetch 2,contr
+	copy pdata,rega
+	iadd contr,contr
+	setarg 9
+	istore 1,contw
+	copy queue,pdata
+	istore 1,contw
+	force 0x0000,pdata
+	istore 2,contw
+	force 4,pdata
+	iadd regb,regb
+	copy regc,pdata
+	isub rega,regc
+	branch l2cap_process_one_signal_rtn
+l2cap_proc_signal_echo_rsp:
+	branch l2cap_process_one_signal_rtn
+
+l2cap_proc_signal_info_rsp:
+	branch l2cap_process_one_signal_rtn
+l2cap_reject_command:
+	force 0,regb
+	call l2cap_get_signal_tx_payload
+	setarg signal_cmd_reject
+	istore 1,contw
+	copy queue,pdata
+	istore 1,contw
+	setarg 2
+	istore 2,contw
+	setarg cmd_not_understood
+	istore 2,contw
+	increase 6,regb
+	arg 4,regc
+	branch l2cap_process_one_signal_rtn
+
+
+
+l2cap_reset_rfcomm_channel_state:
+	setarg 0
+	store 2,mem_RFCOMM_Tx_pkt_length
+	store 2,mem_RFCOMM_remote_CID
+	jam 0,mem_rfcomm_state
+	rtn
+l2cap_reset_sdp_channel_state:
+	setarg 0
+	store 2,mem_sdp_tx_pkt_length
+	store 2,mem_sdp_remote_cid
+	jam 0,mem_sdp_state
+	rtn
+l2cap_reset_hid_ctrl_state:
+	setarg 0
+	store 2,mem_hid_ctrl_remote_cid
+	jam 0,mem_hid_control_state
+	fetch 1,mem_hid_interrupt_state
+	beq 0,l2cap_reset_hid_disconnected
+	rtn
+
+l2cap_reset_hid_int_state:
+	setarg 0
+	store 2,mem_hid_int_remote_cid
+	jam 0,mem_hid_interrupt_state
+	fetch 1,mem_hid_control_state
+	beq 0,l2cap_reset_hid_disconnected
+	rtn
+	
+l2cap_reset_hid_disconnected:
+	jam BT_EVT_HID_DISCONNECTED,mem_fifo_temp
+	branch ui_ipc_send_event	
+
+l2cap_disconnect_interrupt_req:
+	fetch 1,mem_CONTROL_tasks
+	set0  L2CAP_DISCONNECT_INTERRUPT, pdata
+	store 1,mem_CONTROL_tasks
+	fetch 2, mem_hid_int_remote_cid
+	rtn blank
+	call l2cap_malloc_signal_channel
+	fetch 2, mem_hid_int_remote_cid
+	copy pdata,rega
+	force L2CAP_HID_Interrupt_channel,regb
+	branch l2cap_generate_disconnect_req
+l2cap_disconnect_control_req:
+	fetch 1,mem_CONTROL_tasks
+	set0  L2CAP_DISCONNECT_CONTROL, pdata
+	store 1,mem_CONTROL_tasks
+	fetch 2, mem_hid_ctrl_remote_cid
+	rtn blank
+	call l2cap_malloc_signal_channel
+	fetch 2, mem_hid_ctrl_remote_cid
+	copy pdata,rega
+	force L2CAP_HID_Control_channel,regb
+l2cap_generate_disconnect_req:
+	call l2cap_get_req_id
+	call l2cap_get_signal_tx_payload
+	force signal_disconnect_req,pdata
+	istore 1,contw
+	fetch  1,mem_ML2CAP_comm_id
+	istore 1,contw
+	setarg 0x0004
+	istore 2,contw
+	copy rega,pdata
+	istore 2,contw
+	copy regb,pdata
+	istore 2,contw
+	force 0x08,temp //signal tx length in temp
+	branch ml2cap_send_signal
+
+ml2cap_send_signal_connect_req:
+	set1 mark_ext_patch,mark
+	bpatch patch23_7,mem_patch23
+	call l2cap_get_req_id
+	call l2cap_get_signal_tx_payload
+	setarg signal_connect_req
+	istore 1,contw
+	fetch 1,mem_ML2CAP_comm_id
+	istore 1,contw
+	setarg 0x0004
+	istore 2,contw
+	copy temp,pdata	 //PSM
+	istore 2,contw
+	copy timeup,pdata
+	istore 2,contw
+	arg 8,temp
+	branch ml2cap_send_signal
+ml2cap_send_signal_config_req:
+	set1 mark_ext_patch,mark
+	bpatch patch24_0,mem_patch24
+	call l2cap_get_req_id
+	call l2cap_get_signal_tx_payload
+	setarg signal_config_req
+	istore 1,contw
+	fetch 1,mem_ML2CAP_comm_id
+	istore 1,contw
+	setarg 0x0008
+	istore 2,contw
+	/****modigy for nokia*****/
+	copy temp,pdata
+	/*setarg 0x0040*/
+	istore 2,contw
+	setarg 0x0000
+	istore 2,contw
+	setarg 0x01
+	istore 1,contw
+	setarg 0x02
+	istore 1,contw
+	setarg L2CAP_config_MTU_RFCOMM
+	istore 2,contw
+	arg 0xc,temp
+	branch ml2cap_send_signal
+ml2cap_send_signal_disconn_req:
+	set1 mark_ext_patch,mark
+	bpatch patch24_1,mem_patch24
+	call l2cap_get_req_id
+	call l2cap_get_signal_tx_payload
+	setarg signal_disconnect_req
+	istore 1,contw
+	fetch 1,mem_ML2CAP_comm_id
+	increase 1,pdata
+	copy contw,rega
+	store 1,mem_ML2CAP_comm_id
+	copy rega,contw
+	istore 1,contw
+	setarg 0x0004
+	istore 2,contw
+	copy temp,pdata
+	istore 2,contw
+	copy timeup,pdata
+	istore 2,contw
+	arg 0x8,temp
+	//branch ml2cap_send_signal
+	//Fall through
+ml2cap_send_signal:
+	storet 2,mem_l2cap_signal_tx_length
+	copy temp,pdata
+	branch l2cap_malloc_discard,blank
+	call l2cap_get_signal_tx_buff
+	fetch 2,mem_l2cap_signal_tx_length
+	istore 2,contw //make sure that length is still in temp!
+	force L2CAP_signal_channel,pdata
+	istore 2,contw
+	rtn
+
+msdp_send_req_done:
+	fetch 2,mem_sdp_tx_pkt_length
+	branch assert,blank
+	call l2cap_get_sdp_tx_buff
+	fetch 2,mem_sdp_tx_pkt_length
+	istore 2,contw
+	fetch 2,mem_sdp_remote_cid
+	istore 2,contw
+	rtn
+ml2cap_rx_multiplexing:
+	set1 mark_ext_patch,mark
+	bpatch patch24_2,mem_patch24
+	fetch 2, mem_l2cap_rx_pkt_length
+	branch l2cap_rx_reset_state,blank
+	fetch 1,mem_l2cap_rx_cid
+	beq L2CAP_signal_channel,ml2cap_call_proc_signal
+	beq L2CAP_SDP_channel,l2cap_call_proc_sdp
+	beq L2CAP_RFCOMM_channel,l2cap_call_proc_rfcomm
+	beq L2CAP_HID_Control_channel,l2cap_call_proc_hid
+	beq L2CAP_HID_Interrupt_channel,l2cap_call_proc_hid
+	branch l2cap_rx_reset_state
+
+ml2cap_call_proc_signal:
+	set1 mark_ext_patch,mark
+	bpatch patch24_3,mem_patch24
+	call l2cap_malloc_signal_channel
+	force 0,regb
+	call l2cap_get_signal_tx_payload
+	copy pdata,contw
+	fetch 2,mem_l2cap_rx_pkt_length
+	copy pdata,regc
+	fetch 2,mem_l2cap_payload_ptr
+	iforce contr
+ml2cap_proc_one_comm_loop:
+	call ml2cap_proc_one_comm
+	increase -4,regc
+	nbranch ml2cap_proc_one_comm_loop,zero
+	copy regb,temp
+	call ml2cap_send_signal
+	branch l2cap_rx_reset_state
+	
+ml2cap_proc_one_comm:
+	ifetch 1,contr
+	beq signal_connect_req,ml2cap_proc_signal_connect_req
+	beq signal_cmd_reject,ml2cap_proc_signal_cmd_reject
+	beq signal_connect_rsp,ml2cap_proc_signal_connect_rsp
+	beq signal_config_rsp,ml2cap_proc_signal_config_rsp
+	beq signal_config_req,ml2cap_proc_signal_config_req
+	beq signal_disconnect_rsp,ml2cap_proc_signal_disconn_rsp
+	beq signal_disconnect_req,ml2cap_proc_signal_disconn_req
+	beq signal_echo_req,l2cap_proc_signal_echo_req
+	beq signal_info_req,ml2cap_proc_signal_info_req
+	branch ml2cap_proc_send_reject
+
+ml2cap_proc_signal_connect_req:
+	call save_cont_pointers
+	//jam NO_RECONNECTION,memui_reconnect_mode
+	call load_cont_pointers
+	branch l2cap_proc_signal_connect_req
+ml2cap_proc_signal_cmd_reject:
+	ifetch 1,contr
+	copy pdata,queue
+	ifetch 2,contr
+	copy pdata,rega
+	copy regc,pdata
+	isub rega,regc
+mvptr:
+	ifetch 1,contr
+	increase -1,rega
+	nbranch mvptr,zero
+	rtn
+ml2cap_proc_signal_connect_rsp:
+	ifetch 1,contr //id
+	copy pdata,queue
+	ifetch 2,contr
+	copy pdata,rega	//length
+	ifetch 2,contr
+	copy pdata,timeup	//destination	cid
+	ifetch 2,contr
+	copy pdata,temp	//source	cid
+	ifetch 2,contr 		// result
+	sub pdata,0,null
+	branch ml2cap_proc_signal_connect_rsp_sucessful,zero
+	beq L2CAP_connect_refused_PSM_unsupported,ml2cap_proc_signal_connect_refused_result
+	beq L2CAP_connect_refused_no_resources,ml2cap_proc_signal_connect_refused_result
+	branch ml2cap_proc_signal_connect_rsp_mnosucc
+ml2cap_proc_signal_connect_refused_result:
+	jam BT_EVT_ML2CAP_CONN_REFUSED,mem_fifo_temp
+	call ui_ipc_send_event
+ml2cap_proc_signal_connect_rsp_mnosucc:
+	ifetch 2,contr //reason
+	branch mnosucc
+ml2cap_proc_signal_connect_rsp_sucessful:
+	call save_cont_pointers
+	//fetch 1,mem_ML2CAP_comm_id
+	//icompare 0xff,queue
+	//nbranch mnosucc1,true
+	setarg L2CAP_SDP_channel
+	isub temp,null
+	branch ml2cap_proc_signal_connect_rsp_sdp,zero
+	setarg L2CAP_RFCOMM_channel
+	isub temp,null
+	branch ml2cap_proc_signal_connect_rsp_rfcomm,zero
+	setarg L2CAP_HID_Interrupt_channel
+	isub temp,null
+	branch ml2cap_proc_signal_connect_rsp_hid_int,zero
+	setarg L2CAP_HID_Control_channel
+	isub temp,null
+	branch ml2cap_proc_signal_connect_rsp_hid_ctrl,zero
+	branch mnosucc
+ml2cap_proc_signal_connect_rsp_sdp:
+	copy timeup,pdata
+	store 2,mem_sdp_remote_cid
+	fetch 1,mem_sdp_state
+	set1 L2CAP_CHANNEL_STATE_CONN_RES
+	store 1,mem_sdp_state
+	branch mnosucc1
+ml2cap_proc_signal_connect_rsp_rfcomm:
+	copy timeup,pdata
+	store 2,mem_RFCOMM_remote_CID
+	fetch 1,mem_rfcomm_state
+	set1 L2CAP_CHANNEL_STATE_CONN_RES
+	store 1,mem_rfcomm_state
+	branch mnosucc1
+ml2cap_proc_signal_connect_rsp_hid_ctrl:
+	copy timeup,pdata
+	store 2,mem_hid_ctrl_remote_cid
+	fetch 1,mem_hid_control_state
+	set1 L2CAP_CHANNEL_STATE_CONN_RES
+	store 1,mem_hid_control_state
+	branch mnosucc1
+ml2cap_proc_signal_connect_rsp_hid_int:
+	copy timeup,pdata
+	store 2,mem_hid_int_remote_cid
+	fetch 1,mem_hid_interrupt_state
+	set1 L2CAP_CHANNEL_STATE_CONN_RES
+	store 1,mem_hid_interrupt_state
+	//branch mnosucc1
+
+mnosucc1:
+	call load_cont_pointers
+mnosucc:
+	copy regc,pdata
+	isub rega,regc
+	rtn
+
+ml2cap_proc_signal_config_rsp:
+	ifetch 1,contr		//	Ident
+	copy pdata,queue
+	ifetch 2,contr		//	SigLen
+	copy pdata,rega
+	copy regc,pdata
+	isub rega,regc
+	ifetch 2,contr		//	DestnCID
+	copy pdata,timeup
+	ifetch 2,contr
+	ifetch 2,contr		//	Get the result value, check success
+	nbranch mcrsdone1,blank
+	call save_cont_pointers
+	//fetch 1,mem_ML2CAP_comm_id
+	//icompare 0xff,queue
+	//nbranch mcfrsdone,true
+	copy timeup,temp
+	setarg L2CAP_SDP_channel
+	isub temp,null
+	branch ml2cap_proc_signal_config_rsp_sdp,zero
+	setarg L2CAP_RFCOMM_channel
+	isub temp,null
+	branch ml2cap_proc_signal_config_rsp_rfcomm,zero
+	setarg L2CAP_HID_Control_channel
+	isub temp,null
+	branch ml2cap_proc_signal_config_rsp_hid_ctrl,zero
+	setarg L2CAP_HID_Interrupt_channel
+	isub temp,null
+	branch ml2cap_proc_signal_config_rsp_hid_int,zero
+ml2cap_proc_signal_config_rsp_sdp:
+	fetch 1,mem_sdp_state
+	set1 L2CAP_CHANNEL_STATE_RCV_CFG_RES
+	store 1,mem_sdp_state
+	rtn
+ml2cap_proc_signal_config_rsp_rfcomm:
+	fetch 1,mem_rfcomm_state
+	set1 L2CAP_CHANNEL_STATE_RCV_CFG_RES
+	store 1,mem_rfcomm_state
+	rtn
+ml2cap_proc_signal_config_rsp_hid_ctrl:
+	fetch 1,mem_hid_control_state
+	set1 L2CAP_CHANNEL_STATE_RCV_CFG_RES
+	store 1,mem_hid_control_state
+	rtn
+ml2cap_proc_signal_config_rsp_hid_int:
+	fetch 1,mem_hid_interrupt_state
+	set1 L2CAP_CHANNEL_STATE_RCV_CFG_RES
+	store 1,mem_hid_interrupt_state
+	jam BT_EVT_HID_CONNECTED,mem_fifo_temp
+	branch ui_ipc_send_event
+
+
+mcfrsdone:
+	call load_cont_pointers
+mcrsdone1:
+	increase -6,rega
+mloop2:
+	branch mcrsdone,zero
+	increase 1,contr
+	increase -1,rega
+	branch mloop2
+mcrsdone:
+	rtn
+ml2cap_proc_signal_config_req:
+	ifetch 1,contr		//	Ident
+	copy pdata,queue
+	ifetch 2,contr		//	SigLen
+	copy pdata,rega
+	copy regc,pdata
+	isub rega,regc
+	ifetch 2,contr		//	DestnCID
+	increase 2,contr
+	copy pdata,temp
+	setarg  signal_config_rsp
+	istore 1,contw
+	copy queue,pdata
+	istore 1,contw
+	increase 2,rega
+	copy rega,pdata
+	istore 2,contw
+	call save_cont_pointers
+	setarg L2CAP_SDP_channel
+	isub temp,null
+	branch ml2cap_proc_signal_config_req_sdp,zero
+	setarg L2CAP_RFCOMM_channel
+	isub temp,null
+	branch ml2cap_proc_signal_config_req_rfcomm,zero
+	setarg L2CAP_HID_Control_channel
+	isub temp,null
+	branch ml2cap_proc_signal_config_req_hid_ctrl,zero
+	setarg L2CAP_HID_Interrupt_channel
+	isub temp,null
+	branch ml2cap_proc_signal_config_req_hid_int,zero
+	branch mcfgrq_done
+ml2cap_proc_signal_config_req_sdp:
+	fetch 1,mem_sdp_state
+	set1 L2CAP_CHANNEL_STATE_RCV_CFG_REQ,pdata
+	set1 L2CAP_CHANNEL_STATE_SND_CFG_RES,pdata
+	store 1,mem_sdp_state
+	bbit1 L2CAP_CHANNEL_STATE_SND_CFG_REQ,ml2cap_proc_signal_config_req_sdp_nsndreq
+	fetcht 1,mem_CONTROL_tasks
+	set1 L2CAP_init_Config_Req,temp
+	storet 1,mem_CONTROL_tasks
+	copy queue,pdata
+	increase 1,pdata
+	store 1,mem_config_identifier
+	fetch 1,mem_sdp_state
+	set1 L2CAP_CHANNEL_STATE_SND_CFG_REQ,pdata
+	store 1,mem_sdp_state
+ml2cap_proc_signal_config_req_sdp_nsndreq:
+	fetch 2,mem_sdp_remote_cid
+	store 2,mem_config_req_dest_CID
+	branch mcfgrq_done
+ml2cap_proc_signal_config_req_rfcomm:
+	fetch 1,mem_rfcomm_state
+	set1 L2CAP_CHANNEL_STATE_RCV_CFG_REQ,pdata
+	set1 L2CAP_CHANNEL_STATE_SND_CFG_RES,pdata
+	store 1,mem_rfcomm_state
+	fetch 2,mem_RFCOMM_remote_CID
+	branch mcfgrq_done
+ml2cap_proc_signal_config_req_hid_ctrl:
+	fetch 1,mem_hid_control_state
+	set1 L2CAP_CHANNEL_STATE_RCV_CFG_REQ,pdata
+	set1 L2CAP_CHANNEL_STATE_SND_CFG_RES,pdata
+	store 1,mem_hid_control_state
+	fetch 2,mem_hid_ctrl_remote_cid
+	branch mcfgrq_done
+ml2cap_proc_signal_config_req_hid_int:
+	fetch 1,mem_hid_interrupt_state
+	set1 L2CAP_CHANNEL_STATE_RCV_CFG_REQ,pdata
+	set1 L2CAP_CHANNEL_STATE_SND_CFG_RES,pdata
+	store 1,mem_hid_interrupt_state
+	fetch 2,mem_hid_int_remote_cid
+	//branch mcfgrq_done
+
+mcfgrq_done:
+	copy pdata,timeup
+	call load_cont_pointers
+/*******for Nokia**************/
+	copy timeup,pdata
+	/*setarg 0x0040*/
+	istore 2,contw
+	force 0x0000,pdata
+	istore 2,contw
+	force 0x0000,pdata
+	istore 2,contw
+	force 10,pdata
+	iadd regb,regb
+	increase -6,rega
+mloop1:
+	branch mcrqdone,zero
+	ifetch 1,contr
+	istore 1,contw
+	increase 1,regb
+	increase -1,rega
+	branch mloop1
+mcrqdone:
+	rtn
+ml2cap_proc_signal_disconn_req:
+	ifetch 1,contr
+	copy pdata,queue
+	ifetch 2,contr
+	copy pdata,rega
+	copy regc,pdata
+	isub rega,regc
+
+	ifetch 2,contr
+	copy pdata,rega
+	ifetch 2,contr
+	copy pdata,timeup
+	call save_cont_pointers
+	setarg L2CAP_SDP_channel
+	copy rega,temp
+	isub temp,null
+	branch ml2cap_proc_signal_disconn_sdp,zero
+	setarg L2CAP_HID_Control_channel
+	copy rega,temp
+	isub temp,null
+	branch ml2cap_proc_signal_disconn_hid_ctrl,zero
+	setarg L2CAP_HID_Interrupt_channel
+	copy rega,temp
+	isub temp,null
+	branch ml2cap_proc_signal_disconn_hid_int,zero
+	branch mclsrfc
+ml2cap_proc_signal_disconn_sdp:
+	setarg 0x0000
+	store 2,mem_sdp_tx_pkt_length
+	store 2,mem_sdp_remote_cid
+	store 1,mem_sdp_state
+	branch mclssdp
+ml2cap_proc_signal_disconn_hid_ctrl:
+	call l2cap_reset_hid_ctrl_state
+	branch mclssdp
+ml2cap_proc_signal_disconn_hid_int:
+	call l2cap_reset_hid_int_state
+	//call HID_mem_lock
+	//fetch 1, mem_hid_cb1
+	//set1 HID_CB_APP_HID_DISCONNECTED,pdata
+	//store 1, mem_hid_cb1
+	//call HID_mem_unlock
+	branch mclssdp
+mclsrfc:
+	setarg 0x0000
+	store 2,mem_RFCOMM_Tx_pkt_length
+mclssdp:
+	call load_cont_pointers
+	setarg signal_disconnect_rsp
+	istore 1,contw
+	copy queue,pdata
+	istore 1,contw
+	setarg 0x0004
+	istore 2,contw
+	copy rega,pdata
+	istore 2,contw
+	copy timeup,pdata
+	istore 2,contw
+	force 8,pdata
+	iadd regb,regb
+	rtn
+
+ml2cap_proc_signal_disconn_rsp:
+	ifetch 1,contr
+	copy pdata,queue
+	ifetch 2,contr
+	copy pdata,rega
+	ifetch 2,contr
+	copy pdata,timeup
+	ifetch 2,contr
+	copy pdata,temp
+	call save_cont_pointers
+	fetch 1,mem_ML2CAP_comm_id
+	icompare 0xff,queue
+	nbranch mdisdone,true
+	setarg L2CAP_SDP_channel
+	isub temp,null
+	branch ml2cap_proc_signal_disconn_rsp_sdp,zero
+	setarg L2CAP_RFCOMM_channel
+	isub temp,null
+	branch ml2cap_proc_signal_disconn_rsp_rfcomm,zero
+	branch mdisdone
+ml2cap_proc_signal_disconn_rsp_sdp:
+	jam 0,mem_sdp_remote_cid
+	jam 0,mem_sdp_state
+	branch mdisdone
+ml2cap_proc_signal_disconn_rsp_rfcomm:
+	//
+	//
+mdisdone:
+	call load_cont_pointers
+	copy regc,pdata
+	isub rega,regc
+	rtn
+
+ml2cap_proc_send_reject:
+	setarg signal_cmd_reject
+	istore 1,contw
+	ifetch 1,contr
+	istore 1,contw
+	setarg 0x0002
+	istore 2,contw
+	setarg 0x0000
+	istore 2,contw
+	setarg 0x0006
+	iadd regb,regb
+	force 4,regc
+	rtn
+	
+//l2cap command id, 0 is not allowed
+l2cap_get_req_id:
+	fetch 1,mem_ML2CAP_comm_id
+	increase 1,pdata
+	bne 0,l2cap_get_req_id_ok
+	increase 1,pdata
+l2cap_get_req_id_ok:
+	store 1,mem_ML2CAP_comm_id
+	rtn
+
+
+/*********************************************************/
+//char* malloc(short len)
+//input: rega -> len
+//rtn: regb -> pbuff;return from pdata
+//val: queue -> i
+//val: timeup -> buff_cnt
+/*********************************************************/
+l2cap_malloc:
+	set1 mark_ext_patch,mark
+	bpatch patch24_4,mem_patch24
+	arg 0,regb
+	call l2cap_malloc_is_fifo_full
+	nbranch assert,blank//assert when fifo full
+	call l2cap_malloc_get_full_map
+ifdef DEBUG_MALLOC
+	call l2cap_malloc_log_get_ptr
+	copy rega,pdata
+	istore 2,contw
+	sub pdata,1024,null
+	branch assert,positive
+	branch assert,blank
+endif
+	arg mem_tx_buff0,regb//pbuff = buff0;
+	arg 0,queue // i = 0;
+l2cap_malloc_loop:
+	fetcht 1,mem_used_map
+	qisolate1 temp
+	branch l2cap_malloc_next,true//if(1 == (used_map & (1 << i)))goto next;
+	call l2cap_malloc_enough
+	sub timeup,0,null// (0 - timeup)
+	branch l2cap_malloc_next,positive//if(buff_cnt <= 0)goto next;
+	call l2cap_malloc_into_fifo
+	branch l2cap_malloc_rtn//return (pbuff);
+l2cap_malloc_next:
+	increase 128,regb//pbuff += BUFF_SIZE;//point to next buff
+	increase 1,queue
+	setarg 8//BUFF_MAX_COUNT
+	isub queue,null //BUFF_MAX_COUNT - i
+	branch l2cap_malloc_loop,positive//while(i < buff_max_count)
+	arg 0,regb//return NULL
+l2cap_malloc_rtn:
+ifdef DEBUG_MALLOC
+	call l2cap_malloc_log_get_ptr
+	copy regb,pdata
+	istore 2,contw
+endif
+	copy regb,pdata
+	branch assert,blank
+	rtn//return pointer via pdata
+	
+/*********************************************************/
+//void* l2cap_malloc_fifo_out(void)
+//output:len -> temp
+//output:ptr ->pdata
+//only get ptr,not free
+/*********************************************************/
+l2cap_malloc_fifo_out:
+	set1 mark_ext_patch,mark
+	bpatch patch24_5,mem_patch24
+	call l2cap_malloc_fifo_get_first_ptr
+	increase 1,contr
+	ifetch 2,contr //ptr ->pdata
+	rtn 
+
+/*********************************************************/
+//void free_first_buff_in_fifo(void)
+//only free the first one
+/*********************************************************/
+l2cap_malloc_free:
+	set1 mark_ext_patch,mark
+	bpatch patch24_6,mem_patch24
+	call l2cap_malloc_fifo_get_first_ptr
+	copy contr,contw
+	copy contr,temp
+	setarg 0
+	istore 3,contw
+ifdef DEBUG_MALLOC
+	call l2cap_malloc_log_get_ptr
+	setarg 0xaa
+	istore 1,contw
+	istoret 1,contw
+endif
+	rtn
+/*********************************************************/
+//void l2cap_malloc_discard(void)
+//discard the latest malloc
+/*********************************************************/
+l2cap_malloc_discard:
+	set1 mark_ext_patch,mark
+	bpatch patch24_7,mem_patch24
+	call l2cap_malloc_is_fifo_empty
+	branch assert,blank
+	fetch 3,mem_tx_fifo2
+	store 3,mem_tx_fifo3
+	fetch 3,mem_tx_fifo1
+	store 3,mem_tx_fifo2
+	fetch 3,mem_tx_fifo0
+	store 3,mem_tx_fifo1
+	rtn
+/*********************************************************/
+//bool fifo_is_full(void)
+//blank == 1: not full
+//blank == 0: full
+/*********************************************************/
+l2cap_malloc_is_fifo_full:
+	fetch 3,mem_tx_fifo0
+	rtn
+/*********************************************************/
+//bool fifo_nearly_full(void)
+//blank == 1: nearly full
+//blank == 0: not nearly full
+/*********************************************************/
+l2cap_malloc_is_fifo_nearly_full:
+	fetch 3,mem_tx_fifo1
+	rtn
+/*********************************************************/
+//bool fifo_is_empty(void)
+//blank == 1: empty
+//blank == 0: not empty
+/*********************************************************/
+l2cap_malloc_is_fifo_empty:
+	fetch 3,mem_tx_fifo3
+	rtn
+/*********************************************************/
+//char* l2cap_malloc_fifo_get_first_ptr(void)
+//output:contr  -->ptr
+/*********************************************************/	
+l2cap_malloc_fifo_get_first_ptr:
+	call l2cap_malloc_is_fifo_empty
+	branch assert,blank // fifo is empty
+	arg mem_tx_fifo0,contr
+ifdef DEBUG_MALLOC
+	arg 5,loopcnt
+l2cap_malloc_free_loop:
+	increase -1,loopcnt
+	copy loopcnt,pdata
+	branch assert,blank
+else
+l2cap_malloc_free_loop:
+endif
+	ifetch 3,contr
+	branch l2cap_malloc_free_loop,blank
+	increase -3,contr
+	rtn
+
+/*********************************************************/
+//char* l2cap_malloc_get_full_map(void)
+//output:mem_used_map  -->full_map
+//add all maps into one
+/*********************************************************/	
+l2cap_malloc_get_full_map:
+	set1 mark_ext_patch,mark
+	bpatch patch25_0,mem_patch25
+	arg 4,loopcnt
+	arg mem_tx_fifo0_map,contr
+	arg 0,temp
+l2cap_malloc_get_full_map_loop:	
+	ifetch 3,contr
+	and pdata,0xff,pdata
+	ior temp,temp
+	loop l2cap_malloc_get_full_map_loop
+	storet 1,mem_used_map
+	rtn
+/*********************************************************/
+//void buff_into_fifo(char buff_index, char buff_cnt, short len)
+//input: rega -> len
+//input: regc -> buff_index
+//input: timeup -> buff_cnt
+//val:temp ->   (fifo->map)
+/*********************************************************/
+l2cap_malloc_into_fifo:
+	set1 mark_ext_patch,mark
+	bpatch patch25_1,mem_patch25
+	call l2cap_malloc_is_fifo_full
+	nbranch assert,blank //fifo full
+	call l2cap_malloc_is_fifo_empty
+	branch l2cap_malloc_into_fifo_no_push,blank//fifo empty, no need to push
+	fetch 3,mem_tx_fifo1
+	store 3,mem_tx_fifo0
+	ifetch 3,contr//mem_tx_fifo2
+	istore 3,contw//mem_tx_fifo1
+	ifetch 3,contr//mem_tx_fifo3
+	istore 3,contw//mem_tx_fifo2
+	setarg 0
+	istore 3,contw//mem_tx_fifo3
+l2cap_malloc_into_fifo_no_push:
+	arg 0,temp
+	copy timeup,pdata
+	iadd queue,pdata
+l2cap_malloc_into_fifo_loop:
+	qset1 temp//fifo->map |= 1 << i;
+	increase 1,queue
+	isub queue,null
+	nbranch l2cap_malloc_into_fifo_loop,zero
+	//map in temp
+	lshift8 regb,pdata
+	ior temp,pdata
+	store 3,mem_tx_fifo3
+	rtn
+
+/*********************************************************/
+//char is_size_enough(char buff_index, short len)
+//input: rega -> len
+//input: queue -> buff_index
+//rtn: timeup -> buff_cnt
+//val: max_size_fom_buff_index -> temp
+//val: i -> loopcnt
+/*********************************************************/
+l2cap_malloc_enough:
+	set1 mark_ext_patch,mark
+	bpatch patch25_2,mem_patch25
+	call l2cap_malloc_get_full_map
+	copy queue,regc//restore buff_index to regc
+	arg 0,temp
+	arg 0,timeup//default return val
+	//increase 1,queue
+l2cap_malloc_enough_loop:
+	copy queue,pdata
+	beq 8,l2cap_malloc_enough_end
+	fetch 1,mem_used_map
+	qisolate1 pdata
+	branch l2cap_malloc_enough_end,true
+	increase 128,temp
+	increase 1,queue
+	copy rega,pdata
+	isub temp,null
+	branch l2cap_malloc_enough_end,zero//(max_size_fom_buff_index ==  len)
+	branch l2cap_malloc_enough_loop,positive//(max_size_fom_buff_index <  len)
+l2cap_malloc_enough_end:
+	copy temp,pdata
+	isub rega,null
+	nbranch l2cap_malloc_enough_rtn,positive// max_size_fom_buff_index - len > 0
+	copy queue,pdata//i
+	copy regc,temp//buff_index
+	isub temp,timeup//return (i - buff_index)
+l2cap_malloc_enough_rtn:
+	copy regc,queue//restore buff_index to queue
+	rtn
+	
+ifdef DEBUG_MALLOC
+l2cap_malloc_log_get_ptr:
+	fetch 2,mem_tx_malloc_log
+	increase 2,pdata
+	store 2,mem_tx_malloc_log
+	sub pdata,62,null
+	nbranch l2cap_malloc_log_clean,positive
+	increase -2,pdata
+	iadd contw,contw
+	rtn
+l2cap_malloc_log_clean:
+	jam 0x00,mem_tx_malloc_log
+	branch l2cap_malloc_log_get_ptr	
+endif
+
+l2cap_malloc_signal_channel:
+	set1 mark_ext_patch,mark
+	bpatch patch25_3,mem_patch25
+	arg L2CAP_SIGNAL_MALLOC_SIZE,rega
+	call l2cap_malloc
+	store 2,mem_l2cap_signal_tx_buff_ptr
+	increase 4,pdata
+	store 2,mem_l2cap_signal_tx_payload_ptr
+	setarg 0
+	store 2,mem_l2cap_signal_tx_length
+	rtn
+
+l2cap_get_signal_tx_buff:
+	fetch 2,mem_l2cap_signal_tx_buff_ptr
+	branch l2cap_util_pdata_to_contw
+
+l2cap_get_signal_tx_payload:
+	fetch 2,mem_l2cap_signal_tx_payload_ptr
+	branch l2cap_util_pdata_to_contw
+
+
+l2cap_malloc_sdp_channel:
+	set1 mark_ext_patch,mark
+	bpatch patch25_4,mem_patch25
+	arg SDP_MALLOC_SIZE,rega
+	call l2cap_malloc
+	store 2,mem_sdp_tx_buff_ptr
+	increase 4,pdata
+	store 2,mem_sdp_tx_payload_ptr
+	setarg 0
+	store 2,mem_sdp_tx_pkt_length
+	rtn
+
+l2cap_get_sdp_tx_buff:
+	fetch 2,mem_sdp_tx_buff_ptr
+	branch l2cap_util_pdata_to_contw
+
+l2cap_get_sdp_tx_payload:
+	fetch 2,mem_sdp_tx_payload_ptr
+	branch l2cap_util_pdata_to_contw
+
+
+l2cap_malloc_rfcomm_channel:
+	set1 mark_ext_patch,mark
+	bpatch patch25_5,mem_patch25
+	call push_stack
+	jam RFCOMM_MALLOC_FAIL,mem_rfcomm_malloc_fail_flag
+	call l2cap_malloc_is_fifo_full
+	nrtn blank
+	arg RFCOMM_MALLOC_SIZE,rega
+	call l2cap_malloc
+	store 2,mem_rfcomm_tx_buff_ptr
+	increase 4,pdata
+	store 2,mem_rfcomm_tx_payload_ptr
+	setarg 0
+	store 2,mem_rfcomm_tx_pkt_length
+	jam RFCOMM_MALLOC_SUCCEED,mem_rfcomm_malloc_fail_flag
+	branch pop_stack
+
+l2cap_get_rfcomm_tx_buff:
+	fetch 2,mem_rfcomm_tx_buff_ptr
+	branch l2cap_util_pdata_to_contw
+	
+l2cap_get_rfcomm_tx_payload:
+	fetch 2,mem_rfcomm_tx_payload_ptr
+	//fall through
+l2cap_util_pdata_to_contw:
+	branch assert,blank
+	copy pdata,contw
+	rtn
+	
+
+l2cap_lpm_save_calc_len:
+	set1 mark_ext_patch,mark
+	bpatch patch25_6,mem_patch25
+	arg 0,regb
+	arg mem_tx_fifo0_map,rega
+	increase -2,rega
+l2cap_lpm_save_calc_len_loop:
+	increase 2,rega
+	setarg mem_tx_fifo_end
+	isub rega,null
+	branch l2cap_lpm_save_calc_len_end,zero //end of 2lcap tx fifo
+	ifetch 1,rega
+	increase 1,rega
+	branch l2cap_lpm_save_calc_len_loop,blank
+	ifetcht 2,rega
+	ifetch 2,temp
+	iadd regb,regb
+	increase 4,regb //l2cap header len
+	branch l2cap_lpm_save_calc_len_loop
+l2cap_lpm_save_calc_len_end:
+	copy regb,pdata
+	rtn
+
+
+l2cap_lpm_get_wake_lock:
+	arg wake_lock_l2cap_tx,queue
+	branch lpm_get_wake_lock
+
+l2cap_lpm_put_wake_lock:
+	arg wake_lock_l2cap_tx,queue
+	branch lpm_put_wake_lock
+	
+l2cap_lpm_save_txbuf:
+	set1 mark_ext_patch,mark
+	bpatch patch25_7,mem_patch25
+	call l2cap_malloc_get_full_map
+	fetch 1,mem_used_map
+	rtn blank
+	call l2cap_lpm_save_calc_len
+	arg l2cap_lpm_txbuf_len,temp
+	isub temp,null
+	branch l2cap_lpm_get_wake_lock,positive //no enougth space to save l2cap tx data
+	call l2cap_lpm_put_wake_lock
+	arg mem_l2cap_lpm_txbuf,contw
+	arg mem_tx_fifo0,rega
+l2cap_lpm_save_txbuf_loop:
+	setarg mem_tx_fifo_end
+	isub rega,null
+	rtn zero //end of 2lcap tx fifo
+	ifetch 1,rega  //mem_tx_fifoX_map
+	increase 1,rega
+	nbranch l2cap_lpm_save_txbuf_nempty,blank
+	istore 2,contw // length = 0
+	increase 2,rega
+	branch l2cap_lpm_save_txbuf_loop
+l2cap_lpm_save_txbuf_nempty:
+	ifetch 2,rega //ptr
+	increase 2,rega
+	copy pdata,contr
+	ifetch 2,contr  //l2cap len
+	istore 2,contw
+	copy pdata,loopcnt
+	increase 2,loopcnt //add CID len
+	call memcpy
+	branch l2cap_lpm_save_txbuf_loop
+	
+l2cap_lpm_load_txbuf:
+	set1 mark_ext_patch,mark
+	bpatch patch26_0,mem_patch26
+	call l2cap_malloc_get_full_map
+	fetch 1,mem_used_map
+	rtn blank
+	arg mem_tx_fifo0_ptr,rega
+	increase -3,rega //mem_tx_fifo0_ptr -3
+	arg mem_l2cap_lpm_txbuf,contr
+l2cap_lpm_load_txbuf_loop:
+	increase 3,rega //mem_tx_fifoX_ptr
+	setarg mem_tx_fifo_end+1
+	isub rega,null
+	rtn zero //end of 2lcap tx fifo
+	ifetch 2,contr
+	branch l2cap_lpm_load_txbuf_loop,blank
+	increase 4,pdata //l2cap header len
+	copy pdata,loopcnt
+	copy contr,regb
+	ifetch 2,rega //ptr
+	copy pdata,contw
+	copy regb,contr
+	increase -2,contr
+	call memcpy
+	branch l2cap_lpm_load_txbuf_loop
+	
+
+
+	
Index: btkb/program/le.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/le.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/le.prog	(working copy)
@@ -0,0 +1,2711 @@
+ifdef COMPILE_LE
+//******************************************//
+//*************LE INIT ****************//
+//******************************************//
+le_init_param:
+	rtn wake
+	setarg param_le_scan_interval
+	store 2,mem_le_scan_interval
+	setarg param_le_scan_window
+	store 2,mem_le_scan_window
+	rtn
+
+le_init_att:
+	arg notify_handle,temp
+	call le_att_get_handle_ptr
+	add contr,1,pdata
+	store 2,mem_le_notify_attr_start
+	rtn
+
+le_init_conn:
+	set1 mark_ext_patch,mark
+	bpatch patch26_2,mem_patch26
+	disable wake
+	jam 1,mem_app_state
+	jam 1,mem_le_conn_handle
+	jam 3,mem_le_state
+	jam 1,mem_le_arq
+	setarg -1
+	store 2,mem_le_event_count
+	force 0,pdata
+	store 1,mem_le_conn_sm
+	store 1,mem_le_ch
+	store 1,mem_le_op
+	store 3,mem_sniff_rcv
+	store 3,mem_sniff_lost
+	store 5,mem_le_pcnt_tx
+	set1 39,pdata
+	store 5,mem_le_pcnt_rx
+	branch le_supervision_flush
+
+le_init_master:
+	set1 mark_ext_patch,mark
+	bpatch patch26_3,mem_patch26
+	enable master
+	jam lemode_master,mem_le_mode
+	jam 1,mem_le_att_handle
+	jam 1,mem_le_search_handle_start
+	setarg 0xffff
+	store 2,mem_le_search_handle_end
+	force 0,pdata
+	store 5,mem_le_pcnt_rx
+	set1 39,pdata
+	store 5,mem_le_pcnt_tx	
+	branch le_init_conn
+
+
+le_init_slave:
+	set1 mark_ext_patch,mark
+	bpatch patch26_4,mem_patch26
+	disable master
+	jam lemode_slave,mem_le_mode
+	jam 0,mem_le_adv_enable
+	jam 0,mem_lpm_current_mult
+	branch le_init_conn
+	
+
+//******************************************//
+//*************LE main process*********//
+//******************************************//
+le_dispatch:
+	call le_enable
+	call le_scan
+	call le_adv
+	branch le_disable
+
+le_conn_dispatch:
+	set1 mark_ext_patch,mark
+	bpatch patch26_5,mem_patch26
+	call le_enable
+	call app_process_ble
+	fetch 1,mem_le_mode
+	beq lemode_master,le_master_dispatch
+	branch le_slave_dispatch
+	
+//******************************************//
+//***********LE master process*********//
+//******************************************//
+	
+le_master_dispatch:
+	set1 mark_ext_patch,mark
+	bpatch patch26_6,mem_patch26
+	enable master
+	call le_supervision_update
+	branch le_master_disconn,positive
+	call check_ble_disabled
+	call le_setup
+	call le_prepare_tx
+	disable match
+	call le_transmit_receive_sifs
+	nrtn match
+	set1 mark_ext_patch,mark
+	bpatch patch26_7,mem_patch26
+	fetch 1,mem_le_conn_rcv
+	increase 1,pdata
+	store 1,mem_le_conn_rcv
+	call le_acknowledge
+	call le_conn_sm_master
+	disable master
+	rtn
+	
+le_master_disconn:
+	call le_disconnect
+	disable master
+	rtn
+	
+//******************************************//
+//***********LE slave process***********//
+//******************************************//
+le_slave_dispatch:
+	set1 mark_ext_patch,mark
+	bpatch patch27_0,mem_patch27
+	disable attempt
+	call le_supervision_update
+	branch le_slave_disconn,positive
+	call check_ble_disabled
+	call le_setup
+	call le_receive_slave
+	nbranch le_slave_unsync,match
+le_slave_match:
+	set1 mark_ext_patch,mark
+	bpatch patch27_1,mem_patch27
+	call le_got_first_packet
+	call le_acknowledge
+	call le_prepare_tx
+	fetch 1,mem_le_rxbuf
+	bbit1 md,le_slave_more_data //more data to rx
+	call le_xtype_fifo_is_empty
+	nbranch le_slave_more_data,blank// more data to tx
+le_slave_transmit_last:
+	set1 mark_ext_patch,mark
+	bpatch patch27_2,mem_patch27
+	call le_transmit_norx
+le_slave_cont:
+	call check_51cmd
+	fetch 1,mem_le_op
+	bbit1 op_disconn,le_slave_disconn
+le_slave_unsync:
+	set1 mark_ext_patch,mark
+	bpatch patch27_3,mem_patch27
+	call le_savelist
+	call le_lpm_set_mult
+	call le_update_channel_map
+	call le_update_param
+	branch calc_clke_offset
+
+le_slave_more_data:
+	set1 mark_ext_patch,mark
+	bpatch patch27_4,mem_patch27
+	enable attempt
+	call le_transmit_receive_sifs
+	branch le_slave_match,match
+	branch le_slave_cont
+
+le_slave_disconn:
+
+	//fall through
+le_disconnect:
+	set1 mark_ext_patch,mark
+	bpatch patch27_5,mem_patch27
+	call le_clear_connection_info
+	call app_disconn_reason_collect_ble
+	jam BT_EVT_LE_DISCONNECTED,mem_fifo_temp
+	branch ui_ipc_send_event
+
+le_clear_connection_info:
+	fetcht 1,mem_le_conn_handle
+	jam HCI_ERROR_CONNECTION_TIMEOUT,mem_hci_disconn_reason
+	call hci_send_disconn_complete
+	jam 0,mem_le_conn_handle
+	jam lemode_idle,mem_le_mode
+	jam 0,mem_le_state
+	jam 0,mem_app_state
+	rtn
+	
+le_got_first_packet:
+	fetch 1,mem_le_conn_rcv
+	increase 1,pdata
+	store 1,mem_le_conn_rcv
+	fetch 1,mem_le_state
+	rtnbit1 lestate_got_first_packet
+	set1 lestate_got_first_packet
+	store 1,mem_le_state
+	setarg 0
+	store 4,mem_le_transmit_window
+	rtn
+
+
+
+
+le_enable:
+	set1 mark_ext_patch,mark
+	bpatch patch27_6,mem_patch27
+	enable le
+	hjam 7,rfen_ulp			/* enable ulp */
+	branch check_ble_disabled
+
+le_disable:
+	set1 mark_ext_patch,mark
+	bpatch patch27_7,mem_patch27
+	disable le
+	hjam 3,rfen_ulp
+	arg 0,stop_watch
+	rtn
+	
+le_prep:
+	disable enable_crc
+	disable enable_white
+	fetch 3,mem_le_crcinit
+	iforce crc24_init
+	fetch 1,mem_le_ch_mapped
+	reverse pdata,temp
+	set1 1,temp
+	rshift temp,white_init
+	rtn
+	
+
+lerx_setfreq:
+	call le_setfreq
+	call set_freq_rx
+	setarg param_pll_setup
+	call sleep
+	branch rf_rx_enable
+
+letx_setfreq:
+	branch txon,match
+	call le_setfreq
+	branch set_freq_tx
+le_setfreq:
+	set1 mark_ext_patch,mark
+	bpatch patch28_0,mem_patch28
+	call set_sync_on
+	fetch 1, mem_le_testtype
+	nbranch le_ctf_test,blank
+	fetch 1,mem_le_ch_mapped
+	sub pdata,36,null
+	branch le_ctf_normal,positive
+	force 0,temp
+	rtneq 37
+	force 24,temp
+	rtneq 38
+	force 78,temp
+	rtn
+	
+le_ctf_normal:
+	sub pdata,10,null
+	branch le_ctf_low,positive
+	increase 1,pdata
+	
+le_ctf_low:	
+	lshift pdata,pdata
+	add pdata,2,temp
+	rtn
+	
+le_ctf_test:
+	fetch 1,mem_le_ch_mapped
+	lshift pdata,temp
+	rtn
+
+le_sca_map:
+	arg 500,temp
+	rtn blank
+	arg 250,temp
+	rtneq 1
+	arg 150,temp
+	rtneq 2
+	arg 100,temp
+	rtneq 3
+	arg 75,temp
+	rtneq 4
+	arg 50,temp
+	rtneq 5
+	arg 40,temp
+	rtneq 6
+	arg 20,temp
+	rtn
+
+
+	
+le_adv_access:
+	setarg 0x8e89be
+	lshift8 pdata,pdata
+	or_into 0xd6,pdata
+	iforce access
+	setarg 0x555555
+	store 3,mem_le_crcinit
+	rtn
+
+le_setup:
+	set1 mark_ext_patch,mark
+	bpatch patch28_1,mem_patch28
+	enable swfine
+	fetch 4,mem_le_access
+	iforce access
+	call le_map_channel
+	setarg 0x200
+	branch le_setup_master,master
+	fetch 2,mem_le_receive_window
+	rshift pdata,pdata
+le_setup_master:
+	arg param_pll_setup,temp
+	iadd temp,pdata
+	call ahead_window
+	deposit clke
+	store 6,mem_le_rxon_ts
+	rtn
+
+le_next_adv_channel:
+	set1 mark_ext_patch,mark
+	bpatch patch28_2,mem_patch28
+	fetch 1,mem_le_ch_mapped
+	increase 1,pdata
+	store 1,mem_le_ch_mapped
+	rtnne 40
+	jam 37,mem_le_ch_mapped
+	rtn	
+
+le_context_nexthop:
+	set1 mark_ext_patch,mark
+	bpatch patch28_3,mem_patch28
+	add rega,coffset_mode,contr
+	ifetch 1,contr
+	rtnbit0 mode_le
+	add rega,coffset_le_event_cnt,contw
+	ifetch 2,contw
+	increase 1,pdata
+	istore 2,contw
+	add rega,coffset_le_hop,contr
+	ifetch 1,contr
+	add rega,coffset_le_ch,contw
+	ifetcht 1,contw
+	iadd temp,pdata
+	sub pdata,36,null
+	branch le_nexthop_nowrap,positive
+	increase -37,pdata
+le_nexthop_nowrap:
+	istore 1,contw
+	rtn
+
+
+le_calc_channel_map:
+	set1 mark_ext_patch,mark
+	bpatch patch28_4,mem_patch28
+	fetch 5,mem_le_channel_map
+	force 0,temp
+	force 37,loopcnt
+le_count_channels_loop:
+	bbit0 0,le_count_channels_notused
+	increase 1,temp
+le_count_channels_notused:
+	rshift pdata,pdata
+	loop le_count_channels_loop
+	add temp,-1,pdata
+	store 1,mem_le_channels
+	rtn
+
+le_map_channel:
+	set1 mark_ext_patch,mark
+	bpatch patch28_5,mem_patch28
+	fetch 1,mem_le_ch
+	iforce queue
+	fetcht 5,mem_le_channel_map
+	qisolate1 temp
+	branch le_map_channel_end,true
+le_map_channel_next:
+	set1 mark_ext_patch,mark
+	bpatch patch28_6,mem_patch28
+	fetch 1,mem_le_channels
+	isub queue,pdata
+	branch le_map_channel_cont,positive
+	sub pdata,-1,queue
+	branch le_map_channel_next
+le_map_channel_cont:
+	copy queue,loopcnt
+	force 0,queue
+le_map_channel_loop:
+	qisolate1 temp
+	branch le_map_channel_skip,true
+	increase 1,loopcnt
+le_map_channel_skip:
+	deposit loopcnt
+	branch le_map_channel_end,blank
+	increase 1,queue
+	increase -1,loopcnt
+	branch le_map_channel_loop
+le_map_channel_end:
+	deposit queue
+	store 1,mem_le_ch_mapped
+	rtn
+
+
+le_wait_tx:
+	branch le_wait_master,master
+	until null,timeout
+	rtn
+	
+le_wait_master:
+	arg 0xea0,timeup
+	until clkn_rt,meet
+	rtn
+
+le_receive_adv:
+	disable swfine
+	fetch 2,mem_le_scan_window
+	copy pdata,timeup
+	branch le_receive_packet
+
+
+le_receive_slave:
+	set1 mark_ext_patch,mark
+	bpatch patch28_7,mem_patch28
+	enable swfine
+	fetch 2,mem_le_receive_window
+	fetcht 4,mem_le_transmit_window
+	iadd temp,timeup
+le_receive_packet:
+	call lerx_setfreq
+le_receive_rxon:
+	set1 mark_ext_patch,mark
+	bpatch patch29_0,mem_patch29
+	call le_prep
+	disable match
+	enable decode_fec0
+	enable is_rx
+	disable is_tx
+	copy timeup,stop_watch
+	correlate null,timeout
+	branch le_receive_on_attempt,attempt
+	copy clke,temp
+	storet 6,mem_sync_clke
+le_receive_on_attempt:
+	nbranch end_of_packet,sync
+	branch le_receive_skip,attempt
+	arg param_clke_cal_le,clke_rt
+	copy bt_clk,clke_bt
+	fetch 1,mem_le_state
+	bbit0 lestate_got_first_packet,le_receive_skip
+	call lpm_adjust_clk,wake
+le_receive_skip:
+	set1 mark_ext_patch,mark
+	bpatch patch29_1,mem_patch29
+	call save_rssi
+	enable enable_white
+	enable enable_crc
+	parse demod,bucket,8
+	rshift3 pwindow,pdata
+	store 1,mem_le_rxbuf
+	parse demod,bucket,8
+	rshift3 pwindow,pdata
+	istore 1,contw
+	and pdata,0x3f,loopcnt
+	branch lerx_nopayload,zero
+	
+lerx_loop:
+	parse demod,bucket,8
+	rshift3 pwindow,pdata
+	istore 1,contw
+	loop lerx_loop
+	
+lerx_nopayload:
+	set1 mark_ext_patch,mark
+	bpatch patch29_2,mem_patch29
+	parse demod,bucket,24	
+	enable swfine
+	arg param_sifs,stop_watch		// start SIFS timer after last bit of crc
+	rshift32 pdata,pdata
+	rshift16 pdata,pdata
+	istore 3,contw
+	branch end_of_packet,crc_failed
+	enable match
+	fetch 1,mem_last_freq
+	add pdata,2,rega
+	call rf_write_freq				/* set frequency to tx mode freq */
+	disable decode_fec0
+	branch set_sync_on
+
+le_transmit_receive_sifs:
+	set1 mark_ext_patch,mark
+	bpatch patch29_3,mem_patch29
+	call le_transmit
+	fetcht 1,mem_last_freq
+	call set_freq_rx
+	call rf_rx_enable
+	enable swfine
+	arg 5000,timeup	// about 417us
+	branch le_receive_rxon
+
+le_transmit_norx:
+	call le_transmit
+	branch end_of_packet
+	
+le_transmit:
+	set1 mark_ext_patch,mark
+	bpatch patch29_4,mem_patch29
+	call le_prep
+	call letx_setfreq
+	set1 TXGFSK,radio_ctrl
+	enable encode_fec0
+	enable is_tx
+	disable is_rx
+	call le_wait_tx
+	rshift16 access,pdata
+	rshift8 pdata,pdata
+	rshift4 pdata,pdata
+	inject mod,40
+	enable enable_white
+	enable enable_crc
+	set1 mark_ext_patch,mark
+	bpatch patch29_5,mem_patch29
+	fetch 1,mem_le_txheader
+	inject mod,8
+	ifetch 1,contr
+	and pdata,0x3f,loopcnt
+	inject mod,8
+	branch letr_nopayload,zero
+letr_loop:
+	ifetch 1,contr
+	inject mod,8
+	loop letr_loop
+	
+letr_nopayload:
+	enable enable_parity
+	inject mod,24
+	disable enable_parity
+	until null,tx_clear
+	nop 100          /* flush out the last bit */
+	disable encode_fec0
+	rtn
+	
+le_send_adv_ind:
+	set1 mark_ext_patch,mark
+	bpatch patch29_6,mem_patch29
+	fetch 1,mem_le_adv_type
+	beq ADV_DIRECT_IND,le_send_adv_direct_ind
+	fetch 1,mem_le_adv_own_addr_type
+	lshift4 pdata,pdata
+	lshift2 pdata,pdata
+	store 1,mem_le_txheader
+	fetcht 1,mem_le_adv_data_len
+	add temp,6,pdata
+	store 1,mem_le_txlen
+	fetch 6,mem_le_lap
+	store 6,mem_le_txpayload
+	copy temp,loopcnt
+	arg mem_le_adv_data,contr
+	call memcpy
+	branch le_send_adv_transmit
+le_send_adv_direct_ind:
+	fetcht 2,mem_le_notify_handle
+	call le_att_check_notification_enable
+	copy rega,contw
+	setarg 1
+	istore 1,contw
+	fetch 1,mem_le_adv_direct_addr_type
+	lshift4 pdata,pdata
+	lshift2 pdata,pdata
+	increase 1,pdata
+	store 1,mem_le_txheader
+	setarg 12
+	store 1,mem_le_txlen
+	fetch 6,mem_le_lap
+	store 6,mem_le_txpayload
+	fetch 6,mem_hci_plap
+	istore 6,contw
+le_send_adv_transmit:
+	set1 mark_ext_patch,mark
+	bpatch patch29_7,mem_patch29
+	fetch 1,mem_le_adv_transmit
+	increase 1,pdata
+	store 1,mem_le_adv_transmit
+	arg 1800,stop_watch
+	disable match
+	branch le_transmit_receive_sifs
+	
+le_send_scan_request:
+	set1 mark_ext_patch,mark
+	bpatch patch2a_0,mem_patch2a
+	fetch 1,mem_le_scan_type
+	rtnne LE_SCAN_TYPE_ACTIVE,pdata
+	fetch 1,mem_le_adv_transmit
+	increase 1,pdata
+	store 1,mem_le_adv_transmit
+	arg 0x0c03,temp// length + SCAN_REQ PDU
+	fetch 1,mem_le_scan_own_addr_type
+	nsetflag blank,LE_SENDER_ADDR_BIT,temp
+	copy rega,pdata
+	nsetflag blank,LE_RECEIVER_ADDR_BIT,temp	
+	storet 2,mem_le_txheader
+	fetch 6,mem_le_lap
+	istore 6,contw
+	fetch 6,mem_le_plap
+	istore 6,contw
+	branch le_transmit_receive_sifs
+
+
+le_send_scan_response:
+	set1 mark_ext_patch,mark
+	bpatch patch2a_1,mem_patch2a
+	arg SCAN_RSP,temp
+	fetch 1,mem_le_adv_own_addr_type
+	nsetflag blank,LE_SENDER_ADDR_BIT,temp
+	storet 1,mem_le_txheader
+	fetcht 1,mem_le_scan_data_len
+	add temp,6,pdata
+	store 1,mem_le_txlen
+	fetch 6,mem_le_lap
+	store 6,mem_le_txpayload
+	arg mem_le_scan_data,contr
+	copy temp,loopcnt
+	call memcpy
+	branch le_transmit_norx
+
+
+le_connect_request:
+	set1 mark_ext_patch,mark
+	bpatch patch2a_2,mem_patch2a
+	force -1,pdata
+	setsect 2,1
+	store 5,mem_le_channel_map
+	call le_calc_channel_map	
+	force 4,loopcnt
+	arg mem_le_access,contw
+	call generate_random_loop	
+	fetch 2,mem_le_conn_superto
+	store 2,mem_le_superto
+le_con_req_hop_retry:
+	random pdata
+	and_into 0xf,pdata
+	sub pdata,4,null
+	branch le_con_req_hop_retry,positive
+	store 1,mem_le_hop
+	store 1,mem_tmp1
+	set1 mark_ext_patch,mark
+	bpatch patch2a_3,mem_patch2a
+	fetcht 2,mem_le_conn_interval
+	storet 2,mem_le_tsniff	
+	copy temp,regc			// tsniff in regc
+	add clkn_bt,7,pdata			// leave space for offset
+	idiv regc
+	call wait_div_end
+	remainder rega
+	isub rega,pdata
+	iadd regc,pdata
+	fetcht 2,mem_le_dsniff
+	iadd temp,pdata
+	store 4,mem_le_anchor
+	isub clkn_bt,rega
+	increase -6,rega			// window offset
+	arg 0x2205,regb			// length & CONN_REQ PDU
+	fetch 1,mem_le_conn_own_addr_type
+	nsetflag blank,LE_SENDER_ADDR_BIT,regb
+	fetch 1,mem_le_conn_peer_addr_type
+	nsetflag blank,LE_RECEIVER_ADDR_BIT,regb
+	copy regb,pdata
+	store 2,mem_le_txheader
+	fetch 6,mem_le_lap
+	istore 6,contw//own addr
+	fetch 6,mem_le_plap
+	istore 6,contw// peer addr
+	fetch 4,mem_le_access
+	istore 4,contw
+	random pdata
+	istore 2,contw				/* crc init */
+	random pdata
+	istore 1,contw
+	force 2,pdata				/* window size */	
+	istore 1,contw
+	rshift2 rega,pdata
+	istore 2,contw				/* window offset */
+	rshift2 regc,pdata			
+	istore 2,contw				/* conn Interval */
+	set1 mark_ext_patch,mark
+	bpatch patch2a_4,mem_patch2a
+	fetch 2,mem_le_conn_latency			/* slave latency */
+	istore 2,contw
+	fetch 2,mem_le_conn_superto
+	istore 2,contw
+	fetch 5,mem_le_channel_map
+	istore 5,contw				/* channel map */
+	fetch 1,mem_le_hop
+	arg param_le_sca,temp
+	ior temp,pdata
+	istore 1,contw
+	call le_transmit_norx
+	setarg mem_le_txheader
+	add pdata,18,contr
+	ifetch 3,contr
+	store 3,mem_le_crcinit
+	rtn
+		
+le_init_adv:
+	set1 mark_ext_patch,mark
+	bpatch patch2a_5,mem_patch2a
+	disable master
+	branch le_adv_access
+	
+
+
+le_update_param:
+	set1 mark_ext_patch,mark
+	bpatch patch2a_6,mem_patch2a
+	fetch 1,mem_le_state
+	rtnbit0 lestate_update_param
+	fetch 2,mem_le_event_count
+	fetcht 2,mem_le_instant
+	isub temp,pdata
+	nrtn positive
+	fetch 1,mem_le_state
+	set0 lestate_update_param,pdata
+	set0 lestate_got_first_packet,pdata
+	store 1,mem_le_state
+	fetch 4,mem_le_anchor
+	fetcht 2,mem_le_tsniff
+	isub temp,rega
+	set1 mark_ext_patch,mark
+	bpatch patch2a_7,mem_patch2a
+	fetch 1,mem_le_new_param
+	store 1,mem_le_window_size
+	ifetcht 2,contr
+	ifetch 2,contr
+	lshift2 pdata,pdata
+	store 2,mem_le_tsniff
+	lshift2 temp,temp
+	iadd temp,pdata
+	ifetcht 4,contr
+	storet 4,mem_le_slave_latency	// and superTO
+	iadd rega,pdata
+	store 4,mem_le_anchor
+	branch le_receive_window_size
+
+le_update_channel_map:
+	set1 mark_ext_patch,mark
+	bpatch patch2b_0,mem_patch2b
+	fetch 1,mem_le_state
+	rtnbit0 lestate_update_map
+	fetch 2,mem_le_event_count
+	fetcht 2,mem_le_instant
+	isub temp,pdata
+	nrtn positive
+	fetch 1,mem_le_state
+	set0 lestate_update_map,pdata
+	store 1,mem_le_state
+ 	fetch 5,mem_le_new_map
+	store 5,mem_le_channel_map
+	branch le_calc_channel_map	
+	
+	
+le_acknowledge:
+	set1 mark_ext_patch,mark
+	bpatch patch2b_1,mem_patch2b
+	call le_supervision_flush
+	call le_check_wak
+	fetch 1,mem_le_rxbuf
+	rshift pdata,pdata
+	ixor temp,pdata
+	isolate1 nesn,pdata
+	setflag true,mark_old_packet,mark	/* retransmit */
+	fetch 1,mem_le_rxbuf+1			
+	branch le_ack_unenc,blank		/* empty packet, no decryption */
+	fetch 1,mem_le_state
+	bbit0 lestate_encryption,le_ack_unenc
+	call load_sk
+	call le_decrypt
+	nrtn blank
+le_ack_unenc:
+	rtnmark1 mark_old_packet
+	fetcht 1,mem_le_arq
+	setflip nesn,temp
+	storet 1,mem_le_arq
+	branch le_parse
+	
+le_check_wak:
+	set1 mark_ext_patch,mark
+	bpatch patch2b_2,mem_patch2b
+	fetcht 1,mem_le_arq
+	isolate0 wak,temp
+	rtn true
+	fetch 1,mem_le_rxbuf
+	lshift pdata,pdata
+	ixor temp,pdata
+	rtnbit0 sn			/* received NESN is same as SN, NAK */
+	set0 wak,temp
+	setflip sn,temp
+	storet 1,mem_le_arq
+	compare 3,temp,3
+	nrtn true
+	fetch 1,mem_le_txpayload
+	rtnne LL_START_ENC_REQ
+	fetch 1,mem_le_state
+	set1 lestate_encryption,pdata
+	store 1,mem_le_state
+	rtn	
+	
+le_wait_adv:
+	set1 mark_ext_patch,mark
+	bpatch patch2b_3,mem_patch2b
+	call le_next_adv_channel
+	call le_receive_adv
+	fetch 1,mem_le_adv_waitcnt
+	increase 1,pdata
+	store 1,mem_le_adv_waitcnt
+	rtn
+
+le_scan:
+	set1 mark_ext_patch,mark
+	bpatch patch2b_4,mem_patch2b
+	fetch 1,mem_le_scan_enable
+	rtnne LE_SCAN_ENABLE
+	arg le_scan_interval_timer,queue
+	call timer_check
+	nrtn blank
+	fetch 2,mem_le_scan_interval
+	fetcht 2,mem_le_scan_window
+	isub temp,pdata
+	arg le_scan_interval_timer,queue
+	call timer_init
+	disable master
+	call le_init_adv
+	call le_wait_adv
+	nrtn match
+	set1 mark_ext_patch,mark
+	bpatch patch2b_5,mem_patch2b
+	fetch 6,mem_le_rxbuf+2
+	store 6,mem_le_plap
+	call le_scan_dongle
+	call le_scan_addr_to_uart
+
+	fetch 1,mem_le_adv_rcv
+	increase 1,pdata
+	store 1,mem_le_adv_rcv
+	call le_create_conn
+	rtn master
+	call hci_send_le_adv_report_event
+	call le_send_scan_request
+	nrtn match
+	set1 mark_ext_patch,mark
+	bpatch patch2b_6,mem_patch2b
+	fetch 1,mem_le_scanrsp_rcv
+	increase 1,pdata
+	store 1,mem_le_scanrsp_rcv
+	fetch 9,mem_le_rxbuf+8
+	store 9,mem_tmp_buffer
+	branch hci_send_le_adv_report_event
+	
+le_create_conn:
+	set1 mark_ext_patch,mark
+	bpatch patch2b_7,mem_patch2b
+	fetch 1,mem_cmd_le_create_conn
+	rtnne hci_cmd_le_create_conn,pdata
+	fetch 6,mem_le_plap
+	fetcht 6,mem_le_conn_peer_addr
+	isub temp,null
+	nrtn zero
+	call context_new
+	nrtn zero
+	call le_connect_request
+	call le_init_master
+	set1 mark_ext_patch,mark
+	bpatch patch2c_0,mem_patch2c
+	jam 0,mem_hci_cmd
+	jam 0,mem_le_peer_sca
+	fetch 1,mem_device_option
+	bne dvc_op_dongle,le_create_conn_ndongle
+	jam CONN_SM_SEND_WRITE_REQ,mem_le_conn_sm
+le_create_conn_ndongle:
+	arg 0,temp//status successful
+	call hci_send_le_conn_complete
+	jam 0,mem_le_scan_enable
+	jam 0,mem_cmd_le_create_conn
+	jam XT_LL_VERSION_IND,mem_fifo_temp
+	call le_xtype_fifo_in
+	branch context_save
+	
+le_scan_check_sender_addr_type:
+	arg 1,rega// sender_addr_type
+	fetch 1,mem_le_rxbuf
+	rtnbit1 LE_SENDER_ADDR_BIT
+	arg 0,rega
+	rtn
+
+le_xtype_fifo_count:
+	arg mem_le_xtype_fifo,contr
+	branch fifo_content_count
+	
+le_xtype_fifo_is_empty:
+	arg mem_le_xtype_fifo,rega
+	branch fifo_is_empty
+	
+le_xtype_fifo_is_full:
+	arg mem_le_xtype_fifo,rega
+	branch fifo_is_full
+	
+le_xtype_fifo_is_near_full:
+	arg mem_le_xtype_fifo,rega
+	branch fifo_is_near_full
+	
+le_xtype_fifo_in:
+	arg mem_le_xtype_fifo,rega	
+	branch fifo_in
+	
+le_prepare_tx:
+	set1 mark_ext_patch,mark
+	bpatch patch2c_1,mem_patch2c
+	fetch 1,mem_le_arq
+	rtnbit1 wak
+	arg mem_le_xtype_fifo,rega
+	call fifo_out
+	nbranch le_prepare_tx_cmd,blank
+	fetch 1,mem_device_option
+	bne dvc_op_hci,le_send_empty
+	arg 0,type
+	call hci_rx_packet //check acl packet
+	copy type,pdata
+	nrtn blank
+	branch le_send_empty
+le_prepare_tx_cmd:
+	copy pdata,temp
+	set1 mark_ext_patch,mark
+	bpatch patch2c_2,mem_patch2c
+	copy temp,pdata
+	bbit0 5,le_prepare_l2cap
+	force 3,type
+	set0 5,pdata
+	store 1,mem_le_txpayload
+	set1 mark_ext_patch,mark
+	bpatch patch2c_3,mem_patch2c
+	fetch 1,mem_le_txpayload
+	beq LL_CONNECTION_UPDATE_REQ,le_send_connection_update_req
+	beq LL_CHANNEL_MAP_REQ,le_send_channel_map_req
+	beq LL_TERMINATE_IND,le_send_terminate_ind
+	beq LL_ENC_REQ,le_send_enc_req
+	beq LL_ENC_RSP,le_send_enc_rsp
+	beq LL_START_ENC_REQ,le_send_start_enc_req
+	beq LL_START_ENC_RSP,le_send_start_enc_rsp
+	beq LL_UNKNOWN_RSP,le_send_unknown_rsp
+	beq LL_FEATURE_REQ,le_send_feature
+	beq LL_FEATURE_RSP,le_send_feature
+	beq LL_PAUSE_ENC_REQ,le_send_pause_enc_req
+	beq LL_PAUSE_ENC_RSP,le_send_pause_enc_rsp
+	beq LL_VERSION_IND,le_send_version_ind
+	beq LL_REJECT_IND,le_send_reject_ind
+	beq LL_CONNECTION_PARAM_REQ,le_send_conn_param_req  //ACL PACKET
+	branch assert
+	
+le_prepare_l2cap:
+	jam 0,mem_le_txcid+1
+	force 2,type
+	bbit0 6,le_prepare_att
+	beq ATTOP_WRITE_COMMAND,le_prepare_att
+	beq ATTOP_SIGNED_WRITE_COMMAND,le_prepare_att
+	jam LE_L2CAP_CID_SMP,mem_le_txcid
+	set0 6,pdata
+	store 1,mem_le_l2cap
+le_prepare_smp:
+	set1 mark_ext_patch,mark
+	bpatch patch2c_4,mem_patch2c
+	fetch 1,mem_le_l2cap
+le_prepare_smp0:
+	beq SMP_PAIRING_REQUEST,le_send_smp_pairing_request             
+	beq SMP_PAIRING_RESPONSE,le_send_smp_pairing_response            
+	beq SMP_PAIRING_CONFIRM,le_send_smp_pairing_confirm             
+	beq SMP_PAIRING_RANDOM,le_send_smp_pairing_random              
+	beq SMP_PAIRING_FAILED,le_send_smp_pairing_failed              
+	beq SMP_ENCRYPTION_INFORMATION,le_send_smp_encryption_information      
+	beq SMP_MASTER_IDENTIFICATION,le_send_smp_master_identification       
+	beq SMP_IDENTITY_INFORMATION,le_send_smp_identity_information        
+	beq SMP_IDENTITY_ADDRESS_INFORMATION,le_send_smp_identity_address_information
+	beq SMP_SIGNING_INFORMATION,le_send_smp_signing_information         
+	beq SMP_SECURITY_REQUEST,le_send_smp_security_request            
+	branch assert
+	
+le_prepare_att:
+	jam LE_L2CAP_CID_ATT,mem_le_txcid
+	store 1,mem_le_l2cap
+	set1 mark_ext_patch,mark
+	bpatch patch2c_5,mem_patch2c
+le_prepare_att0:
+	fetch 1,mem_le_l2cap
+	beq ATTOP_ERROR_RESPONSE,le_send_att_error_response
+	beq ATTOP_EXCHANGE_MTU_REQUEST,le_send_att_exchange_mtu
+	beq ATTOP_EXCHANGE_MTU_RESPONSE,le_send_att_exchange_mtu
+	beq ATTOP_FIND_INFORMATION_REQUEST,le_send_att_find_information_request
+	beq ATTOP_FIND_INFORMATION_RESPONSE,le_send_att_find_information_response
+	beq ATTOP_FIND_BY_TYPE_VALUE_REQUEST,le_send_att_find_by_type_value_request
+	beq ATTOP_FIND_BY_TYPE_VALUE_RESPONSE,le_send_att_find_by_type_value_response
+	beq ATTOP_READ_BY_TYPE_REQUEST,le_send_att_read_by_type_request
+	beq ATTOP_READ_BY_TYPE_RESPONSE,le_send_att_read_by_type_response
+	beq ATTOP_READ_REQUEST,le_send_att_read_request
+	beq ATTOP_READ_RESPONSE,le_send_att_read_response
+	beq ATTOP_READ_BLOB_REQUEST,le_send_att_read_blob_request
+	beq ATTOP_READ_BLOB_RESPONSE,le_send_att_read_blob_response
+	beq ATTOP_READ_MULTIPLE_REQUEST,le_send_att_read_multiple_request
+	beq ATTOP_READ_MULTIPLE_RESPONSE,le_send_att_read_multiple_response
+	beq ATTOP_READ_BY_GROUP_TYPE_REQUEST,le_send_att_read_by_group_type_request
+	beq ATTOP_READ_BY_GROUP_TYPE_RESPONSE,le_send_att_read_by_group_type_response
+	beq ATTOP_WRITE_REQUEST,le_send_att_write_request
+	beq ATTOP_WRITE_RESPONSE,le_send_att_write_response
+	beq ATTOP_PREPARE_WRITE_REQUEST,le_send_att_prepare_write_request
+	beq ATTOP_PREPARE_WRITE_RESPONSE,le_send_att_prepare_write_response
+	beq ATTOP_EXECUTE_WRITE_REQUEST,le_send_att_execute_write_request
+	beq ATTOP_EXECUTE_WRITE_RESPONSE,le_send_att_execute_write_response
+	beq ATTOP_HANDLE_VALUE_NOTIFICATION,le_send_att_handle_value_notification
+	beq ATTOP_HANDLE_VALUE_INDICATION,le_send_att_handle_value_indication
+	beq ATTOP_HANDLE_VALUE_CONFIRMATION,le_send_att_handle_value_confirmation
+	beq ATTOP_WRITE_COMMAND,le_send_att_write_command
+	beq ATTOP_SIGNED_WRITE_COMMAND,le_send_att_signed_write_command
+	beq EMPTY_LE_DATA_PRE,le_send_empty_le_data_pre
+	beq EMPTY_LE_DATA,le_send_empty_le_data
+	branch assert
+	
+le_send_empty_le_data_pre:
+	jam ATTOP_READ_BY_GROUP_TYPE_REQUEST,mem_fifo_temp
+	call le_xtype_fifo_in
+	
+le_send_empty_le_data:
+	setarg 0x0011
+	store 2,mem_le_txheader
+	fetch 1,mem_le_arq
+	set1 wak,pdata
+	store 1,mem_le_arq
+	jam ATTOP_WRITE_REQUEST,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_send_connection_update_req:
+	force 12,temp
+	branch le_send_packet
+	
+le_send_channel_map_req:
+	force 8,temp
+	branch le_send_packet
+	
+le_send_terminate_ind:
+	force 2,temp
+	branch le_send_packet
+	
+le_send_enc_req:
+	force 0,pdata
+	istore 8,contw					/* RAND=0 */
+	istore 2,contw					/* EDIV=0 */
+	copy contw,temp
+	arg mem_le_skdm,contw
+	force 8,loopcnt
+	call generate_random_loop
+	fetch 8,mem_le_skdm
+	istore 8,temp					/* SKDm */
+	copy contw,temp
+	arg mem_le_ivm,contw
+	force 4,loopcnt
+	call generate_random_loop
+	fetch 4,mem_le_ivm
+	istore 4,temp					/* IVm */
+	force 23,temp
+	branch le_send_packet
+	
+le_send_enc_rsp:
+	copy contw,temp
+	arg mem_le_skds,contw
+	force 8,loopcnt
+	call generate_random_loop
+	fetch 8,mem_le_skds
+	istore 8,temp					/* SKDs */
+	copy contw,temp
+	arg mem_le_ivs,contw
+	force 4,loopcnt
+	call generate_random_loop
+	fetch 4,mem_le_ivs
+	istore 4,temp					/* IVs */
+	call generate_sk
+	jam XT_LL_START_ENC_REQ,mem_fifo_temp
+	call le_xtype_fifo_in
+	force 13,temp
+	branch le_send_packet
+	
+le_send_start_enc_req:
+	force 1,temp
+	branch le_send_packet
+	
+le_send_start_enc_rsp:
+	force 1,temp
+	branch le_send_packet,master
+	jam XT_SMP_ENCRYPTION_INFORMATION,mem_fifo_temp
+	call le_xtype_fifo_in
+	force 1,temp
+	branch le_send_packet
+	
+le_send_unknown_rsp:
+	force 2,temp
+	branch le_send_packet
+	
+le_send_feature:
+	setarg param_le_features
+	istore 8,contw
+	force 9,temp
+	branch le_send_packet
+	
+le_send_pause_enc_req:
+	force 6,temp
+	branch le_send_packet
+	
+le_send_pause_enc_rsp:
+	force 6,temp
+	branch le_send_packet
+	
+le_send_version_ind:
+	setarg param_le_version
+	istore 3,contw
+	setarg param_le_subversion
+	istore 2,contw
+	force 6,temp
+	branch le_send_packet
+	
+le_send_reject_ind:
+	force 2,temp
+	branch le_send_packet
+
+le_send_conn_param_req:
+	increase -1,contw
+	setarg 0x000c
+	istore 2,contw //Length
+	setarg 0x0005
+	istore 2,contw	//CID
+	setarg 0xb412
+	istore 2,contw		
+	setarg 0x0008
+	istore 2,contw
+	setarg 0x0008
+	istore 2,contw //min interval
+	setarg 0x0010
+	istore 2,contw //max interval
+	setarg 0
+	istore 2,contw //latency
+	setarg 0x012c
+	istore 2,contw //timeout	
+	call le_send_autolen
+	force 2,type
+	branch le_send_packet
+
+le_send_smp_pairing_request:
+	setarg 0x1000401
+	store 4,mem_le_preq
+	setarg 0x070710
+	istore 3,contw
+	fetch 6,mem_le_preq+1
+	store 6,mem_le_l2cap_response
+	force 11,temp
+	branch le_send_packet
+	
+le_send_smp_pairing_response:
+	setarg param_smp_paring_response	
+	store 4,mem_le_pres
+	setarg param_smp_key_dist
+	istore 3,contw
+	fetch 6,mem_le_pres+1
+	store 6,mem_le_l2cap_response
+	force 11,temp
+	branch le_send_packet
+	
+le_send_smp_pairing_confirm:
+	call generate_confirm
+	arg mem_le_l2cap_response,contw
+	call store_aes_result
+	force 21,temp
+	branch le_send_packet
+	
+le_send_smp_pairing_random:
+	fetch 8,mem_le_mrand
+	branch le_send_smp_mrandom,master
+	fetch 8,mem_le_srand
+	
+le_send_smp_mrandom:
+	call le_send_smp_128
+	branch le_send_packet
+	
+le_send_smp_pairing_failed:
+	force 6,temp
+	branch le_send_packet
+	
+le_send_smp_encryption_information:
+	jam BT_EVT_LE_ENC_INFO,mem_fifo_temp
+	call ui_ipc_send_event
+	jam XT_SMP_MASTER_IDENTIFICATION,mem_fifo_temp
+	call le_xtype_fifo_in
+	arg mem_le_my_ltk,contw
+	call generate_random
+	fetch 8,mem_le_my_ltk
+	fetch 8,mem_le_ltk
+	call le_send_smp_128
+	branch le_send_packet
+	
+le_send_smp_master_identification:
+	jam XT_SMP_IDENTITY_INFORMATION,mem_fifo_temp
+	call le_xtype_fifo_in
+	arg mem_le_l2cap_response,contw
+	force 8,loopcnt
+	call generate_random_loop
+	force 15,temp
+	branch le_send_packet
+	
+le_send_smp_identity_information:
+	jam XT_SMP_IDENTITY_ADDRESS_INFORMATION,mem_fifo_temp
+	call le_xtype_fifo_in
+	arg mem_le_l2cap_response,contw
+	call generate_random
+	branch le_send_autolen
+	
+le_send_smp_identity_address_information:
+	jam XT_SMP_SIGNING_INFORMATION,mem_fifo_temp
+	call le_xtype_fifo_in
+	force 0,pdata						/* address type:PUBLIC */
+	store 1,mem_le_l2cap_response
+	fetch 6,mem_le_lap
+	istore 6,contw
+	branch le_send_autolen
+	
+le_send_smp_signing_information:
+	arg mem_le_l2cap_response,contw
+	call generate_random
+	branch le_send_autolen
+	
+le_send_smp_security_request:
+	force 6,temp
+	branch le_send_packet
+	
+le_send_smp_128:
+	store 8,mem_le_l2cap_response
+	ifetch 8,contr
+	istore 8,contw
+	force 21,temp
+	rtn
+
+le_send_att_error_response_notfound:	
+	jam ATT_ERR_ATTRIBUTE_NOT_FOUND,mem_le_err_code
+le_send_att_error_response:	
+	jam ATTOP_ERROR_RESPONSE,mem_le_l2cap
+	fetch 3,mem_le_att_opcode
+	store 3,mem_le_l2cap_response
+	fetch 1,mem_le_err_code
+	istore 1,contw
+	branch le_send_autolen
+	
+le_send_att_exchange_mtu:
+	setarg param_le_mtu
+	istore 2,contw
+	branch le_send_autolen
+	
+le_send_att_find_information_request:
+	fetch 2,mem_le_search_handle_start
+	store 2,mem_le_l2cap_response
+	fetch 2,mem_le_search_handle_end
+	istore 2,contw
+	branch le_send_autolen
+	
+	
+
+le_send_att_find_information_response:
+	force 1,pdata
+	store 1,mem_le_l2cap_response
+	call le_init_attlist_search
+le_send_att_find_information_res_loop:
+	call le_att_handle_inrange
+	branch le_send_att_find_information_res_end,blank
+	nbranch le_send_att_find_information_res_next,positive
+	disable user
+	istore 2,contw
+	ifetch 2,contr
+	istore 2,contw
+le_send_att_find_information_res_cont:
+	ifetch 1,contr
+	iadd contr,contr
+	branch le_send_att_find_information_res_loop
+le_send_att_find_information_res_next:
+	increase 2,contr
+	branch le_send_att_find_information_res_cont
+le_send_att_find_information_res_end:
+	branch le_send_att_error_response_notfound,user
+	branch le_send_autolen
+
+	
+le_send_att_find_by_type_value_request:
+	fetch 2,mem_le_search_handle_start
+	branch le_send_empty_le_data,blank
+	store 2,mem_le_l2cap_response
+	fetch 2,mem_le_search_handle_end
+	//setarg 0xffff
+	istore 2,contw
+	fetch 2,mem_le_uuid
+	//setarg 0x2800
+	istore 2,contw
+	fetch 2,mem_le_search_att_type
+	//setarg 0x1801
+	istore 2,contw
+	branch le_send_autolen
+
+	
+le_send_att_find_by_type_value_response:
+	call le_start_end_handle_check_1
+	rtn user
+	fetcht 2,mem_le_uuid
+	setarg UUID_GATT_PRIMARY_SERVICE
+	isub temp,null
+	branch le_send_att_find_by_type_value_res_primary,zero
+	setarg UUID_GATT_SECONDARY_SERVICE
+	isub temp,null
+	branch le_send_att_error_response_notfound,zero
+	setarg UUID_GATT_INCLUDE
+	isub temp,null
+	branch le_send_att_error_response_notfound,zero
+	setarg UUID_GATT_CHARACTERISTIC
+	isub temp,null
+	branch le_send_att_error_response_notfound,zero
+	branch le_send_att_error_response_notfound
+	
+le_send_att_find_by_type_value_res_primary:
+	fetcht 2,mem_le_search_att_type
+	increase 2,contr
+	ifetch 1,contr
+	icopy regc //primary service number
+	increase 1,regc
+	
+le_send_att_find_by_type_value_res_primary_search_loop:
+         increase -1,regc
+         branch le_send_att_error_response_notfound,zero
+         ifetch 2,contr
+	isub temp,null
+	branch le_send_att_find_by_type_value_res_primary_search_end,zero
+	increase 4,contr
+	branch le_send_att_find_by_type_value_res_primary_search_loop
+	
+le_send_att_find_by_type_value_res_primary_search_end:
+	ifetch 2,contr
+	icopy rega//handle start
+	ifetch 2,contr
+	icopy regb//handle end	
+	call le_start_end_handle_check_2
+	rtn user
+	jam ATTOP_FIND_BY_TYPE_VALUE_RESPONSE,mem_le_l2cap
+	deposit rega
+	store 2,mem_le_l2cap_response
+	deposit regb
+	istore 2,contw
+	force 9,temp
+	branch le_send_packet
+	
+
+
+
+le_start_end_handle_check_1:
+	disable user
+	fetcht 2,mem_le_search_handle_start
+	fetch 2,mem_le_search_handle_end
+	isub temp,null
+	nbranch le_start_end_handle_check_1_fail,positive
+	deposit temp
+	rtnne 0
+         
+le_start_end_handle_check_1_fail:
+	enable user
+le_send_att_invalid_handle:
+	jam ATT_ERR_INVALID_HANDLE,mem_le_err_code
+	branch le_send_att_error_response
+	
+le_start_end_handle_check_2:
+	disable user
+	fetcht 2,mem_le_search_handle_start
+	deposit rega
+	isub temp,null
+	nbranch le_start_end_handle_check_2_fail,positive
+	fetch 2,mem_le_search_handle_end
+	isub regb,null
+	nbranch le_start_end_handle_check_2_fail,positive
+	deposit regb
+	isub rega,null
+	nbranch le_start_end_handle_check_2_fail,positive
+	rtn
+         
+le_start_end_handle_check_2_fail:
+	enable user
+	branch le_send_att_error_response_notfound
+
+	
+le_send_att_read_by_type_request:
+	fetch 2,mem_le_search_handle_start
+//	setarg 0x0001
+	istore 2,contw
+	fetch 2,mem_le_search_handle_end
+//	setarg 0x0018
+	istore 2,contw
+	fetch 2,mem_le_search_att_type
+	istore 2,contw
+	force 11,temp
+	branch le_send_packet
+
+	
+le_send_att_read_by_type_response:
+	fetcht 2,mem_le_search_att_type
+	setarg UUID_GATT_CHARACTERISTIC
+	isub temp,null
+	setarg 7
+	branch le_send_att_read_by_type_res_cont,zero
+	setarg UUID_GATT_PRIMARY_SERVICE
+	isub temp,null
+	setarg 6
+	branch le_send_att_read_by_type_res_cont,zero
+	branch le_send_att_error_response_notfound
+le_send_att_read_by_type_res_cont:
+	store 1,mem_le_l2cap_response
+	call le_init_attlist_search
+	force 3,alarm
+le_send_att_read_by_type_res_loop:
+	call le_att_handle_inrange
+	branch le_send_att_read_by_type_res_end,blank
+	nbranch le_send_att_read_by_type_res_next,positive
+	iforce rega
+	ifetch 2,contr
+	isub temp,null
+	nbranch le_send_att_read_by_type_res_next2,zero
+	disable user
+	deposit rega
+	istore 2,contw
+	ifetch 1,contr
+	add pdata,4,loopcnt
+	call memcpy
+	increase -1,alarm
+	branch le_send_att_read_by_type_res_end,zero
+	branch le_send_att_read_by_type_res_next2
+le_send_att_read_by_type_res_next:
+	increase 2,contr
+le_send_att_read_by_type_res_next2:
+	ifetch 1,contr
+	iadd contr,contr
+	branch le_send_att_read_by_type_res_loop
+le_send_att_read_by_type_res_end:
+	branch le_send_att_error_response_notfound,user
+	branch le_send_autolen
+
+	
+le_send_att_read_request:
+	fetch 1,mem_le_temp
+	//branch le_send_att_read_req_end,blank
+         increase -1,pdata
+         store 1,mem_le_temp
+         lshift pdata,pdata
+         //increase -2,pdata
+         iadd contr,contr
+         ifetcht 2,contr
+         storet 2,mem_le_l2cap_response
+	branch le_send_autolen
+	
+le_send_att_read_response:
+	fetcht 2,mem_le_att_handle
+	call le_att_get_handle_ptr
+	branch le_send_att_error_response_notfound,blank
+	ifetch 1,contr
+	branch le_send_autolen,blank
+	sub pdata,22,null
+	branch le_send_att_read_response_less,positive
+	force 22,pdata
+le_send_att_read_response_less:
+	icopy loopcnt
+	call memcpy
+	branch le_send_autolen
+
+	
+le_send_att_read_blob_request:
+	setarg 0x0003
+	store 2,mem_le_l2cap_response
+	setarg 0x0008
+	istore 2,contw
+	branch le_send_autolen
+	
+le_send_att_read_blob_response:
+	fetch 2,mem_le_att_offset
+	iforce rega
+	fetcht 2,mem_le_att_handle
+	call le_att_get_handle_ptr 
+	branch le_send_att_error_response_notfound,blank
+	ifetch 1,contr
+	isub rega,loopcnt
+	nbranch le_send_att_error_response_notfound,positive
+	sub loopcnt,22,null
+	branch le_send_att_read_blob_response_less,positive
+	force 22,loopcnt
+le_send_att_read_blob_response_less:
+	deposit rega
+	iadd contr,contr
+	call memcpy	
+	branch le_send_autolen
+	
+le_send_att_read_multiple_request:
+	setarg 0x0003
+	istore 2,contw
+	setarg 0x0007
+	istore 2,contw
+	setarg 0x0009
+	istore 2,contw
+	branch le_send_autolen
+	
+le_send_att_read_multiple_response:
+	fetch 1,mem_le_temp
+	icopy regc//handle number
+	arg mem_le_rxbuf+7,rega
+	arg mem_le_l2cap_response,regb
+	arg 0,timeup
+	disable user7
+
+le_send_att_read_multiple_response_loop:
+	copy rega,contr
+	ifetcht 2,contr
+	copy contr,rega
+	call le_att_get_handle_ptr 
+	branch le_send_att_read_multiple_response_end,blank
+	ifetch 1,contr
+	icopy loopcnt
+	iadd timeup,timeup
+	//deposit timeup
+	//store 1,0x1ff3
+	//branch loop	
+	sub timeup,24,null
+	nbranch le_send_att_read_multiple_response_end_1,positive
+	copy regb,contw
+	
+le_copy_att_value_loop_3:
+	ifetch 1,contr
+	istore 1,contw
+	loop le_copy_att_value_loop_3
+	copy contw,regb
+	enable user7
+	increase -1,regc
+	branch le_send_att_read_multiple_response_end,zero
+	branch le_send_att_read_multiple_response_loop
+
+le_send_att_read_multiple_response_end:
+	nbranch le_send_att_read_multiple_response_fail,user7
+	disable user7
+	copy timeup,temp
+	increase 5,temp
+	branch le_send_packet
+	
+le_send_att_read_multiple_response_end_1:
+	nbranch le_send_att_read_multiple_response_fail,user7
+	disable user7
+	deposit timeup
+	isub loopcnt,temp
+	increase 5,temp
+	branch le_send_packet
+	
+le_send_att_read_multiple_response_fail:
+	jam ATT_ERR_UNSUPPORTED_GROUP_TYPE,mem_le_err_code
+	branch le_send_att_error_response
+
+	
+le_send_att_read_by_group_type_request:
+	fetch 2,mem_le_att_handle
+	branch le_send_empty_le_data,blank
+	istore 2,contw
+	setarg 0xffff
+	istore 2,contw
+	setarg 0x2800
+	istore 2,contw
+	branch le_send_autolen
+
+	
+le_send_att_read_by_group_type_response:
+	setarg 0x06
+	store 1,mem_le_l2cap_response
+	fetch 2,mem_le_search_att_type
+	iforce rega
+	call le_init_attlist_search
+	force 3,loopcnt
+le_send_att_read_by_group_type_response_loop:
+	call le_att_handle_inrange
+	branch le_send_att_read_by_group_type_response_last,blank
+	nbranch le_send_att_read_by_group_type_response_next,positive
+	iforce alarm
+	ifetch 2,contr
+	isub rega,null			/* same type? */
+	nbranch le_send_att_read_by_group_type_response_cont,zero
+	deposit alarm
+	branch le_send_att_read_by_group_type_response_first,user
+	increase -1,pdata
+	istore 2,contw			/* end handle */
+	istoret 2,contw			/* type uuid */
+	increase 1,pdata
+	increase -1,loopcnt
+	branch le_send_autolen,zero
+le_send_att_read_by_group_type_response_first:
+	disable user
+	istore 2,contw			/* start handle */
+	increase 1,contr
+	ifetcht 2,contr
+	increase -3,contr
+	branch le_send_att_read_by_group_type_response_cont
+le_send_att_read_by_group_type_response_last:
+	branch le_send_att_error_response_notfound,user
+	force -1,pdata
+	istore 2,contw
+	istoret 2,contw
+	branch le_send_autolen
+le_send_att_read_by_group_type_response_next:
+	increase 2,contr
+le_send_att_read_by_group_type_response_cont:
+	ifetch 1,contr
+	iadd contr,contr
+	branch le_send_att_read_by_group_type_response_loop
+	
+
+	
+le_send_att_write_request:
+	fetch 2,mem_le_notify_handle
+	store 2,mem_le_l2cap_response
+	fetch 1,mem_le_handle_data_len
+	copy pdata,loopcnt
+	arg mem_le_handle_data,contr
+	call memcpy
+	branch le_send_autolen
+	
+le_send_att_write_response:
+	fetcht 2,mem_le_att_handle
+	call le_att_get_handle_ptr
+	branch le_send_att_write_response_go,blank
+	increase -2,contr
+	ifetcht 2,contr
+	setarg UUID_CLIENT_CHARACTERISTIC
+	isub temp,null
+	nbranch le_send_att_write_response_go,zero
+	increase 1,contr
+	ifetcht 2,contr
+	setarg 0x0001
+	isub temp,null
+	branch le_send_att_write_response_notify,zero
+	setarg 0x0000
+	isub temp,null
+	nbranch le_send_att_write_response_go,zero
+	branch le_send_att_write_response_go
+	
+le_send_att_write_response_notify:
+	increase -7,contr
+	ifetch 2,contr
+	increase -1,pdata
+	store 2,mem_le_notify_handle	
+	jam ATTOP_HANDLE_VALUE_NOTIFICATION,mem_fifo_temp
+	call le_xtype_fifo_in
+//	jam	CONN_SM_NOTIFY,mem_le_conn_sm
+
+le_send_att_write_response_go:
+	force 5,temp
+	branch le_send_packet
+
+le_send_att_prepare_write_request:
+	force 6,temp
+	branch le_send_packet
+	
+le_send_att_prepare_write_response:
+	force 6,temp
+	branch le_send_packet
+	
+le_send_att_execute_write_request:
+	force 6,temp
+	branch le_send_packet
+	
+le_send_att_execute_write_response:
+	force 6,temp
+	branch le_send_packet
+
+le_att_check_notification_enable: // temp ->handle,output-> pdata,output :contr->rega
+	set1 mark_ext_patch,mark
+	bpatch patch2c_6,mem_patch2c
+	increase 1,temp
+	call le_att_get_handle_ptr
+	increase -2,contr
+	ifetch 2,contr
+	arg CLIENT_CHARACTERTIC_CONFIGURATION,temp
+	isub temp,null
+	nrtn zero
+	increase 1,contr
+	copy contr,rega
+	ifetch 1,contr
+	rtn
+	
+le_send_att_handle_value_notification:
+	jam 0,mem_le_notify_len
+	fetch 2,mem_cb_update_notify_value
+	call callback_func
+	arg mem_le_l2cap,contw
+	increase 1,contw
+	fetcht 2,mem_le_notify_handle
+	istoret 2,contw
+	call le_att_get_handle_ptr 
+	ifetch 1,contr
+	icopy loopcnt
+	call memcpy
+	fetcht 1,mem_le_notify_len
+	increase 7,temp
+	call le_send_packet
+	branch le_clear_notify_att
+
+le_send_att_handle_value_indication:
+	force 6,temp
+	branch le_send_packet
+	
+le_send_att_handle_value_confirmation:
+	force 6,temp
+	branch le_send_packet
+	
+le_send_att_write_command:
+	force 6,temp
+	branch le_send_packet
+	
+le_send_att_signed_write_command:
+	force 6,temp
+	branch le_send_packet
+
+
+le_send_autolen:
+	set1 mark_ext_patch,mark
+	bpatch patch2c_7,mem_patch2c
+	setarg mem_le_txpayload
+	isub contw,pdata
+	sub pdata,0,temp
+	branch le_send_packet
+
+
+le_send_empty:
+	force 0,temp
+	force 1,type
+	
+le_send_packet:
+	set1 mark_ext_patch,mark
+	bpatch patch2d_0,mem_patch2d
+	storet 1,mem_le_txlen
+	compare 2,type,3
+	nbranch le_send_non_l2cap,true
+	add temp,-4,pdata
+	store 2,mem_le_txpayload
+	
+le_send_non_l2cap:
+	fetcht 1,mem_le_arq
+	call le_xtype_fifo_is_empty
+	nsetflag blank,md,temp
+	set1 wak,temp
+	and temp,0xfc,pdata
+	ior type,pdata
+	store 1,mem_le_arq
+	and_into 0x1f,pdata
+	store 1,mem_le_txheader
+	set1 mark_ext_patch,mark
+	bpatch patch2d_1,mem_patch2d
+	fetch 1,mem_le_txheader
+	compare 1,type,3
+	rtn true
+	fetch 7,mem_le_txheader+1
+	fetch 1,mem_le_state
+	rtnbit0 lestate_encryption
+	call load_sk
+	branch le_encrypt
+	
+le_parse:
+	set1 mark_ext_patch,mark
+	bpatch patch2d_2,mem_patch2d
+	call le_xtype_fifo_is_full
+	nbranch assert,blank
+	nrtn blank // xtype fifo full
+	fetch 1,mem_le_rxbuf+1
+	rtn blank
+	fetch 1,mem_le_rxbuf
+	compare 1,pdata,3
+	branch le_parse_l2cap,true //ACL-U continue or empty packet
+	fetch 7,mem_le_rxbuf+1
+	fetch 1,mem_le_rxbuf
+	compare 2,pdata,3
+	branch le_parse_l2cap,true
+	fetch 1,mem_le_rxbuf+2
+	store 1,mem_le_rx_ll_opcode
+	copy pdata,regc
+	set1 mark_ext_patch,mark
+	bpatch patch2d_3,mem_patch2d
+	copy regc,pdata
+	beq LL_CONNECTION_UPDATE_REQ,le_parse_connection_update_req
+	beq LL_CHANNEL_MAP_REQ,le_parse_channel_map_req
+	beq LL_TERMINATE_IND,le_parse_terminate_ind
+	beq LL_ENC_REQ,le_parse_enc_req
+	beq LL_ENC_RSP,le_parse_enc_rsp
+	beq LL_START_ENC_REQ,le_parse_start_enc_req
+	beq LL_START_ENC_RSP,le_parse_start_enc_rsp
+	beq LL_UNKNOWN_RSP,le_parse_unknown_rsp
+	beq LL_FEATURE_REQ,le_parse_feature_req
+	beq LL_FEATURE_RSP,le_parse_feature_rsp
+	beq LL_PAUSE_ENC_REQ,le_parse_pause_enc_req
+	beq LL_PAUSE_ENC_RSP,le_parse_pause_enc_rsp
+	beq LL_VERSION_IND,le_parse_version_ind
+	beq LL_REJECT_IND,le_parse_reject_ind
+	branch assert
+	
+le_parse_l2cap:
+	fetch 1,mem_le_rxbuf+1
+	and pdata,0x1f,pdata //get length
+	rtn blank//empty packet
+	fetch 1,mem_device_option
+	beq dvc_op_hci,le_acl_upgoing
+	fetch 2,mem_le_rxbuf+4//CID
+	beq LE_L2CAP_CID_ATT,le_parse_att
+	beq LE_L2CAP_CID_SMP,le_parse_smp
+	rtn
+
+le_acl_upgoing: //upgoing ACL, from air to host
+	set1 mark_ext_patch,mark
+	bpatch patch2d_4,mem_patch2d
+	call hci_get_packet_ptr
+	fetch 1,mem_le_conn_handle
+	fetcht 1,mem_le_rxbuf//LLID low 2 bits
+	and_into 3,temp
+	lshift8 temp,temp
+	lshift4 temp,temp
+	ior temp,pdata
+	istore 2,contwu
+	fetcht 1,mem_le_rxbuf+1
+	and temp,0x1f,temp
+	istoret 2,contwu //length
+	copy temp,loopcnt
+	call uart_copy_tx_bytes
+	add temp,4,loopcnt
+	call h4_send_packet_acl
+	branch h4_send_acl_trigger
+
+le_acl_downgoing: //downgoing ACL, from host to air
+	set1 mark_ext_patch,mark
+	bpatch patch2d_5,mem_patch2d
+	arg 0x2,type
+	ifetch 2,contru
+	ifetch 2,contru //length
+	branch assert,blank
+	copy pdata,loopcnt
+	arg mem_le_txpayload,contw
+	call uart_copy_rx_bytes	
+	branch le_send_autolen
+	
+le_parse_smp:
+	set1 mark_ext_patch,mark
+	bpatch patch2d_6,mem_patch2d
+	ifetch 1,contr
+	beq SMP_PAIRING_REQUEST,le_parse_smp_pairing_request
+	beq SMP_PAIRING_RESPONSE,le_parse_smp_pairing_response
+	beq SMP_PAIRING_CONFIRM,le_parse_smp_pairing_confirm
+	beq SMP_PAIRING_RANDOM,le_parse_smp_pairing_random
+	beq SMP_PAIRING_FAILED,le_parse_smp_pairing_failed
+	beq SMP_ENCRYPTION_INFORMATION,le_parse_smp_encryption_information
+	beq SMP_MASTER_IDENTIFICATION,le_parse_smp_master_identification
+	beq SMP_IDENTITY_INFORMATION,le_parse_smp_identity_information
+	beq SMP_IDENTITY_ADDRESS_INFORMATION,le_parse_smp_identity_address_information
+	beq SMP_SIGNING_INFORMATION,le_parse_smp_signing_information
+	beq SMP_SECURITY_REQUEST,le_parse_smp_security_request
+	branch assert
+	
+le_parse_att:
+	set1 mark_ext_patch,mark
+	bpatch patch2d_7,mem_patch2d
+	ifetch 3,contr
+	store 3,mem_le_att_opcode
+le_parse_att_p:
+	beq ATTOP_ERROR_RESPONSE,le_parse_att_error_response
+	beq ATTOP_EXCHANGE_MTU_REQUEST,le_parse_att_exchange_mtu_request
+	beq ATTOP_EXCHANGE_MTU_RESPONSE,le_parse_att_exchange_mtu_response
+	beq ATTOP_FIND_INFORMATION_REQUEST,le_parse_att_find_information_request
+	beq ATTOP_FIND_INFORMATION_RESPONSE,le_parse_att_find_information_response
+	beq ATTOP_FIND_BY_TYPE_VALUE_REQUEST,le_parse_att_find_by_type_value_request
+	beq ATTOP_FIND_BY_TYPE_VALUE_RESPONSE,le_parse_att_find_by_type_value_response
+	beq ATTOP_READ_BY_TYPE_REQUEST,le_parse_att_read_by_type_request
+	beq ATTOP_READ_BY_TYPE_RESPONSE,le_parse_att_read_by_type_response
+	beq ATTOP_READ_REQUEST,le_parse_att_read_request
+	beq ATTOP_READ_RESPONSE,le_parse_att_read_response
+	beq ATTOP_READ_BLOB_REQUEST,le_parse_att_read_blob_request
+	beq ATTOP_READ_BLOB_RESPONSE,le_parse_att_read_blob_response
+	beq ATTOP_READ_MULTIPLE_REQUEST,le_parse_att_read_multiple_request
+	beq ATTOP_READ_MULTIPLE_RESPONSE,le_parse_att_read_multiple_response
+	beq ATTOP_READ_BY_GROUP_TYPE_REQUEST,le_parse_att_read_by_group_type_request
+	beq ATTOP_READ_BY_GROUP_TYPE_RESPONSE,le_parse_att_read_by_group_type_response
+	beq ATTOP_WRITE_REQUEST,le_parse_att_write_request
+	beq ATTOP_WRITE_RESPONSE,le_parse_att_write_response
+	beq ATTOP_PREPARE_WRITE_REQUEST,le_parse_att_prepare_write_request
+	beq ATTOP_PREPARE_WRITE_RESPONSE,le_parse_att_prepare_write_response
+	beq ATTOP_EXECUTE_WRITE_REQUEST,le_parse_att_execute_write_request
+	beq ATTOP_EXECUTE_WRITE_RESPONSE,le_parse_att_execute_write_response
+	beq ATTOP_HANDLE_VALUE_NOTIFICATION,le_parse_att_handle_value_notification
+	beq ATTOP_HANDLE_VALUE_INDICATION,le_parse_att_handle_value_indication
+	beq ATTOP_HANDLE_VALUE_CONFIRMATION,le_parse_att_handle_value_confirmation
+	beq ATTOP_WRITE_COMMAND,le_parse_att_write_command
+	beq ATTOP_SIGNED_WRITE_COMMAND,le_parse_att_signed_write_command
+	branch assert
+
+
+le_parse_connection_update_req:
+	ifetch 9,contr
+	store 9,mem_le_new_param
+	ifetch 2,contr
+	store 2,mem_le_instant
+	fetch 1,mem_le_state
+	set1 lestate_update_param,pdata
+	store 1,mem_le_state
+	rtn
+	
+le_parse_channel_map_req:
+	ifetch 5,contr
+	store 5,mem_le_new_map
+	ifetch 2,contr
+	store 2,mem_le_instant
+	fetch 1,mem_le_state
+	set1 lestate_update_map,pdata
+	store 1,mem_le_state
+	rtn
+	
+le_parse_terminate_ind:
+	fetch 1,mem_le_op
+	set1 op_disconn,pdata
+	store 1,mem_le_op
+	rtn
+	
+le_parse_enc_req:
+	increase 10,contr
+	ifetch 8,contr
+	store 8,mem_le_skdm
+	ifetch 4,contr
+	store 4,mem_le_ivm
+	jam XT_LL_ENC_RSP,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_enc_rsp:
+	ifetch 8,contr
+	store 8,mem_le_skds
+	ifetch 4,contr
+	store 4,mem_le_ivs
+	branch generate_sk
+	
+le_parse_start_enc_req:
+	fetch 1,mem_le_state
+	set1 lestate_encryption,pdata
+	store 1,mem_le_state
+	jam XT_LL_START_ENC_RSP,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_start_enc_rsp:
+	rtn master
+	jam XT_LL_START_ENC_RSP,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_unknown_rsp:
+	rtn
+	
+le_parse_feature_req:
+	jam XT_LL_FEATURE_RSP,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_feature_rsp:
+	rtn
+	
+le_parse_pause_enc_req:
+	rtn
+	
+le_parse_pause_enc_rsp:
+	rtn
+	
+le_parse_version_ind:
+	rtn master
+	jam XT_LL_VERSION_IND,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_reject_ind:
+	rtn
+
+
+le_parse_smp_pairing_request:
+	store 1,mem_le_preq
+	ifetch 6,contr
+	istore 6,contw
+	jam XT_SMP_PAIRING_RESPONSE,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_smp_pairing_response:
+	store 1,mem_le_pres
+	ifetch 6,contr
+	istore 6,contw
+	jam XT_SMP_PAIRING_CONFIRM,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_smp_pairing_confirm:
+	arg mem_le_rconfirm,contw
+	call memcpy16
+	jam XT_SMP_PAIRING_RANDOM,mem_fifo_temp
+	branch  le_xtype_fifo_in,master
+	jam XT_SMP_PAIRING_CONFIRM,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_smp_pairing_random:
+	call authenticate_rconfirm
+	branch le_parse_smp_pairing_random_success,zero
+	jam XT_SMP_PAIRING_FAILED,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_smp_pairing_random_success:
+	call generate_stk
+	jam XT_LL_ENC_REQ,mem_fifo_temp
+	branch le_xtype_fifo_in,master
+	jam XT_SMP_PAIRING_RANDOM,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_smp_pairing_failed:
+	rtn
+	
+le_parse_smp_encryption_information:
+	arg mem_le_peer_ltk,contw
+	branch memcpy16
+	
+le_parse_smp_master_identification:
+	rtn
+	
+le_parse_smp_identity_information:
+	rtn
+	
+le_parse_smp_identity_address_information:
+	rtn
+	
+le_parse_smp_signing_information:
+	rtn
+	
+le_parse_smp_security_request:
+	rtn
+
+le_parse_att_error_response:
+	increase -2,contr
+	ifetcht 1,contr
+	setarg ATTOP_FIND_BY_TYPE_VALUE_REQUEST
+	isub temp,null
+	branch le_parse_att_error_res_find_by_type_value,zero
+	setarg ATTOP_FIND_INFORMATION_REQUEST
+	isub temp,null
+	branch le_parse_att_error_res_find_info,zero
+	setarg ATTOP_READ_BY_TYPE_REQUEST
+	isub temp,null
+	branch le_parse_att_error_res_read_by_type,zero
+	setarg ATTOP_READ_BLOB_REQUEST
+	isub temp,null
+	branch le_parse_att_error_res_read_blob,zero
+	setarg ATTOP_READ_MULTIPLE_REQUEST
+	isub temp,null
+	branch le_parse_att_error_res_read_multiple,zero
+	rtn
+	
+le_parse_att_error_res_find_by_type_value:
+	rtn
+	
+le_parse_att_error_res_find_info:
+	rtn
+	
+le_parse_att_error_res_read_by_type:
+	rtn
+	
+le_parse_att_error_res_read_blob:
+	rtn
+	
+le_parse_att_error_res_read_multiple:
+	rtn
+
+	
+le_parse_att_exchange_mtu_request:
+	jam ATTOP_EXCHANGE_MTU_RESPONSE,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_att_exchange_mtu_response:
+	rtn
+	
+le_parse_att_find_information_request:
+	rshift8 pdata,pdata
+	store 2,mem_le_search_handle_start
+	ifetch 2,contr
+	store 2,mem_le_search_handle_end
+	jam ATTOP_FIND_INFORMATION_RESPONSE,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_att_find_information_response:
+	rtn
+	
+le_parse_att_find_info_res_multi:
+	rtn
+	
+le_parse_att_find_info_res_error:
+	rtn
+	
+le_parse_att_find_by_type_value_request:
+	rshift8 pdata,pdata
+	store 2,mem_le_search_handle_start
+	ifetch 2,contr
+	store 2,mem_le_search_handle_end
+	ifetch 2,contr
+	store 2,mem_le_uuid//type
+	ifetch 2,contr
+	store 2,mem_le_search_att_type//value
+	jam ATTOP_FIND_BY_TYPE_VALUE_RESPONSE,mem_fifo_temp
+	branch le_xtype_fifo_in
+
+	
+le_parse_att_find_by_type_value_response:
+	rtn
+	
+le_parse_att_read_by_type_request:
+	rshift8 pdata,pdata
+	store 2,mem_le_search_handle_start
+	ifetch 2,contr
+	store 2,mem_le_search_handle_end
+	ifetch 2,contr
+	store 2,mem_le_search_att_type
+	jam ATTOP_READ_BY_TYPE_RESPONSE,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_att_read_by_type_response:
+	rtn
+	
+le_parse_att_read_request:
+	fetch 2,mem_le_rxbuf+7
+	store 2,mem_le_att_handle
+	jam ATTOP_READ_RESPONSE,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_att_read_response:
+	rtn
+	
+le_send_att_read_res_end:
+	rtn
+	
+le_prepare_descriptor:
+	rtn
+
+	
+le_parse_att_read_blob_request:
+	ifetch 2,contr
+	store 2,mem_le_att_offset
+	jam ATTOP_READ_BLOB_RESPONSE,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_att_read_blob_response: 
+	rtn
+	
+le_parse_att_read_multiple_request:
+	fetch 1,mem_le_rxbuf+1
+	increase -5,pdata
+	rshift pdata,pdata
+	store 1,mem_le_temp
+	jam ATTOP_READ_MULTIPLE_RESPONSE,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_att_read_multiple_response:
+	rtn
+	
+le_parse_att_read_by_group_type_request:
+	rshift8 pdata,pdata
+	store 2,mem_le_search_handle_start
+	ifetch 2,contr
+	store 2,mem_le_search_handle_end
+	ifetch 2,contr
+	store 2,mem_le_search_att_type
+	jam ATTOP_READ_BY_GROUP_TYPE_RESPONSE,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_att_read_by_group_type_response:
+	rtn
+	
+le_parse_att_write_request:
+	fetch 1,mem_le_rxbuf+1
+	increase -7,pdata
+	icopy loopcnt
+	fetcht 2,mem_le_att_handle
+	call le_att_get_handle_ptr
+	branch le_parse_att_write_request_fail,blank
+	ifetch 1,contr
+	isub loopcnt,null
+	nbranch le_parse_att_write_request_fail,positive
+	copy contr,contw
+
+	arg mem_le_rxbuf+9,contr
+	call memcpy
+	jam BT_EVT_LE_WRITE_REQUEST,mem_fifo_temp
+	call ui_ipc_send_event
+le_parse_att_write_request_fail:
+	jam ATTOP_WRITE_RESPONSE,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_parse_att_write_response:
+	fetch 1,mem_le_conn_sm
+	rtn
+	
+le_parse_att_prepare_write_request:
+	rtn
+	
+le_parse_att_prepare_write_response:
+	rtn
+	
+le_parse_att_execute_write_request:
+	rtn
+	
+le_parse_att_execute_write_response:
+	rtn
+	
+le_parse_att_handle_value_notification:
+	//copy contr,rega
+	//fetcht 6,mem_le_plap
+	//fetch 6,mem_le_addr_slave1
+	//isub temp,null
+	//branch le_kb_handle_value_notification,zero
+	//copy rega,contr
+	ifetch 5,contr
+	store 5,mem_mouse_data
+	jam SEND_MOUSE_DATA_CMD,mem_mcmd
+	//jam 3,0x4905
+	call usb_isr
+	rtn
+le_kb_handle_value_notification:
+	copy rega,contr
+	ifetch 8,contr
+	store 8,mem_mouse_data
+	jam SEND_KB_DATA_CMD,mem_mcmd
+	call usb_isr
+	rtn
+	
+le_parse_att_handle_value_indication:
+	rtn
+	
+le_parse_att_handle_value_confirmation:
+	rtn
+	
+le_parse_att_write_command:
+	fetch 1,mem_le_rxbuf+1
+	increase -7,pdata
+	icopy loopcnt
+	fetcht 2,mem_le_att_handle
+	call le_att_get_handle_ptr
+	branch le_parse_att_write_command_fail,blank
+	ifetch 1,contr
+	isub loopcnt,null
+	nbranch le_parse_att_write_command_fail,positive
+	copy contr,contw
+	copy contr,rega
+	copy loopcnt,regb
+	arg mem_le_rxbuf+9,contr
+	call memcpy
+	jam PRCP_LE,mem_prcp
+	call le_writeatt_cb
+le_parse_att_write_command_fail:
+	rtn
+
+	/* rega pointers to data, regb is length */
+le_writeatt_cb:
+	fetch 2,mem_cb_att_write
+	rtn blank
+	iforce pc
+
+
+le_parse_att_signed_write_command:
+	rtn
+
+le_supervision_update:
+	fetcht 4,mem_le_supervision_timer
+	call get_clkbt
+	isub temp,timeup					/* and to 28 bits */
+	deposit timeup
+	fetcht 2,mem_le_superto
+	lshift4 temp,temp
+	lshift temp,temp
+	isub temp,pdata
+	rtn
+	
+le_supervision_flush:
+	call get_clkbt
+	store 4,mem_le_supervision_timer
+	rtn
+	
+	
+	
+le_adv:
+	set1 mark_ext_patch,mark
+	bpatch patch2e_0,mem_patch2e
+	fetch 1,mem_le_adv_enable
+	rtn blank
+	arg le_adv_interval_timer,queue
+	call timer_check
+	nrtn blank
+	disable master
+	enable swfine
+	call le_init_adv
+	call le_next_adv_channel
+	call le_send_adv_ind
+	nbranch le_adv_not_match,match
+	set1 mark_ext_patch,mark
+	bpatch patch2e_1,mem_patch2e
+	fetch 1,mem_le_req_rcv
+	increase 1,pdata
+	store 1,mem_le_req_rcv
+	fetch 1,mem_le_rxbuf
+	and pdata,0x0f,pdata
+	beq SCAN_REQ,le_send_scan_response
+	beq CONNECT_REQ,parse_connect_req
+le_adv_not_match:
+	nop 10000
+	fetch 1,mem_le_ch_mapped
+	bne 39,le_adv
+	call le_ledoff
+	arg le_adv_interval_timer,queue
+	fetch 2,mem_le_adv_interval_max
+	branch timer_init
+	
+
+le_receive_window_size:
+	set1 mark_ext_patch,mark
+	bpatch patch2e_2,mem_patch2e
+	fetch 1,mem_le_peer_sca
+	call le_sca_map
+	fetch 2,mem_le_tsniff
+	imul32 temp,pdata
+	arg 375,temp
+	imul32 temp,pdata
+	arg 100000,temp
+	idiv temp
+	fetch 1,mem_le_window_size
+	arg 20000,temp
+	imul32 temp,pdata
+	store 4,mem_le_transmit_window
+	set1 mark_ext_patch,mark
+	bpatch patch2e_3,mem_patch2e
+	fetch 2,mem_rx_window_sniff
+	call wait_div_end
+	quotient temp
+	iadd temp,pdata
+	store 2,mem_le_receive_window
+	rtn
+
+parse_connect_req:
+	set1 mark_ext_patch,mark
+	bpatch patch2e_4,mem_patch2e
+	fetch 6,mem_le_rxbuf+8
+	fetcht 6,mem_le_lap
+	isub temp,null
+	nrtn zero
+	call le_scan_check_sender_addr_type
+	copy rega,pdata
+	store 1,mem_le_conn_peer_addr_type
+	fetch 7,mem_le_rxbuf+21
+	store 7,mem_tmp_buffer
+	ifetch 8,contr
+	istore 8,contw
+	fetch 6,mem_le_rxbuf+2
+	store 6,mem_le_plap
+	set1 mark_ext_patch,mark
+	bpatch patch2e_5,mem_patch2e
+	increase 6,contr
+	ifetch 8,contr
+	store 8,mem_le_access 	// and crcinit & window size
+	ifetcht 2,contr				// transmit offset
+	lshift2 temp,temp			
+	ifetch 2,contr				// connInterval
+	lshift2 pdata,pdata
+	store 2,mem_le_tsniff
+	store 4,mem_le_anchor
+	isub temp,pdata
+	add pdata,-2,clke_bt
+	ifetch 9,contr
+	store 9,mem_le_slave_latency// and super to & channel map
+	set1 mark_ext_patch,mark
+	bpatch patch2e_6,mem_patch2e
+	ifetch 1,contr
+	rshift4 pdata,temp
+	rshift temp,temp
+	storet 1,mem_le_peer_sca
+	and_into 0x1f,pdata
+	store 1,mem_le_hop
+	call le_receive_window_size
+	call le_calc_channel_map
+	call le_init_slave
+	call context_new
+	nrtn zero
+	set1 mark_ext_patch,mark
+	bpatch patch2e_7,mem_patch2e
+	arg 0,temp//status successful
+	call hci_send_le_conn_complete
+	call calc_clke_offset
+	jam BT_EVT_LE_CONNECTED,mem_fifo_temp
+	call ui_ipc_send_event
+//	call app_get_lpm_wake_lock
+	branch context_save
+	
+
+le_init_attlist_search:
+	set1 mark_ext_patch,mark
+	bpatch patch2f_0,mem_patch2f
+	fetch 2,mem_le_search_handle_start
+	iforce regb
+	fetch 2,mem_le_search_handle_end
+	iforce regc
+	arg mem_le_att_list,contr
+	enable user
+	rtn
+
+	/* return handle in pdata, blank:end of list, positive:in range */
+le_att_handle_inrange:
+	ifetch 2,contr
+	rtn blank
+	isub regb,null			/* less than start ? */
+	nrtn positive
+	isub regc,null			/* greater than end ? */
+	rtn zero
+	branch le_att_handle_blank,positive
+	force 1,null
+	rtn
+le_att_handle_blank:
+	force 0,pdata
+	rtn
+
+	/* handle in temp, return pointer in contr to length, blank not found */	
+le_att_get_handle_ptr:
+	arg mem_le_att_list,contr
+le_att_get_handle_loop:
+	ifetch 2,contr
+	rtn blank
+	increase 2,contr
+	isub temp,null
+	rtn zero
+	ifetch 1,contr			/* length */
+	iadd contr,contr
+	branch le_att_get_handle_loop
+	
+le_data_send_write_req:
+	jam 0x2,mem_le_handle_data_len
+	setarg 0x0001
+	store 2,mem_le_handle_data
+	jam CONN_SM_WAIT_WRITE_RES,mem_le_conn_sm
+	jam ATTOP_WRITE_REQUEST,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+le_data_wait_write_res:
+	rtn
+le_data_wait_write_res1:
+	rtn
+le_conn_sm_master:
+	set1 mark_ext_patch,mark
+	bpatch patch2f_1,mem_patch2f
+	fetch 1,mem_device_option
+	rtnne dvc_op_dongle
+	fetch 1,mem_le_conn_sm
+	beq CONN_SM_SEND_WRITE_REQ,le_data_send_write_req
+	beq CONN_SM_WAIT_WRITE_RES,le_data_wait_write_res
+	beq CONN_SM_WAIT_WRITE_RES1,le_data_wait_write_res1
+	rtn
+
+le_ukey_init:
+	setarg le_ukey
+	store 2,mem_cb_le_process
+	hjam uart_ctrl_normal,core_uart_ctrl
+	setarg uart_baud_115200
+	hstore uart_baud_len,core_uart_baud
+	hjam uartclk_dpll,core_uart_clksel
+	hjam 0x4,core_gpio_sel1
+	setarg le_ukey_wcb
+	store 2,mem_cb_att_write
+	call le_init_att
+	rtn wake
+	branch eeprom_load_reconn_info
+	
+	
+le_ukey:
+	fetch 1,mem_le_mode
+	compare lemode_slave,pdata,0xff
+	setarg 5
+	call set_pwm_steadyon,true
+	ncall set_pwm_blink,true
+	call uartd_prepare_rx
+	branch le_ukey_senddata,blank
+	fetch 2,mem_le_notify_attr_start
+	iforce contw
+	sub loopcnt,20,null
+	branch le_ukey_loop,positive
+	force 20,loopcnt
+le_ukey_loop:
+	ifetch 1,contru
+	istore 1,contw
+	loop le_ukey_loop
+	call uartd_rxdone
+le_ukey_senddata:
+	jam notify_handle,mem_le_notify_handle
+	fetcht 2,mem_le_notify_attr_start
+	ifetch 1,temp
+	rtn blank
+	call le_xtype_fifo_is_full
+	nrtn blank
+	jam ATTOP_HANDLE_VALUE_NOTIFICATION,mem_fifo_temp 
+	branch le_xtype_fifo_in
+
+le_ukey_wcb:
+	copy regb,temp
+	call uartd_prepare_tx
+	copy rega,contr
+	copy regb,loopcnt
+le_writeatt_cb_loop:
+	ifetch 1,contr
+	istore 1,contwu
+	loop le_writeatt_cb_loop
+	branch uartd_send
+
+le_clear_notify_att:
+	fetch 1,mem_device_option
+	rtnne dvc_op_ukey
+	fetch 2,mem_le_notify_handle
+	rtnne notify_handle
+	fetcht 2,mem_le_notify_attr_start
+	setarg 0
+	istore 9,temp
+	istore 9,contw
+	istore 2,contw
+	rtn
+
+
+le_ledoff:
+	fetcht 1,mem_le_adv_led
+	setflip gpio_active_bit,temp
+	branch gpio_out
+
+	
+le_modified_name:
+	set1 mark_ext_patch,mark
+	bpatch patch2f_2,mem_patch2f
+	call le_modified_name_att_list
+	branch le_modified_name_adv
+
+le_modified_name_att_list:
+	fetch 1,mem_le_name_len
+	copy pdata,loopcnt
+	arg UUID_CHRCTR_DEVICE_NAME,temp
+	call le_att_get_uuid_ptr
+	increase 1,contr
+	copy contr,contw
+	arg mem_le_name,contr
+	call memcpy
+	fetch 1,mem_le_name_len
+	sub pdata,MAX_NAME_LEN,loopcnt
+	copy loopcnt,temp
+	copy loopcnt,pdata
+	ncall memcpy_empty,blank	
+	rtn
+
+le_modified_name_adv:	
+	fetch 1,mem_le_adv_data_len
+	fetcht 1,mem_le_adv_data
+	isub temp,pdata
+	copy pdata,loopcnt
+	copy pdata,rega
+	fetch 1,mem_le_adv_data
+	increase 1,pdata
+	arg mem_le_adv_data,contr
+	iadd contr,contr
+	arg mem_le_adv_temp,contw
+	call memcpy
+	set1 mark_ext_patch,mark
+	bpatch patch2f_3,mem_patch2f
+	fetch 1,mem_le_name_len
+	copy pdata,loopcnt
+	increase 1,pdata
+	store 1,mem_le_adv_data
+	arg mem_le_adv_data+2,contw
+	arg mem_le_name,contr
+	call memcpy
+	copy rega,loopcnt
+	arg mem_le_adv_temp,contr
+	call memcpy
+	fetch 1,mem_le_adv_data
+	iadd rega,pdata
+	store 1,mem_le_adv_data_len
+	rtn
+
+
+le_get_device_name:
+	set1 mark_ext_patch,mark
+	bpatch patch2f_4,mem_patch2f
+	arg UUID_CHRCTR_DEVICE_NAME,temp
+	branch le_att_get_uuid_ptr
+
+	// temp is uuid to search
+le_att_get_uuid_ptr:
+	arg mem_le_att_list,contr
+le_att_get_uuid_loop:
+	ifetch 2,contr			// handle
+	branch assert,blank
+	ifetch 2,contr			// uuid
+	isub temp,null
+	rtn zero
+	ifetch 1,contr			// length 
+	iadd contr,contr
+	branch le_att_get_uuid_loop
+
+	
+memcpy_empty:
+	setarg SPACE
+	istore 1,contw
+	loop memcpy_empty
+	rtn
+
+
+le_lpm_set_mult:
+	set1 mark_ext_patch,mark
+	bpatch patch2f_5,mem_patch2f
+	disable wake
+	branch le_lpm_set_mult_attempt,attempt
+	nbranch le_lpm_lost,match
+le_lpm_set_mult_attempt:
+	call lpm_match
+	fetch 2,mem_rx_window_sniff
+	store 2,mem_le_receive_window
+	fetch 1,mem_le_rxbuf
+	compare 1,pdata,3
+	nbranch lpm_mult_short,true		// rx not empty, short interval
+	fetch 1,mem_le_txheader
+	compare 1,pdata,3
+	nbranch lpm_mult_short,true		// tx not empty, short interval
+	fetch 1,mem_le_state
+	bbit1 lestate_update_param,lpm_mult_short
+	branch lpm_mult_wait_timeout
+	
+le_lpm_lost:
+	fetcht 2,mem_rx_window_sniff
+	rshift temp,temp
+	fetch 2,mem_le_receive_window
+	iadd temp,pdata
+	store 2,mem_le_receive_window
+	branch lpm_lost
+
+le_clean_att_list_handle_enable:
+	set1 mark_ext_patch,mark
+	bpatch patch2f_6,mem_patch2f
+	jam 0,mem_le_switch_send_data
+	fetcht 2,mem_le_notify_handle
+	call le_att_check_notification_enable
+	copy rega,contw
+	setarg 0
+	istore 1,contw
+	rtn
+le_scan_addr_to_uart:
+	fetch 1,mem_device_option
+	rtnne dvc_op_module 
+	call get_uart_twptr
+	arg mem_le_plap,rega
+	call adss_hex2string_to_uart
+	setarg 0x2c
+	istore 1,contwu
+	call at_rssi_result
+	branch uartd_send
+	
+//input:regb  prcp_tx_len
+prcp_le_tx:
+	arg PRCP_TX_LE,temp
+	call le_att_check_notification_enable
+	rtnbit0 0
+	call le_xtype_fifo_is_full
+	nrtn blank
+	arg PRCP_TX_LE,temp
+	storet 2,mem_le_notify_handle
+	call le_att_get_handle_ptr
+	branch assert,blank
+	add contr,1,contw
+	arg PRCP_TX_DATA_LEN,loopcnt
+	arg mem_prcp_data,contr
+	call memcpy
+	jam ATTOP_HANDLE_VALUE_NOTIFICATION,mem_fifo_temp
+	branch le_xtype_fifo_in
+prcp_tx:
+	rtn
+
+	/* rega = ad type to search, return zero when found */
+le_search_adtype:
+	set1 mark_ext_patch,mark
+	bpatch patch2f_7,mem_patch2f
+	fetch 1,mem_le_rxbuf + 1
+	arg mem_le_rxbuf + 8,contr
+	iadd contr,loopcnt
+le_search_adtype_loop:
+	ifetcht 1,contr
+	ifetch 1,contr
+	isub rega,null
+	rtn zero
+	add temp,-1,pdata
+	iadd contr,contr
+	deposit loopcnt
+	isub contr,null
+	branch le_search_adtype_loop,positive
+	force 1,null
+	rtn
+	
+
+else
+le_disable:
+le_dispatch:
+le_context_nexthop:
+le_acl_downgoing:
+le_clear_connection_info:
+le_scan_check_sender_addr_type:
+le_conn_dispatch:
+le_ukey_init:
+	rtn
+endif
Index: btkb/program/lmp.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/lmp.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/lmp.prog	(working copy)
@@ -0,0 +1,2669 @@
+	
+/******************************************/
+/*************   LMP Parse   **************/
+/******************************************/
+init_lmp:
+	rtn wake
+init_lmp_work:
+	setarg 0
+	store 1,mem_lmp_to_send
+	store 1,mem_conn_sm
+	store 1,mem_lmo_opcode1
+	store 1,mem_lmo_opcode2
+	store 1,mem_esco_addr
+	store 1,mem_auth_enable
+	store 1,mem_connection_options
+	store 1,mem_pairing_auth
+	jam SWITCH_FLAG_INIT,mem_switch_flag
+	jam 0,mem_switch_fail_master_count
+	jam NULL_ENCRYP,mem_wait_encryption
+init_lmp_reinit:	
+	set1 mark_ext_patch,mark
+	bpatch patch3c_0,mem_patch3c
+	jam 0,mem_pairing_auth
+	jam 0,mem_sp_localsm
+	jam 0,mem_lmp_conn_state
+	fetch 1,mem_device_option
+	rtnne dvc_op_hci,pdata
+	jam 0,mem_link_key_exists
+	//fall through
+parse_rx_done:
+	rtn
+
+parse_lmp:
+	set1 mark_ext_patch,mark
+	bpatch patch3c_1,mem_patch3c
+	call setlocalsm_master,master	//use this flag in hci
+	ncall setlocalsm_slave,master
+	fetch 1,mem_lmo_opcode2
+	ncall lmo_fifo_process,blank
+	fetch 1,mem_lmo_opcode2
+	nrtn blank
+	fetch 1,mem_state_map
+	rtnbit0 smap_rxlmp
+	set0 smap_rxlmp,pdata
+	set0 mark_rxbuf_inuse,mark
+	store 1,mem_state_map
+	fetch 1,mem_rxbuf
+	fetcht 1,mem_state_map
+	isolate1 smap_lmptidinit,pdata
+	setflag true,smap_lmptid,temp
+	storet 1,mem_state_map
+	and_into 0x2,temp //smap_lmptid only
+	storet 1,mem_lmo_tid2
+	fetcht 1,mem_state_map
+	rshift pdata,pdata			/* align lmp_opcode */
+  	store 1,mem_lmi_opcode2
+	set1 mark_ext_patch,mark
+	bpatch patch3c_2,mem_patch3c
+  	fetch 1,mem_lmi_opcode2
+  	beq LMP_ESCAPE,parse_lmp_escape//multi
+  	beq LMP_ACCEPTED,parse_lmp_accepted//multi
+	beq LMP_NOT_ACCEPTED,parse_lmp_not_accepted//multi
+  	beq LMP_SET_AFH, parse_lmp_set_afh
+  	beq LMP_CLKOFFSET_REQ, parse_lmp_clkoffset_req
+ 	beq LMP_ENCRYPTION_MODE_REQ, parse_lmp_encryption_mode_req
+ 	beq LMP_ENCRYPTION_KEY_SIZE_REQ,parse_lmp_crypt_key
+	beq LMP_AUTO_RATE,parse_lmp_auto_rate
+	beq LMP_TEST_CONTROL,parse_lmp_test_control//multi
+	beq LMP_TEST_ACTIVATE,parse_lmp_test_activate
+	beq LMP_SETUP_COMPLETE,parse_lmp_setup_complete
+	beq LMP_SUPERVISION_TIMEOUT,parse_lmp_supervision_timeout
+	beq LMP_FEATURES_REQ,parse_lmp_features_req
+	beq LMP_HOST_CONNECTION_REQ,parse_lmp_conn_req
+	beq LMP_VERSION_REQ,parse_lmp_version_req
+	beq LMP_VERSION_RES,parse_lmp_version_res
+	beq LMP_DETACH,parse_lmp_detach
+	beq LMP_MAX_SLOT,parse_lmp_max_slot
+	beq LMP_MAX_SLOT_REQ,parse_lmp_max_slot_req
+	beq LMP_NAME_REQ,parse_lmp_name_req
+	beq LMP_NAME_RES,parse_lmp_name_res
+	beq LMP_FEATURES_RES,parse_lmp_features_res
+	beq LMP_COMB_KEY,parse_lmp_comb_key
+	beq LMP_AU_RAND, parse_lmp_au_rand
+	beq LMP_IN_RAND,parse_lmp_in_rand
+	beq LMP_SRES,parse_lmp_sres
+	beq LMP_INCR_POWER_REQ,parse_lmp_incr_power
+	beq LMP_DECR_POWER_REQ,parse_lmp_decr_power
+	beq LMP_MAX_POWER, parse_lmp_max_power
+	beq LMP_MIN_POWER, parse_lmp_min_power
+	beq LMP_PAGE_MODE_REQ, parse_lmp_page_mode_req
+	beq LMP_PAGE_SCAN_MODE_REQ, parse_lmp_page_scan_mode_req
+	beq LMP_PREFERRED_RATE, parse_lmp_preferred_rate
+	beq LMP_REMOVE_SCO_LINK_REQ, parse_lmp_remove_sco_link_req
+	beq LMP_SCO_LINK_REQ, parse_lmp_sco_link_req
+	beq LMP_SLOT_OFFSET, parse_lmp_slot_offset
+	beq LMP_SNIFF_REQ, parse_lmp_sniff_req
+	beq LMP_START_ENCRYPTION_REQ, parse_lmp_start_encryption_req
+	beq LMP_STOP_ENCRYPTION_REQ, parse_lmp_stop_encryption_req
+	beq LMP_SWITCH_REQ, parse_lmp_switch_req
+	beq LMP_TEMP_RAND, parse_lmp_temp_rand
+	beq LMP_TEMP_KEY, parse_lmp_temp_key
+	beq LMP_TIMING_ACCURACY_REQ, parse_lmp_timing_accuracy_req
+	beq LMP_TIMING_ACCURACY_RES, parse_lmp_timing_accuracy_res
+	beq LMP_UNIT_KEY, parse_lmp_unit_key
+	beq LMP_UNSNIFF_REQ, parse_lmp_unsniff_req
+	beq LMP_USE_SEMI_PERMANENT_KEY, parse_lmp_use_semi_permanend_key
+	beq  LMP_ENCAPSULATED_HEADER,parse_lmp_encapsulated_header
+	beq  LMP_ENCAPSULATED_PAYLOAD,parse_lmp_encapsulated_payload
+	beq	LMP_SIMPLE_PAIRING_CONFIRM,parse_simple_pairing_confirm
+	beq  LMP_SIMPLE_PAIRING_NUMBER,parse_lmp_simple_pairing_number
+	beq  LMP_DHKEY_CHECK,parse_dhkey_check
+	beq LMP_CLKOFFSET_RES, parse_lmp_clkoffset_res
+	beq LMP_ENC_KEY_SIZE_MASK_REQ,parse_enc_key_size_mask_req
+/* lmp is not recognized, check to see if we respond to all messages */ 
+/* rejecting the unrecognized message with PDU not recognized */
+reject_unknown_packet:
+	jam UNKNOWN_LMP_PDU,mem_lmo_reason2
+reject_lmp_packet:
+	jam LMP_NOT_ACCEPTED,mem_lmo_opcode2
+	rtn
+
+parse_lmp_clkoffset_req:
+	jam LMP_CLKOFFSET_RES,mem_lmo_opcode2
+	rtn	
+
+parse_enc_key_size_mask_req:
+	jam LMP_ENC_KEY_SIZE_MASK_RES,mem_lmo_opcode2
+	rtn
+	
+parse_lmp_set_afh:
+	fetch 4,mem_rxbuf+1
+	lshift pdata,pdata
+	store 4,mem_afh_instant
+	fetch 1,mem_rxbuf+5
+	store 1,mem_afh_new_mod
+	fetch 5,mem_rxbuf+6
+	store 5,mem_afh_map_new
+	fetch 5,mem_rxbuf+11
+	istore 5,contw
+	fetch 1,mem_mode
+	set1 afh_change,pdata
+	store 1,mem_mode
+	rtn
+parse_lmp_escape:
+	fetch 1,mem_rxbuf+1
+	set1 7,pdata
+	store 1,mem_lmi_opcode2
+	beq LMP_EXT_ACCEPTED,parse_lmpext_accepted
+	beq LMP_NOT_ACCEPTED_EXT,parse_lmpext_not_accepted
+	beq LMP_SNIFF_SUBRATING_REQ, parse_lmp_sniff_subrating_req
+	beq LMP_SNIFF_SUBRATING_RES, parse_lmp_sniff_subrating_res
+	beq LMP_PACKET_TYPE_TABLE_REQ,parse_lmpext_packet_type_table_req
+	beq LMP_EXT_FEATURES_REQ,parse_lmpext_features_req
+	beq LMP_EXT_FEATURES_RES,parse_lmpext_features_res
+	beq LMP_EXT_CHN_CLASSIFICATION_REQ,parse_lmpext_chn_classification_req
+	beq LMP_PAUSE_ENCRYPTION_REQ,parse_lmpext_pause_encrypt
+	beq LMP_RESUME_ENCRYPTION_REQ,parse_lmpext_resume_encrypt
+	beq LMP_IO_CAP_REQ,parse_lmpext_iocap_req
+	beq LMP_IO_CAP_RES,parse_lmpext_iocap_res
+	beq LMP_EXT_REMOVE_ESCO_REQ,parse_lmpext_remove_esco_req
+	beq LMP_EXT_ESCO_LINK_REQ,parse_lmpext_esco_link_req
+	rtneq LMP_EXT_FEATURES_RES
+
+
+reject_unknown_ext_packet:
+	jam LMP_NOT_ACCEPTED_EXT,mem_lmo_opcode2
+	jam UNKNOWN_LMP_PDU,mem_lmo_reason2
+	
+	rtn
+parse_lmpext_chn_classification_req:
+	jam LMP_NOT_ACCEPTED_EXT,mem_lmo_opcode2
+	jam NOT_SUPPORT_CHN_CLASSIFICATION,mem_lmo_reason2
+	rtn
+	
+parse_lmpext_esco_link_req:	
+	fetch 1,mem_rxbuf+2
+	store 1,mem_sco_handle
+	fetch 1,mem_rxbuf+3
+	store 1,mem_esco_addr
+	fetch 1,mem_rxbuf+5
+	store 1,mem_esco_desco
+	fetch 1,mem_rxbuf+9
+	store 1,mem_esco_type
+	fetch 1,mem_rxbuf+14
+	store 1,mem_air_mode
+	bmark1 mark_esco,check_esco_prarm
+	set1 mark_esco,mark
+	call push_tid_follow
+	store 1,mem_accptsco_tid
+	force 0,temp
+	branch hci_send_conn_req_event
+
+parse_lmpext_esco_link_req_change_param:
+	jam LMP_EXT_ESCO_LINK_REQ,mem_lmo_opcode2
+	jam prarm_neogotiation,mem_neogotiation_state
+	branch cmd_exit
+
+check_esco_prarm:
+	fetch 1,mem_esco_type
+	bne type_hv3,reject_esco_prarm	
+	jam LMP_EXT_ACCEPTED,mem_lmo_opcode2
+	branch esco_prarm_common
+reject_esco_prarm:
+	set0 mark_esco,mark
+	jam LMP_NOT_ACCEPTED_EXT,mem_lmo_opcode2
+	force HCI_ERROR_UNKNOWN_HCI_COMMAND,temp //sco fail
+	call hci_send_sco_complete
+esco_prarm_common:
+	jam LMP_EXT_ESCO_LINK_REQ,mem_lmi_opcode2
+	rtn
+
+	
+parse_lmpext_remove_esco_req:
+	jam LMP_EXT_ACCEPTED,mem_lmo_opcode2
+	jam LMP_EXT_REMOVE_ESCO_REQ,mem_lmi_opcode2
+	branch stop_esco
+	
+parse_lmpext_iocap_req:
+	call iocap_lmpext_load
+	fetch 1,mem_device_option
+	beq dvc_op_hci,iocap_lmpext_hci
+	jam LMP_IO_CAP_RES,mem_lmo_opcode2
+	rtn
+
+parse_lmpext_iocap_res:
+	call iocap_lmpext_load
+	fetch 1,mem_device_option
+	beq dvc_op_hci,iocap_lmpext_hci
+	branch iocap_lmpext_common
+	
+iocap_lmpext_load:
+	arg      mem_sp_iocap_remote,contw
+	fetch 3, mem_rxbuf+2
+	istore    3,contw
+	rtn
+	
+iocap_lmpext_hci:
+	call hci_send_io_cap_response_event
+iocap_lmpext_common:
+	call check_localsm
+	ncall hci_send_io_cap_req_event,true
+ifdef SIMPLE_PAIRING
+	branch master_set_mem_master_sp_flag,true//is un very ok to use master flag,but we have to add many codes if wo don't
+endif
+	rtn
+parse_lmpext_accepted:
+	fetch 1,mem_rxbuf+3
+	set1 7,pdata
+	store 1,mem_lmi_accepted_opcode
+	beq LMP_PACKET_TYPE_TABLE_REQ,parse_lmpext_accepted_ptt
+	beq LMP_EXT_ESCO_LINK_REQ,play_sco
+	beq LMP_EXT_REMOVE_ESCO_REQ,parse_lmpext_stop_esco
+	rtn
+
+parse_lmpext_stop_esco:
+	branch stop_esco
+	
+parse_lmpext_not_accepted:
+	fetch 1,mem_rxbuf+3
+	set1 7,pdata
+	store 1,mem_lmi_accepted_opcode
+	beq LMP_PACKET_TYPE_TABLE_REQ,parse_lmpext_not_accepted_ptt
+	beq LMP_EXT_ESCO_LINK_REQ,parse_lmpext_not_accepted_esco
+	rtn
+
+parse_lmpext_not_accepted_esco:
+	set0 mark_esco,mark
+	rtn
+
+parse_lmpext_accepted_ptt:
+	fetch 1,mem_ptt
+	fetcht 1,mem_state_map
+	nsetflag blank,smap_edr,temp
+	storet 1,mem_state_map
+parse_lmpext_not_accepted_ptt:
+	fetch 1,mem_state
+	rtnbit0 state_init_seq
+	set0 state_init_seq,pdata
+	store 1,mem_state
+	fetch 1,mem_auth_enable
+	nbranch hci_send_linkkey_req,blank
+	jam LMP_SETUP_COMPLETE,mem_lmo_opcode2
+	rtn
+
+parse_lmpext_pause_encrypt:
+	nbranch parse_lmpext_pause_encrypt_slave, master
+	jam LMP_STOP_ENCRYPTION_REQ,mem_lmo_opcode2
+	branch tid_reply
+
+parse_lmpext_pause_encrypt_slave:	
+	jam LMP_PAUSE_ENCRYPTION_REQ, mem_lmo_opcode2
+	rtn
+
+parse_lmpext_resume_encrypt:
+//trans file to pc may cause pause/resume encrypt
+//if ms is conn_sm_wait_end the controllor won't send ack after recieved start_encypt_accept
+	call tid_reply
+	branch lmp_start_encryption
+
+parse_lmpext_features_req:
+	jam LMP_EXT_FEATURES_RES,mem_lmo_opcode2
+	rtn
+
+parse_lmpext_features_res:
+	fetcht 1,mem_rxbuf+4
+	and temp,0x1,temp
+	storet 1,mem_remote_sppcap
+	fetch 1,mem_hci_cmd
+	bne hci_cmd_wait_remote_ext_feature,parse_lmpext_features_res_not_hci
+	jam 0,mem_hci_cmd
+	call hci_send_remote_ext_features_event
+parse_lmpext_features_res_not_hci:
+	fetch 1,mem_conn_sm
+	rtnne CONN_SM_WAIT_FEATURES_EXT
+	jam CONN_SM_SEND_CONN_REQ,mem_conn_sm
+	branch process_conn_sm
+
+parse_lmp_accepted:
+	fetch 1,mem_rxbuf+1
+	store 1,mem_lmi_accepted_opcode
+	beq LMP_HOST_CONNECTION_REQ,parse_lmp_accepted_hostconn//ok
+	beq LMP_IN_RAND,parse_lmp_accepted_inrand//ok
+	beq LMP_ENCRYPTION_MODE_REQ,parse_lmp_accepted_enc_mode//ok
+	beq LMP_ENCRYPTION_KEY_SIZE_REQ,parse_lmp_accepted_enc_keysize//ok
+	beq LMP_START_ENCRYPTION_REQ,parse_lmp_accepted_start_enc//ok
+	beq LMP_STOP_ENCRYPTION_REQ,parse_lmp_accepted_stop_enc//ok
+	beq LMP_UNSNIFF_REQ,parse_lmp_accepted_unsniff_req//ok
+	beq LMP_SNIFF_REQ,parse_lmp_accepted_sniff_req//ok
+	beq LMP_SCO_LINK_REQ,play_sco
+//	beq LMP_REMOVE_SCO_LINK_REQ,stop_sco
+	beq LMP_SWITCH_REQ,parse_lmp_accepted_switch
+	// simple pairing 
+	beq LMP_ENCAPSULATED_HEADER,parse_lmp_accepted_encapsulated_header//ok
+	beq LMP_ENCAPSULATED_PAYLOAD,parse_lmp_accepted_encapsulated_payload//ok
+	beq LMP_SIMPLE_PAIRING_NUMBER,parse_lmp_accepted_simple_pairing_number//ok
+	beq LMP_DHKEY_CHECK,parse_lmp_accepted_dhkey_check//ok
+	rtn
+	
+parse_lmp_not_accepted:
+	fetch 1,mem_rxbuf+1
+	store 1,mem_lmi_accepted_opcode
+	beq LMP_NAME_REQ,parse_lmp_not_accepted_name_req//ok
+	beq LMP_HOST_CONNECTION_REQ,parse_lmp_not_accepted_hostconn//ok
+	beq LMP_AU_RAND,parse_lmp_not_accepted_aurand//ok
+	beq LMP_SCO_LINK_REQ,parse_lmp_not_accepted_sco_link_req//ok
+	beq LMP_IN_RAND,parse_lmp_not_accepted_inrand//ok
+	beq LMP_SWITCH_REQ,parse_lmp_not_accepted_switch//ok
+	/* simple pairing support */
+	beq  LMP_SIMPLE_PAIRING_NUMBER,parse_lmp_not_accepted_simple_pairing_number//ok
+	beq  LMP_DHKEY_CHECK,parse_lmp_not_accepted_dhkey_check//ok
+	beq LMP_UNSNIFF_REQ,parse_lmp_not_accepted_unsniff_req
+	beq LMP_SNIFF_REQ,parse_lmp_not_acdcept_sniff_req
+	rtn
+
+parse_lmp_accepted_switch:
+	jam BT_EVT_SWITCH_ACCEPT,mem_fifo_temp
+	call ui_ipc_send_event
+	branch role_switch_prepare0
+parse_lmp_not_accepted_switch:
+	jam BT_EVT_SWITCH_NOT_ACCEPT,mem_fifo_temp
+	call ui_ipc_send_event
+	jam SWITCH_FLAG_NOT_ACCEPT,mem_switch_flag
+	setarg TIMER_SWITCH_WAITE
+	arg switch_wait_timer,queue
+	branch timer_init
+
+
+parse_lmp_accepted_hostconn:
+	//fetch 1,mem_state
+	//rtnbit0 state_init_seq
+	fetch 1,mem_lmp_conn_state
+	set1 RECEIVED_CONN_REQ,pdata
+	store 1,mem_lmp_conn_state
+	jam BT_EVT_BB_CONNECTED,mem_fifo_temp
+	call ui_ipc_send_event
+	jam LMP_PACKET_TYPE_TABLE_REQ,mem_lmo_opcode2
+	//nbranch parse_lmp_accepted_hostconn_ctn,master
+parse_lmp_accepted_hostconn_ctn:
+	/* checking to see if we requested host connection */
+	fetch 1,mem_conn_sm
+	bne CONN_SM_WAIT_CONN_ACCEPT, parse_rx_done
+	//branch parse_lmp_accepted_hostconn_master,master
+	/* continuing on with host connection state machine */
+	jam CONN_SM_AUTH_PAIR,mem_conn_sm
+	rtn
+	//branch host_create_conn_auth_pair
+
+	/* we need to move fast and send au_rand...jumping to next part of state machine for conn */
+//parse_lmp_accepted_hostconn_master:
+	//jam CONN_SM_AUTH_PAIR ,mem_conn_sm
+//	rtn
+
+parse_lmp_not_accepted_hostconn:
+	jam ACL_CONNECTION_ALREADY_EXISTS,mem_disconn_reason_send
+	jam LMP_DETACH,mem_lmo_opcode2
+	force HCI_ERROR_HOST_TIMEOUT,temp
+	call hci_send_connection_error
+	/* clearing connection state machine */
+	jam CONN_SM_STANDBY,mem_conn_sm
+	/* sending error message to host */
+	branch parse_rx_done,true
+	rtn
+	
+parse_lmp_not_accepted_sco_link_req:
+	jam LMP_SCO_LINK_REQ,mem_lmo_opcode2
+	rtn
+
+
+parse_lmp_accepted_inrand:
+	fetch 1,mem_link_key_exists
+	nrtn blank
+	call clear_linkkey
+	call  lmp_generate_key
+	rtn master
+	set1 mark_slave_in_rand_accepted,mark
+	rtn
+
+parse_lmp_accepted_enc_mode:
+	nrtn master
+	jam LMP_ENCRYPTION_KEY_SIZE_REQ,mem_lmo_opcode2
+	fetch 1,mem_state_map
+	rtnbit0 smap_encryption
+	jam LMP_STOP_ENCRYPTION_REQ,mem_lmo_opcode2
+	rtn
+
+parse_lmp_accepted_enc_keysize:
+	branch lmp_start_encryption
+	
+parse_lmp_accepted_start_enc:
+	call send_create_conn_start_l2cap_timer_sm
+	fetch 1,mem_state
+	rtnbit1 state_conn_comp
+	jam LMP_SETUP_COMPLETE,mem_lmo_opcode2
+	fetch 1,mem_conn_sm
+	rtnne CONN_SM_ENCRYPT_WAIT
+	jam CONN_SM_ENCRYPT_WAIT_CLEAR,mem_conn_sm
+	rtn
+	
+parse_lmp_accepted_stop_enc:
+	/* again this won't work with multipoint. keep track of anyone else encrypting */
+	//jam HOST_STOP_ENCRYPTION,message_queue_B0
+	//jam 1,message_queue_B1
+	//jam HOST_RETURN_SUCCESS,message_queue_B2
+	//fetch 1,mem_lmp_state2
+	//set1 MESSAGE_QUEUE,pdata
+	//store 1,mem_lmp_state2
+	rtn
+
+parse_lmp_not_accepted_aurand:
+	fetch 1,mem_device_option
+	bne dvc_op_hci,parse_lmp_not_accepted_aurand_send_detach
+	fetch 1,mem_link_key_exists
+	rtn blank
+	fetcht 1,mem_conn_sm
+	jam 0,mem_conn_sm
+	jam 0,mem_link_key_exists
+	fetch 1,mem_rxbuf+2
+	rtnne KEY_MISSING
+	storet 1,mem_conn_sm
+	jam LOCAL_STATEMACHINE,mem_sp_localsm
+	fetch 2,mem_lmpext_ssp_enable
+	fetcht 1,mem_remote_sppcap
+	iand temp,pdata
+	branch cmd_pair,blank
+	branch cmd_ssp
+	
+parse_lmp_not_accepted_aurand_send_detach:	
+	jam LMP_DETACH,mem_lmo_opcode2
+	jam OTHER_END_TERMINATED,mem_disconn_reason_send
+	rtn
+/*in pair remote cancel the pair*/
+parse_lmp_not_accepted_inrand:
+	fetch 1,mem_rxbuf+2
+	beq KEY_MISSING,parse_lmp_inrand_key_missing
+	rtnne PAIRING_NOT_ALLOWED
+	jam PAIRING_NOT_ALLOWED,mem_disconn_reason_send
+	jam LMP_DETACH,mem_lmo_opcode2
+	rtn	
+parse_lmp_inrand_key_missing:
+	jam KEY_MISSING,mem_disconn_reason_send
+	jam LMP_DETACH,mem_lmo_opcode2
+	rtn
+	
+parse_lmp_not_accepted_name_req:
+	rtn
+	
+parse_lmp_not_accepted_simple_pairing_number:
+	jam      SP_STAT_NULL,mem_sp_state
+	jam LMP_DETACH,mem_lmo_opcode2
+	branch   parse_rx_done
+	
+parse_lmp_not_accepted_dhkey_check:
+ifdef LMP_DBG
+	call ice_break
+endif
+	jam      SP_STAT_NULL,mem_sp_state
+	jam LMP_DETACH,mem_lmo_opcode2
+	branch   parse_rx_done
+parse_lmp_not_accepted_unsniff_req:
+	jam BT_EVT_UNSNIFF_NOT_ACCEPT,mem_fifo_temp
+	branch ui_ipc_send_event
+	
+parse_lmp_accepted_unsniff_req:
+	jam BT_EVT_UNSNIFF_ACCEPT,mem_fifo_temp
+	call ui_ipc_send_event
+	call sniff_exit
+	force 0,temp
+	branch hci_send_mode_change
+	
+parse_lmp_accepted_sniff_req:
+	jam BT_EVT_SNIFF_ACCEPT,mem_fifo_temp
+	call ui_ipc_send_event
+	force 0x02,temp
+	call hci_send_mode_change
+	setarg 0
+	store 2,mem_dsniff
+	fetch 2,mem_sniff_param_interval
+	lshift pdata,pdata
+	store 2,mem_tsniff
+	fetch 1,mem_sniff_param_attempt
+	store 1,mem_sniff_attempt
+	fetch 1,mem_sniff_param_timeout
+	store 1,mem_sniff_timeout
+	branch sniff_init
+	
+parse_lmp_not_acdcept_sniff_req:
+	jam BT_EVT_SNIFF_NOT_ACCEPT,mem_fifo_temp
+	branch ui_ipc_send_event
+	
+parse_lmp_crypt_key:
+	fetcht 1,mem_rxbuf+1
+	storet 1,mem_key_size
+	branch accept_lmp_msg
+	
+parse_lmp_setup_complete:
+	fetch 1,mem_lmp_conn_state
+	set1 RECEIVED_SETUP_COMPLETE,pdata
+	store 1,mem_lmp_conn_state
+	rtnbit1 SENT_SETUP_COMPLETE
+	jam LMP_SETUP_COMPLETE,mem_lmo_opcode2
+	branch parse_rx_done
+	
+parse_lmp_max_slot:
+	//jam LMP_MAX_SLOT,mem_lmi_opcode2
+	//branch accept_lmp_msg
+	rtn
+	
+parse_lmp_max_slot_req:
+	fetch 1,mem_max_slot
+	fetcht 1,mem_rxbuf+1
+	isub temp,null
+	//jam LMP_MAX_SLOT_REQ,mem_lmi_opcode2
+	branch accept_lmp_msg,positive
+	jam LMP_NOT_ACCEPTED,mem_lmo_opcode2
+	jam UNSPECIFIED_ERROR,mem_lmo_reason2
+	jam LMP_MAX_SLOT_REQ,mem_lmi_opcode2
+	rtn
+	
+parse_lmp_detach:
+	call prepare_disconnect
+	branch accept_lmp_msg
+	
+accept_lmp_msg:
+	jam LMP_ACCEPTED,mem_lmo_opcode2
+	rtn
+
+parse_lmp_incr_power:
+	jam LMP_MAX_POWER,mem_lmo_opcode2
+	rtn
+
+parse_lmp_decr_power:
+	jam LMP_MIN_POWER,mem_lmo_opcode2
+	rtn
+	
+parse_lmp_version_res:
+	fetch 1,mem_conn_sm
+	rtneq CONN_SM_WAIT_VERSION
+	/* continuing on with host connection state machine */
+	jam CONN_SM_SEND_FEATURES ,mem_conn_sm
+	/* we need to move fast and send au_rand...jumping to next part of state machine for conn */
+	rtn
+
+
+parse_lmp_auto_rate:
+	rtn	
+
+parse_lmp_in_rand:
+	call lmp_copy_rand
+	jam pincode_state_wait_pincode,mem_pincode_state
+	fetch 1,mem_device_option
+	beq dvc_op_hci,parse_lmp_in_rand_hci	
+	jam BT_EVT_PINCODE_REQ,mem_fifo_temp
+	call ui_ipc_send_event
+parse_lmp_in_rand_hci:
+	call hci_send_pincode_req
+	call tid_check
+	nbranch lmp_accept_inrand,true
+	nbranch parse_lmp_inrand_res,master // ignore this because of not ssp temporary
+	jam LMP_NOT_ACCEPTED,mem_lmo_opcode2
+	jam LMP_IN_RAND,mem_lmi_opcode2
+	jam TRANSACTION_COLLISION,mem_lmo_reason2
+	rtn
+parse_lmp_inrand_res:
+	fetch 1,mem_op
+	set1 op_inrand_req,pdata
+	store 1,mem_op
+	rtn
+
+//store current tid
+pop_tid_follow:
+	fetcht 1,mem_state_map
+	nsetflag blank,smap_lmptid,temp
+	storet 1,mem_state_map
+	rtn
+	
+//restore current tid
+push_tid_follow:
+	fetch 1,mem_lmo_tid2
+	rshift pdata,pdata
+	and_into 1,pdata
+	rtn
+	
+parse_lmp_au_rand:
+	call push_tid_follow
+	store 1,mem_sres_tid
+	call lmp_copy_rand
+	jam LMP_SRES,mem_lmo_opcode2
+	fetch 1,mem_link_key_exists
+	nrtn blank
+	fetch 1,mem_state
+	rtnbit1 state_combkey		/* we have comb key, but not verified */
+	jam KEY_MISSING,mem_lmo_reason2
+	fetch 1,mem_device_option
+	bne dvc_op_hci,reject_lmp_packet
+	fetch 1,mem_auth_enable
+	nbranch reject_lmp_packet,blank
+	jam 0,mem_lmo_opcode2
+parse_lmp_inrand_sres:
+	fetch 1,mem_op
+	set1 op_send_sres,pdata
+	store 1,mem_op
+	branch hci_send_linkkey_req
+	
+parse_lmp_sres:	
+	arg mem_plap,rega
+	call function_e1
+	fetch 4,mem_rxbuf+1
+	fetcht 4,mem_input_store
+	isub temp,null
+	branch authentication_ok,zero
+	jam LMP_DETACH,mem_lmo_opcode2
+	jam AUTHENTICATION_FAILURE_ERROR,mem_disconn_reason_send	
+	rtn
+authentication_ok:
+	call copy_aco
+	call linkkey_ready///save link key
+	fetch 1,mem_op
+	isolate1 op_auth_req,pdata
+	set0 op_auth_req,pdata
+	store 1,mem_op
+	call hci_send_auth_complete,true
+	fetch 1,mem_conn_sm
+	beq CONN_SM_AUTH_WAIT,authentication_ok_conn_sm
+	beq CONN_SM_PAIRING_WAIT,authentication_ok_conn_sm
+	rtn
+authentication_ok_conn_sm:
+	fetch 1,mem_pairing_auth
+	rtnne DEFALT_PAIRING_AUTH
+	fetch 1,mem_state_map
+	rtnbit1 smap_encryption
+	branch host_create_conn_encrypt
+
+parse_lmp_comb_key:
+	arg mem_rxbuf+1,rega
+	arg mem_kinit,regb
+	arg mem_random_number,contw
+	call xor16
+	arg mem_plap,rega
+	call generate_linkkey
+	jam LMP_AU_RAND,mem_lmo_opcode2
+	fetch 1,mem_state
+	bbit0 state_combkey,lmp_generate_key
+	rtn
+	
+parse_lmp_name_res:
+	fetch 2,mem_len
+	add pdata,-3,loopcnt	//for remote name length error
+	fetcht 1,mem_rxbuf+1
+	setarg mem_tmp_buffer
+	iadd temp,contw
+	arg mem_rxbuf+3,contr
+	call memcpy
+	fetcht 1,mem_name_offset
+	fetch 1,mem_rxbuf+2
+	isub temp,pdata
+	sub pdata,14,null
+	branch parse_lmp_name_res_end,positive
+	add temp,14,pdata
+	store 1,mem_name_offset
+	jam LMP_NAME_REQ,mem_lmo_opcode2
+	rtn
+parse_lmp_name_res_end:
+	fetch 1,mem_state_map
+	set1 smap_name_res,pdata
+	store 1,mem_state_map
+	bbit1 smap_name_req,lmp_disconnect
+	//force HCI_SUCCESS,queue
+	//branch hci_send_name
+	rtn
+parse_lmp_name_req:
+	fetch 1,mem_rxbuf+1
+	store 1,mem_lmi_opcode2 //offset 
+	jam LMP_NAME_RES,mem_lmo_opcode2
+	rtn
+
+parse_lmp_conn_req:
+	fetch 1,mem_device_option
+	bne dvc_op_hci,accept_lmp_msg
+	force 1,temp
+	branch hci_send_conn_req_event	
+	
+parse_lmp_timing_accuracy_req:
+	jam LMP_TIMING_ACCURACY_RES,mem_lmo_opcode2
+	rtn
+
+parse_lmp_features_req:
+	jam LMP_FEATURES_RES,mem_lmo_opcode2
+	rtn
+
+parse_lmp_version_req:
+	jam LMP_VERSION_RES,mem_lmo_opcode2
+	rtn
+
+parse_lmp_supervision_timeout:
+//	fetch 2,mem_rxbuf+1
+//	store 2,mem_supervision_to
+	rtn
+	
+
+
+parse_lmp_sniff_subrating_req:
+	fetch 2,mem_tsniff
+	iforce temp
+	fetch 1,mem_rxbuf+2
+	store 1,mem_subsniff_rate
+	imul32 temp,temp
+	fetch 2,mem_rxbuf+3
+	lshift pdata,pdata
+	store 2,mem_subsniff_tcmax
+	fetch 4,mem_rxbuf+5
+	lshift pdata,pdata
+ 	store 4,mem_subsniff_instant
+	//product pdata
+	deposit temp
+	store 2,mem_subsniff_tsniff
+	rtn
+parse_lmpext_packet_type_table_req:
+	fetcht 1,mem_ptt
+	fetch 1,mem_rxbuf+2
+	ixor temp,null
+	nbranch reject_unknown_ext_packet,zero
+	isolate1 0,pdata
+	fetch 1,mem_state_map
+	setflag true,smap_edr,pdata
+	store 1,mem_state_map
+	jam LMP_EXT_ACCEPTED,mem_lmo_opcode2
+	jam LMP_PACKET_TYPE_TABLE_REQ,mem_lmi_opcode2
+	rtn
+
+	
+parse_lmp_sniff_subrating_res:
+	rtn
+
+parse_lmp_max_power:
+	rtn
+parse_lmp_min_power:
+	rtn
+parse_lmp_page_mode_req:
+	//jam LMP_PAGE_MODE_REQ,mem_lmi_opcode2
+	branch accept_lmp_msg
+parse_lmp_page_scan_mode_req:
+	//this can influence connection. need accepted
+	//jam LMP_PAGE_SCAN_MODE_REQ,mem_lmi_opcode2
+	branch accept_lmp_msg
+parse_lmp_preferred_rate:
+	rtn
+parse_lmp_remove_sco_link_req:
+	call stop_sco
+	jam LMP_REMOVE_SCO_LINK_REQ,mem_lmi_opcode2
+	branch accept_lmp_msg
+
+
+parse_lmp_sco_link_req:
+	fetch 1,mem_rxbuf+1
+	store 1,mem_sco_handle
+	fetch 1,mem_rxbuf+3
+	store 1,mem_esco_desco
+	fetch 1,mem_rxbuf+6
+	store 1,mem_air_mode
+	call push_tid_follow
+	store 1,mem_accptsco_tid
+	force 0,temp
+	branch hci_send_conn_req_event
+	
+parse_lmp_slot_offset:
+	fetch 2,mem_rxbuf+1
+	store 2,mem_slot_offset
+	rtn
+	
+parse_lmp_sniff_req:
+	fetch 1,mem_state
+	bbit1 state_insniff,lmp_reject_sniff
+	fetch 2,mem_rxbuf+2 /* dsniff */
+	lshift pdata,pdata
+	store 2,mem_dsniff	
+	fetch 2,mem_rxbuf+4 /* tsniff */
+	lshift pdata,pdata
+	store 2,mem_tsniff
+	fetch 2,mem_rxbuf+6 /* sniff attempt */
+	store 1,mem_sniff_attempt
+	iforce temp
+	fetch 2,mem_rxbuf+8 /* sniff timeout */
+	store 1,mem_sniff_timeout
+	isub temp,null
+	nbranch set_big_value_to_attempt,positive
+	store 1,mem_sniff_attempt
+set_big_value_to_attempt:	
+	//call sniff_init
+	jam LMP_ACCEPTED,mem_lmo_opcode2
+	jam LMP_SNIFF_REQ,mem_lmi_opcode2
+	rtn
+
+lmp_reject_sniff:
+	jam PDU_NOT_ALLOWED,mem_lmo_reason2
+	branch reject_lmp_packet
+
+parse_lmp_start_encryption_req:
+	call accept_lmp_msg
+	call lmp_copy_rand
+	call function_e3
+	branch start_encryption
+	
+parse_lmp_stop_encryption_req:
+	call accept_lmp_msg
+	branch stop_encryption
+	
+
+parse_lmp_switch_req:
+	fetch 4,mem_rxbuf+1
+	lshift pdata,pdata
+	//branch parse_lmp_switch_req_not_accept
+	branch parse_lmp_switch_accept,master
+	fetcht 1,mem_link_key_exists
+	nbranch parse_lmp_switch_req_clear_mark,blank
+parse_lmp_switch_req_not_accept:
+	jam LMP_NOT_ACCEPTED,mem_lmo_opcode2
+	jam LMP_SWITCH_REQ,mem_lmi_opcode2
+	jam PDU_NOT_ALLOWED,mem_lmo_reason2
+	rtn
+parse_lmp_switch_req_clear_mark:
+	jam LMP_SLOT_OFFSET,mem_lmo_opcode2
+	jam 0,mem_conn_sm
+	branch role_switch_prepare
+
+parse_lmp_switch_accept:
+	call role_switch_prepare
+	set1 mark_reconn_recieve_switch,mark
+	fetch 1,mem_connection_options
+	set0 CONNECTION_SWITCH,pdata
+	store 1,mem_connection_options
+	branch accept_lmp_msg
+
+	
+
+parse_lmp_temp_rand:
+	rtn
+parse_lmp_temp_key:
+	rtn
+parse_lmp_timing_accuracy_res:
+	rtn
+	
+parse_lmp_unit_key:
+	
+	rtn
+
+	
+parse_lmp_unsniff_req:
+	jam LMP_ACCEPTED,mem_lmo_opcode2
+	jam LMP_UNSNIFF_REQ,mem_lmi_opcode2
+	jam BT_EVT_REMOTE_UNSNIFF,mem_fifo_temp
+	call ui_ipc_send_event
+	force 0,temp
+	call hci_send_mode_change
+	branch sniff_exit
+parse_lmp_use_semi_permanend_key:
+	rtn
+	
+parse_lmp_encapsulated_header:
+	fetch 1,mem_rxbuf+1
+	bne ENCAPSULATED_MAJOR_TYPE_P192,parse_lmp_encapsulated_header_reject
+	fetch 1,mem_rxbuf+2
+	bne ENCAPSULATED_MINOR_TYPE_P192,parse_lmp_encapsulated_header_reject
+	fetch 1,mem_rxbuf+3
+	bne ENCAPSULATED_LEN_P192,parse_lmp_encapsulated_header_reject
+	call check_localsm
+	branch parse_lmp_encapsulated_header_master,true
+	jam SP_STAT_KEY_RECV,mem_sp_state
+parse_lmp_encapsulated_header_master:
+	jam LMP_ACCEPTED,mem_lmo_opcode2
+	jam LMP_ENCAPSULATED_HEADER,mem_lmi_opcode2
+	branch parse_rx_done
+	
+parse_lmp_encapsulated_header_reject:
+	jam      PDU_NOT_ALLOWED,mem_lmo_reason2
+	branch   reject_lmp_packet
+	
+parse_lmp_accepted_encapsulated_header:
+	//jam LMP_ENCAPSULATED_PAYLOAD,mem_lmi_opcode2
+	//branch   accept_lmp_msg  	
+	jam LMP_ENCAPSULATED_PAYLOAD,mem_lmo_opcode2
+      //   branch   accept_lmp_msg  	
+         rtn
+parse_lmp_accepted_simple_pairing_number:
+	call check_localsm
+	rtn true
+	jam      SP_STAT_CONFIRM_RECV,mem_sp_state
+	rtn
+
+parse_lmp_accepted_dhkey_check:
+	//here must be change***  shyd
+	call check_localsm
+ifdef SIMPLE_PAIRING
+	ncall g_noninit,true	//when be master  call g_init
+	call g_init,true
+endif
+	call hci_send_user_confirmation_req
+	call hci_send_ssp_complete		//un very good put here
+	call check_localsm
+	rtn true
+	jam SP_STAT_LINK_KEY_CALC,mem_sp_state
+	jam SP_FLAG_COMMIT,mem_sp_flag
+	rtn
+
+parse_simple_pairing_confirm:
+	arg mem_sp_confirm_remote,contw
+	fetch 8,mem_rxbuf+1
+	istore   8,contw
+	fetch 8,mem_rxbuf+9
+	istore   8,contw
+ifdef SIMPLE_PAIRING
+	branch master_set_mem_master_sp_flag
+endif
+	
+parse_lmp_encapsulated_payload:
+	fetch 1,mem_master_sp_state
+	beq SP_STAT_RANDOM_SEND,parse_encapsulated_payload_master
+	fetch    1,mem_sp_state
+	bne SP_STAT_KEY_RECV,parse_lmp_encapsulated_payload_reject
+parse_encapsulated_payload_master:
+	fetch    1,mem_sp_remote_key_recv_count
+	sub      pdata,0x20,contw
+	nbranch  parse_lmp_encapsulated_payload_reject,positive
+	arg      mem_sp_pubkey_remote,contw
+	iadd     contw,contw
+	fetch 8,mem_rxbuf+1
+	istore   8,contw
+	fetch 8,mem_rxbuf+9
+	istore   8,contw
+	fetch    1,mem_sp_remote_key_recv_count
+	increase 16,pdata
+	store    1,mem_sp_remote_key_recv_count
+	bne ENCAPSULATED_LEN_P192,accept_lmp_msg
+parse_lmp_encapsulated_payload_completed:
+	call check_localsm
+	branch accept_lmp_msg,true
+	jam      SP_KEY_VALID,mem_sp_remote_key_invalid
+	jam      SP_STAT_KEY_GENERATE,mem_sp_state
+	jam      SP_FLAG_COMMIT,mem_sp_flag  
+	branch   accept_lmp_msg
+parse_lmp_encapsulated_payload_reject:
+	jam      PDU_NOT_ALLOWED,mem_lmo_reason2
+	branch   reject_lmp_packet	
+parse_lmp_accepted_encapsulated_payload: 
+	fetch 1,mem_sp_local_key_send_count
+	beq	ENCAPSULATED_LEN_P192,parse_LMP_ENCAPSULATED_PAYLOAD_all_accepted
+	jam LMP_ENCAPSULATED_PAYLOAD,mem_lmo_opcode2
+	branch   parse_rx_done  	
+parse_lmp_encapsulated_payload_all_accepted:   
+	call check_localsm
+	branch parse_lmp_encapsulated_payload_all_accepted_master,true
+	jam      SP_FLAG_COMMIT,mem_sp_flag
+	jam      SP_STAT_COMMIT_CALC,mem_sp_state 
+	branch   parse_rx_done 
+parse_lmp_encapsulated_payload_all_accepted_master:
+	//call sp_master_generate_local_key
+	branch   parse_rx_done   
+
+parse_lmp_simple_pairing_number:
+	fetch 1,mem_master_sp_state
+	beq SP_STAT_RANDOM_SEND,parse_lmp_simple_pairing_number_master
+	fetch    1,mem_sp_state
+	bne SP_STAT_RANDOM_RECV,parse_lmp_simple_pairing_number_reject
+parse_lmp_simple_pairing_number_master:
+	arg      mem_sp_random_remote,contw
+	fetch 8,mem_rxbuf+1
+	istore   8,contw
+	fetch 8,mem_rxbuf+9
+	istore   8,contw
+	call check_localsm
+	branch parse_lmp_simple_pairing_number_master0,true
+	jam      SP_STAT_RANDOM_SEND,mem_sp_state
+	jam      SP_FLAG_COMMIT,mem_sp_flag
+	branch accept_lmp_msg  
+parse_lmp_simple_pairing_number_master0:
+	jam SP_STAT_COMMIT_CALC,mem_master_sp_state
+ifdef SIMPLE_PAIRING
+	branch master_set_mem_master_sp_flag
+endif
+	//jam LMP_SIMPLE_PAIRING_NUMBER,mem_lmi_opcode2
+	//branch accept_lmp_msg  
+parse_lmp_simple_pairing_number_reject:
+	jam      PDU_NOT_ALLOWED,mem_lmo_reason2
+	branch reject_lmp_packet
+	
+parse_dhkey_check:
+	fetch    1,mem_master_sp_state
+	beq SP_STAT_CONFIRM_SEND,parse_dhkey_check_master
+	fetch    1,mem_sp_state
+	bne SP_STAT_CONFIRM_RECV,parse_lmp_dhkey_check_reject
+parse_dhkey_check_master:
+	arg      mem_sp_check_result,contw
+	fetch 8,mem_rxbuf+1
+	istore   8,contw
+	fetch 8,mem_rxbuf+9
+	istore   8,contw
+	call check_localsm
+	branch parse_dhkey_check_master0,true
+	jam      SP_STAT_CONFIRM_CHECK,mem_sp_state
+	jam      SP_FLAG_COMMIT,mem_sp_flag
+	branch   parse_rx_done
+parse_dhkey_check_master0:
+	jam      SP_STAT_CONFIRM_CHECK,mem_master_sp_state
+	jam      SP_FLAG_COMMIT,mem_master_sp_flag
+	branch   parse_rx_done
+parse_lmp_dhkey_check_reject:
+	jam      PDU_NOT_ALLOWED,mem_lmo_reason2
+	branch reject_lmp_packet
+	
+parse_lmp_clkoffset_res:
+	branch parse_rx_done
+		
+parse_lmp_encryption_mode_req:
+	fetch 1,mem_connection_options
+	set0 CONNECTION_ENCRYPT
+	store 1,mem_connection_options
+	call accept_lmp_msg
+	nrtn master					/* do sth only if we're master */
+	fetch 1,mem_rxbuf+1
+	fetcht 1,mem_op
+	setflag blank,op_stop_enc,temp
+	nsetflag blank,op_start_enc,temp
+	storet 1,mem_op
+	rtn 
+	
+parse_lmp_features_res:
+	fetcht 8,mem_rxbuf+1		/*fix bcp(baoshijie) err*/
+	fetch 1,mem_hci_cmd
+	bne hci_cmd_wait_remote_feature,parse_lmp_features_res_not_hci
+	jam 0,mem_hci_cmd
+	call hci_send_remote_features
+parse_lmp_features_res_not_hci:	
+	fetch 1,mem_conn_sm
+	rtnne CONN_SM_WAIT_FEATURES_RES
+	fetch 1,mem_device_option
+	beq dvc_op_hci,parse_lmp_feature_ext_sm
+	fetch 1,mem_connection_options
+	bbit0 CONNECTION_FEATURE_EXT,parse_lmp_send_conn
+parse_lmp_feature_ext_sm:
+	jam CONN_SM_SEND_FEATURES_EXT,mem_conn_sm
+	rtn
+parse_lmp_send_conn:
+	jam CONN_SM_SEND_CONN_REQ,mem_conn_sm
+	rtn
+parse_lmp_test_activate:
+	fetch 1,mem_debug_config
+	store 1,mem_test_mode_old_debug_config
+	jam LMP_ACCEPTED,mem_lmo_opcode2
+	jam LMP_TEST_ACTIVATE,mem_lmi_opcode2
+	rtn
+parse_lmp_test_control:
+	/* the 9 test control parameters are XORed with 0x55 */
+	/* doing the XOR here and storing in mem_temp_payload */
+	jam LMP_ACCEPTED,mem_lmo_opcode2
+	jam LMP_TEST_CONTROL,mem_lmi_opcode2
+	force 9,loopcnt
+	arg mem_rxbuf+1,contr
+	arg mem_temp_payload,contw
+parse_lmp_test_xor:
+	ifetch 1,contr
+	xor_into 0x55,pdata
+	istore 1,contw
+	loop parse_lmp_test_xor
+	fetch 1,test_mode_scenario
+	fetcht 1,mem_tester_emulate
+	set0 tester_no_whitening,temp
+	set0 tester_pattern_test,temp
+	beq EXIT_TEST_MODE,	 parse_lmp_test_control_exit
+	beq PAUSE_TEST_MODE,	 parse_lmp_test_control_pause
+	beq CLOSED_LOOP_BACK_ACL,	 parse_lmp_test_control_loopback
+	beq ACL_WITHOUT_WHITENING,	 parse_lmp_test_control_loopback_nowhite
+	beq CLOSED_LOOP_BACK_SCO,	 parse_lmp_test_control_loopback
+	beq SCO_WITHOUT_WHITENING,	 parse_lmp_test_control_loopback_nowhite
+	beq ZERO_PATTERN,	 parse_lmp_test_control_pattern
+	beq ONE_PATTERN,	 parse_lmp_test_control_pattern
+	beq ALT_PATTERN,	 parse_lmp_test_control_pattern
+	beq ALT2_PATTERN,	 parse_lmp_test_control_pattern
+	beq PSEUDORANDOM,	 parse_lmp_test_control_pattern
+	rtn
+parse_lmp_test_control_exit:
+	/* restoring old parameters */
+	fetch 1,mem_tester_emulate
+	set1 tester_exit,pdata
+	set1 tester_change,pdata
+	store 1,mem_tester_emulate
+	rtn
+parse_lmp_test_control_pattern:
+	set1 tester_pattern_test,temp
+	jam 5,mem_lch_code
+	fetch 2,test_mode_data_length
+	iforce loopcnt
+	store 2,mem_len
+	arg mem_rxbuf,contw
+	call pn9
+parse_lmp_test_control_loopback_nowhite:
+	set1 tester_no_whitening,temp
+parse_lmp_test_control_loopback:
+	set1 tester_change,temp
+	force 0,pdata
+	store 1,mem_slave_rcvcnt
+	store 2,mem_tst_pktcnt_crc
+	store 2,mem_tst_pktcnt_dmh
+	store 2,mem_tst_pktcnt_hec
+	store 2,mem_tst_pktcnt_sync
+	fetch 1,test_mode_hopping_mode
+	compare FIXED_FREQ,pdata,0xff
+	setflag true,tester_fixed_freq,temp
+	storet 1,mem_tester_emulate
+	rtn
+
+parse_lmp_test_control_pause:
+	set0 mark_testmode,mark
+	jam 0,mem_tester_emulate
+	fetch 1,mem_debug_config
+	set0 debug_tx_pattern,pdata
+	store 1,mem_debug_config
+	rtn
+
+check_test_cond:
+	fetch 1,mem_tester_emulate
+	rtnbit0 tester_change
+	fetch 1,mem_tester_cnt
+	increase 1,pdata
+	store 1,mem_tester_cnt
+	rtnne 5
+	jam 0,mem_tester_cnt
+	fetch 1,mem_tester_emulate
+	set0 tester_change,pdata
+	store 1,mem_tester_emulate
+	bbit1 tester_exit,check_test_exit
+	isolate1 tester_no_whitening,pdata
+	call test_no_white,true
+	ncall test_enable_white,true
+	fetch 1,test_mode_packet_type
+	compare 0x20,pdata,0x30
+	fetch 1,mem_state_map
+	setflag true,smap_edr,pdata
+	store 1,mem_state_map
+	fetch 1,mem_tester_emulate
+	fetcht 1,mem_debug_config
+	isolate1 tester_pattern_test,pdata
+	setflag true,debug_tx_pattern,temp
+	isolate1 tester_fixed_freq,pdata
+	setflag true,debug_tx_fixed_freq,temp
+	setflag true,debug_rx_fixed_freq,temp
+	storet 1,mem_debug_config
+	fetch 1,test_mode_tx_freq
+	store 1,mem_tx_fixed_freq
+	fetch 1,test_mode_rx_freq
+	store 1,mem_rx_fixed_freq
+	set1 mark_testmode,mark
+	rtn
+	
+check_test_exit:
+	set0 mark_testmode,mark
+	jam 0,mem_tester_emulate
+	fetch 1,mem_test_mode_old_debug_config
+	store 1,mem_debug_config
+	hfetch 1,core_config
+	and_into 0xfb,pdata			/* whitening on */
+	hstore 1,core_config	
+	rtn
+	
+
+lmp_copy_rand:	
+	arg mem_rxbuf+1,contr
+	arg mem_random_number,contw
+	branch memcpy16
+
+lmp_generate_key:
+	jam LMP_COMB_KEY,mem_lmo_opcode2
+	rtn
+
+lmp_start_encryption:
+	nrtn master
+	jam LMP_START_ENCRYPTION_REQ,mem_lmo_opcode2
+	rtn
+	
+lmp_accept_inrand:
+	arg mem_lap,rega
+	call generate_kinit
+	jam LMP_ACCEPTED,mem_lmo_opcode2
+	jam LMP_IN_RAND,mem_lmi_opcode2
+	rtn
+
+lmp_disconnect:
+	jam 10,mem_conn_timer
+	jam LMP_DETACH,mem_lmo_opcode2
+	jam LOCAL_HOST,mem_disconn_reason_send	
+	rtn
+
+/*********************************/
+/*********lmp send*************/
+/********************************/
+	/* enable user if a lmp packet is to send */
+send_lmp:
+	set1 mark_ext_patch,mark
+	bpatch patch3c_3,mem_patch3c
+	disable user
+	call lmo_fifo_process
+	fetch 1,mem_lmp_to_send
+	rtn blank
+/* lmp message to be processed. this will either be because host??? */
+/* wants to send a lmp message or because one resulted from the LMP */
+/* processing section */
+/********* outgoing lmp lookup table *************/
+	bbit1 7,send_lmp_escape
+	beq LMP_NAME_REQ,	 send_lmp_name_req
+	beq LMP_NAME_RES,	 send_lmp_name_res
+	beq LMP_ACCEPTED,	 send_lmp_accepted
+	beq LMP_NOT_ACCEPTED,	 send_lmp_not_accepted
+	beq LMP_FEATURES_REQ,	 send_lmp_features_req
+	beq LMP_FEATURES_RES,	 send_lmp_features_res
+	beq LMP_TIMING_ACCURACY_RES,	 send_lmp_timing_accuracy_res
+	beq LMP_VERSION_REQ,	 send_lmp_version_req
+	beq LMP_VERSION_RES,	 send_lmp_version_res
+	beq LMP_SETUP_COMPLETE,	 send_lmp_setup_complete
+	beq LMP_SUPERVISION_TIMEOUT,	 send_lmp_superto
+	beq LMP_HOST_CONNECTION_REQ,send_lmp_no_payload
+	beq LMP_IN_RAND,send_lmp_inrand
+	beq LMP_COMB_KEY,send_lmp_comb_key
+	beq LMP_AU_RAND,send_lmp_aurand
+	beq LMP_SRES,send_lmp_sres
+	beq LMP_ENCRYPTION_MODE_REQ,send_lmp_encryption_mode_req
+	beq LMP_ENCRYPTION_KEY_SIZE_REQ,send_lmp_encryption_key_size_req
+	beq LMP_START_ENCRYPTION_REQ,send_lmp_start_encryption
+	beq LMP_DETACH,send_lmp_detach
+	beq LMP_QUALITY_OF_SERVICE_REQ, send_lmp_quality_of_service_req
+	beq LMP_UNIT_KEY,send_lmp_unit_key
+	//Optional (O)
+	beq LMP_SCO_LINK_REQ, send_lmp_sco_link_req	
+	beq LMP_CLKOFFSET_RES, send_lmp_clkoffset_res	
+	beq LMP_MAX_POWER,send_lmp_nopayload_reply
+	beq LMP_MAX_SLOT, send_lmp_max_slot
+	beq LMP_MAX_SLOT_REQ, send_lmp_max_slot_req
+	beq LMP_MIN_POWER,send_lmp_nopayload_reply
+	beq LMP_REMOVE_SCO_LINK_REQ, send_lmp_remove_sco_link_req	
+	beq LMP_SLOT_OFFSET, send_lmp_slot_offset
+	beq LMP_SWITCH_REQ, send_lmp_switch_req
+	beq LMP_SNIFF_REQ, send_lmp_sniff_req
+	beq LMP_STOP_ENCRYPTION_REQ, send_lmp_stop_encryption_req	
+	beq LMP_TIMING_ACCURACY_REQ, send_lmp_timing_accuracy_req
+	beq LMP_UNSNIFF_REQ, send_lmp_unsniff_req
+	beq LMP_ENCAPSULATED_HEADER,send_lmp_encapsulated_header
+	beq LMP_ENCAPSULATED_PAYLOAD,send_lmp_encapsulated_payload
+	beq LMP_SIMPLE_PAIRING_CONFIRM,send_lmp_simple_pairing_comfirm
+	beq LMP_SIMPLE_PAIRING_NUMBER,send_lmp_simple_pairing_number
+	beq LMP_DHKEY_CHECK,send_lmp_dhkey_check
+	beq LMP_AUTO_RATE,send_lmp_auto_rate
+	beq LMP_ENC_KEY_SIZE_MASK_RES,send_lmp_enc_key_size_mask_res
+	//master only must(M)
+	beq LMP_CLKOFFSET_REQ, send_lmp_clkoffset_req
+	beq LMP_QUALITY_OF_SERVICE, send_lmp_quality_of_service
+	beq LMP_TEST_ACTIVATE, send_lmp_test_activate
+	beq LMP_TEST_CONTROL, send_lmp_test_control
+send_lmp_error:
+	branch assert
+	rtn
+send_lmp_escape:
+	beq LMP_EXT_ESCO_LINK_REQ,send_lmpext_esco_req
+	beq LMP_EXT_REMOVE_ESCO_REQ,send_lmpext_remove_esco
+	beq LMP_EXT_ACCEPTED,send_lmpext_accepted
+	beq LMP_EXT_FEATURES_RES,send_lmpext_features_res
+	beq LMP_NOT_ACCEPTED_EXT,send_lmpext_not_accepted
+	beq LMP_EXT_FEATURES_REQ,send_lmpext_features_req
+	beq LMP_PACKET_TYPE_TABLE_REQ,send_lmpext_packet_type_table_req
+	beq LMP_PAUSE_ENCRYPTION_REQ,send_lmpext_pause_encryption_req
+	beq LMP_IO_CAP_REQ,send_lmp_io_cap_req
+	beq LMP_IO_CAP_RES,send_lmpext_io_cap_res
+	beq LMP_SNIFF_SUBRATING_REQ,send_lmpext_sniff_subrating_req
+	beq LMP_SNIFF_SUBRATING_RES,send_lmpext_sniff_subrating_res
+	branch assert
+
+
+/******** LMP follow messages **********/
+/****** TID follow received packet  *******/
+
+send_lmp_accepted:
+	force 2,pdata
+	call msg_send_lmp
+	fetch 1,mem_lmi_opcode
+	istore 1,contw
+	beq LMP_SCO_LINK_REQ,send_lmp_accptsco
+	call send_lmp_follow
+	fetch 1,mem_lmi_opcode
+	beq LMP_IN_RAND,send_lmp_accepted_inrand
+	beq LMP_ENCRYPTION_MODE_REQ,send_lmp_accepted_enc_mode
+	beq LMP_ENCRYPTION_KEY_SIZE_REQ,send_lmp_accepted_enc_key
+	beq LMP_SNIFF_REQ,send_lmp_accept_sniff_req
+	beq LMP_HOST_CONNECTION_REQ,send_lmp_accepted_connection
+	beq LMP_REMOVE_SCO_LINK_REQ,send_lmp_accept_remove_sco_link_req
+	beq LMP_DHKEY_CHECK,send_lmp_accept_dhkey_check
+	beq LMP_START_ENCRYPTION_REQ,send_create_conn_start_l2cap_timer_sm  
+	rtn	
+	
+send_create_conn_start_l2cap_timer_sm:
+	fetch 1,mem_conn_sm
+	rtn blank
+	jam CONN_SM_WAIT_DONE,mem_conn_sm
+	setarg TIMER_ENPT_WAITE
+	arg enpt_delay_timer,queue
+	branch timer_init
+	
+send_lmp_accept_sniff_req:
+	force 0x02,temp
+	call hci_send_mode_change
+	branch sniff_init
+send_lmp_not_accepted:
+	force 3,pdata
+	call msg_send_lmp
+	fetch 1,mem_lmi_opcode
+	beq LMP_AU_RAND,send_not_accept_aurand
+	istore 1,contw
+	fetch 1,mem_lmo_reason
+	istore 1,contw
+	branch send_lmp_follow
+
+send_not_accept_aurand:
+	istore 1,contw
+	fetch 1,mem_lmo_reason
+	istore 1,contw
+	arg mem_sres_tid,temp
+	branch special_tid_store
+
+send_lmpext_accepted:	
+	force 4,queue
+	call send_lmpext
+	setarg LMP_ESCAPE
+	istore 1,contw
+	fetch 1,mem_lmi_opcode
+	set0 7,pdata
+	istore 1,contw
+	fetch 1,mem_lmi_opcode
+	beq LMP_EXT_ESCO_LINK_REQ,send_lmp_accptsco
+	call send_lmp_follow
+	fetch 1,mem_lmi_opcode
+	beq LMP_EXT_REMOVE_ESCO_REQ,send_lmp_accept_remove_sco_link_req
+	rtn
+
+send_lmpext_not_accepted:
+	force 5,queue
+	call send_lmpext
+	setarg LMP_ESCAPE
+	istore 1,contw
+	fetch 1,mem_lmi_opcode
+	set0 7,pdata
+	istore 1,contw
+	fetch 1,mem_lmo_reason
+	istore 1,contw
+	branch send_lmp_follow
+
+send_lmp_accptsco:
+	call play_sco
+	arg mem_accptsco_tid,temp
+	branch special_tid_store
+	
+
+send_lmp_accepted_inrand:
+	call clear_linkkey
+	call tid_check	
+	rtn true
+	branch lmp_generate_key
+
+send_lmp_accepted_enc_mode:
+	fetch 1,mem_op
+	bbit1 op_start_enc,send_lmp_accepted_enc_start
+	rtnbit0 op_stop_enc
+	jam LMP_STOP_ENCRYPTION_REQ,mem_lmo_opcode2
+	set0 op_stop_enc,pdata
+	call tid_reply
+	branch send_lmp_accepted_enc_exit
+send_lmp_accepted_enc_start:
+	jam LMP_ENCRYPTION_KEY_SIZE_REQ,mem_lmo_opcode2
+	set0 op_start_enc,pdata
+send_lmp_accepted_enc_exit:
+	store 1,mem_op
+	rtn
+
+send_lmp_accepted_enc_key:
+	call check_localsm
+	branch lmp_start_encryption,true
+	rtn
+
+send_lmp_accepted_connection:
+	//jam LMP_SETUP_COMPLETE,mem_lmo_opcode2
+	fetch 1,mem_lmp_conn_state
+	set1 RECEIVED_CONN_REQ,pdata
+	store 1,mem_lmp_conn_state
+	jam BT_EVT_BB_CONNECTED,mem_fifo_temp
+	branch ui_ipc_send_event
+
+/*distroy sco handle 0xe00*/
+send_lmp_accept_remove_sco_link_req:
+	rtn
+
+send_lmp_accept_dhkey_check:
+	rtn
+/******** LMP reply messages **********/
+/****** TID always set to remote  *******/
+
+send_lmpext_features_res:
+	force 12,queue
+	call send_lmpext
+	setarg 0x01
+	istore 1,contw
+	fetch 2,mem_lmpext_ssp_enable
+	istore 2,contw
+	setarg 0
+	istore 3,contw
+	setarg 0x00
+	istore 4,contw
+	branch send_lmp_reply
+send_lmpext_io_cap_res:
+         
+         force 5,queue
+         call send_lmpext
+         fetch 1,mem_device_option
+         beq dvc_op_hci,send_lmpext_io_cap_res_hci
+         setarg 0x040003
+         istore 3,contw
+         store 3,mem_sp_iocap_local
+         branch send_lmp_reply
+send_lmpext_io_cap_res_hci:
+	fetch 3,mem_sp_iocap_local
+	istore 3,contw
+	branch send_lmp_reply
+         
+send_lmp_io_cap_req:
+	force 5,queue
+	call send_lmpext
+	fetch 3,mem_sp_iocap_local
+	istore 3,contw
+	branch send_lmp_request
+	
+
+send_lmpext_sniff_subrating_req: 
+
+	rtn
+send_lmpext_sniff_subrating_res: 
+         force 9,queue
+         call send_lmpext
+         fetch 1,mem_subsniff_rate
+         istore 1,contw
+         fetch 2,mem_subsniff_tcmax
+         istore 2,contw
+         fetch 4,mem_subsniff_instant
+         istore 4,contw
+	branch send_lmp_reply
+
+send_lmp_name_res:
+	force 17,pdata
+	call msg_send_lmp
+	fetch 1,mem_lmi_opcode  /* loading name offset */
+	copy pdata,temp
+	beq 0x00,send_lmp_name_res_offset_ok
+	beq 0x0e,send_lmp_name_res_offset_ok
+	beq 0x1c,send_lmp_name_res_offset_ok
+	rtn
+send_lmp_name_res_offset_ok:
+	istore 1,contw	/* writing name offset */
+	fetch 1,mem_local_name_length
+	istore 1,contw	/* writing name length */
+	copy pdata,loopcnt
+	setarg mem_local_name
+	iadd temp,contr	/* setting read location */
+	call memcpy
+	branch send_lmp_reply
+
+
+send_lmp_timing_accuracy_res:
+	force 3,pdata
+	call msg_send_lmp
+	setarg 0x0114
+	istore 2,contw
+	branch send_lmp_reply
+
+send_lmp_clkoffset_res:
+	// dopod s505 must wait for this res
+	force 3,pdata
+	call msg_send_lmp
+	fetch 4,mem_clke_bt
+	isub clkn_bt,pdata
+	branch send_lmp_clkoffset_res_master,master
+	sub pdata,0,pdata		/* our role is slave */
+send_lmp_clkoffset_res_master:	
+	// bit 16-2 of clkslave-clkmaster
+	rshift2 pdata,pdata
+	set0 15,pdata
+	istore 2,contw
+	branch send_lmp_reply
+
+send_lmp_version_res:
+	force 6,pdata
+	call msg_send_lmp
+	fetch 5,mem_lmp_version
+	istore 5,contw
+	branch send_lmp_reply
+
+send_lmp_features_res:
+	force 9,pdata
+	call msg_send_lmp
+	fetch 8,mem_features
+	istore 8,contw
+	branch send_lmp_reply  
+
+
+/******** LMP request messages **********/
+/****** TID always set to local initiated *******/
+	
+send_lmpext_esco_req:
+	branch send_lmpext_esco_req_master,master
+	//jam 0x00,mem_sco_handle
+	//jam 0x7,mem_esco_addr
+	branch send_lmpext_esco_req_slave
+send_lmpext_esco_req_master:
+	jam 0x07,mem_esco_addr
+send_lmpext_esco_req_slave:
+	jam 0,mem_esco_desco
+	force 16,queue
+	call send_lmpext
+	fetch 1,mem_sco_handle
+	istore 1,contw
+	fetch 1,mem_esco_addr
+	istore 1,contw
+	setarg 0
+	istore 1,contw			/* timing ctrl */
+	fetch 1,mem_esco_desco
+	istore 1,contw			/* Desco */
+	setarg 6
+	istore 1,contw			/* Tesco */
+	setarg 2
+	istore 1,contw			/* Wesco */
+	setarg 7
+	istore 1,contw			/* M packet type EV3 */
+	istore 1,contw			/* S packet type EV3 */
+	setarg 30
+	istore 2,contw			/* M packet size */
+	istore 2,contw			/* S packet size */
+	fetch 1,mem_air_mode
+	istore 1,contw
+	fetch 1,mem_neogotiation_state
+	istore 1,contw			/* neogotiation state */
+	nbranch send_lmp_reply,blank
+	branch send_lmp_reply,master
+	branch send_lmp_request
+	
+send_lmpext_remove_esco:
+	force 4,queue
+	call send_lmpext
+	fetch 1,mem_sco_handle
+	istore 1,contw
+	fetch 1,mem_disconn_reason_send
+	istore 1,contw
+	fetch 1,mem_esco_saved_arq
+	store 1,mem_arq 
+	branch send_lmp_request
+	
+
+send_lmpext_features_req:
+	force 12,queue
+	call send_lmpext
+	setarg 0x01
+	istore 1,contw
+	fetch 2,mem_lmpext_ssp_enable
+	istore 2,contw
+	setarg 0
+	istore 3,contw
+	setarg 0x00
+	istore 4,contw
+	branch send_lmp_request
+
+send_lmpext_packet_type_table_req:
+	force 3,queue
+	call send_lmpext
+	fetch 1,mem_ptt
+	istore 1,contw
+	disable user
+	call send_lmp_request
+	nrtn user
+	nrtn master
+	fetch 1,mem_afh_cfg
+	rtnbit0 AFH_CFG_ON
+	call afh_init
+	branch afh_open_all_channels
+	
+//default:featrue is enable,extfeature is disable
+ssp_enable:
+	fetch 1,mem_features+6
+	set1 param_featrue_ssp,pdata
+	store 1,mem_features+6
+	setarg param_lmpext_ssp_enable
+	store 2,mem_lmpext_ssp_enable
+	rtn
+
+ssp_disable:
+	fetch 1,mem_features+6
+	set0 param_featrue_ssp,pdata
+	store 1,mem_features+6
+	setarg 0
+	store 2,mem_lmpext_ssp_enable
+	rtn
+	
+afh_init:
+	jam 0x3,mem_afh_cfg
+	setarg 0
+	store 4,mem_afh_timer
+	arg mem_afh_map_lo,contw
+	call afh_reset_map
+	arg mem_afh_map_new,contw
+	call afh_reset_map
+	arg mem_afh_classify_channel_map,contw
+	call afh_reset_map
+	branch afh_clear_error_counter
+afh_open_all_channels:
+	arg mem_afh_map_new,contw
+	call afh_reset_map
+	call afh_clear_error_counter
+	branch afh_set_send_flag
+
+
+afh_open_classify_map:
+	fetch 5,mem_afh_classify_channel_map
+	store 5,mem_afh_map_new
+	ifetch 5,contr
+	istore 5,contw
+	call afh_clear_error_counter
+	branch afh_set_send_flag
+	
+afh_reset_map:
+	setarg 0xffffff
+	istore 3,contw
+	istore 3,contw
+	istore 3,contw
+	setarg 0x7f
+	istore 1,contw
+	rtn
+afh_clear_error_counter:
+	setarg 0
+	store 2,mem_afh_error_total
+	rtn
+afh_set_send_flag:
+	fetch 1,mem_afh_cfg
+	set1 send_lmp_set_afh,pdata
+	store 1,mem_afh_cfg
+	rtn
+send_set_afh:
+	nrtn master
+	force 16,pdata
+	call msg_send_lmp
+	deposit clkn_bt
+	arg 476,temp
+	iadd temp,pdata
+	rshift pdata,pdata
+	increase 1,pdata
+	set0 0,pdata
+	istore 4,contw
+	copy pdata,temp
+	setarg 1
+	istore 1,contw
+	fetch 5,mem_afh_map_new
+	istore 5,contw
+	ifetch 5,contr
+	istore 5,contw
+	lshift temp,temp
+	storet 4,mem_afh_instant
+	call send_lmp_request
+	fetch 1,mem_mode
+	set1 afh_change,pdata
+	store 1,mem_mode
+	jam 1,mem_afh_new_mod
+	fetch 4,mem_afh_instant
+	arg TIMER_ONE_MINUTE,temp //set ahf_reset_timer
+	iadd temp,pdata
+	store 4,mem_afh_timer
+	fetch 1,mem_afh_cfg
+	rtnbit1 AFH_CFG_MASTER_SENT_REQ
+	jam LMP_EXT_CHN_CLASSIFICATION_REQ,mem_lmo_opcode2
+	rtn
+
+
+send_lmpext_pause_encryption_req:
+	force 2,queue
+	call send_lmpext
+	nbranch send_lmp_reply,master
+	// assume slave will not send pause req firstly???
+	branch send_lmp_request
+
+
+	
+send_lmp_detach:
+	force 2,pdata
+	call msg_send_lmp
+	fetch 1,mem_disconn_reason_send
+	istore 1,contw
+	call send_lmp_request
+prepare_disconnect:
+	fetch 1,mem_op
+	set1 op_disconn,pdata
+	store 1,mem_op
+	jam 50,mem_conn_timer
+	rtn
+	
+
+send_lmp_no_payload:
+	force 1,pdata
+	call msg_send_lmp
+	branch send_lmp_request
+send_lmp_nopayload_reply:
+	force 1,pdata
+	call msg_send_lmp
+	branch send_lmp_reply
+	
+	
+send_lmp_encryption_mode_req:
+	force 2,pdata
+	call msg_send_lmp
+	fetch 1,mem_state_map
+	isolate0 smap_encryption,pdata
+	setflag true,0,pdata
+	and_into 1,pdata
+	istore 1,contw
+	branch send_lmp_request
+
+
+send_lmp_superto:
+	force 3,pdata
+	call msg_send_lmp
+	fetch 2,mem_supervision_to
+	istore 2,contw
+	branch send_lmp_request
+
+send_lmp_name_req:
+	jam 250,mem_conn_timer
+	force 2,pdata
+	call msg_send_lmp
+	fetch 1,mem_name_offset
+	istore 1,contw
+	branch send_lmp_request
+
+send_lmp_test_control:
+	force 10,pdata
+	call msg_send_lmp
+	arg mem_temp_payload,contr
+	force 9,loopcnt
+send_lmp_test_control_loop:	
+	ifetch 1,contr
+	xor_into 0x55,pdata
+	istore 1,contw
+	loop send_lmp_test_control_loop
+	branch send_lmp_request  
+
+send_lmp_quality_of_service_req:
+	branch send_lmp_request
+send_lmp_unit_key:
+	branch send_lmp_request
+
+send_lmp_slot_offset:
+	rtn master
+	call calc_slot_offset
+	force 9,pdata
+	call msg_send_lmp
+	fetch 2,mem_slot_offset
+	istore 2,contw
+	fetch 3,mem_lap
+	istore 3,contw
+	fetch 1,mem_uap
+	istore 1,contw
+	fetch 2,mem_nap
+	istore 2,contw
+	bmark0 mark_switch_initiated,send_lmp_slot_offset_reply
+	set0 mark_switch_initiated,mark
+	call send_lmp_request
+	jam LMP_SWITCH_REQ,mem_lmo_opcode2
+	rtn
+send_lmp_slot_offset_reply:
+	call send_lmp_reply
+	jam LMP_ACCEPTED,mem_lmo_opcode2
+	jam LMP_SWITCH_REQ,mem_lmi_opcode2
+	rtn
+	
+send_lmp_switch_req:
+	arg 0x200,temp
+	branch switch_on_native,master
+	deposit clke_bt
+	branch switch_slack
+switch_on_native:
+	deposit clkn_bt
+switch_slack:
+	deposit bt_clk
+	iadd temp,pdata
+	and_into 0x1fc,pdata
+	store 4,mem_sniff_anchor
+	force 5,pdata
+	call msg_send_lmp
+	fetch 4,mem_sniff_anchor		/* reused as switch instant */
+	rshift pdata,pdata
+	istore 4,contw
+	branch send_lmp_request
+	
+send_lmp_sniff_req:
+	force 10,pdata
+	call msg_send_lmp
+	arg mem_sniff_payload,contr
+	ifetch 9,contr
+	istore 9,contw
+	branch send_lmp_request
+
+	
+send_lmp_timing_accuracy_req:
+/* default to TID_NORM_SEND */
+	force 3,pdata
+	call msg_send_lmp
+	setarg 0x0114
+	istore 2,contw
+	branch send_lmp_request
+	
+send_lmp_unsniff_req:
+//--------------------need to completa
+	force 1,pdata
+	call msg_send_lmp
+	//fetch 1,mem_unsniff_pending
+	//nbranch send_msg_done,blank
+	//jam 1,mem_unsniff_pending
+	//fetch 2,mem_sniff_attempt
+	//fetch 2,mem_nsniff_attempt
+	//lshift3 pdata,pdata
+	//lshift pdata,pdata
+	//store 1,mem_unsniff_cnt
+	branch send_lmp_request
+
+send_lmp_sco_link_req:
+	branch send_lmp_sco_link_master,master
+	jam 0x00,mem_sco_handle
+	fetch 1,mem_mode
+	set1 send_sco_when_slave,pdata
+	store 1,mem_mode
+send_lmp_sco_link_master:
+	jam 0,mem_esco_desco
+	force 7,pdata
+	call msg_send_lmp
+	fetch 1,mem_sco_handle
+	istore 1,contw
+	setarg 0x00		/*timing ctrl flags*/
+	istore 1,contw
+	fetch 1,mem_esco_desco		/*Dsco*/
+	istore 1,contw
+	setarg 0x06		/*Tsco*/
+	istore 1,contw
+	setarg 0x02		/*HV3*/
+	istore 1,contw
+	fetch 1,mem_air_mode
+	istore 1,contw
+	branch send_lmp_reply,master
+	branch send_lmp_tid
+	
+send_lmp_remove_sco_link_req:
+	/* default to TID_NORM_SEND */
+	force 3,pdata
+	call msg_send_lmp
+	fetch 1,mem_sco_handle
+	istore 1,contw
+	force OTHER_END_TERMINATED,pdata
+	istore 1,contw
+	branch send_lmp_request
+	
+send_lmp_max_slot:
+	force 2,pdata
+	call msg_send_lmp
+	fetch 1,mem_max_slot
+	istore 1,contw
+	branch send_lmp_request
+	
+	
+send_lmp_max_slot_req:
+	force 2,pdata
+	call msg_send_lmp
+	setarg 0x05		/*5 slot*/
+	istore 1,contw
+	branch send_lmp_request
+
+send_lmp_setup_complete:
+	fetch 1,mem_state
+	set1 state_conn_comp,pdata
+	store 1,mem_state
+	copy clkn_bt,pdata
+	store 4,mem_aurand_send_delay_time
+	fetch 1,mem_lmp_conn_state
+	bbit1 SENT_SETUP_COMPLETE,send_lmp_setup_complete_has_sent
+	set1 SENT_SETUP_COMPLETE,pdata
+	store 1,mem_lmp_conn_state
+	jam BT_EVT_SETUP_COMPLETE,mem_fifo_temp
+	call ui_ipc_send_event
+	call hci_send_connection_complete
+	force 1,pdata
+	call msg_send_lmp
+	branch send_lmp_request
+send_lmp_setup_complete_has_sent:
+	jam 0,mem_lmp_to_send
+	rtn
+	
+send_lmp_version_req:
+	force 6,pdata
+	call msg_send_lmp
+	fetch 5,mem_lmp_version
+	istore 5,contw
+	branch send_lmp_request
+
+send_lmp_features_req:
+	force 9,pdata
+	call msg_send_lmp
+	fetch 8,mem_features
+	istore 8,contw
+	branch send_lmp_request  
+
+sp_master_send_io_cap_get:
+	call hci_send_io_cap_req_event
+	fetch 1,mem_device_option
+	beq dvc_op_hci,sp_master_send_io_cap_get_hci
+	jam SP_FLAG_COMMIT,mem_master_sp_flag
+	fetch 1,mem_sp_local_key_invalid
+	rtnne SP_KEY_VALID
+sp_master_send_io_cap_get_hci:
+	jam SP_MASTER_STAT_START_DONE,mem_master_sp_state
+	rtn
+
+sp_master_send_io_cap_send:
+	call tid_initiate
+	jam LMP_IO_CAP_REQ,mem_lmo_opcode2
+	jam SP_STAT_KEY_SEND,mem_master_sp_state
+	rtn
+	
+	
+sp_master_send_LMP_ENCAPSULATED_HEADER:
+	call tid_initiate
+	jam      LMP_ENCAPSULATED_HEADER,mem_lmo_opcode2
+	jam SP_STAT_RANDOM_SEND,mem_master_sp_state
+	rtn
+	
+sp_master_commitment_compare:
+	arg mem_sp_calc_result_high,rega
+	arg mem_sp_confirm_remote,regb
+	arg 16,loopcnt
+	call string_compare
+	branch sp_master_commitment_compare_success,zero
+	jam SP_STAT_NULL,mem_master_sp_state
+ifdef SIMPLE_PAIRING
+	call master_clear_mem_master_sp_flag
+endif
+	jam   PDU_NOT_ALLOWED,mem_lmo_reason2
+	jam 	LMP_SIMPLE_PAIRING_NUMBER,mem_lmi_opcode2 
+ifdef LMP_DBG
+	call ice_break
+endif
+	branch reject_lmp_packet
+sp_master_commitment_compare_success:
+	jam 	SP_STAT_CONFIRM_CALC,mem_master_sp_state
+ifdef SIMPLE_PAIRING
+	call master_set_mem_master_sp_flag
+endif
+	jam LMP_SIMPLE_PAIRING_NUMBER,mem_lmi_opcode2
+	branch accept_lmp_msg  
+	
+
+	
+sp_master_send_lmp_simple_pairing_number:
+	jam LMP_SIMPLE_PAIRING_NUMBER,mem_lmo_opcode2
+	rtn
+	
+
+
+sp_send_lmp_encapsulated_header:
+	// calculate the private & public key here
+	//jam      LMP_ENCAPSULATED_HEADER,mem_lmp_to_send
+	jam      LMP_ENCAPSULATED_HEADER,mem_lmo_opcode2
+	//jam      TID_PAIRING,mem_lmp_tid
+	rtn
+	//fetch 1,mem_tid_table
+	//set1 TID_PAIRING,pdata
+	//store 1,mem_tid_table
+     
+    
+send_lmp_encapsulated_header: 
+	jam 0,mem_sp_local_key_send_count
+	force 4,pdata
+	call msg_send_lmp
+	force ENCAPSULATED_MAJOR_TYPE_P192,pdata
+	istore 1,contw
+	force ENCAPSULATED_MINOR_TYPE_P192,pdata
+	istore 1,contw  
+	force ENCAPSULATED_LEN_P192,pdata
+	istore 1,contw 
+	call check_localsm
+	branch send_lmp_request,true
+	branch send_lmp_reply
+
+send_lmp_encapsulated_payload:
+	//jam      TID_PAIRING,mem_lmp_tid
+	 force 17,pdata
+	call msg_send_lmp
+	fetch 1,mem_sp_local_key_send_count
+	arg mem_sp_pubkey_local,contr
+	iadd contr,contr    
+	ifetch   8,contr
+	istore   8,contw
+	ifetch   8,contr
+	istore   8,contw
+	fetch    1,mem_sp_local_key_send_count
+	increase 16,pdata
+	store    1,mem_sp_local_key_send_count
+	call check_localsm
+	branch send_lmp_request,true
+	branch send_lmp_reply
+	//branch send_lmp_request
+	
+sp_send_lmp_simple_pairing_comfirm:
+        jam      SP_STAT_RANDOM_RECV,mem_sp_state
+        jam      LMP_SIMPLE_PAIRING_CONFIRM,mem_lmo_opcode2
+        rtn
+send_lmp_simple_pairing_comfirm:
+        //jam      SP_STAT_RANDOM_RECV,mem_sp_state
+        //jam      TID_PAIRING,mem_lmp_tid
+        force    17,pdata
+        call msg_send_lmp   
+        arg      mem_sp_calc_result_high,contr
+        ifetch   8,contr
+        istore   8,contw
+        ifetch   8,contr
+        istore   8,contw 
+        branch send_lmp_reply
+
+sp_send_lmp_simple_pairing_number:
+	call lmo_fifo_process
+	//if lmo_fifo(0,1,3) is full,we should add code for stop jam NEW LMP to mem_lmo_opcode2
+	jam      LMP_SIMPLE_PAIRING_NUMBER,mem_lmo_opcode2
+	rtn
+
+send_lmp_simple_pairing_number:
+	//jam      TID_PAIRING,mem_lmp_tid
+	call check_localsm
+ifdef SIMPLE_PAIRING
+	call sp_local_random_key_generator,true
+endif
+	force    17,pdata
+	call msg_send_lmp
+	arg      mem_sp_random_local,contr
+	ifetch   8,contr
+	istore   8,contw
+	ifetch   8,contr
+	istore   8,contw
+	call check_localsm
+	nbranch send_lmp_reply,true
+	branch send_lmp_request,true
+
+master_sp_sm_end:
+	//jam DEFAULT_STATEMACHINE,mem_sp_localsm
+	jam SP_STAT_DONE,mem_master_sp_state
+sp_aurand_send:
+	call tid_initiate
+	jam LMP_AU_RAND,mem_lmo_opcode2
+	call check_localsm_master
+ifdef SIMPLE_PAIRING
+	branch sp_master_key_prarm_push,true
+	branch sp_link_key_prarm_push
+endif
+master_sp_send_lmp_dhkey_check:
+	call tid_reply
+sp_send_lmp_dhkey_check: 
+	jam      LMP_DHKEY_CHECK,mem_lmo_opcode2
+	rtn
+send_lmp_dhkey_check: 
+	//jam      TID_PAIRING,mem_lmp_tid
+	force    17,pdata
+	call     msg_send_lmp
+	arg      mem_sp_calc_result_high,contr
+	ifetch   8,contr
+	istore   8,contw
+	ifetch   8,contr
+	istore   8,contw 
+	call check_localsm
+	nbranch send_lmp_reply,true
+	branch send_lmp_request,true
+
+send_lmp_enc_key_size_mask_res:
+	force 3,pdata
+	call msg_send_lmp   
+	setarg 0xfffe //enc key size mask
+	istore 2,contw
+	branch send_lmp_reply
+
+send_lmp_auto_rate:
+	branch send_lmp_request
+send_lmp_clkoffset_req:
+	branch send_lmp_request
+send_lmp_quality_of_service:
+	branch send_lmp_request
+send_lmp_test_activate:
+	branch send_lmp_request
+
+/******** LMP request/reply messages **********/
+/****** TID transaction specific *******/
+
+send_lmp_comb_key:
+	call generate_random_number
+	arg mem_lap,rega
+	call generate_linkkey
+	force 17,pdata
+	call msg_send_lmp
+	arg mem_kinit,rega
+	arg mem_random_number,regb
+	call xor16
+	nbranch send_lmp_follow,master
+	branch send_lmp_tid
+
+send_lmp_inrand:
+	call generate_random_number
+	arg mem_plap,rega
+	call generate_kinit
+send_lmp_rand:	/* used by in_rand,au_rand,start_encrypt */
+	force 17,pdata
+	call msg_send_lmp
+	arg mem_random_number,contr
+	call memcpy16
+	fetch 1,mem_conn_sm 
+	beq CONN_SM_AUTH_WAIT,send_lmp_request
+	beq CONN_SM_PAIRING_WAIT,send_lmp_request
+	branch send_lmp_tid
+
+send_lmp_aurand:
+	fetch 1,mem_pairing_auth
+	branch send_lmp_aurand_notpairing,blank
+	call check_localsm
+	call tid_initiate,true
+	ncall tid_reply,true
+	branch send_lmp_aurand_common
+send_lmp_aurand_notpairing:
+	call tid_initiate
+send_lmp_aurand_common:
+	call generate_random_number
+	branch send_lmp_rand
+
+send_lmp_sres:
+	arg mem_lap,rega
+	call function_e1
+	force 5,pdata
+	call msg_send_lmp
+	fetch 4,mem_input_store
+	istore 4,contw
+	arg mem_sres_tid,temp
+	call special_tid_store
+	call copy_aco
+	call check_localsm
+	branch send_lmp_sres_master,true
+	jam DONE_ENCRYP,mem_wait_encryption
+	fetch 1,mem_pairing_auth
+	rtn blank
+	jam LMP_AU_RAND,mem_lmo_opcode2
+send_lmp_sres_master:
+	fetch 1,mem_link_key_exists
+	rtn blank
+	call check_localsm
+	call hci_send_linkkey_notification,true
+send_lmp_sres_startenc:
+	call check_localsm
+	nbranch send_lmp_sres_startenc_slave,true
+	fetch 1,mem_auth_enable
+	rtn blank
+	jam LMP_ENCRYPTION_MODE_REQ, mem_lmo_opcode2
+	rtn
+send_lmp_sres_startenc_slave:
+	rtnmark0 mark_slave_in_rand_accepted
+	set0 mark_slave_in_rand_accepted,mark
+	jam LMP_ENCRYPTION_MODE_REQ, mem_lmo_opcode2
+	rtn
+	
+
+	
+send_lmp_start_encryption:
+	call generate_random_number
+	call function_e3
+	force 17,pdata
+	call msg_send_lmp
+	arg mem_random_number,contr
+	call memcpy16
+	branch send_lmp_tid
+
+send_lmp_stop_encryption_req:
+	force 1,pdata
+	call msg_send_lmp
+	branch send_lmp_tid
+
+send_lmp_encryption_key_size_req:
+	force 2,pdata
+	call msg_send_lmp
+	force 16,pdata
+	istore 1,contw
+	store 1,mem_key_size
+	branch send_lmp_tid
+
+msg_send_lmp:
+/* FLOW is set high and LMP is indicated */
+	lshift3 pdata,pdata
+	or_into 0x07,pdata
+	store 1,mem_lmo_header_length
+	arg 17,loopcnt
+	arg mem_lmo_payload,contw
+	call clear_mem
+	arg mem_lmo_payload,contw
+	rtn
+
+send_lmpext:
+	and pdata,0x7f,rega
+	jam LMP_ESCAPE,mem_lmp_to_send
+	deposit queue
+	call msg_send_lmp
+	deposit rega
+	istore 1,contw
+	rtn
+
+send_lmp_follow:
+	fetch 1,mem_lmp_to_send
+	lshift pdata,pdata
+	fetcht 1,mem_state_map
+	isolate1 smap_lmptid,temp
+	setflag true,0,pdata
+	branch send_lmp_exit
+
+
+send_lmp_tid:
+	fetcht 1,mem_state_map
+	and_into 1,temp
+	branch send_lmp_end
+
+send_lmp_reply:
+	force 0,temp
+	branch send_lmp_end
+	
+send_lmp_request:
+	force 1,temp
+send_lmp_end:
+	fetch 1,mem_lmp_to_send
+	lshift pdata,pdata
+	setflag master,0,pdata
+	ixor temp,pdata
+send_lmp_exit:
+	store 1,mem_lmo_header_opcode
+	jam 0,mem_lmp_to_send
+	call lmo_fifo_process_lmo0empty
+	enable user
+	rtn
+	
+lmo_fifo_process:
+	set1 mark_ext_patch,mark
+	bpatch patch3c_4,mem_patch3c
+	fetch 1,mem_lmp_to_send
+	branch lmo_fifo_process_lmo0empty,blank
+	fetch 1,mem_lmo_opcode1
+	nrtn blank
+	branch lmo_fifo_process_lmo2to1
+lmo_fifo_process_lmo0empty:
+	fetch 1,mem_lmo_opcode1
+	branch lmo_fifo_process_lmo1_empty,blank
+	fetch 3,mem_lmo_opcode1
+	store 3,mem_lmp_to_send//1=>0
+	fetcht 1,mem_lmo_tid1
+	fetch 1,mem_state_map
+	set0 smap_lmptid,pdata
+	ior temp,pdata
+	store 1,mem_state_map
+	jam 0,mem_lmo_opcode1
+lmo_fifo_process_lmo2to1:
+	fetch 1,mem_lmo_opcode2
+	rtn blank
+	fetch 4,mem_lmo_opcode2
+	store 4,mem_lmo_opcode1//2=>1
+	jam 0,mem_lmo_opcode2
+	rtn
+lmo_fifo_process_lmo1_empty:
+	fetch 1,mem_lmo_opcode2
+	rtn blank
+	fetch 3,mem_lmo_opcode2
+	store 3,mem_lmp_to_send//2=>0	
+	fetcht 1,mem_lmo_tid2
+	fetch 1,mem_state_map
+	set0 smap_lmptid,pdata
+	ior temp,pdata
+	store 1,mem_state_map
+	jam 0,mem_lmo_opcode2
+	rtn
+	
+//input:temp
+special_tid_store:
+	set1 mark_ext_patch,mark
+	bpatch patch3c_5,mem_patch3c
+	fetch 1,mem_state_map
+	copy pdata,regc
+	ifetch 1,temp
+	call pop_tid_follow
+	call send_lmp_follow
+	copy regc,pdata
+	store 1,mem_state_map
+	rtn
+	
+tid_reply:
+	fetcht 1,mem_state_map
+	set0 smap_lmptidinit,temp
+	storet 1,mem_state_map
+	rtn
+	
+tid_initiate:
+	fetcht 1,mem_state_map
+	set1 smap_lmptidinit,temp
+	storet 1,mem_state_map
+	rtn
+	
+	/* true if transaction from remote */
+tid_check:
+	nsetflag master,smap_lmptid,pdata //it is ok
+	fetcht 1,mem_state_map
+	ixor temp,pdata
+	isolate1 smap_lmptid,pdata
+	rtn	
+
+	/* set to remote */
+tid_set_reply:
+	fetch 1,mem_state_map
+	setflag master,smap_lmptid,pdata //it is ok
+	store 1,mem_state_map
+	rtn
+
+	/*rtn true when we lead lmp*/
+check_localsm:
+	fetch 1,mem_sp_localsm
+	compare 	LOCAL_STATEMACHINE,pdata,0x7f
+	rtn
+setlocalsm_master:
+	fetch 1,mem_sp_localsm
+	set1 7,pdata
+	store 1,mem_sp_localsm
+	rtn
+setlocalsm_slave:
+	fetch 1,mem_sp_localsm
+	set0 7,pdata
+	store 1,mem_sp_localsm
+	rtn
+check_localsm_master:
+	fetch 1,mem_sp_localsm
+	isolate1 7,pdata
+	store 1,mem_sp_localsm
+	rtn
+	
+generate_random_number:
+	/* generating a 16 byte random number,storing in ape_random_number */
+	arg mem_random_number,contw
+generate_random:
+	force 16,loopcnt
+generate_random_another:
+generate_random_loop:
+	random pdata
+	istore 1,contw
+	loop generate_random_another
+	rtn
+
+generate_linkkey:
+	call function_e21
+	arg mem_link_key,rega
+	arg mem_input_store,regb
+	ifetch 8,rega					/* check if already got comb key */
+	fetcht 1,mem_state
+	nsetflag blank,state_combkey,temp
+	storet 1,mem_state
+	copy rega,contw
+	call  xor16
+	branch generate_linkkey_continue
+
+/*********************************/
+/*********lmp send*************/
+/********************************/
+
+process_conn_sm:
+	//nrtn master
+	set1 mark_ext_patch,mark
+	bpatch patch3c_6,mem_patch3c
+	fetch 1,mem_lmo_opcode2
+	branch process_conn_sm_continue,blank
+	call lmo_fifo_process
+	fetch 1,mem_lmo_opcode2
+	nrtn blank
+process_conn_sm_continue:
+	fetch 1,mem_conn_sm
+	rtn blank
+	/* state machine begins in standby */
+	//beq CONN_SM_STANDBY, host_create_conn_begin
+	//beq CONN_SM_WAIT_PAGE, host_create_conn_wait_page
+	beq CONN_SM_SEND_CONN_REQ, host_create_conn_send_conn_req
+	beq CONN_SM_WAIT_CONN_ACCEPT, host_create_conn_wait_accept
+	beq CONN_SM_SEND_FEATURES, host_create_conn_send_features
+	beq CONN_SM_WAIT_FEATURES_RES, host_create_conn_waiting
+	beq CONN_SM_SEND_SWITCH,host_create_conn_send_switch
+	beq CONN_SM_AUTH_PAIR, host_create_conn_auth_pair
+	beq CONN_SM_AUTH_PAIR_WAIT, host_create_conn_auth_pair_wait
+	beq CONN_SM_ENCRYPT, host_create_conn_encrypt
+	beq CONN_SM_ENCRYPT_WAIT, host_create_conn_encrypt_wait
+	beq CONN_SM_ENCRYPT_WAIT_CLEAR, host_create_conn_encrypt_wait_clear
+	beq CONN_SM_SEND_SETUP_COMPLETE, host_create_conn_send_setup_complete
+	beq CONN_SM_WAIT_SETUP_COMPLETE, host_create_conn_wait_setup_complete
+	beq CONN_SM_DETACH_DELAY,host_create_conn_master_detach
+	beq CONN_SM_SEND_VERSION, host_create_conn_send_version
+	beq CONN_SM_WAIT_VERSION, host_create_conn_waiting
+	beq CONN_SM_WAIT_SWITCH_AFTER_HOST_CONNECTION, host_creat_conn_wait_switch
+	beq CONN_SM_SEND_FEATURES_EXT,host_creat_conn_send_feat_ext
+	beq CONN_SM_WAIT_FEATURES_EXT,host_create_conn_waiting
+	beq CONN_SM_PAIRING,host_create_conn_pairing
+	beq CONN_SM_PAIRING_WAIT,host_create_conn_pairing_wait
+	beq CONN_SM_AUTH,host_create_conn_auth
+	beq CONN_SM_AUTH_WAIT,host_create_conn_auth_wait
+	beq CONN_SM_DONE,host_create_conn_done
+	beq CONN_SM_WAIT_DONE,host_create_conn_done_wait
+	jam CONN_SM_STANDBY,mem_conn_sm
+	/* sending error message to host */
+	rtn
+host_create_conn_done:
+	fetch 1,mem_lmp_conn_state		
+	rtnbit0 RECEIVED_SETUP_COMPLETE
+	rtnbit0 SENT_SETUP_COMPLETE
+	jam CONN_SM_STANDBY,mem_conn_sm
+	call host_conn_judge_encrypt
+	branch scheduler_start_upper_sm
+	
+host_conn_judge_encrypt:
+	fetch 1,mem_connection_options
+	rtnbit0 CONNECTION_ENCRYPT
+	jam CONN_SM_ENCRYPT_WAIT,mem_conn_sm
+	rtn
+
+host_create_conn_done_wait:
+	arg enpt_delay_timer,queue
+	call timer_check
+	nrtn blank
+	jam CONN_SM_DONE,mem_conn_sm
+	rtn
+	
+host_create_conn_auth:
+	fetch 1,mem_connection_options
+	set0 CONNECTION_AUTH,pdata
+	store 1,mem_connection_options
+	jam CONN_SM_AUTH_WAIT,mem_conn_sm
+	jam LMP_AU_RAND,mem_lmo_opcode2
+	rtn 
+host_create_conn_auth_wait:
+	rtn
+host_create_conn_pairing:
+	fetch 1,mem_pincode_state
+	rtnne pincode_state_pincode_ready //wait for pincode
+	call host_auth
+	jam CONN_SM_PAIRING_WAIT,mem_conn_sm
+	rtn
+
+host_create_conn_pairing_wait:
+	rtn
+host_creat_conn_send_feat_ext:
+	jam CONN_SM_WAIT_FEATURES_EXT,mem_conn_sm
+	jam LMP_EXT_FEATURES_REQ,mem_lmo_opcode2
+	rtn
+host_create_conn_send_version:
+	jam CONN_SM_WAIT_VERSION,mem_conn_sm
+	jam LMP_VERSION_REQ,mem_lmo_opcode2
+	rtn 
+	
+host_creat_conn_wait_switch:
+	fetch 1,mem_switch_flag
+	rtneq SWITCH_FLAG_INIT
+	beq SWITCH_FLAG_ACCEPT,host_create_conn_switch_accept
+	arg switch_wait_timer,queue
+	call timer_check
+	nrtn blank
+	jam SWITCH_FLAG_INIT,mem_switch_flag
+	branch host_create_conn_switch
+host_create_conn_switch_accept:
+	rtn master
+	branch host_create_conn_auth_pair
+
+host_create_conn_send_features:
+	jam CONN_SM_WAIT_FEATURES_RES,mem_conn_sm
+	jam LMP_FEATURES_REQ,mem_lmo_opcode2
+	rtn 
+host_create_conn_send_switch:
+	jam LMP_SWITCH_REQ,mem_lmo_opcode2
+	set1 mark_switch_initiated,mark
+	jam CONN_SM_WAIT_CONN_ACCEPT,mem_conn_sm
+	setarg 0x1ff
+	store 2, mem_soft_timer
+	rtn
+host_create_conn_send_conn_req:
+	jam CONN_SM_WAIT_CONN_ACCEPT,mem_conn_sm
+	jam 0xff,mem_soft_timer
+	set0 mark_reconn_recieve_switch,mark
+	jam LMP_HOST_CONNECTION_REQ,mem_lmo_opcode2
+	branch init_lmp_reinit
+host_create_conn_wait_accept:
+	rtnmark1 mark_reconn_recieve_switch
+	fetch 2,mem_soft_timer
+	sub pdata,1,pdata
+	branch host_create_conn_resend,zero
+	store 2, mem_soft_timer
+	rtn
+host_create_conn_resend:
+	jam CONN_SM_SEND_SWITCH,mem_conn_sm
+	rtn
+host_create_conn_waiting:
+	/* we will exit waiting for connection request accepted, features res, or other commands to finish */
+	rtn 
+
+host_create_conn_switch:
+	fetch 1,mem_lmp_conn_state
+	rtnbit0 SENT_SETUP_COMPLETE
+	rtnbit0 RECEIVED_SETUP_COMPLETE
+	fetch 1,mem_connection_options
+	set0 CONNECTION_SWITCH,pdata
+	store 1,mem_connection_options
+	jam LMP_SWITCH_REQ,mem_lmo_opcode2
+	jam CONN_SM_WAIT_SWITCH_AFTER_HOST_CONNECTION,mem_conn_sm
+	rtn 
+
+host_create_conn_send_setup_complete:
+	jam CONN_SM_WAIT_SETUP_COMPLETE,mem_conn_sm	
+	jam LMP_SETUP_COMPLETE,mem_lmo_opcode2
+	rtn 
+
+host_create_conn_wait_setup_complete:
+	fetch 1,mem_lmp_conn_state
+	rtnbit0 RECEIVED_SETUP_COMPLETE
+	jam CONN_SM_STANDBY,mem_conn_sm	
+
+	rtn
+host_create_conn_wait_setup_complete_rtn:	
+	jam CONN_SM_AUTH_PAIR ,mem_conn_sm
+	rtn
+
+host_create_conn_master_detach:
+	fetch 1, mem_soft_timer
+	increase -1,pdata
+	branch host_create_conn_send_detach,blank//detach
+	store 1, mem_soft_timer
+	rtn 
+host_create_conn_send_detach:
+	jam LMP_DETACH,mem_lmo_opcode2
+	jam LOCAL_HOST,mem_disconn_reason_send
+	jam 0,mem_conn_sm
+	rtn
+host_create_conn_auth_pair:
+	/* checking whether or not to do m/s switch */
+	fetch 1,mem_connection_options
+	bbit1 CONNECTION_SWITCH,host_create_conn_switch
+	bbit1 CONNECTION_AUTH,host_create_conn_auth_pair_true
+host_create_conn_sm_done:
+	jam CONN_SM_DONE,mem_conn_sm
+	rtn
+host_create_conn_auth_pair_true:
+	fetch 1,mem_link_key_exists
+	branch host_create_conn_auth_pair_nokey,blank
+	fetch 1,mem_lmp_conn_state
+	rtnbit0 SENT_SETUP_COMPLETE
+	rtnbit0 RECEIVED_SETUP_COMPLETE
+	fetch 4,mem_aurand_send_delay_time
+	arg 100,temp
+	iadd temp,temp
+	copy clkn_bt,pdata
+	isub temp,null
+	nrtn positive
+	branch host_create_conn_auth
+
+
+
+host_create_conn_auth_pair_nokey:
+	jam CONN_SM_PAIRING,mem_conn_sm
+	jam 4,mem_pin_length
+	setarg 0x3030
+	store 2,mem_pin
+	istore 2,contw
+	jam pincode_state_pincode_ready,mem_pincode_state
+	branch host_create_conn_pairing
+
+host_create_conn_auth_pair_wait:
+	rtn
+host_create_conn_encrypt:
+	fetch 1,mem_connection_options
+	bbit1 CONNECTION_ENCRYPT,host_create_conn_encrypt_start
+	jam CONN_SM_DONE,mem_conn_sm
+	rtn 
+
+host_create_conn_encrypt_start:
+	fetch 1,mem_connection_options
+	set0 CONNECTION_ENCRYPT,pdata
+	store 1,mem_connection_options
+	jam LMP_ENCRYPTION_MODE_REQ,mem_lmo_opcode2  
+	rtn
+
+host_create_conn_encrypt_wait:
+	fetch 1, mem_wait_encryption
+	rtn blank
+	jam CONN_SM_STANDBY,mem_conn_sm
+	branch host_create_conn_encrypt_start 
+
+host_create_conn_encrypt_wait_clear:
+	jam CONN_SM_SEND_SETUP_COMPLETE,mem_conn_sm
+	rtn 
+
+host_auth:
+	fetch 1,mem_op
+	bbit1 op_inrand_req,remote_auth
+	call tid_initiate
+	jam LMP_IN_RAND,mem_lmo_opcode2
+	branch cmd_exit
+remote_auth:
+	fetch 1,mem_op
+	set0 op_inrand_req,pdata
+	store 1,mem_op
+	call lmp_accept_inrand
+	call tid_set_reply
+	branch cmd_exit
+
+pincode_reinit:
+	setarg 4
+	store 1,mem_pin_length
+	setarg 0x3030
+	istore 2,contw
+	istore 2,contw
+	rtn
+	
+
Index: btkb/program/module.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/module.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/module.prog	(working copy)
@@ -0,0 +1,548 @@
+
+ifdef COMPILE_MODULE
+
+
+
+
+module_init:
+	rtn wake
+	jam 0,mem_module_task
+	call module_gpio_init
+	call module_init_static_string
+	setarg module_process_idle
+	store 2,mem_cb_idle_process
+	setarg module_conn_process
+	store 2,mem_cb_bt_process
+	setarg module_process_bb_event
+	store 2,mem_cb_bb_event_process
+	setarg module_le_rx
+	store 2,mem_cb_att_write
+	setarg module_conn_process
+	store 2,mem_cb_le_process
+	set1 mark_ext_patch,mark
+	bpatch patch30_0,mem_patch30
+	setarg module_lpm_lock
+	store 2,mem_cb_check_wakelock
+	setarg module_le_tx_update_data
+	store 2,mem_cb_update_notify_value
+	setarg 0
+	store 4,mem_last_uart_clock
+	store 2,mem_module_prepare_tx_len
+	call module_hardware_init
+	call init_module_environment
+	call check_module_disabled
+	branch eeprom_load_reconn_info
+
+module_hardware_init:
+	rtn wake
+	setarg uart_baud_115200
+	store uart_baud_len,mem_baud
+module_lpm_uart_init:
+	call init_filter_ram
+	setarg mem_module_rx_buf
+	hstore 2,core_uart_rsaddr
+	setarg mem_module_rx_buf_end
+	hstore 2,core_uart_readdr
+	setarg mem_module_tx_buf
+	hstore 2,core_uart_tsaddr
+	setarg mem_module_tx_buf_end
+	hstore 2,core_uart_teaddr
+	hjam 0x4,core_gpio_sel1
+	jam 0xff,mem_ucode_id_local
+	hjam 0x0,core_uart_ctrl
+ 	setarg mem_module_tx_buf
+	hstore 2,core_uart_twptr
+	hstore 2,core_uart_trptrp
+	setarg mem_module_rx_buf
+	hstore 2,core_uart_rrptr
+	branch hci_init_common 
+
+
+module_lpm_init:
+	call module_lpm_uart_init
+	branch module_gpio_init
+	
+module_gpio_init:
+	//module state pin
+	call ui_led_init	
+	call app_led_start_blink
+	//module conn state pin
+	fetcht 1,mem_module_connect_state_gpio
+	call gpio_config_output
+	call module_set_conn_pin_low
+	
+	fetcht 1,mem_module_wake_up_gpio
+	call gpio_config_input
+	fetcht 1,mem_at_gpio
+	branch gpio_config_input_without_wake
+
+module_lpm_lock:
+	fetcht 1,mem_module_wake_up_gpio
+	call gpio_get_bit
+	nbranch app_put_lpm_wake_lock,true
+	branch app_get_lpm_wake_lock
+
+	
+/*************at dispatch*******************/
+module_process_idle:
+	branch module_app_dispatch
+module_conn_process:
+	branch module_app_dispatch
+module_app_dispatch:
+	set1 mark_ext_patch,mark
+	bpatch patch30_1,mem_patch30
+	call module_control_air_flow
+	call module_uart_set
+	call l2cap_malloc_is_fifo_full
+	nrtn blank
+	branch module_process
+module_process_bb_event:
+	copy regc,pdata
+	beq BT_EVT_PINCODE_REQ,module_process_evt_pincode_req
+	beq BT_EVT_RECONN_FAILED,module_reconn_fail
+	beq BT_EVT_RECONN_PAGE_TIMEOUT,module_page_time_out
+	beq BT_EVT_BB_DISCONNECTED,module_process_bb_event_disconned
+	beq BT_EVT_SWITCH_NOT_ACCEPT,module_process_switch_not_accept
+	beq BT_EVT_SWITCH_ACCEPT,module_process_switch_accept
+	beq BT_EVT_SNIFF_ACCEPT,module_process_sniff_accept
+	beq BT_EVT_SNIFF_NOT_ACCEPT,module_process_sniff_not_accept
+	beq BT_EVT_UNSNIFF_ACCEPT,module_process_unsniff_accept
+	beq BT_EVT_UNSNIFF_NOT_ACCEPT,module_process_unsniff_not_accept
+	beq BT_EVT_LE_CONNECTED,module_process_le_conn
+	beq BT_EVT_BB_CONNECTED,module_process_bb_conn
+	beq BT_EVT_LE_DISCONNECTED,module_process_bb_even_le_disconn
+	beq BT_EVT_SETUP_COMPLETE,module_process_setup_complete
+	beq BT_EVT_ENTER_SNIFF,module_sniff_param_check
+	beq BT_EVT_EXIT_SNIFF,app_lpm_mult_disable
+	and pdata,0x0f,temp
+	and_into BT_EVT_TIMER_MASK,pdata
+	beq BT_EVT_TIMER_INIT,module_bb_event_timer
+	rtn
+
+module_process_bb_event_disconned:
+	call module_disconn_start
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason
+	rtnbit0 APP_DISC_AFTER_SETUP_DONE
+	arg 3,loopcnt
+	arg mem_prarm_dis,contr
+	branch send_mem_to_uart
+	
+module_sniff_param_check:
+	//fetch 1,mem_context
+	//rtnbit0 state_insniff
+	fetch 2,mem_context+coffset_tsniff
+	rshift pdata,pdata
+	fetcht 2,mem_sniff_param_interval
+	isub temp,null
+	nbranch module_sniff_param_check_unsniff,zero
+	branch app_lpm_mult_enable
+module_sniff_param_check_unsniff:
+	fetch 1,mem_module_task
+	rtnbit1 AT_TASK_UNSINFF
+	hfetch 2,core_uart_rxitems    //*
+	ncall at_set_unsniff_task_flag,blank    //*加这两句话
+	branch app_bt_sniff_exit
+ 	
+module_process_setup_complete:
+	call module_conn_start
+	call module_check_cmode
+	branch module_uart_send_conn,zero
+	branch  app_bt_disconnect
+module_uart_send_conn:
+	arg 4,loopcnt
+	arg mem_prarm_conn,contr
+	branch send_mem_to_uart
+	
+module_process_bb_even_le_disconn:
+	call module_disconn_start
+	arg 5,loopcnt
+	arg mem_prarm_bledis,contr
+	branch send_mem_to_uart
+
+module_process_evt_pincode_req:
+	call at_restore_pin_code
+	branch  app_bt_set_pincode
+module_process_switch_not_accept:
+	fetch 1,mem_module_task
+	rtnbit0 AT_TASK_SWITCH
+	set0 AT_TASK_SWITCH,pdata
+	store 1,mem_module_task
+	branch at_error_rev_end
+	
+module_process_switch_accept:
+	fetch 1,mem_module_task
+	rtnbit0 AT_TASK_SWITCH
+	set0 AT_TASK_SWITCH,pdata
+	store 1,mem_module_task
+	branch at_nomal_rev_end
+
+module_process_sniff_accept:
+	rtn
+
+module_process_sniff_not_accept:
+	rtn
+	
+module_process_unsniff_accept:
+	fetch 1,mem_module_task
+	bbit0 AT_TASK_UNSINFF,app_bt_enter_sniff
+	branch at_clear_unsniff_task_flag
+	
+module_process_unsniff_not_accept:
+	rtn
+	
+module_process_le_conn:
+	call module_conn_start
+	arg mem_le_plap,regb
+	call module_check_cmode
+	branch module_uart_send_leconn,zero
+	branch  app_ble_disconnect
+module_uart_send_leconn:
+	arg 6,loopcnt
+	arg mem_prarm_bleconn,contr
+	branch  send_mem_to_uart
+
+module_process_bb_conn:
+	rtn
+
+
+module_reconn_fail:
+	arg 7,loopcnt
+	arg mem_prarm_recfail,contr
+	call send_mem_to_uart
+	branch module_disconn_start
+module_page_time_out:
+	arg 7,loopcnt
+	arg mem_prarm_pageout,contr
+	call send_mem_to_uart
+module_disconn_start:
+	call module_start_adv_discovery
+	branch module_set_conn_pin_high
+
+module_start_adv_discovery:
+	fetch 1,mem_module_state
+	isolate1 AT_STATE_SET30,pdata
+	call app_bt_start_discovery,true
+	fetch 1,mem_module_state
+	isolate1 AT_STATE_SET40,pdata
+	call app_ble_start_adv,true
+	rtn
+module_set_conn_pin_high:
+	fetcht 1,mem_module_connect_state_gpio
+	branch gpio_out_active
+
+module_conn_start:
+	call module_stop_adv_discovery
+	branch module_set_conn_pin_low
+	
+module_stop_adv_discovery:
+	fetch 1,mem_module_state
+	isolate1 AT_STATE_SET30,pdata
+	call app_bt_stop_discovery,true
+	fetch 1,mem_module_state
+	isolate1 AT_STATE_SET40,pdata
+	call app_ble_stop_adv,true
+	rtn
+module_set_conn_pin_low:
+	fetcht 1,mem_module_connect_state_gpio
+	branch gpio_out_inactive
+
+
+	
+
+module_process:
+	fetch 1,mem_device_option
+	rtnne dvc_op_module
+	hfetch 2,core_uart_rxitems
+	rtn blank
+	store 2,mem_current_packet_length
+
+	call spp_mode
+	branch at_process,true
+	call at_ckeck_send_buff
+	branch module_tx_packet
+
+
+spp_mode:    //true=1透传\true=0 不透传
+	fetcht 1,mem_at_gpio
+	branch gpio_get_bit
+
+
+module_exit_sniff:
+	fetch 1,mem_module_task
+	rtnbit1 AT_TASK_UNSINFF
+	call at_set_unsniff_task_flag	
+	branch app_bt_sniff_exit
+
+module_tx_packet:
+	fetch 1,mem_context
+	bbit0 state_inconn,spp_send_end
+	fetch 1,mem_context+coffset_mode
+	bbit1 mode_le,modle_le_tx
+	call app_check_sniff
+	branch module_exit_sniff,true
+	branch spp_tx_rfcomm_packet
+
+module_le_rx:
+	call le_att_get_handle_ptr
+	ifetch 1,contr
+	copy contr,rega
+	call get_uart_twptr
+	copy regb,loopcnt
+	copy rega,contr
+	call uart_copy_tx_bytes
+	branch uartd_send
+
+
+module_le_tx_update_data:
+	//get tx len
+	fetch 2,mem_module_prepare_tx_len
+	rtn blank
+	arg DM_LE_BUFF_LEN,temp
+	call not_greater_than
+	store 2,mem_module_temp_len
+	//reduced mem_module_prepare_tx_len
+	copy pdata,temp
+	fetch 2,mem_module_prepare_tx_len
+	isub temp,pdata
+	store 2,mem_module_prepare_tx_len
+	nbranch assert,positive
+	//get destination for copy
+	arg PRCP_TX_LE,temp
+	storet 2,mem_le_notify_handle
+	call le_att_get_handle_ptr
+	branch assert,blank
+	add contr,1,contw
+	//copy len
+	fetch 2,mem_module_temp_len
+	copy pdata,loopcnt
+	//get source for copy
+	call get_uart_rrptr
+	//copy
+	call uart_copy_rx_bytes
+	//release and clean
+	fetch 2,mem_module_temp_len
+	store 2,mem_current_packet_length
+	store 2,mem_le_notify_len
+	branch spp_send_end 
+
+
+modle_le_tx:
+	rtnmark0 mark_context
+	call modle_le_tx_once // 3 times
+	call modle_le_tx_once
+modle_le_tx_once:
+	call le_xtype_fifo_is_near_full
+	nrtn blank
+	hfetch 2,core_uart_rxitems
+	rtn blank
+	fetcht 2,mem_module_prepare_tx_len
+	isub temp,pdata    //uart_rx_len - data_in_ble_tx_fifo
+	nbranch assert,positive
+	store 2,mem_current_packet_length
+	rtn blank
+	call at_ckeck_send_buff_le
+	fetch 2,mem_module_prepare_tx_len
+	fetcht 2,mem_current_packet_length
+	iadd temp,pdata
+	store 2,mem_module_prepare_tx_len
+	fetcht 2,mem_module_prepare_tx_len
+	hfetch 2,core_uart_rxitems
+	isub temp,rega
+	nbranch assert,positive
+	jam ATTOP_HANDLE_VALUE_NOTIFICATION,mem_fifo_temp
+	branch le_xtype_fifo_in
+
+module_bb_event_timer:
+	storet 1,mem_app_evt_timer_count
+module_bb_event_100ms_loop:
+	fetch 1,mem_app_evt_timer_count
+	rtn blank
+	increase -1,pdata
+	store 1,mem_app_evt_timer_count
+	call module_bb_event_hud_ms
+	branch module_bb_event_100ms_loop
+	
+module_bb_event_hud_ms:
+	fetch 2,mem_at_scan_time
+	rtn blank
+	increase -1,pdata
+	store 2,mem_at_scan_time
+	nrtn blank
+	fetch 1,mem_at_using_flag
+	jam 0,mem_at_using_flag
+	bbit1 AT_FLAG_LEINQ,modue_le_inq
+	bbit1 AT_FLAG_INQ,module_inq
+	branch assert
+modue_le_inq:
+	branch app_ble_stop_scan
+module_inq:
+	jam hci_cmd_inquiry_cancel,mem_hci_cmd
+	rtn
+
+at_ckeck_send_buff:
+	fetch 1,mem_context+coffset_mode
+	bbit1 mode_le,at_ckeck_send_buff_le
+	fetch 2,mem_current_packet_length
+	arg DM_REFCOM_BUFF_LEN,temp
+	/*long packet*/
+	call not_greater_than
+	store 2,mem_current_packet_length
+	rtn
+at_ckeck_send_buff_le:
+	fetch 2,mem_current_packet_length
+	arg DM_LE_BUFF_LEN,temp
+	call not_greater_than
+	store 2,mem_current_packet_length
+	rtn
+
+at_set_unsniff_task_flag:
+	fetch 1,mem_module_task
+	set1 AT_TASK_UNSINFF,pdata
+	store 1,mem_module_task
+	rtn
+
+at_clear_unsniff_task_flag:
+	fetch 1,mem_module_task
+	set0 AT_TASK_UNSINFF,pdata
+	store 1,mem_module_task
+	rtn
+
+at_set_cmd_task_flag:
+	fetch 1,mem_module_task
+	set1 AT_TASK_CMD_FLAG,pdata
+	store 1,mem_module_task
+	rtn
+
+at_clear_cmd_task_flag:
+	fetch 1,mem_module_task
+	set0 AT_TASK_CMD_FLAG,pdata
+	store 1,mem_module_task
+	rtn
+
+module_control_air_flow:
+	set1 mark_ext_patch,mark
+	bpatch patch30_2,mem_patch30
+	call check_uart_tx_buff
+	branch app_l2cap_flow_control_enable,positive
+	branch app_l2cap_flow_control_disable
+
+module_uart_set:
+	call spp_mode
+	branch module_set_baud_115200,true
+	hfetcht uart_baud_len,core_uart_baud
+	fetch 2,mem_baud
+	isub temp,null
+	rtn zero
+	branch uart_set_baud_by_mem
+
+
+module_set_baud_115200:
+	hfetcht uart_baud_len,core_uart_baud
+	setarg AT_baud_115200
+	isub temp,null
+	rtn zero
+	hstore uart_baud_len,core_uart_baud
+	rtn
+
+module_check_cmode:
+	set1 mark_ext_patch,mark
+	bpatch patch30_3,mem_patch30
+	fetch 1,mem_module_state
+	isolate0 AT_STATE_CMODE,pdata
+	branch module_check_cmode_close,true
+	arg mem_cmode_addr,rega
+	arg 6,loopcnt
+	branch string_compare
+module_check_cmode_close:
+	force 0,null
+	rtn
+
+module_init_static_string:
+	set1 mark_ext_patch,mark
+	bpatch patch30_4,mem_patch30
+	arg mem_prarm_pswd,contw
+	setsect 0,0x35350
+	setsect 1,0x15115
+	setsect 2,0x12415
+	setsect 3,0x10951
+	istore 9,contw
+	setsect 0,0x2454c
+	setsect 1,0x35053
+	setsect 2,0x2454
+	setsect 3,0x11531
+	istore 9,contw
+	setsect 0,0x34441
+	setsect 1,0x194d4
+	setsect 2,0x12455
+	setsect 3,0x10d4d
+	istore 9,contw
+	setsect 0,0x3414c
+	setsect 1,0xd4d4
+	setsect 2,0x124c4
+	setsect 3,0x13119
+	istore 9,contw
+	setsect 0,0x15247
+	setsect 1,0x3d0d1
+	setsect 2,0xe4e4
+	setsect 3,0x11531
+	istore 9,contw
+	setsect 0,0x34944
+	setsect 1,0x114d4
+	setsect 2,0xe535
+	setsect 3,0x15105
+	istore 9,contw
+	setsect 0,0x14c2b
+	setsect 1,0x114d2
+	setsect 2,0xf525
+	setsect 3,0x11531
+	istore 9,contw
+	setsect 0,0x14e53
+	setsect 1,0x19192
+	setsect 2,0x44c4
+	setsect 3,0x15915
+	istore 9,contw
+	setsect 0,0x35352
+	setsect 1,0xd254
+	setsect 2,0x5444
+	setsect 3,0x10959
+	istore 9,contw
+	setsect 0,0x1454c
+	setsect 1,0x5392
+	setsect 2,0x3525
+	setsect 3,0x13d35
+	istore 9,contw
+	setsect 0,0x14544
+	setsect 1,0x113d3
+	setsect 2,0x4454
+	setsect 3,0x14d35
+	istore 9,contw
+	setsect 0,0x4154
+	setsect 1,0x11155
+	setsect 2,0x13494
+	setsect 3,0x13d0d
+	istore 9,contw
+	setsect 0,0x4f56
+	setsect 1,0x31055
+	setsect 2,0x3454
+	setsect 3,0x1393d
+	istore 9,contw
+	setsect 0,0x1504e
+	setsect 1,0x151d0
+	setsect 2,0x154f4
+	setsect 3,0x14951
+	istore 9,contw
+	setsect 0,0x24345
+	setsect 1,0x25051
+	setsect 2,0x4c4
+	istore 6,contw
+	rtn
+/*************at end*******************/
+		
+else
+module_init:
+module_process_idle:
+module_conn_process:
+module_lpm_init:
+module_init_static_string:
+	branch assert
+endif
Index: btkb/program/mouse.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/mouse.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/mouse.prog	(working copy)
@@ -0,0 +1,751 @@
+
+ifdef COMPILE_MOUSE
+mouse_init:
+	setarg le_mouse
+	store 2,mem_cb_le_process
+	setarg mouse_send_process
+	store 2,mem_cb_bt_process
+	setarg mouse_process_lpm_before
+	store 2,mem_cb_before_lpm
+	setarg mouse_priority_bb_event
+	store 2,mem_cb_bb_event_process
+	setarg mouse_idle
+	store 2,mem_cb_idle_process
+	setarg mouse_le_notify_update_data
+	store 2,mem_cb_update_notify_value
+	jam 0,mem_sp_flag
+	jam 0,mem_master_sp_flag
+	set0 mark_ext_patch,mark
+	bpatch patch18_0,mem_patch18
+	call mouse_init_common
+	rtn wake
+	call mouse_init_environment
+	call mouse_dpi_init
+	setarg mouse_before_hibernate
+	store 2,mem_cb_before_hibernate
+	fetch 2,mem_ui_state_map
+	bbit1 UI_STATE_BTN_DOWN,mouse_start_discovery
+	branch mouse_check_reconn_target
+
+mouse_init_environment:
+	call app_initflag_check
+	branch mouse_load_eeprom_param,zero
+	call eeprom_store_le_local_addr
+	call eeprom_store_mouse_dpi
+	branch app_initflag_store
+mouse_load_eeprom_param:
+	call eeprom_load_reconn_info
+	call eeprom_load_le_loacal_addr
+	branch eeprom_load_mouse_dpi
+
+mouse_dpi_init:
+	jam DPI_BUTTON_STATE_UP,mem_mouse_dpi_button_state
+	branch mouse_modified_dpi
+
+mouse_idle:
+	call ui_check_paring_button
+	call mouse_check_dpi
+	branch mouse_wheel_check
+
+mouse_check_dpi:
+	fetcht 1,mem_dpi_button_gpio
+	call gpio_get_bit
+	nbranch mouse_dpi_up,true
+mouse_dpi_down:
+	fetch 1,mem_mouse_dpi_button_state
+	rtneq DPI_BUTTON_STATE_DOWN
+	jam DPI_BUTTON_STATE_DOWN,mem_mouse_dpi_button_state
+	rtn
+mouse_dpi_up:
+	fetch 1,mem_mouse_dpi_button_state
+	rtneq DPI_BUTTON_STATE_UP
+	jam DPI_BUTTON_STATE_UP,mem_mouse_dpi_button_state
+	fetch 1,mem_mouse_dpi
+	increase 1,pdata
+	and pdata,0x03,pdata
+	store 1,mem_mouse_dpi
+	branch mouse_modified_dpi
+mouse_modified_dpi:
+	setarg MOUSE_DPI_ADDRESS
+	call twspi_read
+	and pdata,0xfc,temp
+	fetch 1,mem_mouse_dpi
+	iadd temp,pdata
+	lshift8 pdata,pdata
+	add pdata,MOUSE_DPI_ADDRESS,pdata
+	call twspi_write
+	branch eeprom_store_mouse_dpi
+
+mouse_init_common:
+	call mouse_init_sunt
+	call mouse_gpio_init
+	hfetch 2,core_clkoff
+	set0 CLOCK_OFF_QDECODER,pdata
+	hstore 2,core_clkoff
+	rtn
+	
+mouse_gpio_init:
+	call lpm_disable_exen_output
+	fetcht 1,mem_whee_a_data_gpio
+	call gpio_config_input
+	fetcht 1,mem_whee_b_data_gpio
+	call gpio_config_input
+	fetcht 1,mem_lbutton_gpio
+	call gpio_config_input
+	fetcht 1,mem_rbutton_gpio
+	call gpio_config_input
+	fetcht 1,mem_mbutton_gpio
+	call gpio_config_input
+	fetcht 1,mem_sensor_data_gpio
+	call gpio_config_input
+	fetcht 1,mem_dpi_button_gpio
+	call gpio_config_input
+	hfetch 1,core_gpio_pu3
+	or_into 0x18,pdata
+	hstore 1,core_gpio_pu3
+	hfetch 1,core_gpio_pd2+1
+	and_into 0xe7,pdata
+	hstore 1,core_gpio_pd2+1
+	rtn 	 
+
+	
+mouse_before_hibernate:
+	setarg 0xbc05
+	call twspi_write
+	jam 1,mem_lpm_current_mult
+
+mouse_process_lpm_before:
+	call mouse_wheel_check
+	arg 25,temp					// set sclk high
+	call gpio_config_output
+	hjam 0,core_gpio_sel1
+	fetcht 1,mem_whee_a_data_gpio
+	call gpio_set_wake_by_current_state
+	fetcht 1,mem_whee_b_data_gpio
+	call gpio_set_wake_by_current_state
+	fetcht 1,mem_lbutton_gpio
+	call gpio_set_wake_by_current_state
+	fetcht 1,mem_rbutton_gpio
+	call gpio_set_wake_by_current_state
+	fetcht 1,mem_mbutton_gpio
+	call gpio_set_wake_by_current_state
+	fetcht 1,mem_sensor_data_gpio
+	call gpio_set_wake
+	fetch 1,mem_lpm_current_mult
+	nrtn blank					// 7.5ms, no gpio wakeup
+	branch gpio_clr_wake
+	
+mouse_wheel_check:
+	set0 mark_ext_patch,mark
+	bpatch patch18_1,mem_patch18
+	arg 0,rega
+	fetcht 1,mem_whee_a_data_gpio
+	call gpio_get_bit
+	setflag true,0,rega
+	fetcht 1,mem_whee_b_data_gpio
+	call gpio_get_bit
+	setflag true,1,rega
+	copy rega,pdata
+
+	and_into  0x3,pdata
+	fetcht 1,mem_mouse_z_now
+	store 1,mem_mouse_z_now
+	isub temp,null
+	branch mouse_wheel_clear,zero
+	fetch 1,mem_mouse_z_before
+	store 1,mem_mouse_z_last
+	storet 1,mem_mouse_z_before
+	fetch 1,mem_mouse_z_now
+	lshift4 pdata,pdata
+	fetcht 1,mem_mouse_z_before
+	lshift2 temp,temp
+	iadd temp,pdata
+	fetcht 1,mem_mouse_z_last
+	iadd temp,pdata
+	beq 0x38,mouse_wheel_forward
+	beq 0x34,mouse_wheel_back
+	beq 0x0b,mouse_wheel_back
+	beq 0x07,mouse_wheel_forward
+	rtn
+
+mouse_wheel_clear:
+	rtn
+	
+mouse_wheel_forward:
+	fetch 1,mem_mouse_z_data
+	increase 1,pdata
+	store 1,mem_mouse_z_data
+	rtn
+	
+mouse_wheel_back:
+	fetch 1,mem_mouse_z_data
+	increase -1,pdata
+	store 1,mem_mouse_z_data
+	rtn
+		
+mouse_process_ble:
+
+	rtn
+mouse_sleep_sensor:
+	setarg 0xB805
+	branch twspi_write
+
+mouse_bb_connected:
+	rtn
+	
+le_mouse_bb_event_write_request:
+	call app_ble_store_reconn_info
+	jam MOUSE_MODE_STATE_BLE,mem_mouse_mode_state
+	call app_lpm_mult_enable
+le_mouse_bb_event_enc_info:
+	branch app_ble_start_write
+
+le_hibernate_timer:
+	fetch 2,mem_le_hibernate_timer
+	rtn blank
+	increase -1,pdata
+	store 2,mem_le_hibernate_timer
+	nrtn blank
+	branch app_enter_hibernate
+	
+mouse_hid_connected:
+	setarg HID_HANDSHAKE_TIMEOUT
+	store 1,mem_hid_handshake_timer_count
+	rtn
+	
+mouse_send_process:
+	fetch 1,mem_app_handshake_flag
+	rtn blank
+	call l2cap_malloc_is_fifo_nearly_full
+	nrtn blank
+	call mouse_motion
+	nrtn user
+	call mouse_no_data_timer_init
+	call mouse_send_blank_packet_timer_init
+mouse_send_data:
+	arg 8,rega
+	call hid_malloc_tx_buff
+	fetch 2,mem_hid_int_remote_cid
+	istore 2,contw
+	setarg 0x02a1
+	istore 2,contw
+	fetch 1,mem_mouse_key
+	istore 1,contw
+	fetch 2,mem_mouse_x
+	arg 0xfff,temp
+	iand temp,pdata
+	fetcht 2,mem_mouse_y
+	lshift4 temp,temp
+	lshift8 temp,temp
+	ior temp,pdata
+	istore 3,contw
+	fetch 1,mem_mouse_z
+	istore 1,contw
+	setarg 0
+	istore 1,contw
+	jam 8,mem_UI_data_txbuff_length
+	rtn
+
+
+mouse_send_blank_packet_timer:
+	set0 mark_ext_patch,mark
+	bpatch patch18_2,mem_patch18
+	fetch 1,mem_mouse_send_blank_timer
+	rtn blank
+	increase -1,pdata
+	store 1,mem_mouse_send_blank_timer
+	nrtn blank
+	call l2cap_malloc_is_fifo_empty
+	nrtn blank
+	setarg 0
+	store 5,mem_mouse_x
+	call mouse_send_data
+	jam  MOUSE_SEND_BLANK_TIMER,mem_mouse_send_blank_timer
+	rtn
+mouse_send_blank_packet_timer_init:
+	fetch 2,mem_mouse_blank_data_timeout
+	store 2,mem_mouse_blank_data_timer
+	jam  MOUSE_SEND_BLANK_TIMER,mem_mouse_send_blank_timer
+	rtn
+	
+mouse_no_data_timer_init:
+	fetch 2,mem_mouse_no_data_timeout
+	store 2,mem_mouse_no_data_timer
+	rtn
+
+	
+mouse_le_notify_update_data:
+	fetcht 2, mem_le_notify_handle
+	call le_att_get_handle_ptr 
+	ifetch 1,contr
+	store 1,mem_le_notify_len
+	rtn
+
+	
+mouse_fill_data_le:
+	set0 mark_ext_patch,mark
+	bpatch patch18_3,mem_patch18
+	fetcht 2, mem_le_notify_handle
+	call le_att_get_handle_ptr
+	add contr,1,contw
+mouse_fill_data:
+	fetch 1,mem_mouse_key
+	istore 1,contw
+	fetch 2,mem_mouse_x
+	arg 0xfff,temp
+	iand temp,pdata
+	fetcht 2,mem_mouse_y
+	lshift4 temp,temp
+	lshift8 temp,temp
+	ior temp,pdata
+	istore 3,contw
+	fetch 1,mem_mouse_z
+	istore 1,contw
+	rtn
+
+mouse_motion:
+	set0 mark_ext_patch,mark
+	bpatch patch18_4,mem_patch18
+	disable user
+	setarg 0
+	store 5,mem_mouse_x
+	call p3204_motion
+	call p3204_sdio_low
+	call mouse_zwheel
+	branch mouse_key
+	
+p3204_motion:
+	fetch 1,mem_sensor_type
+	rtnne SENSOR_TYPE_P3204
+	fetch 1,mem_mouse_move_flag
+	call p3204_clear_data,blank
+	jam 1,mem_mouse_move_flag
+	disable user
+	fetcht 1,mem_sensor_data_gpio
+	call gpio_get_bit
+	nrtn true
+	setarg 0
+	call twspi_read
+	bne P3204_ID,twspi_reset
+	setarg 2
+	call twspi_read
+	rtnbit0 7
+	setarg 3
+	call twspi_read
+	call extsign
+	store 2,mem_mouse_x
+	setarg 4
+	call twspi_read
+	call extsign
+	sub pdata,0,pdata
+	store 2,mem_mouse_y
+	fetch 4,mem_mouse_x
+	enable user
+	rtn
+mouse_zwheel:
+	fetch 1,mem_mouse_z_data
+	rtn blank	
+	store 1,mem_mouse_z
+	jam 0,mem_mouse_z_data
+	enable user
+	rtn
+mouse_key:
+	arg 0,rega
+	fetcht 1,mem_lbutton_gpio
+	call gpio_get_bit
+	setflag true,0,rega
+	fetcht 1,mem_rbutton_gpio
+	call gpio_get_bit
+	setflag true,1,rega
+	fetcht 1,mem_mbutton_gpio
+	call gpio_get_bit
+	setflag true,2,rega
+	deposit rega
+	fetcht 1,mem_mouse_key
+	store 1,mem_mouse_key	
+	ixor temp,pdata
+	sub pdata,0,null
+	rtn zero
+	enable user
+	rtn
+	
+
+
+	/* sdio high will cost extra 9mA */
+p3204_sdio_low:
+	arg 26,temp
+	call gpio_get_bit
+	rtn true
+	setarg 0
+	call twspi_read
+	branch p3204_sdio_low
+
+p3204_clear_data:
+	arg 0,loopcnt
+p3204_clear_data_loop:
+	setarg 2
+	call twspi_read
+	nop 100
+	increase 1,loopcnt
+	fetcht 1,mem_sensor_data_gpio
+	call gpio_get_bit	
+	branch p3204_clear_data_loop,true
+	deposit loopcnt
+	store 2,mem_init_cnt
+	rtn
+mouse_init_sunt:
+	call spid_init
+	rtn wake
+	
+mouse_init_p3204:	
+	setarg 0
+	call twspi_read
+	store 1,mem_sensor_id
+	beq P3204_ID,mouse_init_p3204_cont
+	call twspi_reset
+	nop 10000
+	branch mouse_init_p3204
+mouse_init_p3204_cont:
+	setarg 0x8006
+	call twspi_write
+	nop 1000
+	jam SENSOR_TYPE_P3204,mem_sensor_type
+	rtn
+
+
+
+extsign:
+	rtnbit0 7
+	arg 0xff00,temp
+	ior temp,pdata
+	rtn
+
+
+
+le_mouse:
+	call le_xtype_fifo_is_near_full
+	nrtn blank
+	fetcht 2,mem_le_notify_handle
+	call le_att_check_notification_enable
+	rtnbit0 0
+	fetch 1,mem_le_switch_send_data
+	rtnbit0 0
+	call mouse_motion
+//	call mouse_test
+	nrtn user
+	call mouse_no_data_timer_init
+	//call app_lpm_wake_auto_lock
+	jam ATTOP_HANDLE_VALUE_NOTIFICATION,mem_fifo_temp
+	call le_xtype_fifo_in
+	branch mouse_fill_data_le
+
+mouse_test:
+	rtn user
+	fetch 1,mem_mouse_test_cnt
+	increase 1,pdata
+	store 1,mem_mouse_test_cnt
+	arg 1,temp
+	bbit0 7,mouse_test_pos
+	arg 0xffff,temp
+mouse_test_pos:
+	storet 5,mem_mouse_x
+	enable user
+	rtn
+
+mouse_check_mode_state:
+	disable user
+	fetch 1,mem_mouse_mode_state
+	rtneq MOUSE_MODE_STATE_BLE
+	enable user
+	rtn
+	
+mouse_priority_bb_event:	
+	copy regc,pdata
+	beq BT_EVT_LE_CONNECTED,le_mouse_bb_event_connected
+	beq BT_EVT_BB_CONNECTED,mouse_stop_discovery
+	beq BT_EVT_LE_DISCONNECTED,mouse_bb_disconnected
+	beq BT_EVT_BB_DISCONNECTED,mouse_bb_disconnected
+	beq BT_EVT_SETUP_COMPLETE,mouse_bt_event_setup_complete
+	beq BT_EVT_BUTTON_LONG_PRESSED,mouse_bb_event_discovery_btn
+	beq BT_EVT_HID_HANDSHAKE,mouse_bt_hid_handshake
+	beq BT_EVT_HID_CONNECTED,mouse_bt_hid_connected
+	beq BT_EVT_LE_WRITE_REQUEST,le_mouse_bb_event_write_request
+	beq BT_EVT_LE_ENC_INFO,le_mouse_bb_event_enc_info
+	beq BT_EVT_RECONN_FAILED,mouse_bb_event_reconn_failed
+	beq BT_EVT_RECONN_PAGE_TIMEOUT,mouse_bb_event_reconn_failed
+	beq BT_EVT_PINCODE_REQ,mouse_bb_event_pincode
+	beq BT_EVT_REMOTE_UNSNIFF,app_start_auto_sniff
+	and pdata,0x0f,temp
+	and_into BT_EVT_TIMER_MASK,pdata
+	beq BT_EVT_TIMER_INIT,mouse_bb_event_timer
+	rtn
+
+le_mouse_bb_event_connected:
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	set0 APP_DISC_BY_BUTTON ,pdata
+	store APP_DISC_RSN_SIZE,mem_app_disconn_reason_flag
+	setarg 0
+	store 2,mem_mouse_direct_timer
+	fetch 1,mem_conn_cnt
+	increase 1,pdata
+	store 1,mem_conn_cnt
+	branch mouse_stop_discovery
+
+mouse_bb_event_pincode:
+	call pincode_reinit
+	branch app_bt_set_pincode
+	
+mouse_bb_event_reconn_failed:
+	fetch 2,mem_ui_state_map
+	bbit1 UI_STATE_BTN_DOWN,mouse_start_discovery
+	branch app_bb_hibernate
+
+	
+mouse_bt_hid_connected:
+	call mouse_hid_connected
+	rtn
+mouse_bt_event_setup_complete:
+	rtn
+
+mouse_bb_disconnected:
+	set0 mark_ext_patch,mark
+	bpatch patch18_5,mem_patch18
+	call mouse_bb_discon_clear_stack
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason
+ifdef DEBUG_LIGHT_STATE
+	store 1,0x4c00
+endif
+	bbit1 APP_DISC_BLE,mouse4_0_event_bb_disconn
+	bbit1 APP_DISC_BY_BUTTON,app_disconn_reason_clear
+	bbit1 APP_DISC_AFTER_PAIRING,mouse_event_light_state_pairing
+	bbit1 APP_DISC_AFTER_RECONN,mouse_event_light_state_hibernate
+	bbit1 APP_DISC_AFTER_SNIFF,mouse_event_light_state_hibernate
+	branch mouse_start_discovery
+mouse_bb_discon_clear_stack:
+	setarg 0
+	store 4,mem_mouse_z_last
+	jam 0,mem_mouse_send_blank_timer
+	jam 0,mem_mouse_move_flag
+	jam APP_HANDSHAKE_NULL,mem_app_handshake_flag
+	jam 0,mem_ltk_exists
+	jam 0,mem_mouse_mode_state
+	jam 0,mem_reconnect_timeout
+	rtn
+
+mouse_event_light_state_pairing:
+	bbit1 APP_DISC_AFTER_HANDSHAKE,mouse_event_light_state_hibernate
+	bbit1 APP_DISC_AFTER_SNIFF,mouse_event_light_state_hibernate
+	branch mouse_start_discovery
+mouse_event_light_state_hibernate:
+	fetch 2,mem_ui_state_map
+	bbit1 UI_STATE_BTN_DOWN,mouse_start_discovery
+	branch app_bb_hibernate
+
+mouse4_0_event_bb_disconn:
+	call le_clean_att_list_handle_enable
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason
+	bbit1 APP_DISC_BY_BUTTON,app_disconn_reason_clear
+	branch app_bb_hibernate
+
+mouse_bb_event_timer:
+	set0 mark_ext_patch,mark
+	bpatch patch18_6,mem_patch18
+	storet 1,mem_app_evt_timer_count
+mouse_bb_event_100ms_loop:
+	fetch 1,mem_app_evt_timer_count
+	rtn blank
+	increase -1,pdata
+	store 1,mem_app_evt_timer_count
+	//common part
+	//call app_lpm_wake_auto_lock_timer
+	call mouse_check_hid_handshake_timer
+	call mouse_check_discovery_timeout_timer
+	call mouse_check_direct_timeout_timer
+	call mouse_check_no_data_timeout_timer
+	//process for different mode, BT or BLE
+	fetch 1,mem_mouse_mode_state
+	compare MOUSE_MODE_STATE_BLE,pdata,0xff
+	call mouse4_0_bb_event_100ms,true
+	fetch 1,mem_mouse_mode_state
+	compare MOUSE_MODE_STATE_BT,pdata,0xff
+	call mouse3_0_bb_event_100ms,true
+	branch mouse_bb_event_100ms_loop
+	
+mouse3_0_bb_event_100ms: 
+	//flag user cannot bt changed!!!!
+	call mouse_check_blank_data_timeout_timer
+	branch mouse_send_blank_packet_timer
+	
+mouse4_0_bb_event_100ms:
+	//flag user cannot bt changed!!!!
+	rtn
+	
+mouse_check_hid_handshake_timer:
+	fetch 1,mem_hid_handshake_timer_count
+	rtn blank
+	increase -1,pdata
+	store 1,mem_hid_handshake_timer_count
+	nrtn blank
+	branch mouse_bt_hid_handshake
+
+mouse_check_discovery_timeout_timer:	
+	fetch 2,mem_mouse_discovery_timer
+	rtn blank
+	increase -1,pdata
+	store 2,mem_mouse_discovery_timer
+	nrtn blank
+	call mouse_stop_discovery
+	branch app_enter_hibernate
+
+mouse_check_direct_timeout_timer:
+	fetch 2,mem_mouse_direct_timer
+	rtn blank
+	increase -1,pdata
+	store 2,mem_mouse_direct_timer
+	nrtn blank
+	call app_ble_stop_direct_adv
+	branch app_enter_hibernate
+
+mouse_check_blank_data_timeout_timer:
+	fetch 2,mem_mouse_blank_data_timer
+	rtn blank
+	increase -1,pdata
+	store 2,mem_mouse_blank_data_timer
+	nrtn blank
+	jam 0,mem_mouse_send_blank_timer
+	rtn
+
+mouse_check_no_data_timeout_timer:
+	fetch 2,mem_mouse_no_data_timer
+	rtn blank
+	increase -1,pdata
+	store 2,mem_mouse_no_data_timer
+	nrtn blank
+	branch mouse_disconnect
+	
+mouse_bb_event_discovery_btn:
+	set0 mark_ext_patch,mark
+	bpatch patch18_7,mem_patch18
+	jam 0,mem_mouse_send_blank_timer
+	jam 1,mem_reconnect_timeout
+	setarg 0
+	store 2,mem_mouse_direct_timer
+	call mouse_disconnect
+	fetch 1,mem_device_option
+	isolate1 MODE_4_MOUSE,pdata
+	call mouse4_0_bb_event_discovery_btn,true
+	fetch 1,mem_device_option
+	isolate1 MODE_3_MOUSE,pdata
+	call mouse3_0_bb_event_discovery_btn,true
+	call app_lpm_mult_disable
+	branch mouse_start_discovery
+
+
+
+mouse3_0_check_reconn_target:
+	fetch 6,mem_hci_plap
+	branch app_bt_start_discovery_short,blank	
+	branch app_bt_start_reconnect
+	
+mouse4_0_check_reconn_target:
+	fetch 6,mem_hci_plap
+	branch mouse4_0_no_reconn_target,blank
+	fetch 2,mem_mouse_direct_timeout
+	store 2,mem_mouse_direct_timer
+	call app_lpm_mult_enable
+	branch app_ble_start_direct_adv
+mouse4_0_no_reconn_target:
+	call app_led_start_blink
+	branch app_ble_start_adv
+
+mouse3_0_bb_event_discovery_btn:
+	fetch 2,mem_ui_state_map
+	isolate1 UI_STATE_BT_RECONNECT,pdata
+	call app_bt_reconnect_cancel,true
+	rtn
+mouse4_0_bb_event_discovery_btn:
+	call le_clean_att_list_handle_enable
+	rtn
+	
+mouse_bt_hid_handshake:
+	jam APP_HANDSHAKE_DONE,mem_app_handshake_flag
+	call app_lpm_mult_enable
+	call app_bt_store_reconn_info
+	jam MOUSE_MODE_STATE_BT,mem_mouse_mode_state
+	setarg 0
+	store 2,mem_discovery_timeout_timer_count
+	store 1,mem_hid_handshake_timer_count
+	call app_bt_enter_sniff
+	branch mouse_send_blank_packet_timer_init
+
+mouse_check_reconn_target:
+	fetch 1,mem_xrecord_mode
+	beq REC_3_MODE,mouse3_0_check_reconn_target
+	beq REC_4_MODE,mouse4_0_check_reconn_target	
+	branch mouse_start_discovery
+
+mouse_start_discovery:
+	set0 mark_ext_patch,mark
+	bpatch patch19_0,mem_patch19
+	fetch 1,mem_le_lap
+	increase 1,pdata
+	store 1,mem_le_lap
+	call app_lpm_mult_disable
+	fetch 2,mem_discovery_timeout
+	store 2,mem_mouse_discovery_timer
+	fetch 1,mem_device_option
+	isolate1 MODE_4_MOUSE,pdata
+	call app_ble_start_adv,true
+	fetch 1,mem_device_option
+	isolate1 MODE_3_MOUSE,pdata
+	call app_bt_start_discovery,true
+	branch app_led_start_blink
+
+mouse_stop_discovery:
+	set0 mark_ext_patch,mark
+	bpatch patch19_1,mem_patch19
+	setarg 0
+	store 2,mem_mouse_discovery_timer
+	fetch 1,mem_device_option
+	isolate1 MODE_4_MOUSE,pdata
+	call app_ble_stop_adv,true
+	fetch 1,mem_device_option
+	isolate1 MODE_3_MOUSE,pdata
+	call app_bt_stop_discovery,true
+	branch app_led_stop_blink
+
+mouse_disconnect:
+	set0 mark_ext_patch,mark
+	bpatch patch19_2,mem_patch19
+	setarg 0
+	store 2,mem_mouse_no_data_timer
+	fetch 2,mem_ui_state_map
+	bbit1 UI_STATE_BLE_CONNECTED,app_ble_disconnect
+	fetch 2,mem_ui_state_map
+	bbit1 UI_STATE_BT_CONNECTED,app_bt_disconnect
+	rtn
+
+eeprom_store_mouse_dpi:
+	set0 mark_ext_patch,mark
+	bpatch patch19_3,mem_patch19
+	arg 1,temp
+	arg mem_mouse_dpi,rega
+	arg mouse_dpi_eeprom_addr,regb
+	branch iicd_write_eep_data
+
+eeprom_load_mouse_dpi:
+	set0 mark_ext_patch,mark
+	bpatch patch19_4,mem_patch19
+	arg 1,temp
+	arg mem_mouse_dpi,rega
+	arg mouse_dpi_eeprom_addr,regb
+	branch iicd_read_eep_data
+
+else
+mouse_init:
+	branch assert
+
+endif
+
+
+
Index: btkb/program/patch.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/patch.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/patch.prog	(working copy)
@@ -0,0 +1,2718 @@
+//define BT_30
+define BLE
+//define BLE_PINCODE
+define P24G
+//define GPIO_TEST_01
+define TX_POWER_MAX
+define LE_BATTERY_LEVEL_DISPLAY
+//define WAKE_DEV
+
+	bmark1 mark_ext_patch,patch_ext
+	beq patch00_0,p_soft_reset
+	beq patch00_2,p_soft_reset_2
+	beq patch00_3,p_main_loop
+	beq patch00_5,p_main_loop_end
+//	beq patch01_2,p_idle_page_mode_r0
+	
+	beq patch12_0,p_shutdown_radio
+	beq patch12_2,p_set_freq_rx
+	beq patch12_4,p_set_freq_tx
+	beq patch12_5,p_initialize_radio_cont
+	beq patch16_0,p_lpm_sleep
+	beq patch16_1,p_lpm_recover_clk
+	beq patch16_2,p_lpm_dispatch
+	beq patch16_3,p_lpm_dispatch_next
+	beq patch16_6,p_lpm_dispatch_unconn
+	beq patch17_1,p_lpm_cal_xtal_startup
+	branch assert
+
+patch_ext:	
+ifdef BLE	
+  	beq patch26_2,p_le_init_conn
+	beq patch27_3,le_slave_unsync + 3
+endif	
+	beq patch27_6,p_le_enable
+	beq patch27_7,p_le_disable
+ifdef BLE
+	beq patch29_2,p_lerx_nopayload
+	beq patch29_3,p_le_transmit_receive_sifs
+	beq patch29_4,p_le_transmit
+	beq patch29_6,p_le_send_adv_ind
+	beq patch2a_6,p_le_update_param
+	beq patch2b_2,p_le_check_wak
+	beq patch2c_1,p_le_prepare_tx
+	beq patch2c_3,p_le_prepare_tx_cmd
+	beq patch2c_4,p_le_prepare_smp
+	beq patch2c_5,p_le_prepare_att
+	beq patch2d_1,p_le_send_non_l2cap
+	beq patch2d_2,p_le_parse
+	beq patch2d_3,p_le_parse_ll
+	beq patch2d_6,p_le_parse_smp
+	beq patch2d_7,p_le_parse_att
+endif
+	beq patch30_7,p_ui_timer_check
+	beq patch31_5,p_check_51cmd_once
+	beq patch31_6,p_check_51cmd_once_continue
+	beq patch31_7,p_check_enter_hibernate	
+	beq patch37_5,p_fifo_in
+	beq patch39_5,p_kb_init
+	beq patch39_7,p_app_process_bb_event
+	beq patch3a_0,p_kb_bb_event_timer	
+	branch assert
+
+
+p_soft_reset: 
+	hfetch 1,0x813b
+	store 1,mem_wakup_from_power_flag
+	hjam lock_otp,core_misc_ctrl
+	branch soft_reset+2
+
+p_soft_reset_2:
+ifdef SIMPLE_PAIRING
+	call sp_initialize
+else
+	call ssp_disable
+endif
+	call lpm_recover_clk,wake
+p_sp_cal_loop:
+	call sp_calc_sequence
+	fetch 1,mem_ssp_enable
+	branch main_loop,blank
+	fetch 1,mem_sp_local_key_invalid // simple pairing is not ready
+	branch p_sp_cal_loop,blank
+	branch main_loop
+
+
+
+p_main_loop:	
+	call p_ipc_timer_check
+	call p_ui_check_timer_setup
+	call p_ipc_rx
+	call p_bt_status_handle
+	branch main_loop+2
+
+p_bt_status_handle:
+	fetcht 2,mem_ui_state_map
+	fetch 1, mem_le_adv_enable
+	nsetflag blank,UI_STATE_BLE_ADV,temp
+	storet 2, mem_ui_state_map
+	rtn	
+
+p_main_loop_end:
+	call inquiry_scan_dispatch
+	call page_scan_dispatch
+	call connection_dispatch 
+ifdef P24G
+	call p_g24_dispatch
+endif
+ifdef SIMPLE_PAIRING
+	branch main_loop+15
+else
+	branch main_loop+14
+endif
+
+
+p_ipc_rx:
+	fetch 1,mem_ssp_enable
+	branch p_ipc_rx0,blank
+	fetch 1,mem_sp_local_key_invalid	// simple pairing is not ready
+	rtn blank
+p_ipc_rx0:
+	call p_check_ipc_2bt
+	rtn user
+	byteswap pdata,pdata
+	copy pdata,contr
+	call p_ipc_rx_byte
+	store 1,mem_ipc_rx_type
+	beq IPC_TYPE_CMD,p_ipc_rx_cmd
+ifdef P24G
+	beq IPC_TYPE_24G,p_ipc_rx_24g
+endif
+	copy pdata,temp
+	copy contr,rega
+	fetch 1,mem_context
+	bbit0 state_inconn,p_ipc_abondon_rx_data
+	copy rega,contr
+	rtnmark0 mark_context
+	copy temp,pdata
+ifdef BLE
+	beq IPC_TYPE_BLE,p_ipc_rx_ble
+endif
+	branch assert
+
+p_ipc_abondon_rx_data:
+	copy rega,contr
+	arg mem_tst_pktcnt_sync,contw
+	branch p_ipc_rx_cpy
+
+p_ipc_rx_cmd:
+	call p_ipc_rx_byte
+	call p_ipc_rx_byte
+	store 1,mem_fifo_temp
+	call p_ipc_next_rx
+	branch ui_ipc_send_cmd
+p_ipc_next_rx:
+	call p_ipc_rx_updata_contr
+	copy contr,temp
+	byteswap temp,temp
+	storet 2,mem_ipc_2bt_read_index
+	rtn
+	
+ifdef P24G
+p_ipc_rx_24g:
+	arg mem_24g_txbuf_new,contw
+	branch p_ipc_rx_cpy
+endif
+
+ifdef BLE
+p_ipc_rx_ble:	
+	copy contr,rega
+p_ipc_rx_ble_read_fifo:
+	fetch 1,mem_queue_write
+	add pdata,1,temp
+	and temp,0x03,temp
+	storet 1,mem_queue_write
+	mul32 pdata,7,pdata
+	arg mem_uart_packet,contw
+	iadd contw,contw
+	
+	copy rega,contr
+	call p_ipc_rx_byte
+	copy contr,rega
+	increase -1,pdata
+	copy pdata,loopcnt
+	increase 7,pdata
+	store 1,mem_le51_tx_length
+	copy rega,contr
+	call p_ipc_rx_byte
+	copy contr,rega
+	beq 01,p_report1
+	beq 02,p_report2
+	beq 03,p_report3
+	beq 04,p_report4
+p_report1:
+	fetch 2,mem_att_report1	
+p_set_report:
+	istore 2,contw
+	copy rega,contr
+	call p_ipc_copy
+	call le_xtype_fifo_is_near_full
+	nrtn blank
+	jam ATTOP_HANDLE_VALUE_NOTIFICATION,mem_fifo_temp
+	branch le_xtype_fifo_in
+
+p_report2:
+	fetch 2,mem_att_report2
+	branch p_set_report
+p_report3:
+	fetch 2,mem_att_report3
+	branch p_set_report
+p_report4:
+	fetch 2,mem_att_report_battery
+ifndef LE_BATTERY_LEVEL_DISPLAY
+	istore 2,contw
+	copy rega,contr
+	branch p_ipc_copy
+else	
+	branch p_set_report
+endif	
+
+endif
+
+
+p_ui_check_timer_setup:
+	fetcht 4,mem_ui_check_timer_setup
+	copy clkn_bt,pdata
+	isub temp,pdata
+	fetcht 2,mem_customize_timer_setup		// * 0.3125ms
+	idiv temp
+	call wait_div_end
+	quotient pdata
+	rtn blank
+	copy clkn_bt,temp
+	storet 4,mem_ui_check_timer_setup
+	fetch 1,mem_customize_timer
+	increase 1,pdata
+	store 1,mem_customize_timer
+	rtn
+
+
+
+//1600 == 500ms
+p_ipc_timer_check:
+	fetcht 4,mem_ipc_last_check_timer
+	copy clkn_bt,pdata
+	isub temp,pdata
+	//arg 3200,temp
+	arg 1600,temp
+	idiv temp
+	call wait_div_end
+	quotient pdata
+	rtn blank
+	copy clkn_bt,temp
+	storet 4,mem_ipc_last_check_timer
+	fetcht 2,mem_ipc_bt_timer
+	byteswap temp,temp
+	iadd temp,pdata
+	byteswap pdata,pdata
+	store 2,mem_ipc_bt_timer
+	byteswap pdata,pdata
+	and pdata,0x3,pdata
+	rtnne 0
+	fetch 1,mem_adc_config_flag
+	bbit1 ADC_CONFIG_VINLPM,p_adc_check_vinlpm
+	bbit1 ADC_CONFIG_HVIN,p_adc_check_hvin
+p_adc_check_gpio:
+	arg 0,rega
+	call p_setup_adc_gpio_pu_setup		//disable powerup
+	hjam 0x8f,rf_adc_mode
+	fetch 1,mem_adc_channel
+	hstore 1,rf_adc_ch
+	call p_read_adc
+	arg 1,rega
+	branch p_setup_adc_gpio_pu_setup		//enable powerup
+
+	
+p_adc_check_vinlpm:
+	hjam 0xbf,rf_adc_mode	//read VINLPM voltage directly
+	branch p_read_adc
+
+p_adc_check_hvin:
+	hjam 0xaf,rf_adc_mode	//read HVIN voltage directly
+p_read_adc:
+	hfetch 1,core_uart_baud + 1
+	set1 7,pdata
+	hstore 1,core_uart_baud + 1 
+	hfetch 1,rf_adc_ch
+	or_into 0x30,pdata
+	hstore 1,rf_adc_ch
+	hjam 0x74,rfen_adc	
+	hjam 0x7c,rfen_adc
+	hjam 0xaa,rf_adc_gc
+	nop 5000
+	hfetcht 2,core_adc_sum
+	hfetch 1,core_uart_baud + 1
+	set0 7,pdata
+	hstore 1,core_uart_baud + 1
+	byteswap temp,temp
+	storet 2,mem_adc_current_value
+	rtn
+
+
+p_setup_adc_gpio_pu_setup:
+	arg 0x21,temp
+	fetch 1,mem_adc_channel
+	isub temp,temp			// e.g. 0x33 - 0x21 = 0x12   gpio18
+	copy rega,pdata
+	set1 gpio_active_bit,temp
+	nbranch p_setup_adc_gpio_pu_setup_exit,blank
+	set0 gpio_active_bit,temp
+p_setup_adc_gpio_pu_setup_exit:
+	arg core_gpio_pu0,contw
+	branch gpio_set_bit
+
+
+
+p_ipc_rx_cpy:
+	call p_ipc_rx_byte
+	copy pdata,loopcnt
+p_ipc_copy:
+	call p_ipc_cpy_loop
+	branch p_ipc_next_rx
+	
+p_ipc_cpy_loop:
+	call p_ipc_rx_byte
+	istore 1,contw
+	loop p_ipc_cpy_loop
+	rtn
+
+p_ipc_rx_byte:
+	call p_ipc_rx_updata_contr
+	ifetch 1,contr
+	rtn
+
+p_ipc_rx_updata_contr:
+	setarg mem_ipc_2bt_fifo_end
+	isub contr,null
+	nrtn zero
+	arg mem_ipc_2bt_fifo_head,contr
+	rtn
+
+p_ipc_tx_evt:
+	arg 3,loopcnt
+	arg mem_ipc_tx_evt_buff,contr
+p_ipc_tx_cpy:
+	copy contr,rega
+	fetch 2,mem_ipc_2C51_write_index
+	byteswap pdata,pdata
+	copy pdata,contw
+	copy rega,contr
+p_ipc_tx_loop:
+	ifetch 1,contr
+	istore 1,contw
+	call p_ipc_tx_updata_contw
+	loop p_ipc_tx_loop
+	copy contw,pdata
+	byteswap pdata,pdata
+	store 2,mem_ipc_2C51_write_index
+	rtn
+p_ipc_tx_updata_contw:
+	setarg mem_ipc_2C51_fifo_end
+	isub contw,null
+	nrtn zero
+	arg mem_ipc_2C51_fifo_head,contw
+	rtn
+
+//user: no data
+p_check_ipc_2c51:
+	fetch 2,mem_ipc_2C51_read_index
+	fetcht 2,mem_ipc_2C51_write_index
+	branch p_check_ipc_common
+p_check_ipc_2bt:
+	fetch 2,mem_ipc_2bt_read_index
+	fetcht 2,mem_ipc_2bt_write_index
+p_check_ipc_common:
+	isub temp,null
+	branch enable_usr,zero
+	branch disable_usr
+
+
+p_ui_timer_check:				// 100ms_event   clock overflow
+	copy clkn_bt,pdata
+	store 4,mem_ui_timer_last_btclk_temp
+	fetcht 1,mem_ui_timer_last_btclk+3
+	fetch 1,mem_ui_timer_last_btclk_temp+3
+	isub temp,null
+	ncall p_ui_timer_reinit,positive
+	branch ui_timer_check+2
+
+p_ui_timer_reinit:
+	fetcht 4,mem_ui_timer_last_btclk_temp
+	storet 4,mem_ui_timer_last_btclk
+	storet 4,mem_ipc_last_check_timer
+	storet 4,mem_ui_check_timer_setup
+	rtn
+ 
+	
+p_app_process_bb_event:
+	arg mem_ipc_fifo_bt2c51,rega
+	call fifo_out
+	rtn blank
+	//reaching here mains c51 cannot get bb event.
+	copy pdata,regc
+	call p_app_event_normal_process
+	branch app_process_bb_event_priority
+p_app_event_normal_process:
+	rtneq BT_EVT_LINKKEY_GENERATE
+ifdef BLE	
+	beq BT_EVT_LE_CONNECTED,scale_process_le_conn
+	beq BT_EVT_LE_DISCONNECTED,p_scale_process_le_discon
+endif	
+	branch app_event_normal_process
+
+
+
+// 1clkn_bt = 0.3125ms
+p_kb_bb_event_timer:
+	storet 1,mem_app_evt_timer_count
+	fetch 1,mem_ipc_bt_100ms_timer
+	increase 1,pdata
+	store 1,mem_ipc_bt_100ms_timer
+p_kb_bb_event_100ms_loop:
+	fetch 1,mem_app_evt_timer_count
+	rtn blank
+	increase -1,pdata
+	store 1,mem_app_evt_timer_count
+
+	call p_kb_long_sleep_timer
+ifdef WAKE_DEV
+	call p_kb_wake_remote_dev
+endif
+	branch p_kb_bb_event_100ms_loop
+	
+ifdef WAKE_DEV
+p_kb_wake_remote_dev:
+	fetch 1,mem_suspend_flag
+	nrtn blank
+	fetch 1,mem_kb_wake_timer
+	rtn blank
+	increase -1,pdata
+	store 1,mem_kb_wake_timer
+	rtnne 1
+	jam 100,mem_kb_wake_timer
+	//call app_check_sniff
+	//nrtn true
+	fetch 2,mem_ui_state_map
+	//rtnbit0 UI_STATE_BT_HID_HANDSHAKE
+	rtnbit0 UI_STATE_BT_SNIFF
+	fetch 2,mem_kb_last_data
+	rtn blank
+	call l2cap_malloc_is_fifo_empty
+	nrtn blank
+	fetch 2,mem_kb_last_data
+	copy pdata,rega
+	call hid_malloc_tx_buff
+	add rega,2,loopcnt
+	arg mem_kb_last_data+2,contr
+	branch memcpy
+endif
+
+p_kb_long_sleep_timer:
+	fetch 1,mem_24g_enter_lpm_timer
+	rtn blank
+	increase -1,pdata
+	store 1,mem_24g_enter_lpm_timer
+	rtn
+	
+
+p_c51_user_event:
+	copy regc,pdata
+	and_into BT_EVT_TIMER_MASK,pdata
+	rtneq BT_EVT_TIMER_INIT
+ifdef WAKE_DEV
+	call p_c51_ext_evt
+endif
+	copy regc,pdata
+	rtn blank
+	store 1,mem_ipc_tx_evt
+	branch p_ipc_tx_evt
+ifdef WAKE_DEV
+p_c51_ext_evt:
+	copy regc,pdata
+	beq BT_EVT_ENTER_SNIFF,p_kb_wake_enable
+	beq BT_EVT_BB_DISCONNECTED,p_bk_wake_disable
+	rtn
+p_kb_wake_enable:
+	jam 40,mem_kb_wake_timer
+	setarg 0x0a
+	store 2,mem_kb_last_data
+	fetch 2,mem_hid_int_remote_cid
+	istore 2,contw
+	setarg 0x01a1
+	istore 2,contw
+	rtn
+p_bk_wake_disable:
+	jam 0,mem_kb_wake_timer
+	rtn
+endif	
+	
+
+/*
+****************************************************************************************************
+* All Timer End
+****************************************************************************************************
+*/
+
+p_lpm_recover_clk:
+	jam 0x7f,mem_seqi
+	call lpm_recover_clk+2
+	fetch 1,mem_hibernate_flag
+	rtn blank
+	jam 0,mem_hibernate_flag
+	copy clkn_bt,pdata
+	store 4,mem_ipc_last_check_timer
+	rtn
+
+
+
+p_lpm_cal_xtal_startup:
+	fetch 1,mem_lpm_xtalcnt
+	nrtn blank
+	hjam clksel_rc,core_clksel
+	setarg 0xf0c
+	call lpm_write_config
+	setarg 200000
+	call sleep
+	until null,lpo_edge
+	copy lpo_time,alarm
+	call xtal_fast_wake
+	nop 5000
+	branch lpm_cal_xtal_startup+12
+
+
+p_lpm_dispatch:
+	rtnmark1 mark_24g
+	fetch 2,mem_ui_state_map
+	bbit1 UI_STATE_BLE_CONNECTED,lpm_dispatch+2
+	call lpo_calibration
+	fetch 3,mem_clks_per_lpo
+	rtn blank
+	//fetch 2,mem_context + coffset_tsniff
+	//rtn blank										/* role switch */
+	fetch 1,mem_lpm_mode
+	rtn blank
+
+	call l2cap_malloc_is_fifo_empty
+	nrtn blank
+	call lpm_check_wake_lock
+	nrtn blank
+	call xtal_fast_wake
+	fetch 1,mem_ssp_enable
+	branch lpm_dispatch0,blank
+	fetch 1,mem_sp_local_key_invalid	// simple pairing is not ready
+	rtn blank
+	branch lpm_dispatch0
+
+p_check_IPC_for_LPM:
+	call p_check_ipc_2bt
+	nrtn user
+	call p_check_ipc_2c51
+	nrtn user
+	jam 1,mem_c51_lpm_lock
+	jam SYC_TASK_LPM,mem_c51_flag
+	call p_c51_wait
+	branch p_check_ipc_2bt
+	
+p_lpm_dispatch_next:
+	call p_check_IPC_for_LPM
+	nrtn user
+	fetch 1,mem_c51_lpm_lock
+	nrtn blank
+	branch lpm_dispatch1
+
+p_c51_wait:
+	fetch 1,mem_c51_flag
+	nop 10
+	bne 0,p_c51_wait
+	rtn
+
+
+p_lpm_dispatch_unconn:
+	call p_check_IPC_for_LPM
+	nrtn user
+	fetch 1,mem_c51_lpm_lock
+	nrtn blank
+	branch lpm_dispatch_unconn + 2
+
+
+
+p_initialize_radio_cont:
+	call p_switchto_dpllclk
+	branch initialize_radio_cont + 4	
+p_switchto_dpllclk:
+	fetch 1,mem_lpm_xtalcnt
+	nbranch p_switchdpll_nocal,blank
+	call lpm_cal_xtal_startup
+	nop 30000
+	nop 30000
+	nop 30000
+p_switchdpll_nocal:
+	call switchto_dpllclk
+	hjam clksel_xtal,core_clksel
+	hfetch 1,rf_clkpll_frac+2
+	and_into 0xcf,pdata
+	hstore 1,rf_clkpll_frac+2
+	or_into 0x30,pdata
+	hstore 1,rf_clkpll_frac+2
+	rtn
+
+
+
+p_set_freq_rx:
+	storet 1,mem_last_freq
+	add temp,rx_freq_offset,rega			/* index to frequency */
+	branch set_freq_rx + 4	
+
+p_set_freq_tx_common:
+	storet 1,mem_last_freq
+	add temp,0,rega			// 0--2M 1--1M 2--M  index to frequency 
+	branch rf_write_freq
+	
+p_set_freq_tx:
+	call p_set_freq_tx_common
+	setarg param_pll_setup
+	call sleep
+p_txon:
+	hjam 0x1,rfen_adc
+	hjam 0x3c,rfen_rx
+	hjam 0xe0,rfen_tx
+	hjam 0x12,0x96d   /*Max added, for best Pout*/
+	nop 10 /* wait LDOs to turn ON*/
+	hjam 0x01, rfen_mdm
+	hjam 0x3d, rfen_mdm
+	nop 10 /* wait tx blocks to turn ON*/
+	hjam 0xb7,rfen_sn
+	nop 10 /* wait tx lo buffer to turn ON*/
+	hjam 0x7d, rfen_mdm
+	fetch 1,mem_24g_pairing_sm
+	bne STATE_24G_PAIRING_SUCCESS,p_txpower_0dbm
+	fetch 5,mem_5db_tx_power_param
+	istore 5,contw
+	ifetch 5,contr
+	istore 5,contw
+	hjam 0xdf, 0x956
+	call p_set_tx_step_power
+	hjam 0xdf, 0x955
+	rtn
+
+p_txpower_0dbm:
+	fetch 5,mem_24g_paring_tx_power_param
+	istore 5,contw
+	ifetch 5,contr
+	istore 5,contw
+	fetch 1,mem_pair_state
+	call p_txpower_0dbm_default_set,blank
+	hstore 1,0x8956
+ //	hjam 0xc2, 0x956
+ 	hjam 0xd0, 0x955
+	rtn
+
+p_txpower_0dbm_default_set:
+	setarg 0xc2
+	rtn
+
+	
+	//pout ramp up
+	//c0 ~df	
+p_set_tx_step_power:
+	//hjam 0xff, 0x956   //hjam 0xce, 0x956 only for yc1021C1_#7, BQB, -2.9dBm. changed for ramp_up/down
+	nop 4
+	hjam 0xd1, 0x955
+	nop 4
+	hjam 0xd2, 0x955
+	nop 4
+	hjam 0xd4, 0x955
+	nop 4
+	//d0~df
+	//hjam 0xdf, 0x955  //hjam 0xd7, 0x955 only for yc1021C1_#7, BQB, -2.9dBm. changed for ramp_up/down
+ 	rtn
+
+p_tx_ramp_down_common:
+	hjam 0xd4, 0x955
+	nop 4
+	hjam 0xd2, 0x955
+	nop 4
+	hjam 0xd1, 0x955
+	nop 4 
+	hjam 0xd0, 0x955  //hjam 0xd8, 0x955 only for yc1021C1_#7, BQB, -2.9dBm. changed for ramp_up/down
+	hjam 0xc0, 0x956
+	rtn
+
+p_shutdown_radio:
+	branch shutdown_radio+2,is_rx
+	call p_tx_ramp_down_common
+	branch shutdown_radio+2
+
+
+p_kb_before_hibernate: 
+	enable user
+	hfetch 4,0x8138
+	setflag user,26,pdata
+	hstore 4,core_lpm_reg
+	call  lpm_write_ctrl
+	jam 1,mem_lpm_current_mult
+p_kb_bt_lpm_before:
+	rtn
+
+p_kb_init:
+	fetch 1,mem_le_name_len
+	increase 2,pdata
+	store 1,mem_le_scan_data_len	//update scan_rsp len
+	jam 0,mem_c51_flag
+	jam 6,mem_connection_options
+	call app_lpm_mult_enable
+	setarg p_kb_bt_lpm_before
+	store 2,mem_cb_before_lpm
+	setarg p_c51_user_event
+	store 2,mem_cb_bb_event_process
+	setarg p_mouse_idle
+	store 2,mem_cb_idle_process
+	setarg p_ipc_rx
+	store 2,mem_cb_le_process
+	setarg p_kb_before_hibernate
+	store 2,mem_cb_before_hibernate
+	setarg mem_ipc_2bt_fifo_head
+	byteswap pdata,pdata
+	store 2,mem_ipc_2bt_read_index
+	store 2,mem_ipc_2bt_write_index
+	call lpm_disable_exen_output
+	setarg mem_ipc_2C51_fifo_head
+	byteswap pdata,pdata
+	store 2,mem_ipc_2C51_read_index
+	store 2,mem_ipc_2C51_write_index
+	fetch 1,mem_hibernate_flag
+	beq 0x5a,p_device_init_init_hibwake
+	branch p_deveice_init_wake,wake
+	fetch 2,mem_adc_0v
+	byteswap pdata,pdata
+	store 2,mem_adc_0v
+	fetch 2,mem_adc_3v
+	byteswap pdata,pdata
+	store 2,mem_adc_3v
+	call p_init_adc_from_otp
+	fetch 8,mem_temp
+	nbranch p_deveice_init_reset,blank
+	fetch 2,0x4ad4
+	byteswap pdata,pdata
+	branch p_deveice_init_reset,blank
+	store 2,mem_adc_3v
+p_deveice_init_reset:
+	call p_le_queue_init
+	jam BT_EVT_RESET,mem_ipc_tx_evt
+p_device_init_common:
+	call p_ipc_tx_evt
+	jam 0,mem_hibernate_flag
+	hjam START_C51_CORE,core_docd_ctrl
+	rtn
+p_deveice_init_wake:
+	jam BT_EVT_WAKEUP,mem_ipc_tx_evt
+	branch p_device_init_common
+p_device_init_init_hibwake:
+	copy auxcnt,pdata
+	branch p_enter_hibernate_continue,blank
+	call init_lmp_work
+	call l2cap_init_work
+	setarg 0
+	store 8,mem_context
+	store 2,mem_ui_state_map
+	copy clkn_bt,pdata
+	store 4,mem_ipc_last_check_timer
+	jam BT_EVT_HIBERNATE_WAKE,mem_ipc_tx_evt
+	branch p_device_init_common
+
+p_init_adc_from_otp:
+	call otp_enable_chgpump
+	setarg 0x7e0
+	arg mem_temp,rega
+	arg 14,temp
+	call otpd_read_data
+	call otp_disable_chgpump
+	fetch 1,mem_temp
+	bbit1 1,assert		// limit 1085
+	fetch 8,mem_temp+2
+	rtn blank
+	fetch 1,mem_adc_config_flag
+	bbit1 ADC_CONFIG_VINLPM,p_calc_adc_base_vinlpm
+	bbit1 ADC_CONFIG_HVIN,p_calc_adc_base_hvin
+p_calc_adc_check_gpio:
+	fetch 2,mem_temp + 2
+	byteswap pdata,pdata
+	store 2,mem_adc_0v
+	fetch 2,mem_temp + 8
+	byteswap pdata,pdata
+	store 2,mem_adc_3v
+	rtn
+p_calc_adc_base_vinlpm:
+	fetcht 2,mem_temp + 6
+	fetch 2,mem_temp + 12
+	copy temp,regb
+	copy pdata,rega
+	byteswap pdata,pdata
+	store 2, mem_adc_3v
+	copy rega,pdata
+	isub temp,regc
+	lshift regc,regc
+	copy regb,pdata
+	isub regc,pdata
+	byteswap pdata,pdata
+	store 2, mem_adc_0v
+	rtn
+
+p_calc_adc_base_hvin:
+	fetcht 2,mem_temp + 4
+	fetch 2,mem_temp + 10
+	copy temp,regb
+	copy pdata,rega
+	isub temp,regc
+	rshift2 regc,regc
+	copy regb,pdata
+	isub regc,pdata
+	byteswap pdata,pdata
+	store 2,mem_adc_0v
+	lshift regc,regc
+	copy rega,pdata
+	isub regc,pdata
+	byteswap pdata,pdata
+	store 2,mem_adc_3v
+	rtn
+
+
+p_le_enable:
+	jam 39,mem_le_ch_mapped
+	hjam 0x36,0x90f        /*For BLE, tune AGC_gain_offset, Max added*/
+	hjam 0x5f,0x90b        //for BLE
+	branch le_enable+2
+p_le_disable:
+	hjam 0x2e,0x90f        /*For BR/EDR, tune AGC_gain_offset, Max added*/
+	hjam 0xff,0x90b         //for EDR&BR
+	branch le_disable+2
+
+
+p_mouse_idle:
+	rtn
+p_check_enter_hibernate:
+	fetch 2,mem_ipc_2C51_write_index
+	store 2,mem_ipc_2C51_read_index
+	fetch 2,mem_ipc_2bt_write_index
+	store 2,mem_ipc_2bt_read_index
+	jam SYC_TASK_HIBERNATE,mem_c51_flag
+	call p_c51_wait
+p_enter_hibernate_continue:
+//	branch lpm_hibernate
+	
+	jam 0x5a,mem_hibernate_flag
+	call lpm_write_gpio_wakeup
+	hfetch 4,core_lpm_ctrl
+	set0 15,pdata					
+	hstore 4,core_lpm_reg
+	call lpm_write_ctrl
+	arg param_hibernate_clks,temp
+	branch lpm_sleep
+
+p_fifo_in:
+	ifetcht UTIL_FIFO_LEN,rega
+	and temp,0xff,pdata
+	nbranch p_fifo_in_push,blank
+	rshift8 temp,pdata
+	istore UTIL_FIFO_LEN,rega
+p_fifo_in_push:
+	increase UTIL_FIFO_LEN+UTIL_FIFO_OFFSET,rega
+	ifetch 1,rega
+	nrtn,blank //fifo full
+	branch fifo_in_push+3
+
+
+	
+ 
+p_check_51cmd_once:
+	call ui_ipc_get_lock
+	arg mem_ipc_fifo_c512bt,rega
+	call fifo_out
+	copy pdata,temp
+	call ui_ipc_put_lock
+	copy temp,pdata
+	rtn blank 
+ifdef P24G
+	beq BT_CMD_START_24G,p_check_51cmd_start24g
+	beq BT_CMD_STOP_24G,p_check_51cmd_stop24g
+	beq BT_CMD_PAIR_24G,p_g24_start_pairing_sm1
+
+endif	
+ifdef BLE_PINCODE
+	beq BT_CMD_LE_SET_PINCODE,p_check51_cmd_le_set_pincode
+endif	
+	beq BT_CMD_START_ADV,p_check_51cmd_start_adv
+	beq BT_CMD_START_ADV_DISCOVERY,p_check_51cmd_start_adv
+	beq BT_CMD_START_ADV_REC,p_handle_adv_1
+	beq BT_CMD_SET_RECONNECT_INIT,p_disconnect_connected_device
+	beq BT_CMD_LE_UPDATE_CONN,BT_CMD_LE_UPDATE_CONN_1
+	branch check_51cmd_once+9
+ifdef P24G
+p_check_51cmd_start24g:
+	jam STATE_24G_PAIRING_SUCCESS,mem_24g_pairing_sm
+	branch p_g24_start_24g_mode
+p_check_51cmd_stop24g:
+	set0 mark_24g,mark
+	jam STATE_24G_PAIRING_SUCCESS,mem_24g_pairing_sm
+	branch p_g24_stop_g24_mode
+
+endif
+
+p_slave_ble_disconnect:
+	jam XT_LL_TERMINATE_IND,mem_fifo_temp
+	branch le_xtype_fifo_in
+
+p_check_51cmd_once_continue:
+	fetch 1,mem_lmo_opcode2
+	branch p_check_51cmd_once_continue0,blank
+	call lmo_fifo_process
+	fetch 1,mem_lmo_opcode2
+	nbranch check_51cmd_restore,blank  //process this cmd next time while lmo fifo is full
+p_check_51cmd_once_continue0:
+	fetch 1,mem_fifo_temp
+	bmark0 mark_context,check_51cmd_check_idle
+
+	beq BT_CMD_LE_DISCONNECT,p_slave_ble_disconnect
+
+	branch check_51cmd_once_continue0
+p_check_51cmd_start_adv:	
+	call app_clear_reconnect_flag
+	call check_51cmd_bb_reconn_cancel
+	jam 0,mem_lpm_mode
+	random pdata					//random ble addr
+	store 1,mem_le_lap
+p_handle_adv_0:
+	jam 5,mem_le_adv_data+2
+	setarg 0x181203		
+	store 3,mem_le_adv_data+8
+	
+	arg 7,temp				// mem_le_adv_swift_pair
+	call p_le_adv_data_update
+	branch check_51cmd_adv
+
+p_handle_adv_1:
+	jam 4,mem_le_adv_data+2
+	setarg 0x0000ff		//  ios bluetooth list will display device name when reconnect 
+	store 3,mem_le_adv_data+8
+
+	arg 0,temp
+	call p_le_adv_data_update
+	branch check_51cmd_adv
+	
+p_le_adv_data_update:
+	fetch 1,mem_le_scan_data_len  //  mem_le_name_len + 2 
+	iadd temp,pdata
+	add pdata,11,pdata
+	sub pdata,0x1f,null
+	nbranch p_le_adv_data_overflow,positive
+	store 1,mem_le_adv_data_len
+
+	arg mem_le_adv_data+11,contw
+	copy temp,pdata
+	ncall p_handle_adv_swift_pair,blank
+	
+	fetch 1,mem_le_scan_data_len
+	copy pdata,loopcnt
+	arg mem_le_scan_data,contr
+	branch memcpy
+	
+
+p_handle_adv_swift_pair:
+	copy pdata,loopcnt
+	arg mem_le_adv_swift_pair,contr
+	branch memcpy
+	
+p_le_adv_data_overflow:
+	fetch 1,mem_le_scan_data_len
+	add pdata,11,pdata
+	store 1,mem_le_adv_data_len
+	rtn
+
+p_disconnect_connected_device:
+	//jam 10,mem_recon_count
+	fetch 2,mem_ui_state_map
+	bbit1 UI_STATE_BLE_CONNECTED,app_ble_disconnect
+	bbit1 UI_STATE_BT_RECONNECT,check_51cmd_bb_reconn_cancel
+ifdef P24G	
+	bmark1 mark_24g,p_g24_stop_g24_mode
+endif	
+	jam OFF,mem_le_adv_enable
+	call app_bt_stop_discovery
+	//call mouse3_0_bb_event_discovery_btn
+	jam BT_EVT_RECONNECT_STANDY,mem_fifo_temp
+	branch ui_ipc_send_event
+	
+
+
+p_lpm_sleep:
+	call xtal_fast_wake
+	branch lpm_sleep+2
+
+/*
+p_idle_page_mode_r0:
+	storet 8,mem_temp
+	call timer_check
+	fetcht 8,mem_temp
+	branch idle_page_mode_r0+13
+*/
+
+
+p_hid_rx_process_data_hid_kb:
+	ifetch 1,contr
+	store 1,mem_caps_num_lock
+	rtn	
+
+
+ifdef BLE
+
+ifdef BLE_PINCODE
+p_check51_cmd_le_set_pincode:
+	fetch 1,mem_le_pin_code
+	fetcht 1,mem_le_pin_code+3
+	store 1,mem_le_pin_code+3
+	storet 1,mem_le_pin_code
+	
+	fetch 1,mem_le_pin_code+1
+	fetcht 1,mem_le_pin_code+2
+	store 1,mem_le_pin_code+2
+	storet 1,mem_le_pin_code+1
+
+	jam XT_SMP_PAIRING_CONFIRM,mem_fifo_temp
+	branch le_xtype_fifo_in
+endif
+
+p_scale_process_le_discon:
+	jam 0,mem_le_pause_enc_flag
+	branch scale_process_le_discon
+
+
+p_le_transmit_receive_sifs:
+	call le_transmit
+	fetcht 1,mem_last_freq
+	call set_freq_rx
+	call rf_rx_enable
+	enable swfine
+	arg 5500,timeup	// about 417us
+	//call ice_break
+	branch le_receive_rxon
+
+p_le_init_conn:
+	jam 0x01,mem_le_txheader
+	jam  0,mem_le_txlen
+	branch le_init_conn+2
+
+p_le_transmit:
+	call le_prep
+	call p_letx_setfreq
+	branch le_transmit+4
+
+p_letx_setfreq:
+	branch p_txon,match
+	call le_setfreq
+	branch set_freq_tx
+
+p_le_send_adv_ind:
+	fetch 1,mem_le_rx_window
+	store 4,mem_le_transmit_window// init first packate rx window
+	fetch 1,mem_le_adv_type
+	beq ADV_DIRECT_IND,p_le_send_adv_direct_ind
+	branch le_send_adv_ind+2
+p_le_send_adv_direct_ind:
+	jam 0,mem_le_adv_type
+	branch le_send_adv_direct_ind
+
+p_le_update_param:
+	fetch 1,mem_le_state
+	rtnbit0 lestate_update_param
+	fetch 2,mem_le_event_count
+	fetcht 2,mem_le_instant
+	isub temp,pdata
+	nrtn positive
+	branch le_update_param+8
+
+
+p_le_prepare_tx: 
+	fetch 1,mem_le_arq  
+	rtnbit1 wak 
+
+	fetch 1,mem_le_rxbuf + 1  
+	branch le_prepare_tx + 4,blank  
+	branch le_send_empty      // send empty data when got non empty packet
+
+
+p_le_check_wak:
+	fetcht 1,mem_le_arq
+	isolate0 wak,temp
+	rtn true
+	fetch 1,mem_le_rxbuf
+	lshift pdata,pdata
+	ixor temp,pdata
+	rtnbit0 sn			/* received NESN is same as SN, NAK */
+	set0 wak,temp
+	setflip sn,temp
+	storet 1,mem_le_arq
+	compare 3,temp,3
+	nrtn true
+	fetch 1,mem_le_txpayload
+	beq LL_START_ENC_REQ,p_le_set_enc
+	fetch 1,mem_le_pause_enc_flag
+	beq 1,p_le_clear_enc
+	rtn
+
+p_le_set_enc:
+	fetch 1,mem_le_state
+	set1 lestate_encryption,pdata
+	store 1,mem_le_state
+	rtn	
+	
+p_le_clear_enc:
+	jam 0,mem_le_pause_enc_flag
+	arg 0,pdata
+	store 4,mem_le_last_mic
+	store 1,mem_ltk_exists
+	store 5,mem_le_pcnt_tx
+	set1 39,pdata
+	store 5,mem_le_pcnt_rx
+	fetch 1,mem_le_state
+	set0 lestate_encryption,pdata
+	store 1,mem_le_state
+	rtn
+
+
+
+p_le_prepare_tx_cmd:
+	fetch 1,mem_le_txpayload
+	beq LL_UNKNOWN_RSP,p_le_send_unknown_rsp
+	beq LL_CONNECTION_PARAM_REQ,p_le_send_conn_param_req
+	beq LL_START_ENC_RSP,p_le_send_start_enc_rsp
+//	beq LL_VERSION_IND,p_le_send_version_ind
+	beq LL_TERMINATE_IND,p_le_send_terminate_ind
+	beq LL_PING_RSP,p_le_send_ping_rsp
+	beq LL_PAUSE_ENC_RSP,p_le_send_pause_enc_rsp
+	branch le_prepare_tx_cmd+10
+
+p_le_send_pause_enc_rsp:
+p_le_send_ping_rsp:
+	force 1,temp
+	branch le_send_packet
+
+p_le_send_terminate_ind:
+	setarg 10 // 100ms
+	store 2,mem_le_superto
+	branch le_send_terminate_ind
+
+p_le_send_start_enc_rsp:
+	jam BT_CMD_LE_UPDATE_CONN,mem_fifo_temp
+	call  ui_ipc_send_cmd
+	force 1,temp
+	branch le_send_packet,master
+	jam BT_EVT_LE_PROTOCOL_CONNECTED,mem_fifo_temp
+	call ui_ipc_send_event
+	fetch 1,mem_le_pairing_state
+	beq FLAG_LE_PAIRING_AFTER_AUTH,p_le_send_start_enc_rsp0
+	branch p_le_send_start_enc_rsp_end
+p_le_send_start_enc_rsp0:
+	jam XT_SMP_ENCRYPTION_INFORMATION,mem_fifo_temp
+	call le_xtype_fifo_in
+p_le_send_start_enc_rsp_end:
+	force 1,temp
+	branch le_send_packet
+
+/*	
+p_le_send_version_ind:		logitch version ind
+	setarg 0x005907
+	istore 3,contw
+	setarg 0x005a
+	branch le_send_version_ind+3
+*/
+
+p_le_send_unknown_rsp:
+	fetch 1,mem_le_ll_unknown_type
+	istore 1,contw
+	force 2,temp
+	branch le_send_packet
+
+p_le_send_conn_param_req:
+	increase -1,contw
+	fetch 8,mem_le_connection_updata_param
+	istore 8,contw
+	ifetch 8,contr
+	istore 8,contw
+	force 2,type
+	branch le_send_autolen
+
+p_le_prepare_smp:
+	fetch 1,mem_le_l2cap
+	beq SMP_IDENTITY_ADDRESS_INFORMATION,le_send_smp_identity_address_information + 2
+	beq SMP_PAIRING_RESPONSE,p_le_send_smp_pairing_response
+ifdef BLE_PINCODE	
+	beq SMP_PAIRING_CONFIRM,p_le_send_smp_pairing_confirm 
+endif	
+	beq SMP_MASTER_IDENTIFICATION,le_send_smp_master_identification+2
+	branch le_prepare_smp0
+	
+
+
+p_le_send_smp_pairing_response:
+ifdef BLE_PINCODE
+	setarg 0x000202
+else	
+	setarg param_smp_paring_response
+endif	
+	store 3,mem_le_pres
+ifdef BLE_PINCODE
+	setarg 0x05
+else
+	setarg 0x01
+endif	
+	istore 1,contw
+	setarg param_smp_key_dist0
+	istore 3,contw
+	branch le_send_smp_pairing_response + 4
+
+
+ifdef BLE_PINCODE
+p_le_send_smp_pairing_confirm:
+	call p_generate_confirm
+	arg mem_le_l2cap_response,contw
+	call store_aes_result
+	force 21,temp
+	branch le_send_packet
+
+p_generate_confirm:
+	arg mem_le_mrand,rega
+	branch p_generate_mrand,master
+	arg mem_le_srand,rega
+p_generate_mrand:
+	copy rega,contw
+	call generate_random
+	branch p_function_c1
+
+p_function_c1:
+	fetch 6,mem_le_lap
+	fetcht 6,mem_le_plap
+	branch p_function_c1_master,master
+	fetch 6,mem_le_plap
+	fetcht 6,mem_le_lap
+p_function_c1_master:
+	force regidx_xor,regext_index
+	copy temp,regext
+	increase 1,regext_index
+	rshift32 temp,regext
+	lshift16 pdata,pdata
+	ior regext,regext
+	increase 1,regext_index
+	rshift32 pdata,regext
+	increase 1,regext_index
+	force 0,regext					/* p2 = ia || ra */
+	force 0,pdata
+	fetch 1,mem_le_conn_peer_addr_type
+	fetcht 1,mem_le_adv_own_addr_type
+	nbranch p_function_c1_irat,master
+	//conn as master
+	fetch 1,mem_le_conn_own_addr_type
+	fetcht 1,mem_le_conn_peer_addr_type
+p_function_c1_irat:
+	store 1,mem_le_iat
+	storet 1,mem_le_rat
+	force regidx_data,regext_index
+	arg mem_le_iat,regb
+	force 4,loopcnt
+p_function_c1_loop1:
+	ifetch 4,rega		
+	ifetcht 4,regb
+	ixor temp,regext
+	increase 1,regext_index
+	increase 4,rega
+	increase 4,regb
+	loop p_function_c1_loop1		/* p1 ^ r */
+
+	call aes_clear				/* k = 0 */
+
+	increase -4,regext_index
+	fetch 4,mem_le_pin_code
+	copy pdata,regext
+	increase 4,regext_index
+	branch function_c1_loop1 + 8
+endif
+	
+
+
+p_lerx_nopayload:
+	parse 3,0,24	
+	enable swfine
+	arg param_sifs,27
+	rshift32 pdata,pdata
+	rshift16 pdata,pdata
+	istore 3,contw
+	branch end_of_packet,6
+	enable match
+	fetch 1,mem_last_freq
+	add pdata,0,rega
+	branch lerx_nopayload+12
+
+p_le_parse_att:
+	ifetch 3,contr
+	store 3,mem_le_att_opcode
+	//beq ATTOP_WRITE_REQUEST,p_le_parse_att_write_request
+	beq ATTOP_WRITE_COMMAND,p_le_parse_att_write_command
+	//beq ATTOP_PREPARE_WRITE_REQUEST,p_le_parse_att_prepare_write_request
+	//beq ATTOP_EXECUTE_WRITE_REQUEST,p_le_parse_att_execute_write_request
+	beq ATTOP_EXCHANGE_MTU_REQUEST,p_le_parse_att_exchange_mtu_request
+	beq ATTOP_WRITE_REQUEST,p_le_parse_att_write_request
+	branch le_parse_att_p
+
+p_le_parse_att_write_command:
+	jam 1,mem_reconnect_continue
+	fetch 2,mem_le_att_handle
+	beq HANDLE_UUID_CHRCTR_REPORT_ID1_OUTPUT,p_handle_num
+	branch le_parse_att_write_command
+p_handle_num:
+	//fetch 1,mem_le_rxbuf
+	arg mem_le_rxbuf+9,contr 
+	branch p_hid_rx_process_data_hid_kb
+
+p_le_parse_att_write_request:
+	fetch 2,mem_le_att_handle				//MAC  CAPS
+	sub pdata,HANDLE_UUID_CHRCTR_REPORT_ID1_OUTPUT,null
+	call p_handle_num,zero
+	fetch 2,mem_le_att_handle			
+	sub pdata,HANDLE_UUID_END,null
+	call p_set_lpm_mode,zero	
+	fetch 2,mem_le_att_handle
+	fetcht 2,mem_att_report3
+	increase 1,temp
+	isub temp,null
+	branch p_key_data_send,zero
+	branch le_parse_att_write_request
+p_key_data_send:
+	jam BT_EVT_LE_PROTOCOL_CONNECTED,mem_fifo_temp
+	call ui_ipc_send_event
+	branch le_parse_att_write_request
+
+
+p_set_lpm_mode:
+	jam 1,mem_lpm_mode
+	rtn
+
+
+p_le_parse_att_exchange_mtu_request:
+	jam ATTOP_EXCHANGE_MTU_RESPONSE,mem_fifo_temp
+	branch le_xtype_fifo_in
+
+p_le_prepare_att:
+	fetch 1,mem_le_l2cap
+	beq ATTOP_HANDLE_VALUE_NOTIFICATION,p_le_send_att_handle_value_notification
+	beq ATTOP_HANDLE_VALUE_INDICATION,p_le_send_att_handle_value_indication
+	beq ATTOP_READ_BY_GROUP_TYPE_RESPONSE,p_le_send_att_read_by_group_type_response
+	beq ATTOP_READ_BY_TYPE_RESPONSE,p_le_send_att_read_by_type_response
+	beq ATTOP_FIND_INFORMATION_RESPONSE,p_le_send_att_find_information_response
+	beq ATTOP_FIND_BY_TYPE_VALUE_RESPONSE,p_le_send_att_find_by_type_value_response
+	beq ATTOP_WRITE_RESPONSE,le_send_att_write_response_go
+	beq ATTOP_EXCHANGE_MTU_RESPONSE,p_le_send_att_exchange_mtu_rsp
+	beq ATTOP_READ_RESPONSE, p_le_send_att_read_response
+	beq ATTOP_READ_BLOB_RESPONSE,p_le_send_att_read_blob_response
+	branch le_prepare_att0
+
+p_le_send_att_read_blob_response:
+	fetch 2,mem_le_att_handle
+	beq HANDLE_UUID_CHRCTR_DEVICE_NAME,p_le_send_att_read_blob_response_error
+	branch le_send_att_read_blob_response
+
+p_le_send_att_read_blob_response_error:
+	jam ATT_ERR_INVALID_OFFSET,mem_le_err_code
+	branch le_send_att_error_response
+
+p_le_send_att_exchange_mtu_rsp:
+//	branch p_le_send_att_exchange_mtu_req
+	//branch p_ng_event_remote_mtu_res
+p_le_send_att_exchange_mtu_req:
+	fetch 2,mem_le_local_mtu
+	istore 2,contw
+	branch le_send_autolen
+
+p_le_send_att_read_response:
+	fetch 2,mem_le_att_handle
+	//beq 27,p_le_send_att_read_response_error
+ifndef LE_BATTERY_LEVEL_DISPLAY	
+	beq HANDLE_UUID_BATTERY_LEVEL,le_send_att_error_response_notfound
+endif	
+	beq HANDLE_UUID_CHRCTR_MANUFACTURER_NAME,p_le_send_att_read_response_error
+//	beq HANDLE_UUID_PNP_ID,p_le_send_att_read_response_error
+	branch le_send_att_read_response
+
+p_le_send_att_read_response_error:
+	fetch 1,mem_le_pairing_state
+	bne FLAG_LE_PAIRING_NULL,le_send_att_read_response
+	fetch 1,mem_ltk_states
+	beq LTK_NOT_LOST,le_send_att_read_response	
+	//fetch 1,mem_ltk_exists
+	//nbranch le_send_att_read_response,blank
+	copy contw,temp
+	jam FLAG_LE_PAIRING_START,mem_le_pairing_state	
+	copy temp,contw
+	jam ATT_ERR_INSUFFICIENT_AUTHENTICATION,mem_le_err_code
+	branch le_send_att_error_response
+
+p_le_send_att_find_by_type_value_response:
+	call le_start_end_handle_check_1
+	rtn user
+	fetcht 2,mem_le_search_att_type
+	setarg UUID_SERVICE_HIDS
+	isub temp,null
+	branch p_le_send_att_find_value_by_type_hid,zero
+	setarg UUID_SERVICE_BATTERY
+	isub temp,null
+	branch p_le_send_att_find_value_by_type_battery,zero	
+	setarg UUID_SERVICE_DEVICE_INFO
+	isub temp,null
+	branch p_le_send_att_find_value_by_type_device_info,zero
+	setarg UUID_SERVICE_GENERIC_ATT
+	isub temp,null
+	branch p_le_send_att_find_value_by_type_gatt,zero
+	branch le_send_att_find_by_type_value_response+2
+
+p_le_send_find_value_by_type:
+	fetch 1,mem_shutter_find_type_value_flag
+	arg 0,temp
+	qset1 temp
+	iand temp,pdata
+	bne 0,le_send_att_error_response_notfound
+	fetch 1,mem_shutter_find_type_value_flag
+	qset1 pdata
+	store 1,mem_shutter_find_type_value_flag
+	branch p_le_send_att_find_value_by_type_command
+
+p_le_send_att_find_value_by_type_hid:
+	arg LE_FIND_TYPE_VALUE_HID_BIT,queue
+	branch p_le_send_find_value_by_type
+
+p_le_send_att_find_value_by_type_battery:
+	arg LE_FIND_TYPE_VALUE_BATTERY_BIT,queue
+	branch p_le_send_find_value_by_type
+
+p_le_send_att_find_value_by_type_gatt:
+	arg LE_FIND_TYPE_VALUE_GATT_BIT,queue
+	branch p_le_send_find_value_by_type
+p_le_send_att_find_value_by_type_device_info:
+	arg LE_FIND_TYPE_VALUE_DEVICE_INFO_BIT,queue
+	branch p_le_send_find_value_by_type
+p_le_send_att_find_value_by_type_command:
+	fetch 2,mem_le_search_att_type
+	copy pdata,rega
+	fetcht 2,mem_le_uuid
+	copy temp,regb
+	call p_find_type_value_start_handle
+	branch p_le_save_find_value_handle,zero
+	branch le_send_att_error_response_notfound	
+
+p_find_type_value_start_handle:
+	arg mem_le_att_list,contr
+p_find_type_value_start_handle_loop:
+	ifetch 2,contr
+	rtn blank
+	ifetch 3,contr
+	ifetch 2,contr			// length
+	isub rega,null
+	rtn zero
+	increase -3,contr
+	ifetch 1,contr
+	iadd contr,contr
+	branch p_find_type_value_start_handle_loop
+
+p_le_save_find_value_handle:
+	increase -7,contr
+	ifetch 2,contr
+	store 2,mem_le_find_type_value_start_handle
+	call p_find_type_value_end_handle
+	branch le_send_att_error_response_notfound,blank
+	increase -4,contr
+	ifetch 2,contr
+	increase -1,pdata
+	store 2,mem_le_find_type_value_end_handle
+	jam ATTOP_FIND_BY_TYPE_VALUE_RESPONSE,mem_le_l2cap
+	fetch 4,mem_le_find_type_value_start_handle
+	store 4,mem_le_l2cap_response
+	//fetch 2,mem_le_find_type_value_end_handle
+	//istore 2,contw
+	force 9,temp
+	branch le_send_packet
+	
+p_find_type_value_end_handle:
+	ifetch 2,contr
+	ifetch 1,contr
+	iadd contr,contr
+p_find_type_value_end_handle_loop:
+	ifetch 2,contr
+	rtn blank
+	ifetch 2,contr
+	isub regb,null
+	rtn zero
+	ifetch 1,contr
+	iadd contr,contr
+	branch p_find_type_value_end_handle_loop
+
+p_le_send_att_find_information_response:
+	arg 3,timeup
+	force 1,pdata
+	store 1,mem_le_l2cap_response
+	call le_init_attlist_search
+p_le_send_att_find_information_res_loop:
+	call le_att_handle_inrange
+	branch le_send_att_find_information_res_end,blank
+	nbranch p_le_send_att_find_information_res_next,positive
+	disable user
+	istore 2,contw
+	ifetch 2,contr
+	istore 2,contw
+	increase -1,timeup
+	branch le_send_att_find_information_res_end,zero
+p_le_send_att_find_information_res_cont:
+	ifetch 1,contr
+	iadd contr,contr
+	branch p_le_send_att_find_information_res_loop
+p_le_send_att_find_information_res_next:
+	increase 2,contr
+	branch p_le_send_att_find_information_res_cont
+
+
+
+p_le_send_att_read_by_type_response:
+	fetcht 2,mem_le_search_att_type
+	setarg UUID_CHRCTR_DEVICE_NAME
+	isub temp,null
+	branch p_le_send_att_read_by_type_res_device_name,zero	
+	setarg UUID_PNP_ID
+	isub temp,null
+	branch p_le_send_att_read_by_type_res_pnp_id,zero	
+	setarg UUID_GATT_CHARACTERISTIC
+	isub temp,null
+	nbranch le_send_att_error_response_notfound,zero
+	fetch 2,mem_le_search_handle_start
+	store 2,mem_temp
+	enable user
+p_le_send_att_read_by_type_response_loop:
+	call p_le_att_handle_inrange
+	nbranch p_le_send_att_read_by_type_response_end,positive
+	fetcht 2,mem_temp
+	call p_le_att_get_handle_info
+	beq 1,p_le_send_att_read_by_type_response_end
+	call p_le_att_same_type
+	nbranch p_le_send_att_read_by_type_response_next_handle,zero
+	disable user
+	call p_le_send_att_read_by_type_write_properties
+	call p_le_att_next_handle
+	call p_le_att_get_handle_info
+	call p_le_send_att_read_by_type_write_uuid
+	branch p_le_send_att_read_by_type_response_end
+p_le_send_att_read_by_type_response_next_handle:
+	call p_le_att_next_handle
+	branch p_le_send_att_read_by_type_response_loop
+p_le_send_att_read_by_type_response_end:
+	branch le_send_att_error_response_notfound,user
+	branch p_le_send_auto_len_by_mem
+p_le_send_att_read_by_type_write_properties:
+	fetch 2,mem_temp
+	store 2,mem_le_l2cap_response+1
+	fetch 1,mem_le_search_len
+	copy pdata,loopcnt
+	call p_get_contr
+	arg mem_le_l2cap_response+3,contw
+	call memcpy
+	branch p_store_contw
+p_le_send_att_read_by_type_write_uuid:
+	fetcht 2,mem_le_cur_att_type
+	rshift8 temp,pdata
+	bne 0x05,p_le_send_att_read_by_type_write_short_uuid
+	call p_get_contw
+	fetch 2,mem_temp
+	istore 2,contw
+	call p_store_contw
+	setarg mem_le_att_list
+	iadd temp,contr
+	ifetch 1,contr
+	copy contr,temp
+	copy pdata,loopcnt
+	increase 5,pdata
+	store 1,mem_le_l2cap_response
+	call p_get_contw
+	copy temp,contr
+	call memcpy
+	branch p_store_contw
+p_le_send_att_read_by_type_write_short_uuid:
+	call p_get_contw
+	fetch 2,mem_temp
+	istore 2,contw
+	fetch 2,mem_le_cur_att_type
+	istore 2,contw
+	call p_store_contw
+	jam 7,mem_le_l2cap_response
+	rtn
+p_le_send_att_read_by_type_res_device_name:
+	call le_get_device_name
+p_le_send_att_read_by_type_res_packet:
+	ifetch 1,contr // length
+	copy pdata,loopcnt
+	increase 2,pdata
+	store 1,mem_le_l2cap_response // att packet length
+	increase -5,contr // point to handle
+	ifetch 2,contr
+	istore 2,contw // handle
+	increase 3,contr // point to name
+	call memcpy
+	branch le_send_autolen
+	
+p_le_send_att_read_by_type_res_pnp_id:
+	arg UUID_PNP_ID,temp
+	call le_att_get_uuid_ptr
+	branch p_le_send_att_read_by_type_res_packet
+
+p_le_send_att_read_by_group_type_response:
+	//call ice_break
+	arg 2,timeup
+	fetch 2,mem_le_search_handle_start
+	store 2,mem_temp
+	jam 0,mem_le_search_res
+	enable user
+p_le_send_att_read_by_group_type_response_loop:
+	call p_le_att_handle_inrange
+	nbranch p_le_send_att_read_by_group_type_end0,positive
+	fetcht 2,mem_temp
+	call p_le_att_get_handle_info
+	beq 1,p_le_send_att_read_by_group_type_end1
+	call p_le_att_same_type
+	nbranch p_le_send_att_read_by_group_type_next_handle,zero
+	fetch 1,mem_le_search_res
+	beq 1,p_le_send_att_read_by_group_type_end1
+	nbranch p_le_send_att_read_by_group_type_store_write_record,user		//un first
+	disable user
+	fetch 1,mem_le_search_len
+	increase 4,pdata
+	store 1,mem_le_l2cap_response
+	call p_store_contw
+	branch p_le_send_att_read_by_group_type_store_record
+p_le_send_att_read_by_group_type_store_write_record:
+	fetch 1,mem_le_search_len
+	sub pdata,0x10,null
+	branch p_le_send_att_read_by_group_type_end1,zero
+	fetch 1,mem_le_l2cap_response
+	sub pdata,0x10,null
+	branch p_le_send_att_read_by_group_type_end1,zero
+	fetch 2,mem_temp
+	increase -1,pdata
+	store 2,mem_le_cur_handle_end
+	call p_le_write_att_record
+p_le_send_att_read_by_group_type_store_record:
+	fetch 2,mem_temp
+	store 2,mem_le_cur_handle_start
+	call p_le_store_att_record
+	increase -1,timeup
+	branch p_le_send_att_read_by_group_type_last_find,zero		
+p_le_send_att_read_by_group_type_next_handle:
+	call p_le_att_next_handle
+	branch p_le_send_att_read_by_group_type_response_loop
+p_le_send_att_read_by_group_type_last_find:
+	jam 1,mem_le_search_res
+	branch p_le_send_att_read_by_group_type_next_handle
+p_le_send_att_read_by_group_type_end0:	//> att handle end
+	fetch 2,mem_temp
+	store 2,mem_le_cur_handle_end
+	branch p_le_send_att_read_by_group_type_end_common
+p_le_send_att_read_by_group_type_end1:	//>att max list handle or diff len 
+	fetch 2,mem_temp
+	increase -1,pdata
+	store 2,mem_le_cur_handle_end
+	branch p_le_send_att_read_by_group_type_end_common
+p_le_send_att_read_by_group_type_end_common:
+	branch le_send_att_error_response_notfound,user
+	call p_le_write_att_record
+	branch p_le_send_auto_len_by_mem
+
+p_le_att_next_handle:
+	fetcht 2,mem_temp
+	increase 1,temp
+	storet 2,mem_temp
+	rtn
+
+p_le_store_att_record:
+	fetch 1,mem_le_search_len
+	store 1, mem_tmp_buffer
+	copy pdata,loopcnt
+	call p_get_contr
+	branch memcpy
+	
+p_le_write_att_record:
+	call p_get_contw
+	fetch 2,mem_le_cur_handle_start
+	istore 2,contw
+	fetch 2,mem_le_cur_handle_end
+	istore 2,contw
+	fetch 1,mem_tmp_buffer
+	copy pdata,loopcnt
+	call memcpy
+	branch p_store_contw
+
+
+p_le_att_handle_inrange:
+	fetcht 2,mem_temp
+	fetch 2,mem_le_search_handle_end
+	isub temp,null
+	rtn
+
+p_le_att_same_type:
+	fetch 2,mem_le_search_att_type
+	fetcht 2,mem_le_cur_att_type
+	isub temp,null
+	rtn
+
+p_le_att_get_handle_info:
+	arg mem_le_att_list,contr
+	copy temp,rega
+p_le_att_get_handle_loop:
+	ifetch 2,contr
+	branch p_le_att_unfind_handle,blank
+	ifetcht 2,contr
+	storet 2,mem_le_cur_att_type
+	isub rega,null
+	branch p_le_att_finded_handle, zero
+	ifetch 1,contr			/* length */
+	iadd contr,contr
+	branch p_le_att_get_handle_loop
+p_le_att_unfind_handle:
+	setarg 1
+	rtn
+p_le_att_finded_handle:
+	ifetch 1,contr
+	store 1,mem_le_search_len
+	call p_store_contr
+	setarg 0
+	rtn
+p_get_contw:
+	fetch 2,mem_contw
+	copy pdata,contw
+	rtn
+p_get_contr:
+	fetch 2,mem_contr
+	copy pdata,contr
+	rtn
+p_store_contw:
+	copy contw,pdata
+	store 2,mem_contw
+	rtn
+p_store_contr:
+	copy contr,pdata
+	store 2,mem_contr
+	rtn
+
+p_le_send_auto_len_by_mem:
+	call p_get_contw
+	branch le_send_autolen	
+
+p_le_send_att_handle_value_indication:
+p_le_send_att_handle_value_notification:
+	fetch 1,mem_queue_read
+	add pdata,1,temp
+	and temp,0x03,temp
+	storet 1,mem_queue_read
+	mul32 pdata,7,pdata
+	arg mem_uart_packet,contr
+	iadd contr,contr
+	fetch 1,mem_le51_tx_length
+	increase -5,pdata
+	copy pdata,loopcnt
+	arg mem_le_l2cap+1,contw
+	call memcpy
+	fetcht 1,mem_le51_tx_length
+	branch le_send_packet
+	
+p_le_parse:
+	call le_xtype_fifo_is_full
+	branch le_parse+4
+
+
+p_le_parse_ll:
+	copy regc,pdata
+	beq LL_ENC_REQ,p_le_parse_enc_req
+	beq LL_PAUSE_ENC_REQ,p_le_parse_pause_enc_rsq
+	beq LL_CONNECTION_UPDATE_REQ,p_le_parse_connection_update_req
+	beq LL_PING_REQ,p_le_parse_ping_req
+	beq LL_TERMINATE_IND,p_le_parse_terminate_ind
+	sub pdata,0x0d,null
+	branch le_parse+20,positive
+	store 1,mem_le_ll_unknown_type
+	jam XT_LL_UNKNOWN_RSP,mem_fifo_temp
+	branch le_xtype_fifo_in	
+p_le_parse_connection_update_req:
+
+	call le_parse_connection_update_req
+	fetch 2,mem_le_new_param+3	// interval
+	mul32 pdata,4,temp
+	storet 2,mem_customize_timer_setup
+	rtn
+
+p_le_parse_enc_req:
+	jam DEFAULT_STATES,mem_ltk_states
+	branch le_parse_enc_req
+
+p_le_parse_ping_req:
+	jam XT_LL_PING_RSP,mem_fifo_temp
+	branch le_xtype_fifo_in
+	
+p_le_parse_pause_enc_rsq:
+	jam 1,mem_le_pause_enc_flag
+	jam XT_LL_PAUSE_ENC_RSP,mem_fifo_temp
+	branch le_xtype_fifo_in
+
+p_le_parse_terminate_ind:
+	setarg 20 // 200ms
+	store 2,mem_le_superto
+	rtn
+
+p_le_send_non_l2cap:
+	fetch 1,mem_le_txheader
+	compare 1,type,3
+	branch p_le_send_non_l2cap1,true
+	branch le_send_non_l2cap+14
+p_le_send_non_l2cap1:
+	fetch 1,mem_le_txlen
+	branch p_le_send_empty_clear_md,blank
+	branch le_send_non_l2cap+14
+
+p_le_send_empty_clear_md:		// HUAWEI M5 pair fail
+	fetch 1,mem_le_txheader
+	set0 md,pdata
+	store 1,mem_le_txheader
+	rtn
+
+p_le_parse_smp:
+	ifetch 1,contr
+	beq SMP_PAIRING_REQUEST,p_le_parse_smp_pairing_request
+	beq SMP_PAIRING_RANDOM,p_le_parse_smp_pairing_random
+ifdef BLE_PINCODE	
+	beq SMP_PAIRING_CONFIRM,p_le_parse_smp_pairing_confirm
+endif	
+	beq SMP_IDENTITY_ADDRESS_INFORMATION,p_le_parse_smp_identity_address_information
+	branch le_parse_smp + 4
+
+
+p_le_parse_smp_identity_address_information:
+	jam FLAG_LE_PAIRING_END,mem_le_pairing_state
+	branch le_parse_smp_identity_address_information
+
+p_le_parse_smp_pairing_request:
+	jam 1,mem_le_send_security_request_flag
+	store 1,mem_le_preq
+	ifetch 6,contr
+	istore 6,contw
+	jam XT_SMP_PAIRING_RESPONSE,mem_fifo_temp
+ifdef BLE_PINCODE	
+	call le_xtype_fifo_in
+	jam BT_EVT_LE_PINCODE_REQ,mem_fifo_temp
+	branch ui_ipc_send_event
+else	
+	branch le_xtype_fifo_in
+endif	
+
+p_le_parse_smp_pairing_random:
+ifdef BLE_PINCODE
+	call p_authenticate_rconfirm
+else
+	call authenticate_rconfirm
+endif	
+	branch p_le_parse_smp_pairing_random_success,zero
+	branch le_parse_smp_pairing_random + 2
+p_le_parse_smp_pairing_random_success:
+	jam FLAG_LE_PAIRING_AFTER_AUTH,mem_le_pairing_state
+ifdef BLE_PINCODE
+	branch p_le_parse_smp_pairing_random_success1
+else
+	branch le_parse_smp_pairing_random_success
+endif	
+
+ifdef BLE_PINCODE
+	/* contr = rand pointer */
+p_authenticate_rconfirm:
+	arg mem_le_srand,contw
+	branch p_authenticate_mconfirm,master
+	arg mem_le_mrand,contw
+p_authenticate_mconfirm:
+	copy contr,rega
+	call memcpy16
+	call p_function_c1
+	arg mem_le_rconfirm,contr
+	branch compare_res
+
+
+p_le_parse_smp_pairing_random_success1:
+	call p_generate_stk
+	jam XT_LL_ENC_REQ,mem_fifo_temp
+	branch le_xtype_fifo_in,master
+	jam XT_SMP_PAIRING_RANDOM,mem_fifo_temp
+	branch le_xtype_fifo_in
+
+p_generate_stk:
+	call p_function_s1
+	arg mem_le_ltk,contw
+	branch store_aes_result
+
+p_function_s1:
+	force regidx_data,regext_index
+	fetch 4,mem_le_mrand
+	iforce regext
+	increase 1,regext_index
+	ifetch 4,contr
+	iforce regext
+	increase 1,regext_index
+	fetch 4,mem_le_srand
+	iforce regext
+	increase 1,regext_index
+	ifetch 4,contr
+	iforce regext
+	increase 1,regext_index
+	call aes_clear
+	//arg mem_le_pin_code,contr
+	//call load_key
+	increase -4,regext_index
+	fetch 4,mem_le_pin_code
+	copy pdata,regext
+	increase 4,regext_index
+	force 0x38,aes_ctrl
+	force 0x8,aes_ctrl
+	branch wait_aes
+
+p_le_parse_smp_pairing_confirm:
+	arg mem_le_rconfirm,contw
+	call memcpy16
+	jam XT_SMP_PAIRING_RANDOM,mem_fifo_temp
+	branch  le_xtype_fifo_in,master
+	rtn
+endif
+
+/*
+p_le_modified_name:
+	arg UUID_CHRCTR_DEVICE_NAME,temp
+	call le_att_get_uuid_ptr
+	ifetch 1,contr						// attribute length
+	copy contr,contw
+	fetcht 1,mem_le_name_len
+	copy temp,loopcnt
+	isub temp,temp
+	arg mem_new_le_name,contr
+	call memcpy
+	copy temp,loopcnt
+	ncall memcpy_empty,zero
+p_le_modified_scan:
+	fetcht 1,mem_le_name_len
+	copy temp,loopcnt
+	increase 1,temp
+	storet 1,mem_le_scan_data
+	increase 1,temp
+	increase 1,contw
+	arg mem_new_le_name,contr
+	call memcpy
+	sub temp,0x1f,loopcnt
+	branch clear_mem	
+*/
+
+
+scale_process_le_conn:
+	jam PAIR_UNKNOWN,mem_pair_state
+	call app_ble_stop_adv
+	call app_bt_stop_discovery
+	call  app_lpm_mult_enable
+	branch app_le_event_bb_connected
+
+
+scale_process_le_discon:
+	jam 0,mem_lpm_mult
+	jam 0,mem_ltk_exists
+	jam DEFAULT_STATES,mem_ltk_states
+	jam FLAG_LE_PAIRING_NULL,mem_le_pairing_state
+	jam 0,mem_shutter_find_type_value_flag
+	jam PAIR_UNKNOWN,mem_pair_state
+	branch app_le_event_bb_disconn
+endif
+	
+
+p_le_queue_init:
+	setarg 0
+	store 4,mem_queue_write
+	rtn
+
+		
+ifdef P24G
+p_g24_dispatch:
+	rtnmark0 mark_24g
+	fetch 4,mem_24g_enter_hibernate
+	store 4,mem_24g_enter_hibernate_setup
+	call p_g24_txdata_prep
+	nbranch p_g24_long_sleep,user
+	jam 10,mem_24g_enter_lpm_timer
+	call p_g24_transmit_packet
+	fetch 1,mem_24g_pairing_sm
+	rtnne STATE_24G_PAIRING_SUCCESS
+ifdef TX_POWER_MAX
+	jam TX_POWER_5DB,mem_tx_power
+else
+	call power_ctrl_start
+endif	
+p_g24_short_sleep:
+	fetch 1,mem_mouse_retry_flag
+	nrtn blank
+	call p_check_IPC_for_LPM
+	nrtn user
+	fetch 1,mem_c51_lpm_lock
+	nrtn blank
+	call lpo_calibration
+	fetch 3,mem_clks_per_lpo
+	rtn blank
+	fetch 1,mem_lpm_mode
+	rtn blank
+p_g24_short_sleep_1:	
+	//setarg 0x120000
+	//setarg 0x0a0000
+	fetch 3,mem_24g_short_sleep_counter	
+p_g24_short_sleep_2:	
+	call clk2lpo
+ 	storet 4,mem_sleep_counter
+ 	branch lpm_sleep
+
+p_g24_long_sleep:
+	call p_check_IPC_for_LPM
+	nrtn user
+	fetch 1,mem_c51_lpm_lock
+	nrtn blank
+	call lpo_calibration
+	fetch 3,mem_clks_per_lpo
+	rtn blank
+	fetch 1,mem_lpm_mode
+	rtn blank
+	fetch 1,mem_24g_enter_lpm_timer
+	nbranch p_g24_short_sleep_1,blank	
+	fetch 4,mem_24g_enter_hibernate_setup
+  	branch p_g24_short_sleep_2
+
+p_g24_txdata_prep:
+	fetch 1,mem_24g_pairing_sm
+	bne STATE_24G_PAIRING_SUCCESS,p_g24_pairing_sm	
+ifdef OTA_ENABLE
+	fetch 1,mem_24g_ota_enable
+	beq 1,p_g24_txdata_skip_short_lpm
+endif	
+	call p_g24_package_data
+	call p_g24_get_package_data,user
+	call p_g24_transmit_prep,user
+p_g24_txdata_enable_tx:
+	jam ENSURE_ON_24G,mem_24g_ensure
+	rtn
+
+p_g24_package_data:
+	disable user
+	jam 2,mem_24g_data_type
+	fetch 1,mem_24g_txbuf_new
+	beq 0x04,p_g24_dataready			
+	beq 0x05,p_g24_dataready_mk	
+	beq 0x07,p_g24_dataready_ms
+	beq 0x06,p_g24_dataready_sys
+	fetch 1,mem_mouse_retry_flag
+	ncall enable_user,blank
+	rtn
+p_g24_dataready:				
+	jam 0x00,mem_24g_txbuf_new				//standard key 0x00
+	jam 10,mem_24g_datalen		// 02 + 00 + 8 payload
+	branch p_g24_package_data_rtn
+p_g24_dataready_mk:			
+	jam 0x03,mem_24g_txbuf_new				//multi key 0x03
+	jam 4,mem_24g_datalen		// 02 + 03 + 2 payload
+	branch p_g24_package_data_rtn
+p_g24_dataready_sys:
+	jam 0x02,mem_24g_txbuf_new				//system key 0x02
+	jam 3,mem_24g_datalen		// 02 + 02 + 1 payload
+	branch p_g24_package_data_rtn
+p_g24_dataready_ms:
+	jam 1,mem_24g_data_type		// mouse
+	jam 8,mem_24g_datalen		// 01 + 7 payload
+p_g24_package_data_rtn:	
+	jam 0,mem_24g_get_ack_fail
+	branch enable_user
+
+
+p_g24_get_package_data:
+	fetch 9,mem_24g_txbuf_new
+	store 9,mem_24g_txbuf
+//	setarg 0
+//	store 9,mem_24g_txbuf_new
+	rtn
+
+
+p_g24_transmit_packet:
+	jam 0,mem_24g_retry
+p_g24_transmit_loop:
+	arg param_rx_setup,timeup
+	until clkn_rt,meet
+	call p_g24_transmit_receive_ack
+	nbranch p_g24_retransmit,user3
+	call p_g24_ackpayload_parse
+ifndef TX_POWER_MAX	
+	call power_ctrl_pac_succ_incrs
+endif	
+	fetch 1,mem_24g_pid
+	increase 1,pdata
+	store 1,mem_24g_pid
+	jam 0,mem_mouse_retry_flag
+	fetch 1,mem_24g_pairing_sm
+	bne STATE_24G_PAIRING_SUCCESS,p_g24_paring_mode_start
+p_g24_transmit_abandon:
+	call p_g24_clear_txbuf
+	jam 0,mem_24g_get_ack_fail
+	jam ENSURE_OFF_24G,mem_24g_ensure
+	rtn
+
+
+p_g24_retransmit:
+	jam 1,mem_mouse_retry_flag
+	fetch 1,mem_24g_get_ack_fail
+	increase 1,pdata
+	store 1,mem_24g_get_ack_fail
+	fetch 1,mem_24g_pairing_sm
+	bne STATE_24G_PAIRING_SUCCESS,p_g24_tx_paring_retry
+	fetch 1,mem_24g_get_ack_fail
+	beq  0xff,p_g24_stop_g24_mode
+	fetch 1,mem_24g_get_ack_fail
+	arg 16,temp
+	isub temp,null
+	branch p_g24_ch,positive
+	fetch 1,mem_24g_retry
+	increase 1,pdata
+	store 1,mem_24g_retry
+	nop 10
+	bne retry_24g,p_g24_transmit_loop
+	branch p_g24_ch
+	
+
+p_g24_clear_txbuf:
+	setarg 0
+	store 9,mem_24g_txbuf
+	store 9,mem_24g_txbuf_new
+	rtn
+
+/*
+p_g24_long_sleep_setup:
+	jam 0,mem_mouse_retry_flag
+	call p_g24_clear_txbuf
+	jam 0,mem_24g_get_ack_fail
+	fetch 4,mem_24g_enter_hibernate_max
+	store 4,mem_24g_enter_hibernate
+	rtn
+*/
+
+p_g24_paring_mode_start:
+ifndef TX_POWER_MAX
+	call power_ctrl_pac_succ_cnt_init
+endif	
+	branch p_g24_paring_mode
+
+p_g24_transmit_receive_ack:
+	disable user3
+	call p_g24_transmit
+//	fetch 1,mem_24g_no_ack
+//	beq no_ack_24g,p_g24_transmit_no_ack	//tx no ack
+	force 0,radio_ctrl
+	fetch 4,mem_24g_addr
+	iforce access
+	fetcht 1,mem_last_freq
+	call set_freq_rx
+	call rf_rx_enable
+	call p_g24_receive_rxon
+	call p_g24_end_of_packet,user3
+	rtn
+//p_g24_transmit_no_ack:
+//	jam 0,mem_24g_rxbuf+1
+//	enable user3
+//	branch p_g24_end_of_packet
+
+
+p_g24_tx_paring_retry:
+	jam 0,mem_mouse_retry_flag
+	rtn
+//	fetch 1,mem_24g_get_ack_fail
+//	rtnne 0xff
+//	jam 0,mem_24g_get_ack_fail
+p_g24_stop_g24_mode:
+	jam 0,mem_mouse_retry_flag
+	jam BT_EVT_24G_ATTEMPT_FAIL,mem_fifo_temp
+	branch ui_ipc_send_event
+
+
+p_g24_ackpayload_parse:
+	call p_g24_read_len_pid_crc
+	fetch 1,mem_24g_rxbuf
+	rtnne 0x02					// mem_24g_data_type : 0x02 keyboard	
+	fetch 1,mem_24g_rxdata_length	//ack payload length 
+	rtn blank
+	iforce loopcnt
+	arg mem_24g_rxbuf+2,contr
+	arg mem_24g_rxpayload,contw	//ack payload buffer 
+	call memcpy
+	fetch 1,mem_24g_rxbuf+1
+	compare 0x08,pdata,0xf8
+	nrtn true
+	fetch 1,mem_24g_rxbuf+2
+	beq 0xff,p_pc_sleep_mode	//pc enter sleep mode
+	store 1,mem_caps_num_lock
+//	jam 0,mem_24g_led_flag
+	rtn
+
+p_pc_sleep_mode:
+	jam 1,mem_pc_sleep_flag
+	rtn
+	
+
+ifndef TX_POWER_MAX
+power_ctrl_pac_succ_cnt_init:
+	jam 1,mem_power_ctrl_level
+	jam 0,mem_power_ctrl_pac_succ_cnt
+	rtn
+power_ctrl_pac_succ_incrs:
+	fetch 1,mem_power_ctrl_pac_succ_cnt
+	increase 1,pdata
+	store 1,mem_power_ctrl_pac_succ_cnt
+	rtn
+/*
+power_ctrl_pac_succ_decrs:
+	fetch 1,mem_power_ctrl_pac_succ_cnt
+	sub pdata,1,null
+	ncall power_ctrl_pac_succ_cnt_reinit,positive
+	fetch 1,mem_power_ctrl_pac_succ_cnt
+	rtneq 0
+	increase -1,pdata
+	store 1,mem_power_ctrl_pac_succ_cnt
+	rtn
+power_ctrl_pac_succ_cnt_reinit:
+	jam 2,mem_power_ctrl_pac_succ_cnt
+	rtn
+*/
+power_ctrl_start:
+	arg mem_rssi_signal_buf,rega
+	call p_rssi_average
+	storet 1,mem_rssi_avg_received
+	setarg RSSI_DIS_MAX_24G
+	bmark1 mark_24g,power_ctrl_start_next
+	setarg RSSI_DIS_MAX_BLE
+power_ctrl_start_next:	
+	isub temp,null
+	nbranch power_ctrl_txpower_incrs,positive
+
+	fetch 1,mem_power_ctrl_pac_succ_cnt
+	sub pdata,1,null
+	nbranch power_ctrl_txpower_decrs_check,positive
+	fetch 1,mem_power_ctrl_pac_succ_cnt
+	beq 0,power_ctrl_txpower_incrs
+	rtn
+	
+power_ctrl_txpower_decrs_check:
+	fetch 1,mem_power_ctrl_pac_succ_cnt
+	rtnne 70
+	jam 0,mem_power_ctrl_pac_succ_cnt
+power_ctrl_txpower_decrs:
+	fetcht 1,mem_rssi_avg_received
+	setarg RSSI_DIS_MIN_24G
+	bmark1 mark_24g,power_ctrl_txpower_decrs_next
+	setarg RSSI_DIS_MIN_BLE	
+power_ctrl_txpower_decrs_next:
+	isub temp,null
+	nrtn positive
+	fetch 1,mem_power_ctrl_level
+	beq 0,power_ctrl_decrs_level0
+	increase -1,pdata
+	store 1,mem_power_ctrl_level
+	beq 0,power_ctrl_decrs_level0
+power_ctrl_decrs_level1:
+power_ctrl_incrs_level1:	//0dBm
+	jam TX_POWER_0DB,mem_tx_power
+	rtn
+	
+power_ctrl_txpower_incrs:
+	fetch 1,mem_power_ctrl_level
+	beq 2,power_ctrl_incrs_level2
+	increase 1,pdata
+	store 1,mem_power_ctrl_level
+	beq 1,power_ctrl_incrs_level1
+	
+power_ctrl_incrs_level2:	//+6dBm
+	jam TX_POWER_5DB,mem_tx_power
+	rtn
+	
+power_ctrl_decrs_level0: //-5dBm
+	jam TX_POWER_f5DB,mem_tx_power
+	rtn
+
+
+
+p_rssi_average:
+	arg 0,temp
+	arg RSSI_BUF_LEN_SIGNAL+1,loopcnt
+	copy rega,contr
+p_rssi_average_loop:
+	ifetch 1,contr
+	iadd temp,temp
+	loop p_rssi_average_loop
+	rshift3 temp,temp
+	copy pdata,temp
+	rtnmark0 mark_24g
+	//2BCD
+	div pdata,10
+	call wait_div_end
+	quotient pdata
+	lshift4 pdata,pdata
+	remainder temp
+	ior temp,temp
+	rtn
+endif
+	
+p_g24_start_pairing_sm1:
+	set1 mark_24g,mark
+	call p_g24_pair_init
+	call p_g24_transmit_abandon
+	jam STATE_24G_PAIRING_1,mem_24g_pairing_sm
+	rtn
+
+p_g24_pair_init:
+	jam 0,mem_24g_pid
+	jam G24_PAIR_CH,mem_24g_ch
+	fetch 4,mem_24g_paring_addr
+	branch p_g24_update_addr_and_synccrc8
+
+p_g24_pairing_sm:
+	call p_g24_pair_init
+	fetch 1,mem_24g_ensure
+	beq ENSURE_ON_24G,enable_user
+	fetch 1,mem_24g_pairing_sm
+	beq STATE_24G_PAIRING_1,p_g24_pairing_sm_1
+	beq STATE_24G_PAIRING_2,p_g24_pairing_sm_2
+	beq STATE_24G_PAIRING_3,p_g24_pairing_sm_3
+	branch assert
+
+p_g24_pairing_sm_1:
+	jam STATE_24G_PAIRING_1_WAITING_ACK,mem_24g_pairing_sm
+	jam 0xaa,mem_24g_common_temp
+	branch p_g24_pairing_sm_common
+p_g24_pairing_sm_2:
+	jam STATE_24G_PAIRING_2_WAITING_ACK,mem_24g_pairing_sm
+	jam 0x55,mem_24g_common_temp
+	branch p_g24_pairing_sm_common
+p_g24_pairing_sm_3:
+	jam STATE_24G_PAIRING_3_WAITING_ACK,mem_24g_pairing_sm
+	jam 0x22,mem_24g_common_temp
+p_g24_pairing_sm_common:
+	//fetch 1,mem_24g_data_type
+	//and_into bits_data,pdata
+	//store 1,mem_24g_common_temp+1
+	jam 0x02,mem_24g_common_temp+1	// mem_24g_data_type: 02 keyboard
+	fetch 4,mem_24g_device_addr
+	store 4,mem_24g_common_temp+2
+	jam 0,mem_24g_common_temp+6
+	arg mem_24g_common_temp,rega
+	arg 7,temp
+	call p_g24_put_data_in_buff
+	call p_g24_transmit_prep
+	call p_g24_txdata_enable_tx
+	branch enable_user
+
+p_g24_paring_mode:
+	fetch 1,mem_24g_pairing_sm
+	rtneq STATE_24G_PAIRING_SUCCESS
+	beq STATE_24G_PAIRING_1_WAITING_ACK,p_g24_pairing_sm_1_waiting_ack
+	beq STATE_24G_PAIRING_2_WAITING_ACK,p_g24_pairing_sm_2_waiting_ack
+	beq STATE_24G_PAIRING_3_WAITING_ACK,p_g24_pairing_sm_3_waiting_ack
+	rtn
+
+
+p_g24_pairing_sm_1_waiting_ack:
+	jam STATE_24G_PAIRING_2,mem_24g_pairing_sm
+	branch p_g24_transmit_abandon
+p_g24_pairing_sm_2_waiting_ack:
+	jam STATE_24G_PAIRING_3,mem_24g_pairing_sm
+	branch p_g24_transmit_abandon
+p_g24_pairing_sm_3_waiting_ack:
+	jam STATE_24G_PAIRING_SUCCESS,mem_24g_pairing_sm
+	jam BT_EVT_24G_PAIRING_COMPLETE,mem_fifo_temp
+	call ui_ipc_send_event	
+	fetch 4,mem_24g_rxpayload+2
+	call p_g24_update_addr_and_synccrc8
+	branch p_g24_transmit_abandon
+
+p_g24_start_24g_mode:
+//	rtnmark1 mark_24g
+	set1 mark_24g,mark
+	call p_g24_syncword_crc8
+	call p_g24_ch
+	fetch 1,mem_24g_pairing_sm
+	rtnne STATE_24G_PAIRING_SUCCESS
+	call p_g24_tx_attemp_data_prep
+	setarg 0
+	store 2,mem_24g_check_dongle_times
+p_g24_tx_attemp_dongle_loop:
+	call lpo_calibration
+	nop 2000
+	fetch 1,mem_24g_check_dongle_times
+	beq 0xff,p_g24_stop_g24_mode	//
+	call p_g24_transmit_receive_ack
+	nbranch p_g24_attemp_txdata_retry,user3
+p_g24_tx_attemp_dongle_succ:
+	call p_g24_clear_txbuf
+	set1 mark_24g,mark
+	jam BT_EVT_24G_ATTEMPT_SUCCESS,mem_fifo_temp
+	branch ui_ipc_send_event
+
+
+p_g24_tx_attemp_data_prep:
+	jam 0xff,mem_24g_common_temp
+	fetch 1,mem_24g_data_type
+	store 1,mem_24g_common_temp+1
+	fetch 4,mem_24g_device_addr
+	store 4,mem_24g_common_temp+2
+	arg 6,temp
+	arg mem_24g_common_temp,rega
+	call p_g24_put_data_in_buff
+	branch p_g24_transmit_prep
+	
+p_g24_attemp_txdata_retry:
+	fetch 2,mem_24g_check_dongle_times
+	increase 1,pdata
+	store 2,mem_24g_check_dongle_times
+	call p_g24_ch
+	branch p_g24_tx_attemp_dongle_loop
+
+
+p_g24_put_data_in_buff:
+	storet 1,mem_24g_datalen
+	copy temp,loopcnt
+	arg mem_24g_txbuf,contw
+	copy rega,contr
+	branch memcpy
+
+p_g24_read_len_pid_crc:
+//read control
+	fetch 1,mem_24g_rxbuf+1
+	rshift3 pdata,pdata
+	store 1,mem_24g_rxdata_length
+//get crc
+	increase 1,pdata
+	arg mem_24g_rxbuf+1,contr
+	iadd contr,contr
+	ifetch 3,contr
+	store 3,mem_24g_sta_crc
+	rtn
+
+p_rssi_signal:
+	fetcht 1,mem_rssi_signal_index
+	setarg mem_rssi_signal_buf
+	iadd temp,contw
+	copy rega,pdata
+	istore 1,contw
+	increase 1,temp
+	and_into RSSI_BUF_LEN_SIGNAL,temp
+	storet 1,mem_rssi_signal_index
+	rtn
+
+//p_rssi_noise:
+//	call save_rssi
+//	rtn blank
+//	fetcht 1,mem_rssi_noise_index
+//	arg mem_rssi_noise_buf,rega
+//	call p_rssi_store
+//	storet 1,mem_rssi_noise_index
+//	rtn
+//	
+//p_rssi_store:
+//	copy rega,pdata
+//	iadd temp,contw
+//	fetch 1,mem_rssi
+//	istore 1,contw
+//	increase 1,temp
+//	and_into RSSI_BUF_LEN_SIGNAL,temp
+//	rtn
+
+p_g24_update_addr_and_synccrc8:	
+	store 4,mem_24g_addr
+
+//output: 1BYTE crc8
+p_g24_syncword_crc8:
+	arg 0,rega
+	arg 4,loopcnt
+	arg mem_24g_addr,contr
+p_g24_syncword_crc8_loop:
+	ifetch 1,contr
+	iadd rega,rega
+	loop p_g24_syncword_crc8_loop
+	copy rega,pdata
+	store 2,mem_24g_syncword
+	fetch 1,mem_24g_syncword
+	fetcht 1,mem_24g_syncword+1
+	iadd temp,pdata
+	store 1,mem_24g_syncword_crc8
+	rtn
+
+
+p_g24_transmit_prep:
+// total length
+	fetch 1,mem_24g_datalen
+	increase 2,pdata
+	store 1,mem_24g_txlen
+// data type
+	fetch 1,mem_24g_data_type
+	store 1,mem_24g_txpayload
+//prepare 5bit payload length, 2bit PID, 1bit NO_ACK
+	fetch 1,mem_24g_datalen
+	lshift3 pdata,pdata
+	fetcht 1,mem_24g_pid
+	and temp,0x03,temp
+	lshift temp,temp
+	ior temp,pdata
+	fetcht 1,mem_24g_no_ack
+	iadd temp,pdata
+	istore 1,contw
+//prepare payload data
+	fetch 1,mem_24g_pairing_sm
+	bne STATE_24G_PAIRING_SUCCESS,p_g24_transmit_prep_pair
+	fetch 1,mem_24g_data_type
+	istore 1,contw
+p_g24_transmit_prep_pair:	
+	fetch 1,mem_24g_datalen
+	iforce loopcnt
+	fetch 1,mem_24g_data_type
+	beq 1,p_g24_transmit_prep_mouse
+	arg mem_24g_txbuf,contr
+	call memcpy
+// type == 2 && mem_24g_txbuf[0] == 0x03  : multi	
+// type == 1 && mem_24g_txbuf[0] == 0x03  : mouse
+// if transmit fail,next package will send mouse data
+	fetch 1,mem_24g_txbuf	
+	beq 0x03,p_g24_multi_key_setup
+	rtn
+p_g24_multi_key_setup:
+	jam 0x02,mem_24g_txbuf
+	rtn
+
+
+p_g24_transmit_prep_mouse:
+	arg mem_24g_txbuf+1,contr
+	branch memcpy
+
+p_g24_ch:
+	fetcht 1,mem_24g_current_ch_number
+	call p_g24_ch_calc
+	increase 1,temp
+	and_into 3,temp //map size =4
+	storet 1,mem_24g_current_ch_number
+	rtn
+
+p_g24_ch_calc:
+	fetch 1,mem_24g_addr	
+	and_into 0x03,pdata
+	mul32 pdata,4,rega			//24addr low bit0 bit1 ,00-map1,01-map2,10-map3,11-map4
+	setarg mem_24g_ch_map1
+	iadd rega,pdata
+	iadd temp,contr
+	ifetch 1,contr
+	store 1,mem_24g_ch
+	rtn
+
+p_g24_prep:
+	disable enable_crc
+	disable enable_white
+	setarg 0x555555
+	iforce crc24_init
+	fetch 1,mem_24g_ch
+	reverse pdata,temp
+	set1 1,temp
+	rshift temp,white_init
+	rtn
+
+p_g24_receive_rxon:
+	call p_g24_prep
+	enable decode_fec0	
+	enable is_rx
+	disable is_tx
+	enable swfine
+	fetch 2,mem_24g_rx_window
+	iforce stop_watch
+	correlate null,timeout
+	nbranch p_g24_sync_timeout,sync
+	disable decode_fec0
+	enable decode_fec1
+	enable enable_white
+	enable enable_crc
+	parse demod,bucket,8
+	rshift3 pwindow,pdata
+	store 1,mem_24g_get_syncword_crc8
+	fetcht 1,mem_24g_syncword_crc8
+	isub temp,null
+	nbranch p_g24_end_of_packet,zero
+	parse demod,bucket,8
+	rshift3 pwindow,pdata
+	store 1,mem_24g_rxbuf	//device id
+//	fetch 1,mem_24g_mode
+//	sub pdata,rx_24g,null
+//	branch p_g24_receive_skip,zero
+	fetch 1,mem_24g_rxbuf
+	fetcht 1,mem_24g_data_type
+	icompare bits_data,temp
+	nbranch p_g24_end_of_packet,true
+p_g24_receive_skip:
+	parse demod,bucket,8
+	rshift3 pwindow,pdata
+	istore 1,contw
+	rshift3 pdata,pdata
+	and pdata,0x1f,loopcnt	//max payload: 32bytes
+	branch p_g24rx_nopayload,zero
+p_g24rx_loop:
+	parse demod,bucket,8
+	rshift3 pwindow,pdata
+	istore 1,contw
+	loop p_g24rx_loop
+p_g24rx_nopayload:
+	//receive rssi hex
+	copy contw,rega
+	parse demod,bucket,8
+	rshift3 pwindow,pdata
+	store 1,mem_rssi_hex_received
+	copy rega,contw
+	parse demod,bucket,24
+	enable swfine
+	arg param_sifs,stop_watch	
+	rshift32 pdata,pdata
+	rshift16 pdata,pdata
+	istore 3,contw
+	disable decode_fec1
+	branch p_g24_end_of_packet,crc_failed
+	enable user3
+	fetch 1,mem_last_freq
+	add pdata,0,rega
+	call rf_write_freq
+	disable decode_fec0
+	call set_sync_on
+	fetch 1,mem_rssi_hex_received
+	copy pdata,rega
+	branch p_rssi_signal
+	
+
+p_g24_sync_timeout:
+//	call p_rssi_noise
+//	branch p_g24_end_of_packet
+p_g24_end_of_packet:
+	disable encode_fec1
+	disable decode_fec1
+	branch end_of_packet
+
+p_g24_set_freq_tx:
+	call set_sync_on
+	fetcht 1,mem_24g_ch
+	branch set_freq_tx
+
+p_g24_transmit:
+	call le_enable
+	fetch 4,mem_24g_addr
+	iforce access
+	call p_g24_prep
+	call p_g24_set_freq_tx
+	set1 TXGFSK,radio_ctrl
+	enable encode_fec0
+	enable is_tx
+	disable is_rx
+	rshift16 access,pdata
+	rshift8 pdata,pdata
+	rshift4 pdata,pdata
+	inject mod,40
+	disable encode_fec0
+	enable encode_fec1
+	enable enable_white
+	enable enable_crc
+	fetch 1,mem_24g_syncword_crc8
+	inject mod,8
+	fetch 1,mem_24g_txlen
+	iforce loopcnt
+	arg mem_24g_txpayload,contr
+p_g24tr_loop:
+	ifetch 1,contr
+	inject mod,8
+	loop p_g24tr_loop
+	enable enable_parity
+	inject mod,24	//crc
+	disable enable_parity
+	until null,tx_clear
+	nop 100
+	disable encode_fec0
+	disable encode_fec1
+	branch set_sync_on
+
+
+endif
+
+ifdef GPIO_TEST_01	
+p_test_gpio_blink:
+	fetch 1,mem_24g_txfail_cnt
+	branch p_test_io_on,blank
+	branch p_test_io_off
+
+p_test_io_on:
+	jam 1,mem_24g_txfail_cnt
+	arg 0x10,temp
+	branch gpio_out_active
+p_test_io_off:
+	jam 0,mem_24g_txfail_cnt
+	arg 0x10,temp
+	branch gpio_out_inactive
+endif
+	
Index: btkb/program/peripherals.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/peripherals.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/peripherals.prog	(working copy)
@@ -0,0 +1,1330 @@
+
+/* ===================== two wire SPI gpio ======================= */
+
+twspi_reset:
+	set0 mark_ext_patch,mark
+	bpatch patch1f_6,mem_patch1f
+	hfetch 1,core_gpio_oe3
+	arg 0x06,temp
+	ior temp,pdata
+	hstore 1,core_gpio_oe3
+	hfetch 1,core_gpio_out3
+	ior temp,pdata
+	hstore 1,core_gpio_out3
+	hjam 0,core_gpio_sel1	
+	hfetch 1,core_gpio_out3
+	set0 1,pdata
+	set0 2,pdata
+	hstore 1,core_gpio_out3	
+	nop 30
+	hjam 1,core_gpio_sel1	
+	rtn
+twspi_write:
+	branch spid_write_reg
+
+twspi_read:
+	branch spid_read_reg
+
+
+
+/* ===================== code loading ======================= */
+
+
+read_function_aes:
+	nbranch read_function,user
+	hfetch 1,core_gpio_key2
+	or_into 0x20,pdata   	// enable aes 
+	hstore 1,core_gpio_key2
+read_function:
+	copy temp,null
+	branch read_fuction_zero,zero
+	copy regc,pc
+read_fuction_zero:
+	isolate0 0,null
+	branch set_ucode_status
+	
+/* return temp = block length */
+get_block_header:
+	force 4,temp
+get_block_header0:
+	arg mem_ucode_buf,rega
+	hfetch 1,core_gpio_key2
+	and_into 0xdf,pdata   	// disable aes for header
+	hstore 1,core_gpio_key2
+	call read_function
+	arg 0x55aa,rega
+	fetch 2,mem_ucode_buf
+	ifetcht 2,contr
+	isub rega,null
+	rtn	
+
+read_first_block:
+	arg 2,temp
+	arg mem_ucode_ptr,rega
+	call read_function
+	fetch 2,mem_ucode_ptr
+	store 2,mem_addr_mi
+	call get_iv,user
+	rtn
+	
+get_iv:
+	arg 16,temp
+	arg mem_ucode_keybuf,rega
+	hfetch 1,core_gpio_key2
+	and_into 0xdf,pdata   // disable aes for iv
+	hstore 1,core_gpio_key2
+	call read_function
+	arg mem_ucode_keybuf,contr
+	arg 16,loopcnt
+	call aes_load_data
+	call aes_init
+	call aes_clear_data
+	branch do_aes_cbc					/* generate first IV */
+
+load_storage:
+	disable match
+	call get_block_header
+	nrtn zero
+	enable match
+	hjam 0x80, core_ucode_ctrl
+	hjam 0,core_ucode_hi
+	hjam 0,core_ucode_low
+	arg core_ucode_data,rega
+	call read_function_aes
+	hjam 0x0, core_ucode_ctrl
+	call get_block_header
+	nrtn zero
+	force 0,pdata
+	hstore 2,core_docd_paddr
+	arg core_docd_pdata,rega
+	call read_function_aes
+load_storage_loop:
+	arg 6,temp
+	call get_block_header0
+	nrtn zero
+	ifetch 2,contr
+	iforce rega
+	call read_function
+	branch load_storage_loop
+
+
+
+	
+	/* only load memory data from eeprom */
+reload_eeprom:
+	call clean_mem
+	setarg 0x1000
+	store 2,mem_addr_mi
+	arg iicd_read_eep,regc
+	arg 2,loopcnt
+reload_eeprom_loop:
+	call get_block_header
+	nrtn zero
+	fetch 2,mem_addr_mi
+	byteswap pdata,pdata
+	iadd temp,pdata
+	byteswap pdata,pdata
+	store 2,mem_addr_mi
+	loop reload_eeprom_loop
+	branch load_storage_loop
+	
+loadcode:
+	hjam 0x25,core_clkoff			// disable debug uart
+	hjam 5,core_docd_ctrl
+	call clean_mem
+loadcode_lpm:
+	disable user
+	call otp_enable_chgpump
+	setarg otp_ucode_flag
+	arg mem_otp_ucode_flag,rega
+	arg 2,temp
+	call otpd_read_data
+	fetch 2,mem_otp_ucode_flag
+	bbit0 otp_uflag_aes, loadcode_otp
+	setarg otp_ucode_aeskey
+	arg mem_ucode_keybuf,rega
+	arg 16,temp
+	call otpd_read_data
+	hjam lock_otp,core_misc_ctrl	// disable further read/write of key
+	arg mem_ucode_keybuf,contr
+	call load_key
+	enable user					// set user for aes
+loadcode_otp:
+	fetch 2,mem_otp_ucode_flag
+	byteswap pdata,pdata
+	arg 0x7ff,temp
+	iand temp,pdata
+	branch loadcode_spi, zero
+	call otp_set_addr
+	arg otpd_read_code,regc
+	call get_iv,user
+	call load_storage
+	fetch 1,mem_ucode_status
+	compare 3,pdata,3
+	nbranch loadcode_otp,true	// crc error, try again
+loadcode_spi:
+	call otp_disable_chgpump
+	fetch 1,mem_otp_ucode_flag
+	bbit1 otp_uflag_skip_flash, loadcode_iic
+	setarg 0x0
+	store 3,mem_addr_hi
+	call spid_init_flash
+	arg spid_read_flash,regc
+	call read_first_block
+	call load_storage
+	nbranch loadcode_iic,match
+	fetch 1,mem_ucode_status
+	compare 3,pdata,3
+	nbranch loadcode_spi,true	// crc error, try again
+loadcode_iic:
+	fetch 1,mem_otp_ucode_flag
+	bbit1 otp_uflag_skip_eep,loadcode_hci
+	setarg 0x0
+	store 2,mem_addr_mi
+	arg iicd_read_eep,regc
+	call iicd_init_12m
+	call read_first_block
+	call load_storage
+	nbranch loadcode_hci,match
+	fetch 1,mem_ucode_status
+	compare 3,pdata,3
+	nbranch loadcode_iic,true	// crc error, try again
+loadcode_hci:
+	hjam 0x21,core_clkoff			// enable debug uart
+	fetch 1,mem_otp_ucode_flag
+	rtnbit0 otp_uflag_hci
+	call hci_init
+loadcode_hci_loop:
+	call hci_rx_packet
+	branch loadcode_hci_loop
+
+/* true flag is set into status */
+set_ucode_status:
+	fetch 1,mem_ucode_status
+	lshift pdata,pdata
+	setflag true,0,pdata
+	isolate0 15,rega
+	rtn true
+	store 1,mem_ucode_status
+	rtn
+
+	/* queue is bit position of hw done status */
+decrypt_code:
+	hfetch 1,core_gpio_key2
+	rtnbit0 5
+	branch decrypt_code_skip	/* skip to key generation at first for speed */
+decrypt_code_loop:
+	hfetch 1,core_dma_status
+	qisolate1 pdata
+	rtn true
+decrypt_code_skip:
+	hfetch 1,core_misc_status
+	bbit0 1,decrypt_code_loop
+	call do_aes_cbc
+	branch decrypt_code_loop
+
+
+	/* loopcnt is ucode instruction count, pdata is buffer ptr */
+save_ucode:
+	copy loopcnt,temp
+	storet 2,mem_patch_len
+	hjam 0x80, core_ucode_ctrl
+	hjam 0,core_ucode_hi
+	hjam 0,core_ucode_low
+	store 2,mem_patch_ptr
+	iforce contw
+	lshift2 loopcnt,loopcnt
+save_ucode_loop:
+	hfetch 1,core_ucode_data
+	istore 1,contw
+	loop save_ucode_loop
+	hjam 0x0, core_ucode_ctrl
+	rtn
+
+load_ucode:
+	fetch 2,mem_patch_ptr
+	rtn blank
+	hjam 0x80, core_ucode_ctrl
+	hjam 0,core_ucode_hi
+	hjam 0,core_ucode_low
+	fetcht 2,mem_patch_len
+	lshift2 temp,loopcnt
+	iforce contr
+load_ucode_loop:
+	ifetch 1,contr
+	hstore 1,core_ucode_data
+	loop load_ucode_loop
+	hjam 0x0, core_ucode_ctrl
+	rtn
+
+
+/* ===================== SPI dma ======================= */
+
+spid_init:
+	set0 mark_ext_patch,mark
+	bpatch patch1f_7,mem_patch1f
+	hjam 0x75,core_spid_ctrl	// A7530 should at least 34, or write fail
+	hjam 10,core_spid_delay	// 4us delay
+	setarg mem_spid_tbuf
+	hstore 2,core_spid_txaddr
+	setarg mem_spid_rbuf
+	hstore 2,core_spid_rxaddr
+	hfetch 1,core_gpio_sel1
+	set1 0,pdata
+	set0 1,pdata
+	hstore 1,core_gpio_sel1
+	rtn
+
+spid_reset:
+	hfetch 1,core_spid_ctrl
+	set1 7,pdata
+	hstore 1,core_spid_ctrl
+	set0 7,pdata
+	hstore 1,core_spid_ctrl
+	rtn
+
+
+/* pdata 6:0 is reg address, 15:8 is data to write */
+spid_write_reg:
+	set1 7,pdata
+	store 2,mem_spid_tbuf
+	set1 mark_ext_patch,mark
+	bpatch patch20_0,mem_patch20
+	hjam 2,core_spid_txlen
+	hjam 0,core_spid_rxlen
+	hjam spid_start,core_misc_ctrl
+	branch wait_spid_done
+
+/* pdata 6:0 is reg address */
+spid_read_reg:
+	force 1,temp
+/* pdata 6:0 is burst reg address, temp is bytes to read */
+spid_read_regs:
+//	nop 100
+	store 1,mem_spid_tbuf
+	set1 mark_ext_patch,mark
+	bpatch patch20_1,mem_patch20
+	hjam 1,core_spid_txlen
+	hstoret 2,core_spid_rxlen
+	hjam spid_start,core_misc_ctrl
+	call wait_spid_done
+	fetch 1,mem_spid_rbuf
+	rtn
+
+wait_spid_done:
+	fetch 2,mem_afh_error_total
+	increase 1,pdata
+	store 2,mem_afh_error_total
+	hfetch 1,core_dma_status
+	bbit0 spid_done,wait_spid_done
+	rtn
+
+spid_init_flash:
+	hjam 0x40,core_spid_ctrl
+	hjam 0x0,core_spid_delay
+	hfetch 1,core_gpio_sel1
+	set0 0,pdata
+	set1 1,pdata
+	hstore 1,core_gpio_sel1
+	setarg 0
+	store 4,mem_spid_tbuf
+	rtn
+
+spid_unlock_flash:
+	setarg 0
+	hstore 2,core_spid_rxlen
+	setarg 1
+	hstore 1,core_spid_txlen
+	setarg mem_spid_tbuf
+	hstore 2,core_spid_txaddr
+	jam 6,mem_spid_tbuf
+	hjam spid_start,core_misc_ctrl
+	branch wait_spid_done
+
+
+	/* pdata is flash address, rega pointers to txdata(4 ahead bytes should be left), temp is length */
+spid_write_flash:
+	increase 4,temp
+	hstoret 2,core_spid_txlen
+	increase -4,rega
+	arg 2,temp
+	istoret 1,rega
+	rshift16 pdata,temp
+	istoret 1,contw
+	rshift8 pdata,temp
+	istoret 1,contw
+	istore 1,contw
+	deposit rega
+	hstore 2,core_spid_txaddr
+	setarg 0
+	hstore 2,core_spid_rxlen
+	hjam spid_start,core_misc_ctrl
+	branch wait_spid_done
+	
+
+/* temp is length, rega pointers to buf */
+spid_read_flash:
+	hstoret 2,core_spid_rxlen
+	setarg 4
+	hstore 2,core_spid_txlen
+	jam 3,mem_spid_tbuf
+	setarg mem_spid_tbuf
+	hstore 2,core_spid_txaddr
+	deposit rega
+	hstore 2,core_spid_rxaddr
+	hfetch 1,core_spid_ctrl
+	isolate0 15,rega
+	setflag true,6,pdata
+	hstore 1,core_spid_ctrl
+	hjam spid_start,core_misc_ctrl
+spi_read_flash_wait:
+	hfetch 1,core_dma_status
+	bbit1 7,spi_read_flash_wait			// waiting for spid write
+	arg spid_done,queue
+	call decrypt_code
+	call wait_spid_done
+	isolate1 spid_crcok,pdata
+	call set_ucode_status
+	fetch 1,mem_addr_hi
+	lshift16 pdata,regb
+	fetch 1,mem_addr_mi
+	lshift8 pdata,pdata
+	ior regb,regb
+	fetch 1,mem_addr_lo
+	ior regb,pdata
+	iadd temp,pdata
+	store 1,mem_addr_lo
+	rshift8 pdata,pdata
+	store 1,mem_addr_mi
+	rshift8 pdata,pdata
+	store 1,mem_addr_hi
+	rtn
+
+
+/* ===================== I2C dma ======================= */
+iicd_init_5m:
+	hjam 0xa,core_clksel			// use 5M rc clock to load eeprom
+	hjam 2,core_iicd_scl_low
+ 	hjam 3,core_iicd_scl_high
+	hjam 3,core_iicd_start_setup
+	hjam 3,core_iicd_start_hold
+	hjam 3,core_iicd_stop_setup
+	hjam 2,core_iicd_data_setup
+	rtn
+
+iicd_init_12m:
+	hjam 5,core_iicd_scl_low
+ 	hjam 7,core_iicd_scl_high
+	hjam 7,core_iicd_start_setup
+	hjam 7,core_iicd_start_hold
+	hjam 7,core_iicd_stop_setup
+	hjam 5,core_iicd_data_setup
+	rtn
+
+
+
+wait_iicd_done:
+	hfetch 1,core_dma_status
+	bbit0 iicd_done,wait_iicd_done
+	rtn
+
+	/* pdata is iic addr, rega points to buf, temp is length */
+iicd_read_data:
+	store 1,mem_iicd_tbuf
+	setarg mem_iicd_tbuf
+	hstore 2,core_iicd_txaddr
+	setarg 1
+	hstore 2,core_iicd_txlen
+	hstoret 2,core_iicd_rxlen
+	deposit rega
+	hstore 2,core_iicd_rxaddr
+	hjam 1,core_iicd_ctrl
+	hjam iicd_start,core_misc_ctrl
+	branch wait_iicd_done
+
+byteswap_addr_mi:
+	byteswap pdata,pdata
+	store 2,mem_addr_mi
+	rtn
+
+
+//length:temp 
+//mem ptr:rega
+//eeprom addr offset:regb
+iicd_read_eep_data:
+	set1 mark_ext_patch,mark
+	bpatch patch20_2,mem_patch20
+	fetch 2,mem_eeprom_base
+	iadd regb,pdata
+
+/* pdata:eeprom address, rega pointers to buf, temp is length  */
+iicd_read_eep_adr:
+	byteswap pdata,pdata
+	store 2,mem_addr_mi
+
+/* rega pointers to buf, temp is length  */
+iicd_read_eep:
+	set1 mark_ext_patch,mark
+	bpatch patch20_3,mem_patch20
+	setarg 4
+	hstore 2,core_iicd_txlen
+	jam 0xa0,mem_iicd_tbuf
+	jam 0xa1,mem_iicd_tbuf+3
+	setarg mem_iicd_tbuf
+	hstore 2,core_iicd_txaddr
+	hstoret 2,core_iicd_rxlen
+	deposit rega
+	hstore 2,core_iicd_rxaddr
+	setarg 2
+	isolate0 15,rega
+	setflag true,0,pdata
+	hstore 1,core_iicd_ctrl
+	hjam iicd_start,core_misc_ctrl
+	arg iicd_done,queue
+	call decrypt_code
+	call wait_iicd_done
+	isolate1 iicd_crcok,pdata	
+	call set_ucode_status
+	fetch 2,mem_addr_mi
+	byteswap pdata,pdata
+	iadd temp,pdata
+	byteswap pdata,pdata
+	store 2,mem_addr_mi
+	rtn
+
+	
+//length:temp 
+//mem ptr:rega
+//eeprom addr offset:regb
+iicd_write_eep_data:
+	set1 mark_ext_patch,mark
+	bpatch patch20_4,mem_patch20
+	fetch 2,mem_eeprom_base
+	iadd regb,pdata
+
+//cuur ptr:pdata length:temp buf:rega
+iicd_write_ota_data:
+	store 2,mem_pdatatemp //curr ptr
+	set1 mark_ext_patch,mark
+	bpatch patch20_5,mem_patch20
+	storet 2,mem_temp	//len
+	copy rega,pdata
+	store 2,mem_contr
+iicd_write_eep_loop:
+	call iicd_eep_transparency
+
+	fetcht 2,mem_regb
+	fetch 2,mem_contr
+	copy pdata,rega
+	fetch 2,mem_pdatatemp
+	
+	call iicd_write_eep
+
+	fetch 2,mem_regb
+	fetcht 2,mem_contr
+	iadd temp,temp
+	storet 2,mem_contr
+	fetcht 2,mem_pdatatemp
+	iadd temp,temp
+	storet 2,mem_pdatatemp
+	fetch 2,mem_temp
+	nbranch iicd_write_eep_loop,blank
+	rtn
+	
+//in:
+//1.size 2.len 3.src 4.des
+//mem_regc page's area
+//mem_pdatatemp curr ptr
+//mem_temp all len      
+//mem_regb curr len
+iicd_eep_transparency:
+	set1 mark_ext_patch,mark
+	bpatch patch20_6,mem_patch20
+	fetch 2,mem_eeprom_block_size
+	increase -1,pdata
+	fetcht 2,mem_pdatatemp
+	ior temp,pdata
+	increase 1,pdata
+	store 3,mem_regc
+
+	fetch 2,mem_temp
+	iadd temp,pdata
+
+	fetcht 3,mem_regc
+	isub temp,pdata
+	nbranch iicd_eep_deal_short_packet,positive
+	store 2,mem_temp
+	fetch 3,mem_regc
+	fetcht 2,mem_pdatatemp
+	isub temp,pdata
+	store 2,mem_regb
+	rtn
+iicd_eep_deal_short_packet:
+	fetch 2,mem_temp
+	store 2,mem_regb
+	setarg 0
+	store 2,mem_temp
+	rtn
+
+
+
+	/* pdata is eeprom address, rega pointers to txdata(3 ahead bytes should be left), temp is length */
+iicd_write_eep:
+	copy pdata,regb
+	set1 mark_ext_patch,mark
+	bpatch patch20_7,mem_patch20
+	copy regb,pdata
+	increase 3,temp
+	hstoret 2,core_iicd_txlen
+	increase -3,rega
+	ifetcht 3,rega
+	copy temp,regb
+	arg 0xa0,temp
+	istoret 1,rega
+	byteswap pdata,pdata
+	istore 2,contw
+	deposit rega
+	hstore 2,core_iicd_txaddr
+	setarg 0
+	hstore 2,core_iicd_rxlen
+	hjam 1,core_iicd_ctrl
+	hjam iicd_start,core_misc_ctrl
+	call wait_iicd_done
+	copy regb,pdata
+	istore 3,rega
+	nop 10000
+	nop 10000
+	nop 10000
+	rtn
+
+/* ===================== OTP ======================= */
+
+otp_enable_chgpump:
+	hjam 0x70,rfen_chgpump
+	nop param_chgpump_delay
+	rtn
+
+otp_disable_chgpump:
+	hjam 0x30,rfen_chgpump
+	rtn
+	
+otp_set_addr:
+	lshift3 pdata,pdata
+	hstore 2,core_otp_addr
+	hjam 0,core_otpd_ctrl
+	rtn	
+
+/* pdata = otp address, rega pointers data, loopcnt is count */
+otp_write:
+	call otp_set_addr
+	call otp_ce
+otp_program:
+	ifetcht 1,rega
+	increase 1,rega
+	force 0,queue
+otp_program_bit:
+	qisolate0 temp
+	branch otp_skip_0,true
+	hfetch 1,core_otp_din
+	set1 6,pdata				/* din */
+	set1 7,pdata				/* dle */
+	hstore 1,core_otp_din
+	hjam 0x02,core_otp_ctrl	/* web */
+	hjam 0x82,core_otp_ctrl
+	set0 7,pdata				/* dle */
+	hstore 1,core_otp_din
+	hjam 0x8a,core_otp_ctrl	/* pgmen */
+	nop 11
+	hjam 0xca,core_otp_ctrl	/* vppen */
+	nop 33
+	hjam 0x4a,core_otp_ctrl	/* web 2nd */
+	nop 44
+	hjam 0xca,core_otp_ctrl	/* release web */
+	nop 22
+	hjam 0x8a,core_otp_ctrl	/* release vppen */
+	nop 33
+	hjam 0x82,core_otp_ctrl	/* release pgmen */
+	nop 1
+	hjam 0x92,core_otp_ctrl	/* pgmvfy */
+	nop 10
+	hjam 0xb2,core_otp_ctrl	/* readen */
+	hfetch 1,core_otp_rdata
+	hjam 0x92,core_otp_ctrl	/* release readen */
+	nop 1
+	hjam 0x82,core_otp_ctrl	/* release pgmvfy */
+	qisolate0 pdata
+	branch otp_program_bit,true	/* program error */
+otp_skip_0:
+	hfetch 2,core_otp_addr
+	increase 1,pdata
+	hstore 2,core_otp_addr
+	increase 1,queue
+	compare 8,queue,0xf
+	nbranch otp_program_bit,true
+	loop otp_program
+	hjam 0x83,core_otp_ctrl
+	rtn
+
+otp_ce:
+	hjam 0x82,core_otp_ctrl	/* ceb */
+	nop 12
+	hjam 0x80,core_otp_ctrl	/* rstn */
+	hjam 0x82,core_otp_ctrl	/* release rstn */
+	nop 150					/* waiting for vdd25 stable */
+	rtn
+
+	/* rega points to data, temp is count */
+otpd_read_init:
+	call otp_ce
+otpd_read_special:
+	hjam 0xa2,core_otp_ctrl	/* readen */
+	deposit rega
+	hstore 2,core_otpd_addr
+	set1 11,temp
+	isolate0 15,pdata
+	setflag true,15,temp
+	hstoret 2,core_otpd_len
+	hjam otpd_start,core_misc_ctrl
+	rtn
+
+otpd_wait_end:
+	hfetch 1,core_dma_status
+	bbit0 otpd_done,otpd_wait_end
+	rtn
+	
+	/* pdata=otp address, rega points to data, temp is count */
+otpd_read_data:
+	call otp_set_addr
+	call otpd_read_init
+	call otpd_wait_end
+	hjam 0x83,core_otp_ctrl	/* release ceb */
+	rtn
+
+
+
+/* rega pointers to buf, temp is length */
+otpd_read_code:	
+	hfetch 2,core_current_otp_addr
+	hstore 2,core_otp_addr
+	call otpd_read_init
+	arg otpd_done,queue
+	call decrypt_code
+	call otpd_wait_end
+	isolate1 otpd_crcok,pdata	
+	call set_ucode_status
+	hjam 0x83,core_otp_ctrl	/* release ceb */
+	rtn
+
+/* ===================== uart dma ======================= */
+uartd_rx_cnt_got_first_byte:
+	jam 1,mem_uartd_rxitems_got_data
+	force uart_rx_timer,queue
+	fetch 2,mem_uartd_rx_timeout
+	branch timer_init
+uartd_rx_cnt_with_threshold:
+	hfetch 2,core_uart_rxitems
+	rtn blank
+	fetcht 1,mem_uartd_rxitems_threshold
+	isub temp,null
+	branch uartd_rx_cnt_rtn_value,positive
+	fetch 1,mem_uartd_rxitems_got_data
+	branch uartd_rx_cnt_got_first_byte,blank
+	arg uart_rx_timer,queue
+	call timer_check
+	branch uartd_rx_cnt_rtn_value,blank
+	setarg 0
+	rtn
+uartd_rx_cnt_rtn_value:
+	force uart_rx_timer,queue
+	call timer_stop
+	jam 0,mem_uartd_rxitems_got_data
+	hfetch 2,core_uart_rxitems
+	rtn
+	
+
+
+
+	
+	/* temp=bytes to send */	
+uartd_prepare_tx:
+	hfetch 2,core_uart_twptr
+	iforce contwu
+	rtn
+
+uartd_send:
+	deposit contwu
+	hstore 2,core_uart_twptr
+	rtn
+
+uartd_prepare_rx:
+	hfetch 2,core_uart_rxitems
+	rtn blank
+	iforce loopcnt
+	hfetch 2,core_uart_rrptr
+	iforce contru
+	rtn
+
+	//len in temp
+uartd_rxdone_by_len:
+	hfetch 2,core_uart_rrptr
+	iadd temp,pdata
+	copy pdata,contru
+uartd_rxdone:
+	deposit contru
+	hstore 2,core_uart_rrptr
+	rtn
+
+uart_set_baud_by_mem:
+	fetch uart_baud_len,mem_baud
+	hstore uart_baud_len,core_uart_baud
+	rtn
+
+/* ===================== eeprom data ======================= */
+
+eeprom_store_le_reconn_info:
+	fetch 6,mem_le_plap
+	store 6,mem_temp_lap
+	jam REC_4_MODE,mem_record_bt_mode
+	branch eeprom_store_reconn_info
+eeprom_store_bd_reconn_info:
+	fetch 6,mem_plap
+	store 6,mem_temp_lap
+	jam REC_3_MODE,mem_record_bt_mode
+eeprom_store_reconn_info:
+	set1 mark_ext_patch,mark
+	bpatch patch21_0,mem_patch21
+	call eeprom_store_remote_bdaddr
+	call eeprom_store_last_record_index
+	fetch 1,mem_record_bt_mode
+	beq REC_4_MODE,eeprom_store_rec_4_mode
+	beq REC_3_MODE,eeprom_store_link_key
+	rtn
+eeprom_store_rec_4_mode:
+	call eeprom_store_le_ltl
+	branch eeprom_store_le_local_addr
+	
+//
+eeprom_load_reconn_info:
+	set1 mark_ext_patch,mark
+	bpatch patch21_1,mem_patch21
+	call eeprom_load_reconn_bdaddr
+	fetch 1,mem_select_list_item
+	rtneq 0xff
+	fetch 6,mem_temp_lap
+	store 6,mem_hci_plap
+	fetch 1,mem_record_bt_mode
+	store 1,mem_xrecord_mode
+	beq REC_3_MODE,eeprom_load_rec_3_mode
+	beq REC_4_MODE,eeprom_load_rec_4_mode
+	rtn
+eeprom_load_reconn_bdaddr:
+	call eeprom_load_last_record_index
+	fetch 1,mem_select_list_item
+	rtneq 0xff
+	branch eeprom_load_remote_bdaddr
+eeprom_load_rec_3_mode:
+	call eeprom_load_link_key
+	branch check_link_key_load
+eeprom_load_rec_4_mode:
+	call eeprom_load_ltk_key
+	branch check_ltk_load
+eeprom_clear_bd_reconn_info:
+	call eeprom_load_bdaddr_list
+	disable user
+	call find_addr_from_bd_list
+	nbranch at_error_rev_end,user
+eeprom_clear_reconn_info_common:
+	fetcht 2,mem_list_item_ptr
+	increase -1,temp
+	setarg 0
+	istore 7,temp
+	arg 28,temp
+	arg mem_bdaddr_list_buff+7,rega
+	arg eeprom_bdaddr_list,regb
+	branch iicd_write_eep_data
+
+eeprom_clear_all_reconn_info:
+	set1 mark_ext_patch,mark
+	bpatch patch21_2,mem_patch21
+	arg mem_bdaddr_list_buff,contw
+	force 4,loopcnt
+	call memset0
+	arg 28,temp
+	arg mem_bdaddr_list_buff,rega
+	arg eeprom_bdaddr_list,regb
+	branch iicd_write_eep_data
+
+eeprom_erase_reconn_info:
+	set1 mark_ext_patch,mark
+	bpatch patch21_3,mem_patch21
+	setarg 0x0
+	store 3,mem_plap
+	istore 3,contw
+	branch eeprom_store_remote_bdaddr
+	
+eeprom_load_last_record_index:
+	arg 1,temp
+	arg mem_select_list_item,rega
+	arg eeprom_last_record,regb
+	branch iicd_read_eep_data
+
+eeprom_store_last_record_index:
+	arg 1,temp
+	arg mem_select_list_item,rega
+	arg eeprom_last_record,regb
+	branch iicd_write_eep_data
+
+
+eeprom_store_remote_bdaddr:
+	set1 mark_ext_patch,mark
+	bpatch patch21_4,mem_patch21
+	call eeprom_load_bdaddr_list
+	disable user
+	call find_addr_from_bd_list
+	rtn user
+eeprom_store_remote_addr_unfind:
+	jam 0,mem_select_list_item
+	fetch 6,mem_temp_lap
+	store 6,mem_bdaddr_list_buff+1
+	fetch 1,mem_record_bt_mode
+	store 1,mem_bdaddr_list_buff
+	arg 28,temp
+	arg mem_bdaddr_list_buff,rega
+	arg eeprom_bdaddr_list,regb
+	branch iicd_write_eep_data
+
+
+eeprom_store_le_local_addr:
+	arg 6,temp
+	arg mem_le_lap,rega
+	arg eeprom_le_reconn_local_addr,regb
+	branch iicd_write_eep_data
+	
+eeprom_load_le_loacal_addr:
+	arg 6,temp
+	arg mem_le_lap,rega
+	arg eeprom_le_reconn_local_addr,regb
+	branch iicd_read_eep_data
+
+
+eeprom_load_remote_bdaddr:
+	set1 mark_ext_patch,mark
+	bpatch patch21_5,mem_patch21
+	arg 7,temp
+	arg mem_temp_reconn_record,rega
+	arg eeprom_bdaddr_list,regb
+	fetch 1,mem_select_list_item
+	mul32 pdata,7,pdata
+	iadd regb,regb
+	branch iicd_read_eep_data
+
+eeprom_linkkey_addr:
+	arg 0x10,temp
+	arg eeprom_linkkey_list,regb
+	fetch 1,mem_select_list_item
+	lshift4 pdata,pdata
+	iadd regb,regb
+	rtn
+	
+eeprom_store_le_ltl:
+	arg mem_le_ltk,rega
+	branch eeprom_store_link_key_common
+eeprom_store_link_key:
+	arg mem_link_key,rega
+eeprom_store_link_key_common:
+	set1 mark_ext_patch,mark
+	bpatch patch21_6,mem_patch21
+	call eeprom_linkkey_addr
+	branch iicd_write_eep_data
+
+eeprom_load_ltk_key:
+	arg mem_le_ltk,rega
+	branch eeprom_load_link_key_common
+eeprom_load_link_key:
+	arg mem_link_key,rega
+eeprom_load_link_key_common:
+	set1 mark_ext_patch,mark
+	bpatch patch21_7,mem_patch21
+	call eeprom_linkkey_addr
+	branch iicd_read_eep_data
+
+
+	
+eeprom_load_bdaddr_list:
+	arg 28,temp
+	arg mem_bdaddr_list_buff+7,rega
+	arg eeprom_bdaddr_list,regb
+	branch iicd_read_eep_data
+
+find_addr_from_bd_list:
+	set1 mark_ext_patch,mark
+	bpatch patch22_0,mem_patch22
+	setarg mem_bdaddr_list_buff+7
+	store 2,mem_list_item_ptr
+	jam 0,mem_select_list_item
+	arg 4,loopcnt
+find_addr_from_list:
+	copy loopcnt,pdata
+	store 1,mem_pdatatemp
+	fetch 2,mem_list_item_ptr
+	copy pdata,rega
+	call find_addr_from_list_compare
+	rtn user
+	fetch 2,mem_list_item_ptr
+	increase 7,pdata
+	store 2,mem_list_item_ptr
+	fetch 1,mem_select_list_item
+	increase 1,pdata
+	store 1,mem_select_list_item
+	fetch 1,mem_pdatatemp
+	copy pdata,loopcnt
+	loop find_addr_from_list
+	rtn
+
+check_link_key_load:
+	fetch 8,mem_link_key
+	fetcht 8,mem_link_key+8
+	ior temp,pdata
+	rtn blank
+	jam 1,mem_link_key_exists
+	rtn
+check_ltk_load:
+	fetch 6,mem_hci_plap
+	rtn blank
+	jam 1,mem_ltk_exists
+	rtn
+
+find_addr_from_list_compare:
+	arg mem_temp_reconn_record,regb
+	arg 7,loopcnt
+	call string_compare
+	branch enable_usr,zero
+	rtn
+enable_usr:
+	enable user
+	rtn
+le_eeprom_load_reconn_info:
+	branch assert
+
+
+/* =============== GPIO CONTROL ================= */
+
+
+	//temp [4:0]=GPIO number, 0-31, 
+gpio_set_wake_by_current_state:
+	set1 mark_ext_patch,mark
+	bpatch patch22_1,mem_patch22
+	set1 7,temp
+	call gpio_get_bit
+	nsetflag true,7,temp
+	//branch gpio_set_wake
+	//fall through
+	
+	//temp [4:0]=GPIO number, 0-31, [7]=0, low active
+gpio_set_wake:
+	set1 mark_ext_patch,mark
+	bpatch patch22_2,mem_patch22
+	isolate0 7,temp
+	and temp,0x1f,queue
+	fetch 4,mem_gpio_wakeup_low
+	qsetflag true,pdata
+	store 4,mem_gpio_wakeup_low
+	fetch 4,mem_gpio_wakeup_high
+	nqsetflag true,pdata
+	store 4,mem_gpio_wakeup_high
+	rtn
+	
+	//temp [4:0]=GPIO number, 0-31, [7]=0, low active
+gpio_clr_wake:
+	set1 mark_ext_patch,mark
+	bpatch patch22_3,mem_patch22
+	isolate0 7,temp
+	and temp,0x1f,queue
+	fetch 4,mem_gpio_wakeup_low
+	qset0 pdata
+	store 4,mem_gpio_wakeup_low
+	fetch 4,mem_gpio_wakeup_high
+	qset0 pdata
+	store 4,mem_gpio_wakeup_high
+	rtn
+
+
+gpio_config_input_nowake:
+	call gpio_clr_wake
+	branch gpio_config_input_without_wake
+
+	//temp [4:0]=GPIO number, 0-31, [7]=0, low active
+gpio_config_input:
+	ncall gpio_set_wake,wake
+
+gpio_config_input_without_wake:
+	arg core_gpio_pd0,contw
+	call gpio_set_bit
+	setflip gpio_active_bit,temp
+	arg core_gpio_pu0,contw
+	call gpio_set_bit
+	set0 gpio_active_bit,temp
+	arg core_gpio_oe0,contw
+	branch gpio_set_bit
+	
+	//temp [4:0]=GPIO number, 0-31, [7]=0, low active. set gpio to inactive state
+gpio_config_output:	
+	setflip gpio_active_bit,temp
+	call gpio_out
+	set1 gpio_active_bit,temp
+	arg core_gpio_oe0,contw
+	branch gpio_set_bit
+	
+gpio_common:
+	and temp,0x07,queue
+	rshift3 temp,pdata
+	and_into 3,pdata
+	iadd contw,contw
+	ifetch 1,contw
+	rtn
+
+	
+	/* temp is gpio number, return true if gpio active */
+gpio_get_bit:
+	arg core_gpio_in,contw
+	call gpio_common
+	isolate1 gpio_active_bit,temp
+	branch gpio_get_bit_reverse,true
+	qisolate0 pdata
+	rtn
+gpio_get_bit_reverse:
+	qisolate1 pdata
+	rtn
+
+gpio_out_inactive:
+	isolate1 7,null
+	branch gpio_out_flag
+
+gpio_out_active:
+	isolate0 7,null
+
+	/* temp is gpio number,  [7]=1,set out equa true flag if gpio active */
+gpio_out_flag:
+	setarg 0
+	nsetflag true,gpio_active_bit,pdata
+	ixor temp,temp
+	
+	/* temp is gpio number,0-31, [7]=out bit value */
+gpio_out:
+	arg core_gpio_out0,contw
+
+	//temp [4:0]=GPIO number, 0-31, [7]=bit value; contw is gpio reg base
+gpio_set_bit:
+	call gpio_common
+	isolate1 gpio_active_bit,temp
+	qsetflag true,pdata
+	istore 1,contw
+	rtn
+
+gpio_test:
+	fetch 1,mem_seqi
+	rtneq 0x7f
+	hjam 0,core_gpio_out3
+	nop 30
+	hjam 8,core_gpio_out3
+	rtn
+
+
+/* ===================== PWM ======================= */
+
+set_pwm_blink:
+	lshift8 pdata,pdata
+	lshift4 pdata,pdata
+	hstore 2,core_pwm_ncnt0
+	hstore 2,core_pwm_pcnt0
+	rtn
+
+set_pwm_steadyon:
+	setarg 0
+	hstore 2,core_pwm_ncnt0
+	setarg 1
+	hstore 2,core_pwm_pcnt0
+	rtn
+
+set_pwm_off:
+	setarg 0
+	hstore 2,core_pwm_ncnt0
+	hstore 2,core_pwm_pcnt0
+	rtn
+
+	
+/* ===================== CODEC ======================= */
+
+init_filter_ram:
+ifdef COMPILE_HCI_BCSP
+	arg 0x8800,contw
+	arg 0x20,loopcnt
+	call memset0
+	setarg 0x4f9
+	hstore 2,0x8848
+	hstore 2,0x884a
+	hstore 2,0x884c
+	hstore 2,0x886c
+	hstore 2,0x888c
+	hstore 2,0x88ac
+	setarg 0x204
+	hstore 2,0x88ae
+	setarg 0x0506
+	hstore 2,0x88b0
+	setarg 0x0504
+	hstore 2,0x88b2
+	setarg 0x0200
+	hstore 2,0x88b4
+	setarg 0xFEFB
+	hstore 2,0x88b6
+	setarg 0xFAF9
+	hstore 2,0x88b8
+	setarg 0xFAFB
+	hstore 2,0x88ba
+	setarg 0xFD00
+	hstore 2,0x88bc
+	setarg 0x0408
+	hstore 2,0x88be
+	setarg 0x0A0C
+	hstore 2,0x88c0
+	setarg 0x0B09
+	hstore 2,0x88c2
+	setarg 0x0500
+	hstore 2,0x88c4
+	setarg 0xF8F1
+	hstore 2,0x88c6
+	setarg 0xECE8
+	hstore 2,0x88c8
+	setarg 0xE9EB
+	hstore 2,0x88ca
+	setarg 0xF500
+	hstore 2,0x88cc
+	setarg 0x1223
+	hstore 2,0x88ce
+	setarg 0x374B
+	hstore 2,0x88d0
+	setarg 0x5E71
+	hstore 2,0x88d2
+	setarg 0x787F
+	hstore 2,0x88d4
+endif
+	rtn
+
+enable_pcm:
+	set1 mark_ext_patch,mark
+	bpatch patch22_4,mem_patch22
+	hfetch 2,core_clkoff
+	set0 CLOCK_OFF_CODEC,pdata
+	hstore 2,core_clkoff
+	hjam 0x11,core_enc_ctrl
+	hjam 0x1,core_cvsd_ctrl
+	hjam 0x1,core_codec_ctrl
+	hjam 0x11,core_dec_ctrl
+	rtn
+
+disable_pcm:
+	set1 mark_ext_patch,mark
+	bpatch patch22_5,mem_patch22
+	hfetch 2,core_clkoff
+	set1 CLOCK_OFF_CODEC,pdata
+	hstore 2,core_clkoff
+	hjam 0x4,core_enc_ctrl
+	hjam 0x4,core_dec_ctrl
+	hjam 0x0,core_cvsd_ctrl
+	hjam 0x0,core_codec_ctrl
+	rtn
+
+
+
+get_sco_data:
+	fetch 1,mem_state
+	rtnbit0 state_insco
+	arg mem_sco_obuf,contw
+	arg 30,loopcnt
+get_sco_data_loop:
+	hfetch 1,core_pcminfifo
+	istore 1,contw
+	loop get_sco_data_loop
+	rtn
+	
+
+process_sco_data:
+	fetch 1,mem_state
+	rtnbit0 state_insco
+	arg mem_sco_ibuf,contr
+	force 30,loopcnt
+process_sco_loop:
+	ifetch 1,contr
+	hstore 1,core_pcmoutfifo
+	loop process_sco_loop
+	rtn
+
+init_sched:
+	rtn
+
+
+
+/* ===================== sniff GPIO CONTROL ======================= */
+gpio_cfg_uart_tx_output:
+	call gpio_uart2gpio
+	arg UART_WAKEUP_TX,temp
+	branch gpio_config_output
+
+gpio_pu_uart_tx:
+	call gpio_cfg_uart_tx_output
+	arg UART_WAKEUP_TX,temp
+	branch gpio_out_inactive
+
+gpio_pd_uart_tx:
+	call gpio_cfg_uart_tx_output
+	arg UART_WAKEUP_TX,temp
+	branch gpio_out_active
+
+gpio_cfg_uart_rx_output:
+	call gpio_uart2gpio
+	arg UART_WAKEUP_RX,temp
+	branch gpio_config_output
+
+gpio_pu_uart_rx:
+	call gpio_cfg_uart_rx_output
+	arg UART_WAKEUP_RX,temp
+	branch gpio_out_inactive
+
+gpio_pd_uart_rx:
+	call gpio_cfg_uart_rx_output
+	arg UART_WAKEUP_RX,temp
+	branch gpio_out_active
+
+gpio_tx_config_input_with_pu:
+	call gpio_uart2gpio
+	hfetch 1, core_gpio_pu0
+	set1 UART_WAKEUP_TX,pdata
+	hstore 1,core_gpio_pu0
+	arg UART_WAKEUP_TX,temp
+	branch gpio_config_input
+
+gpio_rx_config_input_with_pu:
+	call gpio_uart2gpio
+	hfetch 1, core_gpio_pu0
+	set1 UART_WAKEUP_RX,pdata
+	hstore 1,core_gpio_pu0
+	arg UART_WAKEUP_RX,temp
+	branch gpio_config_input
+	
+gpio_gpio2uart:
+	hfetch 1,core_gpio_sel1
+	or_into 0x04,pdata
+	hstore 1,core_gpio_sel1
+	rtn
+
+gpio_uart2gpio:
+	hfetch 1,core_gpio_sel1
+	and_into 0xfb,pdata
+	hstore 1,core_gpio_sel1
+	rtn
+
+gpio_check_uart_state:
+	hfetch 1,core_gpio_sel1
+	isolate1 2,pdata
+	rtn
+	
Index: btkb/program/prcp.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/prcp.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/prcp.prog	(working copy)
@@ -0,0 +1,297 @@
+
+ifdef COMPILE_PRCP
+prcp_init:
+	setarg prcp_process
+	store 2,mem_cb_att_write
+	rtn
+prcp_process:
+	call clear_prcp_sendbuff
+	fetch 1,mem_prcp
+	beq PRCP_LE,le_prcp
+	beq PRCP_SSP,prcp
+	branch assert
+le_prcp:
+	arg PRCP_RX_LE,temp
+	storet 2,mem_le_notify_handle
+	call le_att_get_handle_ptr
+	ifetch 1,contr
+	call prcp_parse
+	branch prcp_le_tx
+prcp:
+	call prcp_parse
+	branch prcp_tx
+prcp_parse:
+	copy contr,rega
+	set1 mark_ext_patch,mark
+	bpatch patch26_1,mem_patch26
+	ifetch 1,contr
+	beq COMMON_RES,prcp_parse_common_res
+	beq READ_REGISTERS_REQ,prcp_parse_read_registers_req
+	beq READ_REGISTERS_RES,prcp_parse_read_registers_res
+	beq WRITE_REGISTERS_REQ,prcp_parse_write_registers_req
+	beq I2C_CONFIG_REQ,prcp_parse_i2c_config_req
+	beq I2C_READ_REQ,prcp_parse_i2c_read_req
+	beq I2C_READ_RES,prcp_parse_i2c_read_res
+	beq I2C_WRITE_REQ,prcp_parse_i2c_write_req
+	beq SPI_CONFIG_REQ,prcp_parse_spi_config_req
+	beq SPI_READ_REQ,prcp_parse_spi_read_req
+	beq SPI_READ_RES,prcp_parse_spi_read_res
+	beq SPI_WRITE_REQ,prcp_parse_spi_write_req
+	beq PWM_CONFIG_REQ,prcp_parse_pwm_config_req
+	beq PWM_WRITE_REQ,prcp_parse_pwm_write_req
+	beq GPIO_CONFIG_REQ,prcp_parse_gpio_config_req
+	beq GPIO_READ_REQ,prcp_parse_gpio_read_req
+	beq GPIO_READ_RES,prcp_parse_gpio_read_res
+	beq GPIO_WRITE_REQ,prcp_parse_gpio_write_req
+	beq OTA_WRITE_REQ,prcp_parse_ota_write_req
+	beq OTA_END_CMD,prcp_parse_ota_end_cmd
+	rtn
+
+
+prcp_parse_common_res:
+	copy rega,contr
+    	ifetch 1,contr
+    	lshift8 pdata,pdata
+    	store 3,mem_prcp_data
+	rtn
+prcp_parse_read_registers_req:
+	rtn
+prcp_parse_read_registers_res:
+	rtn
+prcp_parse_write_registers_req:
+	rtn
+/*********************************************/
+/************** prcp_spi********************/
+/*********************************************/
+prcp_parse_spi_config_req:
+	rtn
+prcp_parse_spi_read_req:
+	rtn
+prcp_parse_spi_read_res:
+	rtn
+prcp_parse_spi_write_req:
+	rtn
+/***********************************************/
+/************** prcp_pwm********************/
+/***********************************************/
+prcp_parse_pwm_config_req:
+	ifetch 4,contr
+	hstore 1,core_gpio_sel2
+	rshift8 pdata,pdata
+	hfetcht 1,core_gpio_sel1
+	and_into 0x7f,temp
+	ior temp,temp
+	hstoret 1,core_gpio_sel1
+	rshift8 pdata,pdata
+	hfetcht 1,core_clkoff+1
+	and_into 0xdf,temp
+	ior temp,temp
+	hstoret 1,core_clkoff+1
+	rshift8 pdata,pdata
+	hfetcht 1,core_clksel
+	and_into 0x3f,temp
+	ior temp,temp
+	hstoret 1,core_clksel
+	branch prcp_parse_common_res
+prcp_parse_pwm_write_req:
+	ifetch 9,contr
+    hfetcht 1,core_gpio_key2//PWM_enable
+    and_into 0x3f,temp
+	ior temp,temp
+	hstoret 1,core_gpio_key2
+	rshift8 pdata,pdata
+	hstore 2,core_pwm_pcnt0
+	rshift16 pdata,pdata
+	hstore 2,core_pwm_ncnt0
+	rshift16 pdata,pdata
+	hstore 2,core_pwm_pcnt1
+	rshift16 pdata,pdata
+	hstore 2,core_pwm_ncnt1
+	branch prcp_parse_common_res
+/**********************************************/
+/************** prcp_gpio********************/
+/***********************************************/
+prcp_parse_gpio_config_req:
+	ifetch 4,contr
+    	hstore 4,core_gpio_oe0
+    	ifetch 4,contr
+    	hstore 4,core_gpio_pu0
+   	ifetch 4,contr
+    	hstore 4,core_gpio_pd0
+    	ifetch 1,contr
+    	hstore 1,core_gpio_sel
+    	ifetch 1,contr
+    	hstore 1,core_gpio_sel1
+  	ifetch 1,contr
+    	hstore 1,core_gpio_sel2
+    	branch prcp_parse_common_res
+prcp_parse_gpio_read_req:
+	branch prcp_parse_gpio_read_res
+prcp_parse_gpio_read_res:
+	jam 0x10,mem_prcp_data
+    	arg mem_prcp_data+1,contw
+   	hfetch 4,core_gpio_out0
+    	istore 4,contw
+    	hfetch 4,core_gpio_in
+    	istore 4,contw
+    	rtn
+prcp_parse_gpio_write_req:
+	ifetcht 1,contr
+    	ifetch 1,contr
+   	lshift3 pdata,pdata
+   	lshift4 pdata,pdata
+   	ior temp,temp
+  	call gpio_out
+    	branch prcp_parse_common_res
+
+/*********************************************/
+/************** prcp_i2c********************/
+/*********************************************/
+prcp_parse_i2c_read_req:
+	ifetcht 1,contr
+	hstoret 1,iic_slave_addr
+	ifetch 1,contr
+	compare 1,pdata,0xff
+	ifetch 1,contr
+	hstore 1,iic_fifo
+	branch iic_read_data_len,true
+	ifetch 1,contr
+	hstore 1,iic_fifo
+iic_read_data_len:
+	ifetch 1,contr
+	copy pdata,loopcnt
+	increase -1,pdata
+	or_into 0x90,pdata
+	hstore 1,iic_ctr//read byte
+	hjam 2,iic_cr//
+	nop 1
+	//call iic_wait
+	arg mem_prcp_data ,contw
+iic_read_loop:
+	hfetch 1,iic_fifo
+	istore 1,contw
+	loop iic_read_loop
+	rtn
+
+clear_prcp_sendbuff:
+	setarg 0
+	store 4,mem_prcp_data
+	istore 8,contw
+	istore 8,contw
+	rtn
+	
+/*********************************************/
+/************** prcp_ota********************/
+/* rxbuf:[0]head,[1-2]offset,[3]len,[4-19]data]*/
+//rega points to rxbuf
+prcp_parse_ota_write_req:
+        copy rega,pdata//copy contr,pdata
+        increase 1,pdata//
+        store 2,rx_buf_data_ptr
+        fetch 2, mem_eeprom_ota_base_addr
+        beq 0x0000,prcp_parse_ota_start1
+prcp_parse_ota_load:    
+        fetch 2, mem_eeprom_ota_base_addr
+        fetcht 2,rx_buf_data_ptr
+        ifetcht 2,temp
+        iadd temp,pdata
+        fetcht 2,rx_buf_data_ptr
+        increase 2,temp
+        copy temp,contr
+        ifetcht 1,contr  // data_len =>temp 
+        copy contr,rega //data_buf to rega
+        branch iicd_write_ota_data 
+
+prcp_parse_ota_start1:   /*compute the bytes of code*/    
+	setarg 0x0002
+	byteswap pdata,pdata
+	store 2,mem_addr_mi
+	arg iicd_read_eep,regc
+	arg 0x2,loopcnt
+prcp_parse_ota_loop1:
+         call get_block_header
+	nbranch prcp_parse_ota_start2, zero
+	fetch 2,mem_addr_mi
+	byteswap pdata,pdata
+	iadd temp,pdata
+	store 2,mem_eeprom_ota_base_addr
+	byteswap pdata,pdata
+	store 2,mem_addr_mi
+	loop prcp_parse_ota_loop1
+prcp_parse_ota_start2: /*compute the bytes of init-mem*/  
+	fetch 2, mem_eeprom_ota_base_addr
+	byteswap pdata,pdata
+	store 2,mem_addr_mi
+	arg iicd_read_eep,regc
+	arg 0xffff,loopcnt
+prcp_parse_ota_loop2:
+         call get_block_header
+	nbranch prcp_parse_ota_load, zero
+	fetch 2,mem_addr_mi
+	byteswap pdata,pdata
+	iadd temp,pdata
+	increase 2,pdata
+	store 2,mem_eeprom_ota_base_addr
+	byteswap pdata,pdata
+	store 2,mem_addr_mi
+	loop prcp_parse_ota_loop2
+
+prcp_parse_ota_end_cmd:  /*end of ota*/
+         fetch 2,mem_eeprom_ota_base_addr
+         increase 2,pdata
+         byteswap pdata,pdata
+         store 2,mem_eeprom_ota_base_addr
+	arg mem_eeprom_ota_base_addr,rega  
+         arg 0x02,temp  
+         arg  0x0000,pdata
+         call  iicd_write_ota_data
+         setarg 0x0000
+         store 2,mem_eeprom_ota_base_addr
+	rtn
+
+prcp_parse_i2c_config_req:
+	rtn
+prcp_parse_i2c_read_res:
+	rtn
+prcp_parse_i2c_write_req:
+	rtn	
+	
+	
+else
+prcp_init:
+prcp_process:
+le_prcp:
+prcp:
+prcp_parse:
+prcp_parse_common_res:
+prcp_parse_read_registers_req:
+prcp_parse_read_registers_res:
+prcp_parse_write_registers_req:
+prcp_parse_spi_config_req:
+prcp_parse_spi_read_req:
+prcp_parse_spi_read_res:
+prcp_parse_spi_write_req:
+prcp_parse_pwm_config_req:
+prcp_parse_pwm_write_req:
+prcp_parse_gpio_config_req:
+prcp_parse_gpio_read_req:
+prcp_parse_gpio_read_res:
+prcp_parse_gpio_write_req:
+prcp_parse_i2c_read_req:
+iic_read_data_len:
+iic_read_loop:
+prcp_parse_i2c_config_req:
+prcp_parse_i2c_read_res:
+prcp_parse_i2c_write_req:
+clear_prcp_sendbuff:
+prcp_parse_ota_write_req:
+prcp_parse_ota_load: 
+prcp_parse_ota_start1: 
+prcp_parse_ota_loop1:
+prcp_parse_ota_start2:
+prcp_parse_ota_loop2:
+prcp_parse_ota_end_cmd:
+
+	branch assert
+endif
+
Index: btkb/program/rfcomm.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/rfcomm.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/rfcomm.prog	(working copy)
@@ -0,0 +1,846 @@
+
+ifdef COMPILE_RFCOMM
+rfcomm_init:
+	rtn wake
+	jam 0,mem_rfcomm_send_more_pkt
+	jam BITS9600,memRemoteRPNBitRate        
+	jam DATABITS8,memRemotePRNDataBits      
+	jam 0x11,memRemotePRNXon
+	jam 0x13,memRemotePRNXoff
+	setarg 0
+	store 3,memRemotePRNStopBit
+	store 1,mem_spp_state                  
+	jam 0,memui_reconnect_mode
+	//branch rfcomm_init_spp
+rfcomm_init_spp:
+	set1 mark_ext_patch,mark
+	bpatch patch37_7,mem_patch37
+	setarg 0
+	store 1,mem_spp_state
+	store 1,mem_remote_spp_channel
+	store 1,mem_pn_dlci
+	jam 0x50,mem_credit_given
+	rtn
+
+set_CR_bit:
+	or_into 0x02,temp
+	rtn
+
+
+/*below added by koufan*/
+
+/*rfcomm_send */
+
+
+
+	/*rfcomm_calculate_FCS_sabm*/
+	/*input: address in temp*/
+	/*output: FCS in pdata  */
+rfcomm_calculate_FCS_sabm:
+	copy temp,pdata
+	reverse pdata,pdata //address
+	store 1,memFCStemp3
+	force INI_TX_SABM,pdata
+	reverse pdata,pdata
+	store 1,memFCStemp2
+	force 0x01,pdata                        
+	reverse pdata,pdata
+	store 1,memFCStemp1
+	call caculate_fcs
+	copy temp,pdata                        
+	rtn
+rfcomm_calculate_FCS_ua:
+	reverse pdata,pdata //address
+	store 1,memFCStemp3
+	force   RSP_TX_UA, pdata
+	reverse pdata, pdata
+	store   1, memFCStemp2
+	force   0x01, pdata
+	reverse pdata, pdata
+	store   1, memFCStemp1
+	branch caculate_fcs
+	/* FCS return from temp                */
+rfcomm_calculate_FCS_dlci0:
+	fetch 1,mem_rfcomm_initiator
+	branch rfcomm_calculate_FCS_dlci0_res,blank
+	setarg 0x70 //FCS of initiator
+	rtn
+rfcomm_calculate_FCS_dlci0_res:
+	setarg 0xaa//FCS of responder
+	rtn
+	
+rfcomm_save_FCS_uih:
+	reverse pdata, pdata //address 
+	store 1,memFCStemp3                     /* contw distroided                    */
+	force RSP_RX_UIH,pdata 
+	call caculate_UIHdata_fcs
+	fetcht 2,mem_contw_temp
+	copy temp,contw
+	istore 1,contw                      /* save FCS for later use              */
+	copy contw,temp
+	storet 2,mem_contw_temp
+	force RSP_RX_UIH_WDATA,pdata             /* P/F =1 + RSP_RX_UIH                 */
+	call caculate_UIHdata_fcs
+	fetcht 2,mem_contw_temp
+	copy temp,contw
+	istore 1,contw             /* save FCS for later use              */
+	rtn	
+/**********************************************************************/
+/* This subroutine caculates the FCS for UIH data                     */
+/* Input:                                                             */
+/*        the address byte at memFCStemp3(bit reversed), control byte */
+/*        at pdata (not bit reversed)                                 */
+/* Output:                                                            */
+/*        pdata: the FCS                                              */
+/**********************************************************************/  
+caculate_UIHdata_fcs:
+	reverse pdata,pdata
+	store   1,memFCStemp2
+	fetch   2, memFCStemp2                     
+	lshift8 pdata,pdata
+	store 3,mem_mod2div_temp
+	arg     0x107,rega
+	arg 0xf,regb
+	call mod2div
+	xor_into     0xd7, pdata
+	invert  pdata,pdata
+	reverse pdata,pdata
+	rtn
+	
+/**********************************************************************/
+/* This subroutine caculates the FCS                                  */
+/* Input:                                                             */
+/*        the address byte at memFCStemp3, control byte at memFCStemp2*/  
+/*        lenght at memFCStemp1 (all above data are bit reversed)     */
+/* Output:                                                            */
+/*        temp: the FCS                                               */
+/**********************************************************************/     
+caculate_fcs:
+	fetch 3, memFCStemp1                    /* load 3 bytes start at memFCStemp1   */
+	store 3,mem_mod2div_temp
+	arg 0x107,rega
+	arg 0xf,regb  //24bit(memFCStemp1+..+memFCStemp3) - 9bit(rega) = 15bit
+	call mod2div
+	lshift8 pdata,pdata 
+	arg 0x7, regb  //16bit(lshift8 pdata,pdata ) - 9bit(rega) = 7bit
+	call mod2div
+	xor_into     0x2b, pdata		//0x3d
+	invert  pdata, pdata                        
+	reverse pdata, pdata                      /* FCS at pdata                        */
+	copy    pdata, temp
+	rtn
+
+mod2div:
+	arg 0,regc
+	copy regb,loopcnt
+	call right_shift_n // right shift pdata (regb)bit
+	icopy temp
+mod2div_loop:
+	//jam 1,0x1fff
+//mod2div_loop1:
+	//fetch 1,0x1fff
+	//nbranch mod2div_loop1,blank
+	copy temp,pdata
+	lshift regc,regc//quotient
+	bbit0 8, mod2div_not_enough_reduction//the high bit of 0x107
+	ixor rega,temp// temp----remainer
+	increase 1,regc// quotient
+mod2div_not_enough_reduction: //Minuend smaller than Subtrahend
+	lshift temp,temp
+	fetch 3,mem_mod2div_temp
+	increase -1,regb
+	compare 0xff,regb,0xff
+	branch mod2div_end,true
+	copy regb,loopcnt
+	call right_shift_n // right shift pdata (regb)bit
+	isolate1 0,pdata
+	setflag true,0,temp //move a new bit from Dividend(queue) into Minuend(pdata)
+	branch mod2div_loop
+mod2div_end:
+	//output:remainer in pdata
+	rshift  temp,pdata
+	rtn
+
+get_rfcomm_snd_adss:
+	fetcht 1,mem_pn_dlci
+dlci_to_address_cmd:
+	//input DLCI from temp
+	lshift2 temp,temp
+	set1 RFCOMM_ADDRESS_EXT_LEN,temp
+	fetch 1,mem_rfcomm_initiator
+	ncall set_CR_bit,blank
+	storet 1,mem_rfcomm_send_adss
+	rtn
+
+dlci_to_address_res:
+	//input DLCI from temp
+	lshift2 temp,temp
+	set1 RFCOMM_ADDRESS_EXT_LEN,temp
+	fetch 1,mem_rfcomm_initiator
+	call set_CR_bit,blank
+	rtn
+channel_to_dlci:
+	//input channel from temp
+	lshift temp,temp
+	fetch 1,mem_rfcomm_initiator
+	setflag blank,0,temp //direction in dlci
+	//output dlci to temp
+	rtn
+rfcomm_rx_process_DLCI0_sabm:
+	fetcht 1,mem_current_channel //address
+	jam 0xd7,mem_current_fcs //FCS
+	call rfcomm_send_ua
+	fetch 1,mem_rfcomm_state
+	set1 L2CAP_CHANNEL_RFCOMM_ONLY_SABM,pdata
+	set1 L2CAP_CHANNEL_RFCOMM_ONLY_UA,pdata
+	store 1,mem_rfcomm_state
+	jam 0,mem_rfcomm_initiator
+	branch rfcomm_rx_process_end
+rfcomm_rx_process_DLCI0_ua:
+	fetch 1,mem_rfcomm_state
+	set1 L2CAP_CHANNEL_RFCOMM_ONLY_UA,pdata
+	store 1,mem_rfcomm_state
+	branch rfcomm_rx_process_end
+
+	
+rfcomm_rx_process:
+	set1 mark_ext_patch,mark
+	bpatch patch38_0,mem_patch38
+	fetch 1,memui_reconnect_mode
+	beq NO_RECONNECTION,rfcomm_rx_process_remote_page
+	branch rfcomm_rx_process_reconn
+
+rfcomm_rx_process_remote_page:
+	fetch 2,mem_l2cap_payload_ptr
+	copy pdata,contr
+	call get_rfcomm_head_struct
+	fetch 1,mem_current_channel
+	beq 0,parse_dlci0_rp
+	branch parse_uih_rp
+parse_dlci0_rp:
+	set1 mark_ext_patch,mark
+	bpatch patch38_1,mem_patch38
+	fetch 1,mem_current_frame_type
+	beq RFCOMM_FRAME_TYPE_SABM,rfcomm_rx_process_DLCI0_sabm
+	beq RFCOMM_FRAME_TYPE_UA,rfcomm_rx_process_DLCI0_ua
+	beq RFCOMM_FRAME_TYPE_UIH,parse_DLCI0_rp_uih
+	rtneq RFCOMM_FRAME_TYPE_DISCONN
+	branch assert
+
+
+parse_DLCI0_rp_uih:
+	fetch 2,mem_rfcomm_uih_payload_ptr
+	copy pdata,contr
+	call get_rfcomm_uih_head_struct
+	fetch 1,mem_uih_cmd_type
+	beq UIH_PARAM_NEG_CMD,parse_DLCI0_rp_uih_pn_cmd
+	beq UIH_PARAM_NEG_RES,parse_DLCI0_rp_uih_pn_res
+	beq UIH_MODEM_STATUS_CMD,parse_DLCI0_rp_uih_ms_cmd
+	beq UIH_MODEM_STATUS_RES,parse_DLCI0_rp_uih_ms_res
+	branch rfcomm_rx_process_end
+	
+parse_DLCI0_rp_uih_pn_cmd:
+	call parse_DLCI0_rp_uih_pn_res_common
+	fetch 1,mem_pn_dlci
+	rshift pdata,pdata
+	sub pdata,SPP_SLAVE_CHANNEL,null
+	branch parse_DLCI0_rp_uih_pn_cmd_spp,zero
+	branch assert
+parse_DLCI0_rp_uih_pn_cmd_spp:
+	fetch 1,mem_spp_state
+	set1 RFCOMM_CHANNEL_STATE_PN_CMD,pdata
+	set1 RFCOMM_CHANNEL_STATE_PN_RES,pdata
+	store 1,mem_spp_state
+	call rfcomm_send_param_neg_res
+	branch rfcomm_rx_process_end
+	
+parse_DLCI0_rp_uih_pn_res:
+	call parse_DLCI0_rp_uih_pn_res_common
+	branch rfcomm_rx_process_end
+
+parse_DLCI0_rp_uih_pn_res_common:
+	call get_param_payload_ptr
+	branch  get_rfcomm_prarmer_negotiation
+
+get_rfcomm_param_modem_status:
+	call get_param_payload_ptr
+	ifetch 1,contr
+	rshift3 pdata,pdata
+	store 1,mem_ms_channel
+	ifetch 1,contr
+	store 1,mem_ms_param
+	rtn
+
+
+get_rfcomm_head_struct:
+	ifetch 1,contr
+	store 1,mem_current_adss
+	rshift3 pdata,pdata
+	store 1,mem_current_channel
+	ifetch 1,contr
+	store 1,mem_current_frame_type
+get_rfcomm_current_length:
+	call get_rfcomm_length_common
+	storet 2,mem_current_length
+	copy contr,pdata
+	store 2,mem_rfcomm_uih_payload_ptr
+	rtn
+
+get_rfcomm_uih_head_struct:
+	ifetch 1,contr
+	rshift pdata,pdata
+	store 1,mem_uih_cmd_type
+	call get_rfcomm_length_common
+	storet 2,mem_uih_length
+	copy contr,pdata
+	store 2,mem_param_payload_ptr
+	rtn
+
+
+get_param_payload_ptr:
+	fetch 2,mem_param_payload_ptr
+	copy pdata,contr
+	rtn
+
+get_rfcomm_param_length_common:
+	fetch 2,mem_param_payload_ptr
+	copy pdata,contr
+get_rfcomm_length_common:
+	ifetch 1,contr
+	copy pdata,temp
+	rshift temp,temp
+	rtnbit1 0
+	ifetch 1,contr
+	lshift3 pdata,pdata
+	lshift4 pdata,pdata
+	iadd temp,temp
+	rtn
+
+get_rfcomm_prarmer_negotiation:
+	ifetch 1,contr
+	store 1,mem_pn_dlci
+	ifetch 1,contr
+	store 1,mem_pn_credit_flow_type_info
+	ifetch 1,contr
+	store 1,mem_pn_priority
+	ifetch 1,contr
+	store 1,mem_pn_acknowledg_timer
+	ifetch 2,contr
+	store 2,mem_pn_max_frame_size
+	ifetch 1,contr
+	store 1,mem_pn_max_retrans
+	ifetch 1,contr
+	store 1,mem_remote_credits
+	rtn
+
+
+parse_DLCI0_rp_uih_ms_cmd:
+	call get_rfcomm_param_modem_status
+	fetch 1,mem_ms_channel
+	sub pdata,1,null
+	branch parse_DLCI0_rp_uih_ms_cmd_spp,zero
+	branch assert
+parse_DLCI0_rp_uih_ms_cmd_spp:
+	fetch 1,mem_spp_state
+	set1 RFCOMM_CHANNEL_STATE_RCV_MS_CMD,pdata
+	set1 RFCOMM_CHANNEL_STATE_SND_MS_RES,pdata
+	store 1,mem_spp_state
+	fetcht 1,mem_pn_dlci
+	lshift2 temp,temp
+	or_into 3,temp
+	call rfcomm_send_modem_status_res
+	jam MORE_PKT_MSC_CMD_SPP,mem_rfcomm_send_more_pkt
+	branch rfcomm_rx_process_end
+	
+parse_DLCI0_rp_uih_ms_res:
+	call get_rfcomm_param_modem_status
+	fetch 1,mem_ms_channel
+	sub pdata,1,null
+	branch parse_DLCI0_rp_uih_MS_RES_spp,zero
+	branch assert
+parse_DLCI0_rp_uih_ms_res_spp:
+	fetch 1,mem_spp_state
+	set1 RFCOMM_CHANNEL_STATE_RCV_MS_RES,pdata
+	store 1,mem_spp_state
+	branch rfcomm_rx_process_end
+
+parse_uih_rp:
+	fetch 1,mem_current_channel
+	sub pdata,SPP_SLAVE_CHANNEL,null
+	branch parse_uih_rp_spp,zero
+	branch assert
+parse_uih_rp_spp:
+	fetch 1,mem_current_frame_type
+	beq RFCOMM_FRAME_TYPE_UA,parse_uih_rp_spp_ua
+	beq RFCOMM_FRAME_TYPE_SABM,parse_uih_rp_spp_sabm
+	beq RFCOMM_FRAME_TYPE_UIH,parse_uih_spp_uih
+	beq RFCOMM_FRAME_TYPE_UIH_CREDITS,parse_uih_spp_uih_credits
+	beq RFCOMM_FRAME_TYPE_DISCONN,parse_uih_rp_spp_disconn
+	branch assert
+parse_uih_rp_spp_ua:
+	fetch 1,mem_spp_state
+	set1 RFCOMM_CHANNEL_STATE_UA,pdata
+	store 1,mem_spp_state
+	branch rfcomm_rx_process_end
+parse_uih_rp_spp_sabm:
+	fetch 1,mem_spp_state
+	set1 RFCOMM_CHANNEL_STATE_UA,pdata
+	set1 RFCOMM_CHANNEL_STATE_SABM,pdata
+	store 1,mem_spp_state
+	fetch 1,mem_current_adss
+	call rfcomm_calculate_FCS_ua
+	store 1,mem_current_fcs
+	call rfcomm_send_ua
+	fetch 1,mem_current_adss
+	rshift2 pdata,pdata
+	store 1,mem_pn_dlci
+	lshift2 pdata,pdata
+	set0 RFCOMM_ADDRESS_CR,pdata
+	set1 RFCOMM_ADDRESS_EXT_LEN,pdata 
+	arg mem_HIUfcs_spp,temp // mem_HIUfcs_HF_WCredits in regb++
+	storet 2,mem_contw_temp
+	call rfcomm_save_FCS_uih
+	branch rfcomm_rx_process_end
+	
+parse_uih_spp_uih_credits:
+	fetch 2,mem_rfcomm_uih_payload_ptr
+	copy pdata,contr
+	increase 1,pdata
+	store 2,mem_rfcomm_uih_payload_ptr
+	ifetch 1,contr //remote credits
+	fetcht 1,mem_remote_credits
+	iadd temp,pdata
+	store 1,mem_remote_credits
+parse_uih_spp_uih:
+	call rfcomm_increase_credit_given
+parse_uih_spp_uih_cont:
+	call get_rfcomm_snd_adss
+	call rfcomm_send_uih_without_payload
+	call spp_process_rx_data
+	branch rfcomm_rx_process_end
+	
+parse_uih_rp_spp_disconn:
+	call rfcomm_init_spp
+	fetch 1,mem_current_adss
+	call rfcomm_calculate_FCS_ua
+	store 1,mem_current_fcs
+	call rfcomm_send_ua
+	branch rfcomm_rx_process_end
+	
+///////////////////////////////////////////
+///////////////////////////////////////////
+///////////////////////////////////////////
+rfcomm_rx_process_reconn:
+	fetch 2,mem_l2cap_payload_ptr
+	copy pdata,contr
+	call get_rfcomm_head_struct
+	fetch 1,mem_current_channel
+	beq 0,parse_DLCI0_reconn
+	branch parse_uih_reconn
+		
+parse_DLCI0_reconn:
+	set1 mark_ext_patch,mark
+	bpatch patch38_2,mem_patch38
+	fetch 1,mem_current_frame_type
+	beq RFCOMM_FRAME_TYPE_SABM,rfcomm_rx_process_DLCI0_sabm
+	beq RFCOMM_FRAME_TYPE_UA,rfcomm_rx_process_DLCI0_ua
+	beq RFCOMM_FRAME_TYPE_UIH,parse_DLCI0_reconn_uih
+	branch rfcomm_rx_process_end
+parse_DLCI0_reconn_uih:
+	fetch 2,mem_rfcomm_uih_payload_ptr
+	copy pdata,contr
+	call get_rfcomm_uih_head_struct
+	fetch 1,mem_uih_cmd_type
+	beq UIH_PARAM_NEG_CMD,parse_DLCI0_reconn_uih_pn_cmd
+	beq UIH_PARAM_NEG_RES,parse_DLCI0_reconn_uih_pn_cmd
+	beq UIH_MODEM_STATUS_CMD,parse_DLCI0_reconn_uih_ms_cmd
+	beq UIH_MODEM_STATUS_RES,parse_DLCI0_reconn_uih_ms_res
+	branch rfcomm_rx_process_end
+
+parse_DLCI0_reconn_uih_pn_cmd:
+	call parse_DLCI0_rp_uih_pn_res_common
+	fetch 1,mem_pn_dlci
+	rshift pdata,pdata
+	fetcht 1,mem_remote_spp_channel
+	isub temp,null
+	branch parse_DLCI0_reconn_uih_pn_cmd_spp,zero
+	branch assert
+parse_DLCI0_reconn_uih_pn_cmd_spp:
+	fetch 1,mem_spp_state
+	set1 RFCOMM_CHANNEL_STATE_PN_RES,pdata
+	store 1,mem_spp_state
+	branch rfcomm_rx_process_end
+
+parse_DLCI0_reconn_uih_ms_cmd:
+	call get_rfcomm_param_modem_status
+	fetch 1,mem_ms_channel
+	fetcht 1,mem_remote_spp_channel
+	isub temp,null
+	branch parse_DLCI0_reconn_uih_ms_cmd_spp,zero
+	branch assert
+	branch rfcomm_rx_process_end
+parse_DLCI0_reconn_uih_ms_cmd_spp:
+	fetch 1,mem_spp_state
+	set1 RFCOMM_CHANNEL_STATE_RCV_MS_CMD,pdata
+	set1 RFCOMM_CHANNEL_STATE_SND_MS_RES,pdata
+	store 1,mem_spp_state
+	fetcht 1,mem_pn_dlci
+	lshift2 temp,temp
+	or_into 3,temp
+	call rfcomm_send_modem_status_res
+	branch rfcomm_rx_process_end
+	
+parse_DLCI0_reconn_uih_ms_res:
+	call get_rfcomm_param_modem_status
+	fetch 1,mem_ms_channel
+	fetcht 1,mem_remote_spp_channel
+	isub temp,null
+	branch parse_DLCI0_reconn_uih_ms_res_spp,zero
+	branch assert
+parse_DLCI0_reconn_uih_ms_res_spp:
+	fetch 1,mem_spp_state
+	set1 RFCOMM_CHANNEL_STATE_RCV_MS_RES,pdata
+	store 1,mem_spp_state
+	branch rfcomm_rx_process_end
+
+parse_uih_reconn:
+	fetch 1,mem_current_channel
+	fetcht 1,mem_remote_spp_channel
+	isub temp,null
+	branch parse_uih_reconn_spp,zero
+	branch assert
+	branch rfcomm_rx_process_end
+
+parse_uih_reconn_spp:
+	fetch 1,mem_current_frame_type
+	beq RFCOMM_FRAME_TYPE_UA,parse_uih_reconn_spp_ua
+	beq RFCOMM_FRAME_TYPE_UIH,parse_uih_spp_uih
+	beq RFCOMM_FRAME_TYPE_UIH_CREDITS,parse_uih_spp_uih_credits
+	beq RFCOMM_FRAME_TYPE_DISCONN,parse_uih_reconn_spp_disconn
+parse_uih_reconn_spp_ua:
+	fetch 1,mem_spp_state
+	set1 RFCOMM_CHANNEL_STATE_UA,pdata
+	store 1,mem_spp_state
+	branch rfcomm_rx_process_end
+parse_uih_reconn_spp_sabm:
+	branch parse_uih_reconn_spp_sabm//loop
+parse_uih_reconn_spp_disconn:
+	branch parse_uih_rp_spp_disconn
+rfcomm_rx_process_end:
+	rtn
+	
+rfcomm_send_more_pkt:
+	fetch 1,mem_rfcomm_send_more_pkt
+	rtn blank
+	beq MORE_PKT_MSC_CMD_SPP,rfcomm_send_more_pkt_msc_cmd_spp
+	branch assert
+	
+rfcomm_send_more_pkt_msc_cmd_spp:
+	jam 0,mem_rfcomm_send_more_pkt
+	call l2cap_malloc_rfcomm_channel
+	arg SPP_SLAVE_CHANNEL,temp
+	lshift3 temp,temp
+rfcomm_send_more_pkt_msc_cmd_spp0:
+	or_into 0x03,temp
+	arg 0xaa,rega
+	call rfcomm_send_modem_status_cmd
+	call l2cap_get_rfcomm_tx_buff
+	copy contw,contr
+	ifetch 2, contr
+	branch assert,blank
+	rtn
+
+rfcomm_send_sabm:
+	set1 mark_ext_patch,mark
+	bpatch patch38_3,mem_patch38
+	call l2cap_get_rfcomm_tx_buff
+	setarg 0x0004
+	istore 2,contw //l2cap len
+	fetch 2,mem_rfcomm_remote_cid
+	istore 2,contw//cid
+	fetch 1,mem_current_adss
+	istore 1,contw //address
+	setarg 0x013f
+	istore 2,contw
+	fetch 1,mem_current_fcs
+	istore 1,contw
+	rtn
+rfcomm_send_ua:
+	set1 mark_ext_patch,mark
+	bpatch patch38_4,mem_patch38
+	call l2cap_malloc_rfcomm_channel
+	call l2cap_get_rfcomm_tx_buff
+	setarg 0x0004
+	istore 2,contw //l2cap len
+	fetch 2,mem_rfcomm_remote_cid
+	istore 2,contw//cid
+	fetch 1,mem_current_adss
+	istore 1,contw //address
+	setarg 0x0173
+	istore 2,contw
+	fetch 1,mem_current_fcs
+	istore 1,contw
+	rtn
+rfcomm_send_param_neg_cmd:
+	set1 mark_ext_patch,mark
+	bpatch patch38_5,mem_patch38
+	call l2cap_get_rfcomm_tx_buff
+	setarg 0x000e
+	istore 2,contw //l2cap len
+	fetch 2,mem_rfcomm_remote_cid
+	istore 2,contw//cid
+	fetch 1,mem_rfcomm_initiator
+	lshift pdata,pdata
+	set1 0,pdata //ext len
+	istore 1,contw //DLCI0 address
+	setarg 0x15ef
+	istore 2,contw
+	setarg 0x1183
+	istore 2,contw
+	copy temp,pdata //DLCI in temp
+	istore 1,contw
+	setarg 0x0000f0
+	istore 3,contw
+	setarg RFCOMM_MAX_FRAME_SIZE
+	istore 2,contw
+	setarg 0
+	istore 1,contw
+	setarg 0x01		//change here later
+	istore 1,contw
+	call rfcomm_calculate_FCS_dlci0
+	istore 1,contw
+	jam 0x10,mem_credit_given
+	rtn
+rfcomm_send_param_neg_res:
+	set1 mark_ext_patch,mark
+	bpatch patch38_6,mem_patch38
+	call l2cap_malloc_rfcomm_channel
+	call l2cap_get_rfcomm_tx_buff
+	setarg 0x000e
+	istore 2,contw //l2cap len
+	fetch 2,mem_rfcomm_remote_cid
+	istore 2,contw//cid
+	fetch 1,mem_rfcomm_initiator
+	lshift pdata,pdata
+	set1 0,pdata //ext len
+	istore 1,contw //DLCI0 address
+	setarg 0x15ef
+	istore 2,contw
+	setarg 0x1181
+	istore 2,contw
+	fetch 1,mem_pn_dlci
+	istore 1,contw //DLCI
+	setarg 0x0000e0
+	istore 3,contw
+	setarg RFCOMM_MAX_FRAME_SIZE //max frame size
+	istore 2,contw 
+	setarg 0x00 //max retrans
+	istore 1,contw
+	setarg 0x07
+	istore 1,contw // init credits
+	call rfcomm_calculate_FCS_dlci0
+	istore 1,contw
+	rtn
+rfcomm_send_modem_status_cmd:
+	set1 mark_ext_patch,mark
+	bpatch patch38_7,mem_patch38
+	call l2cap_get_rfcomm_tx_buff
+	setarg 0x0008
+	istore 2,contw //l2cap len
+	fetch 2,mem_rfcomm_remote_cid
+	istore 2,contw//cid
+	fetch 1,mem_rfcomm_initiator
+	lshift pdata,pdata
+	set1 0,pdata //ext len
+	istore 1,contw //DLCI0 address
+	setarg 0x09ef
+	istore 2,contw
+	setarg 0x05e3
+	istore 2,contw
+	copy temp,pdata //DLCI adress
+	istore 1,contw
+	setarg 0x8d
+	istore 1,contw
+	call rfcomm_calculate_FCS_dlci0
+	istore 1,contw
+	rtn
+
+rfcomm_send_modem_status_res:
+	set1 mark_ext_patch,mark
+	bpatch patch39_0,mem_patch39
+	call l2cap_malloc_rfcomm_channel
+	call l2cap_get_rfcomm_tx_buff
+	setarg 0x0008
+	istore 2,contw //l2cap len
+	fetch 2,mem_rfcomm_remote_cid
+	istore 2,contw//cid
+	copy temp,timeup
+	fetch 1,mem_rfcomm_initiator
+	lshift pdata,pdata
+	set1 0,pdata //ext len
+	istore 1,contw //DLCI0 address
+	setarg 0x09ef
+	istore 2,contw
+	setarg 0x05e1
+	istore 2,contw
+	copy timeup,pdata //DLCI address in temp
+	istore 1,contw
+	setarg 0x8d
+	istore 1,contw
+	call rfcomm_calculate_FCS_dlci0
+	istore 1,contw
+	rtn
+
+rfcomm_send_uih_without_payload:
+	set1 mark_ext_patch,mark
+	bpatch patch39_1,mem_patch39
+	fetch 1,mem_credit_given
+	rtn blank
+	hfetch 2,core_uart_rxitems
+	nrtn blank
+	copy rega,pdata
+	store 1,mem_pdatatemp+1
+	storet 1,mem_pdatatemp
+	call l2cap_malloc_is_fifo_full
+	nrtn blank
+	call l2cap_malloc_rfcomm_channel
+	call l2cap_get_rfcomm_tx_buff
+	setarg 0x05
+	istore 2,contw
+	fetch 2,mem_RFCOMM_remote_CID
+	istore 2,contw
+	fetch 1,mem_rfcomm_send_adss
+	istore 1,contw
+	setarg 0x01ff
+	istore 2,contw
+	fetch 1,mem_credit_given
+	istore 1,contw
+	fetch 1,mem_HIUfcs_SPP_WCredits
+	istore 1,contw
+	jam 0,mem_credit_given
+	rtn
+	
+rfcomm_increase_credit_given:
+	fetch 2,mem_current_length
+	rtn blank
+	fetch 1,mem_credit_given
+	increase 1,pdata
+	store 1,mem_credit_given
+	rtn
+
+spp_process_rx_data:
+	set1 mark_ext_patch,mark
+	bpatch patch39_2,mem_patch39
+	fetch 2,mem_current_length
+	copy pdata,loopcnt
+	call uartd_prepare_tx
+	fetch 2,mem_rfcomm_uih_payload_ptr
+	copy pdata,contr
+	call uart_copy_tx_bytes
+	branch uartd_send
+
+spp_tx_rfcomm_packet:
+	set1 mark_ext_patch,mark
+	bpatch patch39_3,mem_patch39
+	//credit
+	fetch 1,mem_remote_credits
+	rtn blank
+	increase -1,pdata
+	store 1,mem_remote_credits
+	fetch 2,mem_pn_max_frame_size
+	fetcht 2,mem_current_packet_length
+	isub temp,null
+	branch spp_tx_rfcomm_from_uart,positive
+	store 2,mem_current_packet_length
+spp_tx_rfcomm_from_uart:
+	fetch 1,mem_credit_given
+	branch spp_tx_rfcomm_from_uart_without_credit,blank
+	jam 1,mem_rfcomm_send_offset
+	fetch 1,mem_HIUfcs_SPP_WCredits
+	store 1,mem_rfcomm_send_fcs
+	setarg RSP_RX_UIH_WDATA
+	store 1,mem_rfcomm_send_frame_type
+	branch spp_tx_rfcomm_from_uart_common
+spp_tx_rfcomm_from_uart_without_credit:
+	jam 0,mem_rfcomm_send_offset
+	fetch 1,mem_HIUfcs_SPP
+	store 1,mem_rfcomm_send_fcs
+	setarg RSP_TX_UIH
+	store 1,mem_rfcomm_send_frame_type
+spp_tx_rfcomm_from_uart_common:
+	set1 mark_ext_patch,mark
+	bpatch patch39_4,mem_patch39
+	fetch 1,mem_current_packet_length
+	sub pdata,127,null
+	branch spp_tx_rfcomm_from_uart_common0,positive
+	fetch 1,mem_rfcomm_send_offset
+	increase 1,pdata
+	store 1,mem_rfcomm_send_offset
+spp_tx_rfcomm_from_uart_common0:
+	call get_rfcomm_snd_adss
+	fetch 2,mem_current_packet_length
+	increase 8,pdata	//fcs + rfcommhead + l2caphead == 8
+	fetcht 1,mem_rfcomm_send_offset
+	iadd temp,rega
+	//rfcomm payload
+	call l2cap_malloc
+	store 2,mem_rfcomm_tx_buff_ptr
+	increase 4,pdata
+	store 2,mem_rfcomm_tx_payload_ptr
+	copy pdata,contw
+	fetch 1,mem_rfcomm_send_adss
+	istore 1,contw
+	fetch 1,mem_rfcomm_send_frame_type
+	istore 1,contw
+	call spp_tx_write_length
+	call spp_tx_write_given_credit
+	call get_uart_rrptr	
+	fetch 1,mem_current_packet_length
+	copy pdata,loopcnt
+	call uart_copy_rx_bytes
+	fetch 1,mem_rfcomm_send_fcs
+	istore 1,contw
+	fetch 2,mem_rfcomm_tx_buff_ptr
+	copy pdata,contw
+	fetch 2,mem_current_packet_length
+	fetcht 1,mem_rfcomm_send_offset
+	iadd temp,pdata
+	increase 4,pdata
+	istore 2,contw
+	fetch 2,mem_rfcomm_remote_cid
+	istore 2,contw
+	jam 0,mem_credit_given	//whatever mem_credit_given is set to 0
+	branch spp_send_end
+	
+spp_tx_write_length:
+	fetch 2,mem_current_packet_length
+	sub pdata,0x7f,null
+	nbranch spp_tx_write_long_packet,positive
+	lshift pdata,pdata
+	set1 0,pdata
+	istore 1,contw
+	rtn
+spp_tx_write_long_packet:
+	fetch 2,mem_current_packet_length
+	rshift3 pdata,pdata
+	rshift4 pdata,temp
+	and_into 0x7f,pdata
+	lshift pdata,pdata
+	set0 0,pdata
+	istore 1,contw
+	istoret 1,contw
+	rtn
+spp_tx_write_given_credit:
+	fetch 1,mem_credit_given
+	rtn blank
+	istore 1,contw
+	rtn
+
+	
+
+
+else
+
+rfcomm_init:
+	rtn
+endif
Index: btkb/program/scheduler.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/scheduler.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/scheduler.prog	(working copy)
@@ -0,0 +1,491 @@
+scheduler_process:
+	set1 mark_ext_patch,mark
+	bpatch patch33_5,mem_patch33
+	call check_51cmd
+	call app_process_bb_event
+	call process_conn_sm
+/* check the connection state sequence byte */
+	set1 mark_ext_patch,mark
+	bpatch patch33_6,mem_patch33
+ifdef SIMPLE_PAIRING
+	call sp_calc_sequence
+	call simple_pairing_sequence
+	call master_simple_paring_sequence
+endif
+//return if it is hci mode. 'cause the following is host part.
+	set1 mark_ext_patch,mark
+	bpatch patch33_7,mem_patch33
+	fetch 1,mem_device_option
+	rtneq dvc_op_hci
+//notify BB to tx a l2cap packet
+	call l2cap_malloc_is_fifo_full
+	nrtn blank
+	//for conn to MTK 
+	call l2cap_call_proc_sigal_pending
+scheduler_process1:
+	call l2cap_malloc_is_fifo_full
+	nrtn blank
+	set1 mark_ext_patch,mark
+	bpatch patch34_0,mem_patch34
+//to generat a new l2cap packet
+	call process_upper_sm
+	call l2cap_send_config_req
+ifdef COMPILE_RFCOMM
+	call rfcomm_send_more_pkt//use this function to send msc_cmd after msc_rep sent
+endif
+scheduler_process0:
+	call scheduler_tx_disconnect_hid //may not used
+	set1 mark_ext_patch,mark
+	bpatch patch34_1,mem_patch34
+	call l2cap_malloc_is_fifo_full
+	nrtn blank
+	branch app_process_bt
+	
+scheduler_tx_disconnect_hid:
+	set1 mark_ext_patch,mark
+	bpatch patch34_2,mem_patch34
+	fetch 1,mem_CONTROL_tasks		
+	bbit1 L2CAP_DISCONNECT_INTERRUPT,L2CAP_disconnect_interrupt_req
+	bbit1 L2CAP_DISCONNECT_CONTROL,L2CAP_disconnect_control_req
+	rtn
+	
+scheduler_tx_l2cap_pkt:
+	set1 mark_ext_patch,mark
+	bpatch patch34_3,mem_patch34
+	call l2cap_malloc_is_fifo_empty
+	rtn blank //empty
+	fetch 1,mem_op
+	rtnbit1 op_txl2cap
+	call l2cap_malloc_fifo_out
+	store 2,mem_txptr
+	copy pdata,contr
+	ifetch 2,contr
+	increase 4,pdata
+	store 2,mem_tx_len
+	jam 6,mem_tx_lch//start pkt
+	set1 mark_ext_patch,mark
+	bpatch patch34_4,mem_patch34
+	fetch 2,mem_l2cap_tx_multi_offset
+	branch scheduler_tx_l2cap_start_pkt,blank
+	fetch 1,mem_op
+	rtnbit0 op_pkt_comp
+	set0 op_pkt_comp,pdata
+	store 1,mem_op
+	jam 5,mem_tx_lch//continue pkt
+	fetcht 2,mem_l2cap_tx_multi_offset
+	fetch 2,mem_txptr
+	iadd temp,pdata
+	store 2,mem_txptr
+	fetch 2,mem_tx_len
+	isub temp,pdata
+	store 2,mem_tx_len
+scheduler_tx_l2cap_start_pkt:
+	set1 mark_ext_patch,mark
+	bpatch patch34_5,mem_patch34
+	fetch 2,mem_tx_len
+	branch assert,blank
+	arg l2cap_max_pkt_len,temp //max len of dh3 pkt
+	isub temp,pdata
+	nbranch scheduler_Tx_l2cap_last_pkt,positive
+	set1 mark_ext_patch,mark
+	bpatch patch34_6,mem_patch34
+	storet 2,mem_tx_len //l2cap_max_pkt_len
+	fetch 2,mem_l2cap_tx_multi_offset
+	iadd temp,pdata
+	store 2,mem_l2cap_tx_multi_offset
+	branch scheduler_Tx_l2cap_pkt_end
+scheduler_Tx_l2cap_last_pkt:
+	setarg 0
+	store 2,mem_l2cap_tx_multi_offset
+scheduler_Tx_l2cap_pkt_end:
+	fetch 1,mem_op
+	set1 op_txl2cap,pdata
+	store 1,mem_op
+	rtn
+
+scheduler_start_upper_sm:
+	fetch 1,mem_UI_profile_supported
+	bbit1 support_HID,scheduler_start_upper_sm_hid
+	jam UPPERSM_RECONN_SDP_CONN,mem_upper_sm_reconn
+	rtn
+scheduler_start_upper_sm_hid:
+	jam UPPERSM_RECONN_HID_CTRL_CONN,mem_upper_sm_reconn
+	rtn
+	
+process_upper_sm:
+	fetch 1,memui_reconnect_mode
+	nbranch process_upper_sm_reconn,blank
+process_upper_sm_remote_page:
+	fetch 1,mem_upper_sm_remote_page
+	//beq UPPERSM_RP_IDLE,process_upper_sm_rp_idle
+	rtn blank
+	//nothing to do when remote page to create a connection.
+	jam 0,mem_upper_sm_remote_page
+process_upper_sm_rp_wait:
+	rtn
+
+
+process_upper_sm_reconn:
+	set1 mark_ext_patch,mark
+	bpatch patch34_7,mem_patch34
+	fetch 1,mem_upper_sm_reconn
+	rtn blank
+	beq UPPERSM_RECONN_SDP_CONN,process_upper_sm_reconn_sdp_conn
+	beq UPPERSM_RECONN_SDP_CONN_WAIT,process_upper_sm_reconn_sdp_conn_wait
+	beq UPPERSM_RECONN_SDP_CFG,process_upper_sm_reconn_sdp_cfg
+	beq UPPERSM_RECONN_SDP_CFG_WAIT,process_upper_sm_reconn_sdp_cfg_wait
+	beq UPPERSM_RECONN_SS_SPP,process_upper_sm_reconn_ss_spp
+	beq UPPERSM_RECONN_SS_SPP_WAIT,process_upper_sm_reconn_ss_spp_wait
+	beq UPPERSM_RECONN_SDP_DISCONN,process_upper_sm_reconn_sdp_disconn
+	beq UPPERSM_RECONN_SDP_DISCONN_WAIT,process_upper_sm_reconn_sdp_disconn_wait
+	beq UPPERSM_RECONN_HID_CTRL_CONN,process_upper_sm_reconn_hid_ctrl_conn
+	beq UPPERSM_RECONN_HID_CTRL_CONN_WAIT,process_upper_sm_reconn_hid_ctrl_conn_wait
+	beq UPPERSM_RECONN_HID_CTRL_CFG,process_upper_sm_reconn_hid_ctrl_cfg
+	beq UPPERSM_RECONN_HID_CTRL_CFG_WAIT,process_upper_sm_reconn_hid_ctrl_cfg_wait
+	beq UPPERSM_RECONN_HID_INT_CONN,process_upper_sm_reconn_hid_int_conn
+	beq UPPERSM_RECONN_HID_INT_CONN_WAIT,process_upper_sm_reconn_hid_int_conn_wait
+	beq UPPERSM_RECONN_HID_INT_CFG,process_upper_sm_reconn_hid_int_cfg
+	beq UPPERSM_RECONN_HID_INT_CFG_WAIT,process_upper_sm_reconn_hid_int_cfg_wait
+	beq UPPERSM_RECONN_RFCOMM_CONN,process_upper_sm_reconn_rfcomm_conn
+	beq UPPERSM_RECONN_RFCOMM_CONN_WAIT,process_upper_sm_reconn_rfcomm_conn_wait
+	beq UPPERSM_RECONN_RFCOMM_CFG,process_upper_sm_reconn_rfcomm_cfg
+	beq UPPERSM_RECONN_RFCOMM_CFG_WAIT,process_upper_sm_reconn_rfcomm_cfg_wait
+	beq UPPERSM_RECONN_RFCOMM_SABM,process_upper_sm_reconn_rfcomm_sabm
+	beq UPPERSM_RECONN_RFCOMM_SABM_WAIT,process_upper_sm_reconn_rfcomm_sabm_wait
+	beq UPPERSM_RECONN_SPP_CMD_PN,process_upper_sm_reconn_spp_cmd_pn
+	beq UPPERSM_RECONN_SPP_CMD_PN_WAIT,process_upper_sm_reconn_spp_cmd_pn_wait
+	beq UPPERSM_RECONN_SPP_SABM,process_upper_sm_reconn_spp_sabm
+	beq UPPERSM_RECONN_SPP_SABM_WAIT,process_upper_sm_reconn_spp_sabm_wait
+	beq UPPERSM_RECONN_SPP_CMD_MS,process_upper_sm_reconn_spp_cmd_ms
+	beq UPPERSM_RECONN_SPP_CMD_MS_WAIT,process_upper_sm_reconn_spp_cmd_ms_wait
+process_upper_sm_reconn_wait:
+	rtn
+process_upper_sm_reconn_sdp_conn:
+	call upper_sm_send_sdp_conn //return n-user if sending failed
+	jam UPPERSM_RECONN_SDP_CONN_WAIT,mem_upper_sm_reconn
+	fetch 1,mem_sdp_state
+	set1 L2CAP_CHANNEL_STATE_CONN_REQ,pdata
+	store 1,mem_sdp_state
+	rtn
+process_upper_sm_reconn_sdp_cfg:
+	jam UPPERSM_RECONN_SDP_CFG_WAIT,mem_upper_sm_reconn
+	fetch 1,mem_sdp_state
+	rtnbit1 L2CAP_CHANNEL_STATE_SND_CFG_REQ
+	jam UPPERSM_RECONN_SDP_CFG,mem_upper_sm_reconn
+	call upper_sm_send_sdp_cfg //return n-user if sending failed
+	jam UPPERSM_RECONN_SDP_CFG_WAIT,mem_upper_sm_reconn
+	fetch 1,mem_sdp_state
+	set1 L2CAP_CHANNEL_STATE_SND_CFG_REQ,pdata
+	store 1,mem_sdp_state
+	rtn
+process_upper_sm_reconn_ss_spp:
+	call l2cap_malloc_is_fifo_empty
+	nrtn blank
+	call upper_sm_send_ss_spp
+	jam UPPERSM_RECONN_SS_SPP_WAIT,mem_upper_sm_reconn
+	rtn
+process_upper_sm_reconn_sdp_disconn:
+	call upper_sm_send_sdp_disconn
+	jam UPPERSM_RECONN_SDP_DISCONN_WAIT,mem_upper_sm_reconn
+	rtn
+process_upper_sm_reconn_hid_ctrl_conn:
+	call upper_sm_send_hid_ctrl_conn
+	jam UPPERSM_RECONN_HID_CTRL_CONN_WAIT,mem_upper_sm_reconn
+	fetch 1,mem_hid_control_state
+	set1 L2CAP_CHANNEL_STATE_CONN_REQ,pdata
+	store 1,mem_hid_control_state
+	rtn
+process_upper_sm_reconn_hid_ctrl_cfg:    
+	call upper_sm_send_hid_ctrl_cfg
+	jam UPPERSM_RECONN_HID_CTRL_CFG_WAIT,mem_upper_sm_reconn
+	fetch 1,mem_hid_control_state
+	set1 L2CAP_CHANNEL_STATE_SND_CFG_REQ,pdata
+	store 1,mem_hid_control_state
+	rtn
+process_upper_sm_reconn_hid_int_conn:
+	call upper_sm_send_hid_int_conn
+	jam UPPERSM_RECONN_HID_INT_CONN_WAIT,mem_upper_sm_reconn
+	fetch 1,mem_hid_interrupt_state
+	set1 L2CAP_CHANNEL_STATE_CONN_REQ,pdata
+	store 1,mem_hid_interrupt_state
+	rtn
+process_upper_sm_reconn_hid_int_cfg:    
+	call upper_sm_send_hid_int_cfg
+	jam UPPERSM_RECONN_HID_INT_CFG_WAIT,mem_upper_sm_reconn
+	fetch 1,mem_hid_interrupt_state
+	set1 L2CAP_CHANNEL_STATE_SND_CFG_REQ,pdata
+	store 1,mem_hid_interrupt_state
+	rtn
+process_upper_sm_reconn_rfcomm_conn:
+	call upper_sm_send_rfcomm_conn
+	jam UPPERSM_RECONN_RFCOMM_CONN_WAIT,mem_upper_sm_reconn
+	fetch 1,mem_rfcomm_state
+	set1 L2CAP_CHANNEL_STATE_CONN_REQ,pdata
+	store 1,mem_rfcomm_state
+	rtn
+process_upper_sm_reconn_rfcomm_cfg: 
+	call upper_sm_send_rfcomm_cfg
+	jam UPPERSM_RECONN_RFCOMM_CFG_WAIT,mem_upper_sm_reconn
+	fetch 1,mem_rfcomm_state
+	set1 L2CAP_CHANNEL_STATE_SND_CFG_REQ,pdata
+	store 1,mem_rfcomm_state
+	rtn
+process_upper_sm_reconn_rfcomm_sabm:
+	call upper_sm_send_rfcomm_sabm
+	jam UPPERSM_RECONN_RFCOMM_SABM_WAIT,mem_upper_sm_reconn
+	fetch 1,mem_rfcomm_state
+	set1 L2CAP_CHANNEL_RFCOMM_ONLY_SABM,pdata
+	store 1,mem_rfcomm_state
+	rtn
+process_upper_sm_reconn_spp_cmd_pn: 
+	call upper_sm_send_spp_cmd_pn
+	fetch 1,mem_spp_state
+	set1 RFCOMM_CHANNEL_STATE_PN_CMD
+	store 1,mem_spp_state
+	jam UPPERSM_RECONN_SPP_CMD_PN_WAIT,mem_upper_sm_reconn
+	rtn
+process_upper_sm_reconn_spp_sabm:   
+	call upper_sm_send_spp_sabm
+	fetch 1,mem_spp_state
+	set1 RFCOMM_CHANNEL_STATE_SABM
+	store 1,mem_spp_state
+	jam UPPERSM_RECONN_SPP_SABM_WAIT,mem_upper_sm_reconn
+	fetch 1,mem_remote_spp_channel //address in pdata
+	lshift3 pdata,pdata
+	or_into 3,pdata
+	arg mem_HIUfcs_SPP,temp // mem_HIUfcs_spp_WCredits in regb++
+	storet 2,mem_contw_temp
+	branch rfcomm_save_FCS_uih
+process_upper_sm_reconn_spp_cmd_ms: 
+	call upper_sm_send_spp_cmd_ms
+	fetch 1,mem_spp_state
+	set1 RFCOMM_CHANNEL_STATE_SND_MS_CMD
+	store 1,mem_spp_state
+	jam UPPERSM_RECONN_SPP_CMD_MS_WAIT,mem_upper_sm_reconn
+	rtn
+
+process_upper_sm_reconn_sdp_conn_wait:
+	fetch 1,mem_sdp_state
+	rtnbit0 L2CAP_CHANNEL_STATE_CONN_RES
+	jam UPPERSM_RECONN_SDP_CFG,mem_upper_sm_reconn
+	branch process_upper_sm_reconn
+process_upper_sm_reconn_sdp_cfg_wait:
+	fetch 1,mem_sdp_state
+	rtnne L2CAP_CHANNEL_SETUP_COMPLETE
+	jam UPPERSM_RECONN_SS_SPP ,mem_upper_sm_reconn
+process_upper_sm_reconn_ss_spp_wait:
+	fetch 1,mem_message_to_uppersm
+	rtnne RECIEVE_SS_REASULT_HF
+	jam 0,mem_message_to_uppersm
+	jam UPPERSM_RECONN_SDP_DISCONN,mem_upper_sm_reconn
+	branch process_upper_sm_reconn
+process_upper_sm_reconn_sdp_disconn_wait:
+	fetch 1,mem_sdp_state
+	nrtn blank
+	fetch 1,mem_UI_profile_supported
+	bbit1 support_HID,process_upper_sm_reconn_setup_hid
+	bbit1 support_SPP,process_upper_sm_reconn_setup_rfcomm
+	branch process_upper_sm_reconn_termination
+process_upper_sm_reconn_hid_ctrl_conn_wait:
+	fetch 1,mem_hid_control_state
+	rtnbit0 L2CAP_CHANNEL_STATE_CONN_RES
+	jam UPPERSM_RECONN_HID_CTRL_CFG,mem_upper_sm_reconn
+	branch process_upper_sm_reconn
+process_upper_sm_reconn_hid_ctrl_cfg_wait:
+	fetch 1,mem_hid_control_state
+	rtnne L2CAP_CHANNEL_SETUP_COMPLETE
+	jam UPPERSM_RECONN_HID_INT_CONN,mem_upper_sm_reconn
+	branch process_upper_sm_reconn
+process_upper_sm_reconn_hid_int_conn_wait:  
+	fetch 1,mem_hid_interrupt_state
+	rtnbit0 L2CAP_CHANNEL_STATE_CONN_RES
+	jam UPPERSM_RECONN_HID_INT_CFG,mem_upper_sm_reconn
+	branch process_upper_sm_reconn
+process_upper_sm_reconn_hid_int_cfg_wait:  
+	fetch 1,mem_hid_interrupt_state
+	rtnne L2CAP_CHANNEL_SETUP_COMPLETE
+	fetch 1,mem_UI_profile_supported
+	bbit1 support_SPP,process_upper_sm_reconn_setup_rfcomm
+	branch process_upper_sm_reconn_termination
+process_upper_sm_reconn_rfcomm_conn_wait: 
+	fetch 1,mem_rfcomm_state
+	rtnbit0 L2CAP_CHANNEL_STATE_CONN_RES
+	jam UPPERSM_RECONN_RFCOMM_CFG,mem_upper_sm_reconn
+	branch process_upper_sm_reconn
+process_upper_sm_reconn_rfcomm_cfg_wait:
+	fetch 1,mem_rfcomm_state
+	rtnne L2CAP_CHANNEL_SETUP_COMPLETE
+	jam UPPERSM_RECONN_RFCOMM_SABM,mem_upper_sm_reconn
+	branch process_upper_sm_reconn
+process_upper_sm_reconn_rfcomm_sabm_wait:  
+	fetch 1,mem_rfcomm_state
+	rtnne L2CAP_CHANNEL_RFCOMM_DLCI0_OPENED
+	fetch 1,mem_UI_profile_supported
+	bbit1 support_SPP,process_upper_sm_reconn_setup_spp
+	branch process_upper_sm_reconn_termination
+process_upper_sm_reconn_spp_cmd_pn_wait:
+	fetch 1,mem_spp_state
+	rtnbit0 RFCOMM_CHANNEL_STATE_PN_RES
+	jam UPPERSM_RECONN_SPP_SABM,mem_upper_sm_reconn
+	branch process_upper_sm_reconn
+process_upper_sm_reconn_spp_sabm_wait:
+	fetch 1,mem_spp_state
+	rtnbit0 RFCOMM_CHANNEL_STATE_UA
+	jam UPPERSM_RECONN_SPP_CMD_MS ,mem_upper_sm_reconn
+	branch process_upper_sm_reconn
+process_upper_sm_reconn_spp_cmd_ms_wait: 
+	fetch 1,mem_spp_state
+	rtnne RFCOMM_CHANNEL_SETUP_COMPLETE
+	branch process_upper_sm_reconn_termination
+
+process_upper_sm_reconn_setup_hid:
+	jam UPPERSM_RECONN_HID_CTRL_CONN,mem_upper_sm_reconn
+	branch process_upper_sm_reconn
+
+process_upper_sm_reconn_setup_rfcomm:
+	jam UPPERSM_RECONN_RFCOMM_CONN,mem_upper_sm_reconn
+	branch process_upper_sm_reconn
+process_upper_sm_reconn_setup_spp:
+	jam UPPERSM_RECONN_SPP_CMD_PN,mem_upper_sm_reconn
+	branch process_upper_sm_reconn
+
+
+
+process_upper_sm_reconn_termination:
+	jam 0,mem_upper_sm_reconn
+	rtn
+upper_sm_send_sdp_conn:
+	set1 mark_ext_patch,mark
+	bpatch patch35_0,mem_patch35
+	call l2cap_malloc_signal_channel
+	setarg PSM_SDP
+	copy pdata,temp
+	setarg L2CAP_SDP_channel
+	copy pdata,timeup
+	branch ML2CAP_send_signal_connect_req
+	
+upper_sm_send_sdp_cfg:
+	set1 mark_ext_patch,mark
+	bpatch patch35_1,mem_patch35
+	call l2cap_malloc_signal_channel
+	fetch 2,mem_SDP_remote_CID
+	copy pdata,temp
+	branch ML2CAP_send_signal_config_req
+	
+upper_sm_send_sdp_disconn:
+	set1 mark_ext_patch,mark
+	bpatch patch35_2,mem_patch35
+	call l2cap_malloc_signal_channel
+	fetch 2,mem_SDP_remote_CID
+	copy pdata,temp
+	arg L2CAP_SDP_channel,timeup
+	call ML2CAP_send_signal_disconn_req
+	fetch 1,mem_sdp_state
+	set0 L2CAP_CHANNEL_STATE_RCV_CFG_RES ,pdata
+	store 1,mem_sdp_state
+	rtn
+//service search
+upper_sm_send_ss_spp:
+	set1 mark_ext_patch,mark
+	bpatch patch35_3,mem_patch35
+	call l2cap_malloc_sdp_channel
+	call sdp_send_spp_request
+	branch MSDP_send_req_done
+
+upper_sm_send_rfcomm_conn:
+	set1 mark_ext_patch,mark
+	bpatch patch35_4,mem_patch35
+	call l2cap_malloc_signal_channel
+	setarg PSM_RFCOMM
+	copy pdata,temp
+	setarg L2CAP_RFCOMM_channel
+	copy pdata,timeup
+	branch ML2CAP_send_signal_connect_req
+
+upper_sm_send_rfcomm_cfg:
+	set1 mark_ext_patch,mark
+	bpatch patch35_5,mem_patch35
+	call l2cap_malloc_signal_channel
+	fetch 2,mem_rfcomm_remote_cid
+	copy pdata,temp
+	branch ML2CAP_send_signal_config_req
+
+upper_sm_send_hid_ctrl_conn:
+	set1 mark_ext_patch,mark
+	bpatch patch35_6,mem_patch35
+	call l2cap_malloc_signal_channel
+	setarg PSM_HID_control
+	copy pdata,temp
+	setarg L2CAP_HID_Control_channel
+	copy pdata,timeup
+	branch ML2CAP_send_signal_connect_req
+
+upper_sm_send_hid_ctrl_cfg:
+	set1 mark_ext_patch,mark
+	bpatch patch35_7,mem_patch35
+	call l2cap_malloc_signal_channel
+	fetch 2,mem_hid_ctrl_remote_cid
+	copy pdata,temp
+	branch ML2CAP_send_signal_config_req
+
+upper_sm_send_hid_int_conn:
+	set1 mark_ext_patch,mark
+	bpatch patch36_0,mem_patch36
+	call l2cap_malloc_signal_channel
+	setarg PSM_HID_interrupt
+	copy pdata,temp
+	setarg L2CAP_HID_interrupt_channel
+	copy pdata,timeup
+	branch ML2CAP_send_signal_connect_req
+	
+upper_sm_send_hid_int_cfg:
+	set1 mark_ext_patch,mark
+	bpatch patch36_1,mem_patch36
+	call l2cap_malloc_signal_channel
+	fetch 2,mem_hid_int_remote_cid
+	copy pdata,temp
+	branch ML2CAP_send_signal_config_req
+
+upper_sm_send_rfcomm_sabm:
+	set1 mark_ext_patch,mark
+	bpatch patch36_2,mem_patch36
+	call l2cap_malloc_rfcomm_channel
+	//force 3,temp //address
+	jam 3,mem_current_adss
+	jam 0x1c,mem_current_fcs
+	call rfcomm_send_sabm
+	jam 1,mem_rfcomm_initiator
+	rtn
+
+upper_sm_send_spp_cmd_pn:
+	set1 mark_ext_patch,mark
+	bpatch patch36_3,mem_patch36
+	call l2cap_malloc_rfcomm_channel
+	fetcht 1,mem_remote_spp_channel
+	call channel_to_dlci
+	storet 1,mem_pn_dlci
+	branch rfcomm_send_param_neg_cmd
+
+upper_sm_send_spp_sabm:
+	set1 mark_ext_patch,mark
+	bpatch patch36_4,mem_patch36
+	call l2cap_malloc_rfcomm_channel
+	fetcht 1,mem_pn_dlci
+	call dlci_to_address_cmd
+	call rfcomm_calculate_FCS_sabm //sabm fcs use once only,not need to save
+	store 1,mem_current_fcs
+	fetcht 1,mem_pn_dlci
+	call dlci_to_address_cmd
+	storet 1,mem_current_adss
+	branch rfcomm_send_sabm
+
+upper_sm_send_spp_cmd_ms:
+	set1 mark_ext_patch,mark
+	bpatch patch36_5,mem_patch36
+	call l2cap_malloc_rfcomm_channel
+	fetcht 1,mem_pn_dlci
+	call dlci_to_address_cmd //address in temp
+	branch rfcomm_send_modem_status_cmd
+
+
+
Index: btkb/program/sdp.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/sdp.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/sdp.prog	(working copy)
@@ -0,0 +1,1315 @@
+/**********************************************************************/
+/* Subroutine: sdp_process                                         */
+/* Process Service Discovery Request                                  */
+/* Called from L2CAP, check PDUID, branch to different req processings*/
+/*                                                                    */  
+/* Input:       mem_L2CAP_Rx_payload                                  */
+/* Output:      mem_SDP_Tx_payload, mem_SDP_Tx_pkt_length	      */
+/*                                                                    */
+/**********************************************************************/     
+sdp_process:
+	set1 mark_ext_patch,mark
+	bpatch patch3c_7,mem_patch3c
+	fetch 2,mem_l2cap_payload_ptr
+	iforce contr
+	ifetch 1,contr
+	copy pdata,regb				/* PDUID */
+	store 1,mem_sdp_pduid
+	ifetch 2,contr
+	store 2,mem_sdp_transactionid			/* save transaction id */
+	ifetch 1,contr				/* higher byte of parameter length */
+	lshift8 pdata,timeup				
+	ifetch 1,contr				/* lower byte of parameter length */
+	iadd timeup,timeup				/* parameter length stored in "timeup" */
+	set1 mark_ext_patch,mark
+	bpatch patch3d_0,mem_patch3d
+	deposit regb						/* PDUID  */
+	beq SDP_SERVICE_SEARCH_REQUEST,servicesearch_req			
+	beq SDP_SERVICE_ATTRIBUTE_REQUEST,serviceattribute_req
+	beq SDP_SERVICE_SEARCH_ATTRIBUTE_REQUEST,servicesearchattribute_req
+	beq SDP_SERVICE_SEARCH_ATTRIBUTE_RESPONSE,servicesearchattribute_res
+	branch sdp_insufficient_resource
+
+/**********************************************************************/
+/* servicesearch_req			                              */
+/* Processing Service Search Request                                  */
+/* Call: ask_serviceclassid, empty_response                     */
+/*                                                                    */  
+/* Input:       mem_L2CAP_Rx_payload pointer in contr                 */
+/* Output:      mem_SDP_Tx_payload, mem_SDP_Tx_pkt_length	      */
+/*                                                                    */
+/**********************************************************************/     
+servicesearch_req:
+	call ask_serviceclassid
+	compare 1,temp,0xff
+	branch empth_sa_rsp,true
+	compare 0xff,temp,0xff
+	branch sdp_invalid_reqest_syntax,true
+
+	ifetch 2,contr				/* max aservice record count */
+	store 2,mem_sdp_record_maxcnt
+	increase -2,timeup
+
+	increase -1,timeup				/* continuation state 1 byte (0) */
+	nbranch sdp_invalid_pdu_size,zero		/* invalid pdu size */
+	arg mem_uuid_search_pat,timeup
+	ifetch 2,timeup
+	rtn blank
+	increase 2,timeup
+	call search_uuid
+	call l2cap_get_sdp_tx_payload			/* put the pointer to Tx buffer  */
+	force 3,pdata						/* PDUID 3, Service Search Response */
+	istore 1,contw
+	fetch 2,mem_sdp_transactionid			/* write transaction id */
+	istore 2,contw
+	lshift2 queue,pdata
+	add pdata,5,pdata
+	add pdata,5,regc
+	byteswap pdata,pdata
+	istore 2,contw							/* write parLength */
+	deposit queue
+	byteswap pdata,pdata
+	istore 2,contw							/* write TotSrvRecCount */
+	istore 2,contw							/* write CurSrvRecCount */
+	arg mem_handle_list,contr
+	copy queue,loopcnt
+	branch servicesearch_req_blank,zero
+servicesearch_req_loop:	
+	ifetch 4,contr
+	istore 4,contw
+	loop servicesearch_req_loop
+servicesearch_req_blank:	
+	force 0,pdata
+	istore 1,contw							/* continuation state */
+	deposit regc
+	store 1,mem_sdp_tx_pkt_length
+	branch assert,blank
+	rtn
+
+/**********************************************************************/
+/* serviceattribute_req			                              */
+/* Processing Service Attribute Request                               */
+/* Call: ask_attributeid, empty_response (if 3 stored attr.     */
+/* not asked) or answer_attributelist                              */  
+/* Input:       mem_L2CAP_Rx_payload pointer in contr                 */
+/* Output:      mem_SDP_Tx_payload, mem_SDP_Tx_pkt_length	      */
+/*                                                                    */
+/**********************************************************************/     
+serviceattribute_req:
+	ifetch 4,contr				/* service record handle */
+	store 4,mem_sdp_record_handle	 
+	increase -4,timeup
+	iforce temp
+	ifetch 2,contr				/* max attribute byte count */
+	byteswap pdata,pdata
+	increase -18,pdata	
+	store 2,mem_sdp_attribute_maxbyte
+	increase -2,timeup
+	call dataelementtype6		/* result: data size stored in rega */
+	branch sdp_invalid_reqest_syntax,zero
+	compare 5,rega,0xff
+	//branch serviceattribute_req_all,true
+	branch serviceattribute_judge_WholeRangle,true
+serviceattribute_isnot_wholerangle:
+	arg mem_attrib_list,contw
+	force 0,queue
+	branch serviceattribute_req_loop
+serviceattribute_judge_wholerangle:
+	ifetch 1,contr
+	bne 0xa,sdp_invalid_reqest_syntax
+	ifetch 2,contr
+	nbranch serviceattribute_judge_WholeRangle_false1,blank
+	ifetch 1,contr
+	bne 0xff,serviceattribute_judge_WholeRangle_false2
+	ifetch 1,contr
+	bne 0xff,serviceattribute_judge_WholeRangle_false3		//also exist potential bug because mem_attrib_list length is only 7f
+	increase -5,contr
+	branch serviceattribute_req_all
+serviceattribute_judge_wholerangle_false3:
+	increase -5,contr
+	branch serviceattribute_isnot_wholerangle
+serviceattribute_judge_wholerangle_false2:
+	increase -4,contr
+	branch serviceattribute_isnot_wholerangle
+serviceattribute_judge_wholerangle_false1:
+	increase -3,contr
+	branch serviceattribute_isnot_wholerangle
+serviceattribute_req_loop:	
+	ifetch 1,contr
+	beq 0x09, serviceattribute_req_one_id
+	beq 0x0a, serviceattribute_req_range_id
+serviceattribute_req_range_id:
+	ifetch 2, contr
+	istore 2, contw
+	increase 1,queue
+	byteswap pdata,regb
+	ifetch 2, contr
+	byteswap pdata,pdata
+serviceattribute_req_range_id_increase:	
+	increase 1, regb
+	isub regb, null
+	nbranch serviceattribute_req_range_id_finish,positive
+	copy pdata, regc
+	byteswap regb,pdata
+	istore 2, contw
+	increase 1,queue
+	copy regc, pdata
+	branch serviceattribute_req_range_id_increase
+serviceattribute_req_range_id_finish:
+	increase -5,timeup
+	increase -5,rega
+	branch serviceattribute_req_check_next_id
+serviceattribute_req_one_id:
+	ifetch 2,contr
+	istore 2,contw //save the attribute id in mem_attrib_list
+	increase 1,queue
+	increase -3,timeup
+	increase -3,rega
+serviceattribute_req_check_next_id:	
+	nbranch sdp_invalid_reqest_syntax,positive
+	nbranch serviceattribute_req_loop,zero
+	increase -1,timeup
+	nbranch sdp_invalid_reqest_syntax,zero
+	
+	call l2cap_get_sdp_tx_payload
+	increase 10,contw//arg mem_SDP_Tx_payload+10,contw
+	arg mem_attrib_list,rega
+answer_handle_attributelist_next:
+	copy queue,pdata
+	branch answer_handle_attributelist_end,blank
+	ifetch 2,rega
+	branch answer_handle_attributelist_end,blank
+	iforce regb /* regb is the attribute ID */
+	fetch 4,mem_sdp_record_handle	
+	iforce temp
+	call search_handle_attrib
+	branch answer_handle_attributelist_notfound,blank
+	increase -3,contr
+	ifetch 3,contr
+	istore 3,contw
+	call sdp_data_len_obs
+	branch answer_handle_attributelist_notfound,blank
+	iforce loopcnt	
+	call memcpy
+answer_handle_attributelist_notfound:
+	increase 2,rega
+	increase -1, queue
+	branch answer_handle_attributelist_next
+
+answer_handle_attributelist_end:
+	force 0,pdata
+	istore 1,contw
+	increase -1,contw
+	fetcht 2,mem_sdp_tx_payload_ptr
+	add temp,10,pdata//setarg mem_SDP_Tx_payload+10
+	isub contw,pdata
+	sub pdata,0,rega
+	byteswap rega, pdata
+	add temp,8,regb//store 2,mem_SDP_Tx_payload+8
+	istore 2,regb
+	increase 3,rega
+	byteswap rega, pdata
+	add temp,5,regb//store 2,mem_SDP_Tx_payload+5
+	istore 2,regb
+	increase 3,rega
+	byteswap rega, pdata
+	add temp,3,regb//store 2,mem_SDP_Tx_payload+3// ParLength
+	istore 2,regb	
+	increase 5,rega
+	copy rega,pdata
+	store 2,mem_sdp_tx_pkt_length
+	setarg 0x36
+	add temp,7,regb//jam 0x36, mem_SDP_Tx_payload+7
+	istore 1,regb
+	setarg 5
+	istore 1,temp//jam 5,mem_SDP_Tx_payload	// PDU ID
+	fetch 2,mem_sdp_transactionid
+	add temp,1,regb//store 2,mem_SDP_Tx_payload+1
+	istore 2,regb
+	rtn
+serviceattribute_req_all:	
+	ifetch 1,contr
+	bne 0xa,sdp_invalid_reqest_syntax
+	ifetch 2,contr
+	nbranch sdp_invalid_reqest_syntax,blank
+	ifetch 1,contr
+	bne 0xff,sdp_invalid_reqest_syntax
+	ifetch 1,contr
+	bne 0xff,sdp_invalid_reqest_syntax
+	increase -5,timeup
+	ifetch 1, contr
+	beq 0, continue_zero
+	beq 1, continue_one_byte
+	beq 2, continue_two_byte
+continue_zero:	
+	store 2, mem_sdp_continue_byte
+	increase -1,timeup				/* continuation state byte (0) */
+	branch continue_end
+continue_one_byte:
+	ifetch 1, contr
+	store 2, mem_sdp_continue_byte
+	increase -2,timeup				/* continuation state byte (1) */
+	branch continue_end
+continue_two_byte:
+	ifetch 2, contr
+	byteswap pdata,pdata
+	store 2, mem_sdp_continue_byte	
+	increase -3,timeup				/* continuation state byte (2) */
+continue_end:
+	nbranch sdp_invalid_pdu_size,zero		/* invalid pdu size */
+	call 	search_handle
+	nbranch sdp_invalid_service_record_handle,zero
+	copy contr,rega
+	call l2cap_get_sdp_tx_payload
+	copy rega,contr
+	increase 3,contw//arg mem_SDP_Tx_payload+3,contw
+	copy contr,timeup //sdp start pointer
+	call sdp_get_data
+	copy pdata, rega //sdp total length
+	fetch 2, mem_sdp_continue_byte
+	copy pdata, regb
+	copy rega,pdata
+	isub regb,regb //total_length - continue_byte in regb
+	fetch 2, mem_sdp_attribute_maxbyte
+	isub regb, null
+	nbranch fragment_sdp, positive
+	// the last fragment
+	disable user
+	fetch 2, mem_sdp_continue_byte
+	branch fisrt_fragment,blank
+	iadd timeup, contr //set the read pointer
+	increase 3,regb //include the total length field, 3 bytes
+	copy regb, loopcnt
+	copy loopcnt, pdata
+	increase 3, pdata
+	byteswap pdata,pdata
+	istore 2, contw
+	copy loopcnt, pdata
+	byteswap pdata,pdata
+	istore 2, contw
+	branch answer_attributelist_full_loop
+fisrt_fragment:
+	add rega,6,loopcnt
+	branch parlength_continue_byte, user
+	byteswap loopcnt,pdata
+	branch parlength_continue_byte_end
+parlength_continue_byte:
+	copy loopcnt, pdata
+	increase 2, pdata
+	byteswap pdata,pdata
+parlength_continue_byte_end:
+	istore 2,contw				/* ParLength */
+	increase -3,loopcnt
+	byteswap loopcnt,pdata			
+	istore 2,contw				/* AttrListByteCount */
+	copy timeup,contr
+	branch answer_attributelist_full_loop
+fragment_sdp:
+	enable user
+	fetch 2, mem_sdp_attribute_maxbyte
+	copy pdata, rega
+	copy pdata, loopcnt
+	fetch 2, mem_sdp_continue_byte
+	branch fisrt_fragment,blank
+	iadd timeup, contr
+	copy rega,pdata
+	increase 5,pdata
+	byteswap pdata,pdata	
+	istore 2, contw
+	copy rega,pdata
+	byteswap pdata,pdata
+	istore 2, contw
+answer_attributelist_full_loop:	
+	ifetch 1,contr
+	istore 1,contw
+	loop answer_attributelist_full_loop
+	nbranch last_frag_continue, user
+	force 2,pdata
+	istore 1,contw
+	copy contr, pdata
+	isub timeup, pdata
+	byteswap pdata,pdata
+	istore 2, contw
+	branch sdp_frag_end
+last_frag_continue:
+	force 0,pdata
+	istore 1,contw
+sdp_frag_end:	
+	fetch 2,mem_sdp_tx_payload_ptr//setarg mem_SDP_Tx_payload
+	isub contw,pdata
+	sub pdata,0,pdata
+	store 2,mem_sdp_tx_pkt_length
+	call l2cap_get_sdp_tx_payload//jam 5,mem_SDP_Tx_payload
+	setarg 5
+	istore 1,contw
+	fetch 2,mem_sdp_transactionid
+	istore 2,contw//store 2,mem_SDP_Tx_payload+1
+	rtn			
+/**********************************************************************/
+/* servicesearchattribute_req                          		      */
+/* Processing Service Search Attribute Request                        */
+/* Call: ask_serviceclassid, ask_attributeid, empty_response */
+/*       or answer_attributelist                                   */  
+/* Input:       contr                                                 */
+/* Output:      mem_SDP_Tx_payload, mem_SDP_Tx_pkt_length             */
+/*                                                                    */
+/**********************************************************************/     
+servicesearchattribute_req:
+	//compare 29,timeup,0xff
+	//branch empty_ssa_rsp,true
+	call ask_serviceclassid
+	compare 0xff,temp,0xff
+	branch servicesearchattribute_req_all,true
+	ifetch 2,contr				/* max attribute byte count */
+	store 2,mem_sdp_attribute_maxbyte
+	increase -2,timeup
+	call dataelementtype6
+	arg mem_attrib_list,contw
+	force 0,queue
+servicesearchattribute_req_loop:	
+	ifetch 3,contr //service recorde handle 0x0a0000ffff
+	bne 0x09,servicesearchattribute_req_all
+servicesearchattribute_req_uuid:
+	rshift8 pdata,pdata
+	istore 2,contw //save the attribute id in mem_attrib_list
+	increase 1,queue
+	increase -3,timeup
+	increase -3,rega
+	nbranch sdp_invalid_reqest_syntax,positive
+	nbranch servicesearchattribute_req_loop,zero
+	increase -1,timeup
+	nbranch sdp_invalid_reqest_syntax,zero
+servicesearchattribute_req_search:
+	call l2cap_get_sdp_tx_payload
+	increase 13,contw//arg mem_SDP_Tx_payload+13,contw
+	fetch 2,mem_uuid_search_pat
+	iforce regc
+	arg mem_attrib_list,rega
+answer_attributelist_next:	
+	ifetch 4,rega
+	branch answer_attributelist_end,blank
+	ifetch 2,rega
+	iforce regb						/* regb is the attribute ID */
+	call search_attrib
+	branch answer_attributelist_notfound,blank
+	increase -3,contr
+	ifetch 3,contr
+	istore 3,contw
+	call sdp_data_len_obs
+	iforce loopcnt	
+answer_attributelist_attrib_loop:
+	ifetch 1,contr
+	istore 1,contw
+	loop answer_attributelist_attrib_loop
+answer_attributelist_notfound:
+	increase 2,rega
+	branch answer_attributelist_next
+servicesearchattribute_req_all:
+	//bne 0x0a,sdp_invalid_reqest_syntax
+	//rshift8 pdata,pdata
+	//nbranch sdp_invalid_reqest_syntax,blank
+	ifetch 1,contr
+	//bne 0xff,sdp_invalid_reqest_syntax
+	ifetch 1,contr
+	//bne 0xff,sdp_invalid_reqest_syntax
+	increase -5,timeup
+	increase -5,rega
+	nbranch sdp_invalid_reqest_syntax,positive
+	arg mem_uuid_search_pat,timeup
+	ifetch 2,timeup
+	//rtn blank
+	increase 2,timeup
+	call search_uuid  //handle number in queue
+	deposit queue
+	store 1,mem_handle_humber
+	branch empty_ssa_rsp,blank
+	arg 0,queue
+	call l2cap_get_sdp_tx_payload
+	increase 10,contw//arg mem_SDP_Tx_payload+10,contw
+	branch servicesearchattribute_req_next_handle
+answer_attributelist_end:
+	force 0,pdata
+	istore 1,contw
+	increase -1,contw
+	fetcht 2,mem_sdp_tx_payload_ptr
+	add temp,13,pdata//setarg mem_SDP_Tx_payload+13
+	isub contw,pdata
+	branch no_attribute_return,zero
+	sub pdata,0,pdata
+	add temp,12,regb//store 1,mem_SDP_Tx_payload+12
+	istore 1,regb
+	increase 3,pdata
+	add temp,9,regb//store 1,mem_SDP_Tx_payload+9
+	istore 1,regb
+	increase 3,pdata
+	byteswap pdata,pdata
+	add temp,5,regb//store 2,mem_SDP_Tx_payload+5
+	istore 2,regb		/* AttrListByteCount */
+	rshift8 pdata,pdata
+	increase 3,pdata
+	byteswap pdata,pdata
+	add temp,3,regb//store 2,mem_SDP_Tx_payload+3
+	istore 2,regb		/* ParLength */
+	rshift8 pdata,pdata
+	increase 5,pdata
+	store 1,mem_sdp_tx_pkt_length	/*packet length*/
+	
+	fetch 2,mem_sdp_transactionid
+	add temp,1,regb//mem_SDP_Tx_payload+1
+	istore 2,regb
+	setarg 7
+	istore 1,temp//jam 7,mem_SDP_Tx_payload//PDU ID 
+	//jam 0,mem_SDP_Tx_payload+8		
+	//jam 0x36,mem_SDP_Tx_payload+7
+	//jam 0,mem_SDP_Tx_payload+11		
+	//jam 0x36,mem_SDP_Tx_payload+10
+	setarg 0x0036
+	add temp,7,regb
+	istore 2,regb
+	add temp,10,regb
+	istore 2,regb
+	rtn
+no_attribute_return:
+	jam 10,mem_sdp_tx_pkt_length
+	call l2cap_get_sdp_tx_payload
+	//jam 7,mem_SDP_Tx_payload	//PDU ID
+	setarg 7
+	istore 1,contw 
+	fetch 2,mem_sdp_transactionid
+	istore 2,contw
+	//store 2,mem_SDP_Tx_payload+1
+	//jam 0,mem_SDP_Tx_payload+3
+	//jam 5,mem_SDP_Tx_payload+4	 //ParLength =5
+	setarg 0x0500
+	istore 2,contw
+	//jam 0,mem_SDP_Tx_payload+5
+	//jam 2,mem_SDP_Tx_payload+6	// AttrListByteCount =2
+	setarg 0x0200
+	istore 2,contw
+	//jam 0x35,mem_SDP_Tx_payload+7
+	//jam 0,mem_SDP_Tx_payload+8
+	//jam 0,mem_SDP_Tx_payload+9
+	setarg 0x000035
+	istore 3,contw
+	rtn
+	
+servicesearchattribute_req_attributelist_loop:	
+	ifetch 1,contr
+	istore 1,contw
+	increase 1, regb //mem_sdp_continue_byte
+	increase -1, rega  //mem_sdp_attribute_maxbyte
+	branch servicesearchattribute_req_check_next_ctn,zero
+	loop servicesearchattribute_req_attributelist_loop
+servicesearchattribute_req_check_next_ctn:	
+	copy contw, timeup
+	copy regb, pdata
+	store 2, mem_sdp_continue_byte
+	copy rega, pdata
+	store 2, mem_sdp_attribute_maxbyte
+	branch answer_attributelist_with_ctn_bytes,blank
+	branch answer_attributelist_with_ctn_end, user
+	copy timeup,contw
+servicesearchattribute_req_check_handle:	
+	increase 1,queue
+	fetch 1, mem_handle_humber
+	isub queue,null
+	nbranch servicesearchattribute_req_next_handle,zero
+	branch answer_attributelist_end_long
+servicesearchattribute_req_next_handle:	
+	arg mem_handle_list,contr
+	lshift2 queue,pdata
+	iadd contr,contr
+	ifetch 4, contr //handle in pdata
+	iforce temp
+	call 	search_handle
+	copy contr,timeup
+	call sdp_get_data
+	add pdata,3,loopcnt
+	fetch 2, mem_sdp_attribute_maxbyte
+	copy pdata, rega
+	fetch 2, mem_sdp_continue_byte
+	copy pdata, regb
+	copy timeup,contr
+	branch servicesearchattribute_req_attributelist_loop
+answer_attributelist_with_ctn_bytes:
+	arg 0, queue
+	arg 0, regb
+answer_attributelist_calc_attribute_length:	
+	arg mem_handle_list,contr
+	lshift2 queue,pdata
+	iadd contr,contr
+	ifetch 4, contr //handle in pdata
+	iforce temp
+	call 	search_handle
+	call sdp_get_data
+	add pdata,3,pdata
+	iadd regb, regb
+	increase 1,queue
+	fetch 1, mem_handle_humber
+	isub queue,null
+	nbranch answer_attributelist_calc_attribute_length,zero
+	
+	copy timeup,contw
+	force 2,pdata
+	istore 1,contw
+	fetch 2, mem_sdp_continue_byte
+	byteswap pdata,pdata
+	istore 2, contw
+	increase -3,contw
+	fetcht 2,mem_sdp_tx_payload_ptr
+	add temp,10,pdata //setarg mem_SDP_Tx_payload+10
+	isub contw,pdata
+	sub pdata,0,pdata
+	iforce rega
+
+	deposit regb //no longer use regb??
+	add temp,9,regb//store 1,mem_SDP_Tx_payload+9
+	istore 1,regb
+	rshift8 pdata,pdata
+	add temp,8,regb
+	istore 1,regb//store 1,mem_SDP_Tx_payload+8
+	increase 3,rega
+	deposit rega
+	add temp,6,regb
+	istore 1,regb//store 1,mem_SDP_Tx_payload+6	/* AttrListByteCount */
+	rshift8 pdata,pdata
+	add temp,5,regb
+	istore 1,regb//store 1,mem_SDP_Tx_payload+5
+	increase 5,rega
+	deposit rega
+	add temp,4,regb
+	istore 1,regb//store 1,mem_SDP_Tx_payload+4	/* ParLength */
+	rshift8 pdata,pdata
+	add temp,3,regb
+	istore 1,regb//store 1,mem_SDP_Tx_payload+3
+	increase 5,rega
+	deposit rega
+	store 2,mem_sdp_tx_pkt_length	
+	setarg 7
+	istore 1,temp//jam 7,mem_SDP_Tx_payload	 //PDU ID
+	setarg 0x36
+	add temp,7,regb//jam 0x36,mem_SDP_Tx_payload+7
+	istore 1,regb
+	add temp,1,regb//store 2,mem_SDP_Tx_payload+1
+	fetch 2,mem_sdp_transactionid
+	istore 2,regb
+	rtn
+answer_attributelist_with_ctn_end:
+	copy timeup,contw
+	force 0,pdata
+	istore 1,contw
+	increase -1, contw
+	fetcht 2,mem_sdp_tx_payload_ptr
+	add temp,7,pdata//setarg mem_SDP_Tx_payload+7
+	isub contw,pdata
+	sub pdata,0,pdata
+	iforce rega
+
+	deposit rega
+	add temp,6,regb//store 1,mem_SDP_Tx_payload+6
+	istore 1,regb
+	rshift8 pdata,pdata
+	add temp,5,regb//store 1,mem_SDP_Tx_payload+5  /* AttrListByteCount */
+	istore 1,regb
+	increase 3,rega
+	deposit rega
+	add temp,4,regb//store 1,mem_SDP_Tx_payload+4	/* ParLength */
+	istore 1,regb
+	rshift8 pdata,pdata
+	add temp,3,regb//store 1,mem_SDP_Tx_payload+3
+	istore 1,regb
+	increase 5,rega
+	deposit rega
+	store 2,mem_sdp_tx_pkt_length	
+
+	setarg 7
+	istore 1,temp//jam 7,mem_SDP_Tx_payload	/* PDU ID */
+	
+	fetch 2,mem_sdp_transactionid
+	add temp,1,regb//store 2,mem_SDP_Tx_payload+1
+	istore 2,regb
+	rtn
+	
+answer_attributelist_end_long:
+	force 0,pdata
+	istore 1,contw
+	increase -1,contw
+	fetcht 2,mem_sdp_tx_payload_ptr
+	add temp,10,pdata//setarg mem_SDP_Tx_payload+10
+	isub contw,pdata
+	sub pdata,0,pdata
+	iforce rega
+
+	deposit rega
+	add temp,9,regb//store 1,mem_SDP_Tx_payload+9
+	istore 1,regb
+	rshift8 pdata,pdata
+	add temp,8,regb//store 1,mem_SDP_Tx_payload+8
+	istore 1,regb
+	
+	increase 3,rega
+	deposit rega
+	add temp,6,regb//store 1,mem_SDP_Tx_payload+6	/* AttrListByteCount */
+	istore 1,regb
+	rshift8 pdata,pdata
+	add temp,5,regb//store 1,mem_SDP_Tx_payload+5
+	istore 1,regb
+	increase 3,rega
+	deposit rega
+	add temp,4,regb//store 1,mem_SDP_Tx_payload+4	/* ParLength */
+	istore 1,regb
+	rshift8 pdata,pdata
+	add temp,3,regb//store 1,mem_SDP_Tx_payload+3
+	istore 1,regb
+	increase 5,rega
+	deposit rega
+	store 2,mem_sdp_tx_pkt_length	
+	setarg 0x36
+	add temp,7,regb
+	istore 1,regb//jam 0x36,mem_SDP_Tx_payload+7
+	setarg 7
+	istore 1,temp//jam 7,mem_SDP_Tx_payload	/* PDU ID */
+	fetch 2,mem_sdp_transactionid
+	add temp,1,regb//store 2,mem_SDP_Tx_payload+1
+	istore 2,regb
+	rtn	
+sdp_data_len_obs:
+	copy contr,timeup
+	ifetch 1,contr
+	and pdata,0x07,loopcnt
+	rshift3 pdata,pdata
+	beq 6,sdp_data_len_6_obs
+	beq 1,sdp_data_len_1
+	beq 4,sdp_data_len_6
+	beq 5,sdp_data_len_5
+	branch sdp_data_len_rtn
+sdp_data_len_6_obs:
+	call sdp_get_data_6_obs
+	branch sdp_data_len_rtn
+sdp_get_data_6_obs:
+	deposit loopcnt
+	beq 5,sdp_get_data_6_8bit_obs
+	beq 6,sdp_get_data_6_16bit_obs
+	force 3,loopcnt
+	branch sdp_get_data_1
+sdp_get_data_6_8bit_obs:
+	ifetch 1,contr
+	increase 2,pdata
+	rtn
+sdp_get_data_6_16bit_obs:
+	ifetch 2,contr
+	byteswap pdata,pdata
+	increase 3,pdata
+	rtn
+
+sdp_send_spp_request:
+	call l2cap_get_sdp_tx_payload
+	copy pdata,contw
+	setarg 6//Search Attr Req
+	istore 1,contw
+	setarg sdp_tid_spp					
+	istore 2,contw
+	setarg 0x0f00 //length15
+	istore 2,contw
+	setarg 0x1a0535
+	istore 3,contw
+	setarg 0x0111
+	lshift16 pdata,pdata //UUID
+	istore 4,contw
+	setarg 0x2600 //max return len
+	istore 2,contw
+	setarg 0x0335
+	istore 2,contw
+	setarg 0x0009
+	istore 2,contw
+	setarg 0x0004
+	istore 2,contw
+	jam 0x14,mem_sdp_tx_pkt_length
+	rtn
+
+/**********************************************************************/
+/* servicesearchattribute_res			                      */
+/* Processing Service Search Attribute Response                       */
+/* Call: dataelementtype6, attribute_reading                    */
+/* Input:       contr                                                 */
+/* Output:      mem_sdp_record_handle,mem_sdp_search_failed           */
+/*                                                                    */
+/**********************************************************************/     
+servicesearchattribute_res:
+	copy contr,temp				/* save reading pointer */
+	fetch 2,mem_sdp_transactionid			/* check if this is the response for   */
+	beq sdp_tid_spp,servicesearchattribute_res_spp
+	//no profiles now, hs,hf,pbap,avtarg were cut off
+	//maybe add something about spp
+	branch srchfail
+
+servicesearchattribute_res_spp:
+	copy temp,contr
+	increase -3,timeup
+	copy timeup,pdata
+	beq 2,srchfail// empty response
+	call find_rfcomm_channel_number
+	rtn user
+	store 1,mem_remote_spp_channel
+	jam RECIEVE_SS_REASULT_HF,mem_message_to_uppersm
+	rtn
+
+srchfail:
+	rtn
+	/* find_rfcomm_channel_number	*/
+	/* input att_list_lenth in pdata   	*/
+	/* input att_list_ptr in contr		*/
+	/* output channel_number in pdata	*/
+	/* output failed while user was set	*/
+find_rfcomm_channel_number:
+	enable user
+	copy pdata,loopcnt
+	arg 0x0400,temp //att_descriptor_list
+find_rfcomm_channel_number_loop://find att_descriptor_list
+	ifetch 2,contr
+	isub temp,null
+	branch find_rfcomm_channel_number_find_adl,zero
+	increase -1,contr
+	loop find_rfcomm_channel_number_loop
+	rtn
+find_rfcomm_channel_number_find_adl:
+	arg 0x0300,temp
+find_rfcomm_channel_number_loop2:
+	ifetch 2,contr
+	isub temp,null
+	branch find_rfcomm_channel_number_find_rfcomm,zero
+	increase -1,contr
+	loop find_rfcomm_channel_number_loop2
+	rtn
+find_rfcomm_channel_number_find_rfcomm:
+	ifetch 1,contr
+	ifetch 1,contr
+	disable user
+	rtn
+/**********************************************************************/
+/* Subroutine: attribute_reading                                   */
+/* Reading each Data Element Sequence inside one Attribute List       */
+/* Called from servicesearchattribute_res                             */
+/* Call dataelementtype6                                           */  
+/* Input:       contr,timeup                                          */
+/* Output:      timeup,mem_sdp_LACAP_found,mem_sdp_RFCOMM_found      */
+/*                                                                    */
+/*                                                                    */
+/**********************************************************************/     
+attribute_reading:
+	call dataelementtype6		/* decode data element sequence */
+	branch rdnortn,zero  
+	force 0,regb					/* regb to be used as 128 bit uuid flag */
+	ifetch 1,contr
+	increase -1,rega  
+	increase -1,timeup  
+	compare 0x18,pdata,0xf8			/* 5 MSB: b00011, uuid */
+	nbranch rduuid3,true
+	compare 0x04,pdata,0x07			/* 3 LSB: b100, 128 bits uuid */
+	nbranch is032,true
+	force 1,regb					/* mark it as 128 bit uuid */
+skp2bytes:
+	increase 2,contr				/* skip 2 bytes */
+	increase -2,rega	
+	increase -2,timeup
+	branch rduuid1				/* add 126 bits  */
+is032:
+	compare 0x02,pdata,0x07			/* 3 LSB: b010 32 bits uuid */
+	nbranch is016,true
+	branch skp2bytes			
+is016:
+	compare 0x01,pdata,0x07			/* 3 LSB: b001 16 bit uuid */
+	nbranch rduuid3,true
+rduuid1:
+	ifetch 1,contr				/* get higher order byte */
+	increase -1,rega
+	increase -1,timeup
+	bne 0x01, rduuid2
+	ifetch 1,contr				/* get lower order byte */
+	increase -1,rega
+	increase -1,timeup
+	bne 0x00, rduuid3
+	jam 0xff,mem_sdp_LACAP_found			/* set L2CAP found parameter */
+	branch rduuid3
+rduuid2:
+	bne 0x00, rduuid3
+	ifetch 1,contr				/* get lower order byte */
+	increase -1,rega
+	increase -1,timeup
+	bne 0x03, rduuid3
+	copy regb,null
+	branch not16by,zero				/* 128 bit uuid, skip 12 bytes */
+	increase -12,contr	
+	increase -12,timeup
+not16by:		
+	force 0xff,pdata
+	store 1,mem_sdp_RFCOMM_found			/* set RFCOMM found parameter */
+	ifetch 1,contr
+	increase -1,rega
+	increase -1,timeup
+	compare 0x08,pdata,0xf8		//b00001	
+	nbranch rduuid3,true
+	compare 0x00,pdata,0x07
+	branch unsign1,true
+	compare 0x01,pdata,0x07
+	branch unsign2,true
+	compare 0x02,pdata,0x07
+	branch unsign4,true
+	compare 0x03,pdata,0x07
+	branch unsign8,true
+	compare 0x04,pdata,0x07
+	nbranch rduuid3,true
+	increase 8,contr
+	increase -8,rega
+	increase -8,timeup
+unsign8:  
+	increase 4,contr
+	increase -4,rega
+	increase -4,timeup
+unsign4:  
+	increase 2,contr
+	increase -2,rega
+	increase -2,timeup
+unsign2:  
+	increase 1,contr
+	increase -1,rega
+	increase -1,timeup
+unsign1:  
+	ifetch 1,contr
+	increase -1,rega
+	increase -1,timeup
+rduuid3:
+	increase -1,timeup
+	increase -1,rega
+	branch rduuid3,positive			/* if rega=0, done */
+	increase 1,timeup				/* return byte count */
+	force 0x01,pdata
+	rtn,
+rdnortn:
+	force 0x00,pdata
+	rtn,						    
+
+sdp_invalid_service_record_handle:		
+	setarg 0x0200
+	store 2,mem_sdp_error_code
+	branch sdp_error_rsp
+sdp_invalid_pdu_size:				
+	setarg 0x0400
+	store 2,mem_sdp_error_code
+	branch sdp_error_rsp
+sdp_insufficient_resource:			
+	setarg 0x0600
+	store 2,mem_sdp_error_code
+	branch sdp_error_rsp
+sdp_invalid_reqest_syntax:			
+	setarg 0x0300
+	store 2,mem_sdp_error_code
+sdp_error_rsp:	
+	call l2cap_get_sdp_tx_payload
+	istore 1,contw
+	fetch 2,mem_sdp_transactionid			
+	istore 2,contw
+	setarg 0x0200					
+	istore 2,contw
+	fetch 2,mem_sdp_error_code			
+	istore 2,contw
+	jam  7,mem_sdp_tx_pkt_length
+	rtn
+
+ask_serviceclassid:  
+	force 0,temp					/* use "temp" to mark syntax error or to mark 128 bit uuid */
+	arg mem_uuid_search_pat,contw
+	call dataelementtype6
+	branch asksrv_error,zero
+classidloop:
+	ifetch 1,contr
+	increase -1,rega
+	increase -1,timeup
+	compare 0x18,pdata,0xf8			/* 5 MSB: b00011: uuid */
+	nbranch asksrv_error,true
+	compare 0x04,pdata,0x07			/* 3 LSB: b100 128 bits uuid */
+	nbranch cmp032,true
+	force 1,temp					/* mark it as 128 bit uuid */
+skip2bytes:
+	ifetch 1,contr
+	increase -1,rega	
+	increase -1,timeup
+	bne 0x00, frstbwrong
+	ifetch 1,contr
+	increase -1,rega	
+	increase -1,timeup
+	beq 0x00, cmpuuid
+	branch scndbwrong
+frstbwrong:  
+	increase 1,contr
+	increase -1,rega	
+	increase -1,timeup
+scndbwrong:  
+	increase 2,contr				/* skip 2 bytes, first 2 bytes already wrong */
+	increase -2,rega	
+	increase -2,timeup
+	compare 0x00,temp,0xff                        /* 128 bits or 32 bits ? */
+	branch loopornot,true
+	increase 12,contr				/* skip 12 bytes, first 2 bytes already wrong */
+	increase -12,rega	
+	increase -12,timeup
+	branch loopornot
+cmp032:
+	compare 0x02,pdata,0x07			/* 3 LSB: b010 32 bits uuid */
+	nbranch cmp016,true
+	branch skip2bytes			
+cmp016:
+	compare 0x01,pdata,0x07			/* 3 LSB: b001 16 bit uuid */
+	nbranch asksrv_error,true
+cmpuuid:
+	ifetch 2,contr				/* higher order byte */
+	increase -2,rega
+	increase -2,timeup
+	istore 2,contw
+uuidsize:
+	compare 0x00,temp,0xff			/* is this 128 bits uuid */
+	branch loopornot,true
+	copy contr,temp
+	ifetch 1,contr
+	bne 0x00, wrong12b
+	ifetch 1,contr
+	bne 0x00, wrong12b
+	ifetch 1,contr
+	bne 0x10, wrong12b
+	ifetch 1,contr
+	bne 0x00, wrong12b
+	ifetch 1,contr
+	bne 0x80, wrong12b
+	ifetch 1,contr
+	bne 0x00, wrong12b
+	ifetch 1,contr
+	bne 0x00, wrong12b
+	ifetch 1,contr
+	bne 0x80, wrong12b
+	ifetch 1,contr
+	bne 0x5f, wrong12b
+	ifetch 1,contr
+	bne 0x9b, wrong12b
+	ifetch 1,contr
+	bne 0x34, wrong12b
+	ifetch 1,contr
+	beq 0xfb, chck12dn
+wrong12b:
+	copy temp,contr  
+wrong12b1:
+	increase 12,contr				/* skip 12 bytes */
+	force 0x00,queue
+	force 0x00,temp
+	branch chck12dn
+noclass:
+	ifetch 1,contr
+	increase -1,rega
+	increase -1,timeup
+	branch uuidsize
+chck12dn:
+	increase -12,timeup
+	increase -12,rega
+loopornot:
+	compare 0x00,rega,0xff
+	nbranch classidloop,true
+	force 0,pdata
+	istore 2,contw			/* end list with null */
+	rtn,
+asksrv_error:
+	arg 0xff,temp
+	rtn
+
+/**********************************************************************/
+/* Subroutine: dataelementtype6                                    */
+/* Parse Data Element Sequence, obtain the data size                  */
+/* Input:  SDP Rx Buf Pointer in contr, parameter count in timeup     */
+/* Output: data size in rega, SDP Rx Buf Pointer in contr             */
+/*         and  parameter count in timeup, return with zero flag set: */
+/*         syntax error                                               */
+/**********************************************************************/     
+dataelementtype6:
+	ifetch 1,contr
+	increase -1,timeup
+	compare 0x30,pdata,0xf8			/* 5 MSB: b00110: type 6 */
+	nbranch dsize_error,true
+	compare 0x07,pdata,0x07			/* 3 LSB: b111: 32 bits */
+	branch dsize32,true
+	compare 0x06,pdata,0x07			/* 3 LSB: b110: 16 bits */
+	branch dsize16,true
+	compare 0x05,pdata,0x07			/* 3 LSB: b101: 8 bits */
+	nbranch dsize_error,true
+	ifetch 1,contr
+	copy pdata,rega				/* data in reg A */
+	increase -1,timeup
+	branch dsize
+dsize32:
+	increase 2,contr				/* just move pointer +2, zero in 2 high byte */
+	increase -2,timeup
+dsize16:
+	ifetch 2,contr
+	byteswap pdata,rega
+	increase -2,timeup
+set_nblank:
+dsize:
+	force 0x01,pdata
+	rtn
+set_blank:
+dsize_error:
+	force 0x00,pdata
+	rtn
+
+/**********************************************************************/
+/* Subroutine: empty_response                                      */
+/* Send empty response                                                */
+/*                                                                    */
+/* Input:       mem_sdp_pduid, mem_sdp_transactionid                  */
+/* Output:      mem_SDP_Tx_payload, mem_SDP_Tx_pkt_length             */
+/*                                                                    */
+/**********************************************************************/     
+empth_sa_rsp:
+	setarg 0x03
+	store 1, mem_sdp_pduid
+	branch empty_response
+empty_ssa_rsp:
+	setarg 0x07
+	store 1, mem_sdp_pduid
+empty_response:
+	call l2cap_get_sdp_tx_payload			/* empty attribute list */
+	fetch 1,mem_sdp_pduid				/* PDUID */
+	istore 1,contw
+	copy pdata,regb
+	fetch 2,mem_sdp_transactionid			/* copy back transaction id */
+	istore 2,contw
+	
+	setarg 0x0500
+	istore 2, contw
+	compare 0x05,regb,0xff			/* pduid 3 */
+	branch fullsearch,true
+	compare 0x07,regb,0xff			/* pduid 3 */
+	branch fullsearch,true
+	setarg 0x000000
+	istore 3,contw
+	istore 2,contw
+	branch outempty
+
+fullsearch:					/* pduid must be 5 or 7 */
+	//force 0x00,pdata
+	//istore 1,contw
+	//force 0x02,pdata
+	//istore 1,contw
+	//force 0x35,pdata
+	//istore 1,contw
+	setarg 0x350200
+	istore 3,contw
+	//force 0x00,pdata
+	//istore 1,contw
+	//force 0x00,pdata
+	//istore 1,contw
+	setarg 0
+	istore 2, contw
+outempty:
+	jam 10,mem_sdp_tx_pkt_length
+	rtn
+
+sdp_data_len:
+	copy contr,timeup
+	ifetch 1,contr
+	and pdata,0x7,loopcnt
+	rshift3 pdata,pdata
+	beq 6,sdp_data_len_6
+	beq 1,sdp_data_len_1
+	beq 4,sdp_data_len_6
+	beq 5,sdp_data_len_5
+sdp_data_len_rtn:	
+	copy timeup,contr
+	rtn
+sdp_data_len_1:
+	call sdp_data_size
+	increase 1,pdata
+	branch sdp_data_len_rtn
+sdp_data_len_5:
+	force 2,pdata
+	branch sdp_data_len_rtn
+sdp_data_len_6:
+	call sdp_get_data_6
+	increase 2,pdata
+	branch sdp_data_len_rtn
+	
+sdp_get_data:
+	ifetch 1,contr
+	and pdata,0x7,loopcnt
+	rshift3 pdata,pdata
+	beq 6,sdp_get_data_6
+	beq 1,sdp_get_data_1
+	beq 5,sdp_get_data_6_8bit
+	rtn
+sdp_get_data_1:
+	call sdp_data_size
+	iforce loopcnt
+	force 0,temp
+sdp_get_data_1_loop:	
+	lshift8 temp,temp
+	ifetch 1,contr
+	ior temp,temp
+	loop sdp_get_data_1_loop
+	rtn
+sdp_get_data_6:
+	deposit loopcnt
+	beq 5,sdp_get_data_6_8bit
+	beq 6,sdp_get_data_6_16bit
+	force 3,loopcnt
+	branch sdp_get_data_1
+sdp_get_data_6_8bit:
+	ifetch 1,contr
+	rtn
+sdp_get_data_6_16bit:
+	ifetch 2,contr
+	byteswap pdata,pdata
+	rtn
+
+	/* get data size according to size index in loopcnt */
+sdp_data_size:
+	force 1,pdata
+	copy loopcnt,null
+	rtn zero
+sdp_data_size_loop:
+	lshift pdata,pdata
+	loop sdp_data_size_loop
+	rtn
+
+
+
+	/* return handles in queue if found */
+search_uuid:
+	iforce regc
+	set1 mark_ext_patch,mark
+	bpatch patch3d_1,mem_patch3d
+	force 0,queue
+	fetch 2, memui_uuid_table
+	iforce contr
+	arg mem_handle_list,contw
+search_uuid_next:
+	disable user
+	ifetch 1,contr
+	rtn blank
+	iforce loopcnt
+search_uuid_loop:	
+	ifetch 2,contr
+	isub regc,null
+	nbranch search_uuid_not_found,zero
+	enable user					/* uuid match */
+search_uuid_not_found:
+	loop search_uuid_loop
+	ifetch 4,contr					/* get handle */
+	nbranch search_uuid_nomatch,user
+	istore 4,contw
+	increase 1,queue
+search_uuid_nomatch:	
+	call sdp_get_data
+	iadd contr,contr			/* next paragraph */
+	branch search_uuid_next
+
+	/* return handle in pdata if found, 0 if not */
+search_handle:
+	fetch 2,memui_uuid_table
+	iforce contr
+search_handle_loop:	
+	ifetch 1,contr
+	rtn blank
+	lshift pdata,pdata
+	iadd contr,contr
+	ifetch 4,contr
+	isub temp,null
+	rtn zero
+	call sdp_get_data
+	iadd contr,contr
+	branch search_handle_loop
+
+/**
+* input regb and regc.regb is the attribute ID and regc is UUID.
+* set contr if find attribute or 0 if not
+*/
+	
+search_attrib:
+	set1 mark_ext_patch,mark
+	bpatch patch3d_2,mem_patch3d
+	fetch 2,memui_uuid_table
+	iforce contr
+search_attrib_next:
+	ifetch 1,contr
+	branch search_attrib_end, blank
+	iforce loopcnt
+search_attrib_loop:	
+	ifetch 2,contr
+	isub regc,null						/* regc is UUID, compare it */
+	branch search_attrib_found_uuid,zero
+	loop search_attrib_loop
+	increase 4,contr
+	call sdp_get_data
+	iadd contr,contr			/* next paragraph */
+	branch search_attrib_next	
+search_attrib_found_uuid:
+	increase -1,loopcnt
+	lshift loopcnt,pdata
+	iadd contr,contr
+	increase 4,contr
+	call sdp_get_data
+	iadd contr,temp					/* attribute list end */
+search_attrib_loop_attribs:	
+	increase 1,contr
+	ifetch 2,contr
+	isub regb,timeup
+	//force 0x1,pdata,zero
+	setflag zero, 0,pdata
+	copy timeup, timeup
+	rtn zero							/* attribute found */
+	call sdp_data_len
+	iadd contr,contr
+	deposit temp
+	isub contr,null
+	branch search_attrib_end, zero /*attribute end, not found the attribute, return contr = 0*/
+	branch search_attrib_loop_attribs	
+search_attrib_end:
+	force 0,contr
+	force 0,pdata
+	rtn
+	
+
+//search the attribute according the record handle
+//record handle in temp, attribute in regb
+//set the contr to zero if not found
+search_handle_attrib:	
+	set1 mark_ext_patch,mark
+	bpatch patch3d_3,mem_patch3d
+	fetch 2,memui_uuid_table
+	iforce contr
+search_handle_attrib_next:
+	ifetch 1,contr
+	branch search_handle_attrib_end, blank
+	lshift pdata,pdata
+	iadd contr, contr
+	ifetch 4,contr
+	isub temp,null						/* regc is UUID, compare it */
+	branch search_handl_attrib_found_handle,zero
+	call sdp_get_data
+	iadd contr,contr			/* next paragraph */
+	branch search_handle_attrib_next	
+search_handl_attrib_found_handle:
+	call sdp_get_data
+	iadd contr,temp					/* attribute list end */
+search_handle_attrib_loop_attribs:	
+	increase 1,contr
+	ifetch 2,contr
+	isub regb,null
+	rtn zero							/* attribute found */
+	call sdp_data_len
+	iadd contr,contr
+	deposit temp
+	isub contr,null
+	branch search_handle_attrib_end, zero /*attribute end, not found the attribute, return contr = 0*/
+	branch search_handle_attrib_loop_attribs
+search_handle_attrib_end:
+	force 0,contr
+	rtn	
+
+	
Index: btkb/program/security.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/security.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/security.prog	(working copy)
@@ -0,0 +1,1140 @@
+generate_kinit:
+	call function_e22
+	arg mem_input_store,contr
+	arg mem_kinit,contw		/* Kinit is ready */
+	branch memcpy16
+
+
+function_e21:	/* rega pointers to bdaddr */
+	disable user
+	call function_expand
+	arg mem_random_number,contr
+	arg mem_x,contw
+	force 15,loopcnt
+	call memcpy			
+	ifetch 1,contr
+	xor_into 6,pdata
+	istore 1,contw
+	setarg mem_y
+	store 2,memp_ar_input
+	setarg mem_x
+	store 2,memp_ar_key
+	set1 mark_ar2,mark
+	branch function_ar
+
+
+	
+function_e22:		/* rega pointers to bdaddr */
+	fetcht 1,mem_pin_length
+	force 16,regb			/* total 16 bytes */
+	add temp,6,regc		/* regc is l' */
+	sub regc,16,null		
+	branch function_e22_pin_init,positive 
+	force 16,regc
+function_e22_pin_init:			/* generate x from pin and bdaddr */
+	arg mem_x,contw
+function_e22_genx_pin:
+	arg mem_pin,contr
+	copy temp,loopcnt
+	disable user
+function_e22_genx_loop:
+	ifetch 1,contr
+	istore 1,contw
+	increase -1,regb
+	branch function_e22_genx_end,zero
+	loop function_e22_genx_loop
+	branch function_e22_genx_pin,user
+	enable user
+	force 6,loopcnt
+	copy rega,contr
+	branch function_e22_genx_loop
+function_e22_genx_end:
+	arg mem_random_number,contr
+	arg mem_y,contw
+	call memcpy16
+	fetch 1,mem_y15
+	ixor regc,pdata
+	store 1,mem_y15	/* inpy[15] = rand_num[15]^l'; */
+	setarg mem_y
+	store 2,memp_ar_input
+	setarg mem_x
+	store 2,memp_ar_key
+	set1 mark_ar2,mark
+	branch function_ar
+
+
+
+
+function_e1:	/* rega pointers to bdaddr */
+	disable user
+	call function_expand
+	branch function_hash
+
+function_e3:
+	arg mem_aco,rega
+	enable user
+	call function_expand
+	call function_hash
+	arg mem_input_store,contr
+	arg mem_kc,contw
+	branch memcpy16
+
+	/* costs 41769 clocks */
+function_hash:
+	setarg mem_random_number
+	store 2,memp_ar_input
+	setarg mem_link_key
+	store 2,memp_ar_key
+	set0 mark_ar2,mark
+	call function_ar
+	arg mem_input_store,rega
+	arg mem_random_number,regb
+	arg mem_x,contw
+	call xor16
+	arg mem_x,rega
+	arg mem_y,regb
+	copy regb,contw
+	enable user
+	call add16
+	call key_offset
+	setarg mem_y
+	store 2,memp_ar_input
+	setarg mem_x
+	store 2,memp_ar_key
+	set1 mark_ar2,mark
+	branch function_ar
+	
+
+	/* totally costs 20700 clocks */
+function_ar:
+	jam 0,mem_ar_hround
+	fetch 2,memp_ar_key
+	iforce contr
+	arg mem_key_store,contw
+	call memcpy16
+	fetch 2,memp_ar_input
+	iforce contr
+	arg mem_input_store,contw
+	call memcpy16
+	
+function_ar_loop:
+	call key_scheduling
+	disable user
+	bmark0 mark_ar2,function_ar_original
+	fetch 1,mem_ar_hround
+	bne 4,function_ar_original
+	fetch 2,memp_ar_input
+	iforce regb
+	call xor_mod32_ar2
+function_ar_original:
+	call xor_mod32
+	call el_boxes
+	fetch 1,mem_ar_hround
+	increase 1,pdata
+	store 1,mem_ar_hround
+
+	call key_scheduling
+	enable user
+	call xor_mod32
+	call pht
+	call permute
+	call pht
+	call permute
+	call pht
+	call permute
+	call pht
+	fetch 1,mem_ar_hround
+	increase 1,pdata
+	store 1,mem_ar_hround
+	bne 16,function_ar_loop
+	call key_scheduling
+	disable user
+	branch xor_mod32
+	
+/* input round number and temp key in mem_key_store, and output the next temp key in mem_key_store */
+/* round key is generated and store in mem_round_key */
+key_scheduling:
+	fetch 1,mem_ar_hround
+	arg mem_key_store,contr
+	branch key_sched_zero,blank
+	iforce regb      			/* regb is half round */
+	force 17,loopcnt
+	copy contr,contw
+key_rotateloop:
+	ifetch 1,contr
+	lshift3 pdata,temp
+	rshift2 pdata,pdata
+	rshift3 pdata,pdata
+	ior temp,pdata
+	istore 1,contw
+	loop key_rotateloop
+	setarg mem_key_store
+	iadd regb,contr
+	force 16,loopcnt    
+	arg mem_round_key,contw
+key_select_octet_loop:
+	ifetch 1,contr
+	istore 1,contw
+	compare mem_key_store_end,contr,0xff
+	nbranch key_select_octet_nwrap,true
+	increase -17,contr
+key_select_octet_nwrap:
+	loop key_select_octet_loop
+	force 0,rega         /* rega is index of octet within row */
+	add regb,-1,regc    /* this is the row index, half_round#1 is 0 */
+	lshift2 regc,regc
+	lshift2 regc,regc
+	call enable_authrom
+	setarg mem_b_box
+	iadd regc,regc       /* regc hold the starting address of the row */
+	arg mem_round_key,contw
+	force 16,loopcnt
+bias_round_key_loop:
+	ifetcht 1,regc
+	ifetch 1,contw
+	iadd temp,pdata
+	istore 1,contw
+	increase 1,regc
+	loop bias_round_key_loop
+	branch disable_authrom
+
+key_sched_zero:    /* round 0, key1 */
+	force 16,loopcnt
+	force 0,temp
+create_byte_16_loop:
+	ifetch 1,contr
+	ixor temp,temp
+	loop create_byte_16_loop
+	deposit temp
+	istore 1,contr    	/* store the byte #16 */
+	arg mem_key_store,contr
+	arg mem_round_key,contw
+	branch memcpy16
+
+xor_mod32:     /* xor on 0,3, add on 1,2. if user is set, invert. x in rega and y in regb, out in contw */
+	arg mem_round_key,regb
+xor_mod32_ar2:
+	force 16,loopcnt
+	arg mem_input_store,rega
+	copy rega,contw
+xor_mod32_loop:	
+	ifetcht 1,rega
+	ifetch 1,regb
+	ixor temp,alarm
+	and loopcnt,3,regc
+	nbranch xor_mod32_invert,user
+	xor_into 3,regc
+xor_mod32_invert:
+	sub regc,1,regc
+	branch xor_even,positive
+	iadd temp,alarm
+xor_even:
+	deposit alarm
+	istore 1,contw
+	increase 1,rega
+	increase 1,regb
+	loop xor_mod32_loop
+	rtn
+
+el_boxes:
+	call enable_authrom
+	force 16,loopcnt
+	arg mem_input_store,rega
+el_box_loop:	
+	ifetch 1,rega
+	arg mem_e_box,contr
+	and loopcnt,3,regc
+	sub regc,1,null
+	branch e_boxes,positive
+	arg mem_l_box,contr
+e_boxes:
+	iadd contr,contr
+	ifetch 1,contr
+	istore 1,rega
+	increase 1,rega
+	loop el_box_loop
+	branch disable_authrom
+
+pht:				
+	force 8,loopcnt
+	arg mem_input_store,contr
+	copy contr,contw
+pht_loop:
+	ifetch 1,contr
+	iforce rega
+	ifetch 1,contr
+	iforce regb
+	lshift rega,pdata
+	iadd regb,pdata
+	istore 1,contw
+	deposit rega
+	iadd regb,pdata
+	istore 1,contw
+	loop pht_loop
+	rtn
+
+/* 8 11 12 15 2 1 6 5 10 9 14 13 0 7 4 3 */
+permute:			
+	setarg 0x8ae42c
+	iforce temp
+	force 7,loopcnt
+	call permute_exchange
+	setarg 0xd751b
+	iforce temp
+	force 5,loopcnt
+	call permute_exchange
+	fetch 1,mem_input_store+15
+	iforce rega
+	fetch 1,mem_input_store+3
+	store 1,mem_input_store+15
+	deposit rega
+	store 1,mem_input_store+3
+	rtn
+
+permute_exchange:
+	and temp,0xf,regb
+permute_loop:
+	and temp,0xf,pdata
+	arg mem_input_store,contw
+	iadd contw,contw
+	ifetch 1,contw
+	iforce regc
+	deposit rega
+	istore 1,contw
+	copy regc,rega
+	rshift4 temp,temp
+	loop permute_loop	
+	setarg mem_input_store
+	iadd regb,contw
+	deposit rega
+	istore 1,contw
+	rtn
+
+add16:
+	enable user
+	branch xor_add16
+
+xor16:
+	disable user
+xor_add16:	/* if user is set, do add, else do xor */
+	force 16,loopcnt	/* rega and regb pointers to src, contw is result */
+xoradd_loop:
+	ifetcht 1,rega
+	ifetch 1,regb
+	branch xoradd_add,user
+	ixor temp,pdata
+	branch xoradd_store
+xoradd_add:	
+	iadd temp,pdata
+xoradd_store:	
+	istore 1,contw
+	increase 1,rega
+	increase 1,regb
+	loop xoradd_loop
+	rtn
+
+	
+function_expand:		/* rega pointers to bdaddr, or aco and user is set */
+	arg mem_y,contw
+	ifetch 6,rega
+	istore 6,contw
+	branch expand_12,user
+	ifetch 6,rega
+	branch expand_cont
+expand_12:
+	ifetch 6,contr
+expand_cont:
+	istore 6,contw
+	ifetch 4,rega
+	istore 4,contw
+	rtn
+
+key_offset:
+	arg mem_link_key,contr
+	arg mem_x,contw
+	arg 0,temp
+	setarg 0x8395a7
+	call concatenate_temp24
+	setarg 0xb3c1df
+	call concatenate_temp24
+	setarg 0xe5e9
+	call concatenate_temp16
+	copy temp,regab
+	disable user
+	call key_addxor
+	copy regab,temp
+	enable user
+	branch key_addxor
+
+key_addxor:
+	force 8,loopcnt
+key_addxor_loop:	
+	ifetch 1,contr
+	compare 1,loopcnt,1
+	branch key_high,user
+	branch key_xor,true
+key_add:	
+	iadd temp,pdata
+	branch key_store
+key_high:
+	branch key_add,true
+key_xor:
+	ixor temp,pdata
+key_store:
+	istore 1,contw
+	rshift8 temp,temp
+	loop key_addxor_loop
+	rtn
+
+copy_aco:
+	fetch 6,mem_input_store+4
+	store 6,mem_aco
+	ifetch 6,contr
+	istore 6,contw
+	rtn
+	
+concatenate_temp24:
+	lshift8 temp,temp
+concatenate_temp16:
+	lshift16 temp,temp
+	ior temp,temp
+	rtn
+
+ifdef TESTING
+test_security:
+	fetch 1,0xff
+	branch test_security,blank
+
+	/* inrand */
+	setarg 0x1BC683
+	store 3,0x0
+	setarg 0x122980
+	istore 3,contw
+	setarg 0xD0DB17
+	istore 3,contw
+	setarg 0x2B1D78
+	istore 3,contw
+	setarg 0x2743A6
+	istore 3,contw
+	setarg 0xD8
+	istore 1,contw
+
+	/* comb A */
+	setarg 0xA6D0C9
+	store 3,0x10
+	setarg 0xA9E86C
+	istore 3,contw
+	setarg 0x9E89D5
+	istore 3,contw
+	setarg 0xC61838
+	istore 3,contw
+	setarg 0x6F0318
+	istore 3,contw
+	setarg 0x9F
+	istore 1,contw
+
+	/* comb B */
+	setarg 0x7F6833
+	store 3,0x20
+	setarg 0xE62E1B
+	istore 3,contw
+	setarg 0x9F67FC
+	istore 3,contw
+	setarg 0x8D3712
+	istore 3,contw
+	setarg 0x0B846C
+	istore 3,contw
+	setarg 0x4A
+	istore 1,contw
+
+	/* auth rand A */
+	setarg 0xFBB686
+	store 3,0x30
+	setarg 0x19FE7F
+	istore 3,contw
+	setarg 0x16A439
+	istore 3,contw
+	setarg 0xF4F6A4
+	istore 3,contw
+	setarg 0x10D61D
+	istore 3,contw
+	setarg 0xDE
+	istore 1,contw
+
+	/* auth rand B */
+	setarg 0x735B0C
+	store 3,0x40
+	setarg 0xA7F06B
+	istore 3,contw
+	setarg 0x04625E
+	istore 3,contw
+	setarg 0x3463B0
+	istore 3,contw
+	setarg 0xB8F17A
+	istore 3,contw
+	setarg 0x7C
+	istore 1,contw
+
+	/* address A */
+	setarg 0xf91330
+	store 3,0xb0
+	setarg 0x664c7d
+	istore 3,contw
+
+	/* address B */
+	setarg 0xdc7100
+	store 3,0xb8
+	setarg 0x2ea003
+	istore 3,contw
+
+	/* sres A */
+	setarg 0x2EEE19
+	store 3,0x50
+	setarg 0x7E
+	istore 1,contw
+
+	/* sres B */
+	setarg 0x4231A4
+	store 3,0x58
+	setarg 0xD1
+	istore 1,contw
+
+	/* linkA */
+	setarg 0xa6a026
+	store 3,0x60
+	setarg 0x2569d2
+	istore 3,contw
+	setarg 0xab4a9d
+	istore 3,contw
+	setarg 0x5e87c0
+	istore 3,contw
+	setarg 0x792aa9
+	istore 3,contw
+	setarg 0x4b
+	istore 1,contw
+
+	/* linkB */
+	setarg 0xa1f07d
+	store 3,0x70
+	setarg 0xec97a6
+	istore 3,contw
+	setarg 0xae31eb
+	istore 3,contw
+	setarg 0x6fe3c4
+	istore 3,contw
+	setarg 0xa1ae1a
+	istore 3,contw
+	setarg 0x3a
+	istore 1,contw
+
+	/* linkkey */
+	setarg 0x07505b
+	store 3,0x80
+	setarg 0xc9fe74
+	istore 3,contw
+	setarg 0x057b76
+	istore 3,contw
+	setarg 0x316404
+	istore 3,contw
+	setarg 0xd884b3
+	istore 3,contw
+	setarg 0x71
+	istore 1,contw
+
+	/* K */
+	setarg 0x0c333f
+	store 3,0x90
+	setarg 0x41de70
+	istore 3,contw
+	setarg 0x9b05a2
+	istore 3,contw
+	setarg 0xb954a2
+	istore 3,contw
+	setarg 0xb37516
+	istore 3,contw
+	setarg 0x36
+	istore 1,contw
+
+	/* kinit */
+	setarg 0x5ff91a
+	store 3,0xa0
+	setarg 0x39b5a4
+	istore 3,contw
+	setarg 0x258f2d
+	istore 3,contw
+	setarg 0x5d4a85
+	istore 3,contw
+	setarg 0x656ad3
+	istore 3,contw
+	setarg 0xab
+	istore 1,contw
+
+	arg 0,contr
+	arg mem_random_number,contw
+	call memcpy16
+	setarg 0x3131
+	store 2,mem_pin
+	istore 2,contw
+	jam 4,mem_pin_length
+	arg 0xb8,rega
+	call function_e22
+	arg mem_input_store,contr
+	arg mem_kinit,contw
+	call memcpy16
+	arg 0x10,rega
+	arg mem_kinit,regb
+	arg mem_random_number,contw
+	call xor16
+	arg 0xb0,rega
+	call function_e21
+	arg 0x60,regb
+	call compare16
+error_lka:
+	nbranch error_lka,zero
+	arg mem_input_store,contr
+	arg mem_link_key,contw	
+	call memcpy16
+	arg 0x20,rega
+	arg mem_kinit,regb
+	arg mem_random_number,contw
+	call xor16
+	arg 0xb8,rega
+	call function_e21
+	arg 0x70,regb
+	call compare16
+error_lkb:
+	nbranch error_lkb,zero
+	arg mem_input_store,rega
+	arg mem_link_key,regb
+	arg mem_link_key,contw
+	call xor16
+	arg 0x30,contr
+	arg mem_random_number,contw
+	call memcpy16
+	arg 0xb8,rega
+	call function_e1
+	arg 0x50,regb
+	force 4,loopcnt
+	call compare_key
+error_sresa:
+	nbranch error_sresa,zero
+	arg 0x40,contr
+	arg mem_random_number,contw
+	call memcpy16
+	arg 0xb0,rega
+	call function_e1
+	arg 0x58,regb
+	force 4,loopcnt
+	call compare_key
+error_sresb:
+	nbranch error_sresb,zero
+	branch loop1
+	
+	arg 0,contr
+	arg mem_random_number,contw
+	call memcpy16
+	force 12,loopcnt
+	call memcpy
+	arg 0x1c,contr
+	arg mem_link_key,contw
+	call memcpy16
+	arg 0x10,rega
+	call function_e3
+	branch loop1
+
+compare16:
+	force 16,loopcnt
+compare_key:
+	arg mem_input_store,rega
+compare_loop:
+	ifetch 1,rega
+	ifetcht 1,regb
+	isub temp,null
+	nrtn zero
+	increase 1,rega
+	increase 1,regb
+	loop compare_loop
+	force 0,pdata
+	rtn
+	
+endif
+
+loop1:	
+	branch loop1
+
+/* ==================== LE security ================= */
+
+generate_stk:
+	call function_s1
+	arg mem_le_ltk,contw
+	branch store_aes_result
+
+	/* contr = rand pointer */
+authenticate_rconfirm:
+	arg mem_le_srand,contw
+	branch authenticate_mconfirm,master
+	arg mem_le_mrand,contw
+authenticate_mconfirm:
+	copy contr,rega
+	call memcpy16
+	call function_c1
+	arg mem_le_rconfirm,contr
+	branch compare_res
+
+generate_confirm:
+	arg mem_le_mrand,rega
+	branch generate_mrand,master
+	arg mem_le_srand,rega
+generate_mrand:
+	copy rega,contw
+	call generate_random
+	branch function_c1
+
+generate_sk:
+	arg mem_le_skdm,contr
+	call load_data128
+	arg mem_le_ltk,contr
+	call load_regext
+	force 0x38,aes_ctrl
+	force 0x0,aes_ctrl
+	call wait_aes
+	arg mem_le_sk,contw
+	branch store_aes_result
+
+	/* temp=packet counter, rega = length or block counter*/
+first_block_counter:
+	force 0x49,pdata
+	branch first_block
+first_block_data:
+	force 1,pdata
+first_block:
+	force regidx_data,regext_index			/* B0 */
+	lshift8 temp,regext
+	ior regext,regext
+	increase 1,regext_index
+	rshift8 temp,regext
+	rshift16 regext,regext
+	fetch 2,mem_le_ivm
+	lshift16,pdata,pdata
+	ior regext,regext				/* octet3&octet4 of counter and low 16 bit of IV */
+	increase 1,regext_index
+	ifetch 4,contr					/* IV2-IV5 */
+	iforce regext
+	increase 1,regext_index
+	ifetch 2,contr					/* IV6-IV7 */
+	byteswap rega,regext
+	lshift16 regext,regext
+	ior regext,regext
+	increase 1,regext_index
+	rtn
+
+
+	/* temp=packet counter, regc pointers to data */	
+generate_mic:
+	add regc,1,contr
+	ifetch 1,contr
+	iforce rega
+	call first_block_counter
+	call do_aes_ocb
+
+	force regidx_data,regext_index			/* B1 */
+	ifetch 1,regc
+	and_into 0x3,pdata
+	lshift16 pdata,regext
+	set1 8,regext
+	call clear_hidata
+	call do_aes_cbc
+
+	copy rega,loopcnt
+	add regc,2,contr
+	call padding_data
+generate_mic_loop:
+	call aes_load_data
+	call do_aes_cbc
+	deposit loopcnt
+	branch generate_mic_end,blank
+	branch generate_mic_loop
+generate_mic_end:
+	force regidx_result,regext_index
+	deposit regext
+	store 4,mem_le_mic
+	rtn
+
+aes_crypt_data:
+	increase 1,rega
+	call first_block_data
+	copy regc,contr
+	call aes_load_xor
+	call do_aes_ctr
+	call store_enc_data
+	increase 16,regc
+	increase -16,regb
+	branch aes_crypt_data,positive
+	rtn
+	
+le_encrypt:
+	arg mem_le_txheader,regc
+	fetcht 5,mem_le_pcnt_tx
+	call generate_mic
+	force regidx_xor,regext_index
+	iforce regext
+	force 0,rega					/* rega is block counter */
+	call first_block_data
+	call do_aes_ctr
+	arg mem_le_txpayload,regc
+	fetch 1,mem_le_txlen
+	add pdata,-1,regb
+	iadd regc,contw
+	force regidx_result,regext_index
+	deposit regext
+	istore 4,contw	
+	call aes_crypt_data
+	fetch 1,mem_le_txlen
+	increase 4,pdata
+	store 1,mem_le_txlen
+	fetcht 5,mem_le_pcnt_tx
+	increase 1,temp
+	storet 5,mem_le_pcnt_tx
+	rtn
+
+le_decrypt:
+	fetch 1,mem_le_rxbuf+1
+	sub pdata,20,null
+	branch le_dec_cont,positive
+le_dec_cont:
+	arg mem_le_rxbuf+2,regc
+	add pdata,-1,regb
+	increase -4,pdata				/* mic will be discarded */
+	store 1,mem_le_rxbuf+1
+	iadd regc,contr
+	ifetch 4,contr
+	force regidx_xor,regext_index
+	iforce regext
+	force 0,rega					/* rega is block counter */
+	fetcht 5,mem_le_pcnt_rx
+	call first_block_data
+	call do_aes_ctr
+	force regidx_result,regext_index
+	deposit regext
+	store 4,mem_le_peer_mic
+	call aes_crypt_data
+	arg mem_le_rxbuf,regc
+	call generate_mic
+	fetcht 4,mem_le_peer_mic
+	isub temp,pdata				/* MIC ok? */
+	nrtn blank
+	fetch 4,mem_le_last_mic			/* reduntdant packet? */
+	isub temp,pdata
+	rtn blank
+	storet 4,mem_le_last_mic
+	fetch 5,mem_le_pcnt_rx
+	increase 1,pdata
+	store 5,mem_le_pcnt_rx
+	force 0,pdata
+	rtn
+
+wait_aes:
+	nbranch wait_aes,aes_ready
+	rtn
+
+do_aes_ocb:
+	force 0x30,aes_ctrl
+	force 0x0,aes_ctrl
+	branch wait_aes
+
+do_aes_cbc:
+	force 0x32,aes_ctrl
+	force 0x2,aes_ctrl
+	branch wait_aes
+
+do_aes_ctr:
+	force 0x34,aes_ctrl
+	force 0x4,aes_ctrl
+	branch wait_aes
+
+do_aes_cfb:
+	force 0x36,aes_ctrl
+	force 0x6,aes_ctrl
+	branch wait_aes
+	
+aes_init:
+	force 1,aes_ctrl
+	force 0,aes_ctrl
+	rtn
+function_s1:
+	force regidx_data,regext_index
+	fetch 4,mem_le_mrand
+	iforce regext
+	increase 1,regext_index
+	ifetch 4,contr
+	iforce regext
+	increase 1,regext_index
+	fetch 4,mem_le_srand
+	iforce regext
+	increase 1,regext_index
+	ifetch 4,contr
+	iforce regext
+	increase 1,regext_index
+	call aes_clear
+	force 0x38,aes_ctrl
+	force 0x8,aes_ctrl
+	branch wait_aes
+
+	/* rega pointers to random number */
+function_c1:
+	fetch 6,mem_le_lap
+	fetcht 6,mem_le_plap
+	branch function_c1_master,master
+	fetch 6,mem_le_plap
+	fetcht 6,mem_le_lap
+function_c1_master:
+	force regidx_xor,regext_index
+	copy temp,regext
+	increase 1,regext_index
+	rshift32 temp,regext
+	lshift16 pdata,pdata
+	ior regext,regext
+	increase 1,regext_index
+	rshift32 pdata,regext
+	increase 1,regext_index
+	force 0,regext					/* p2 = ia || ra */
+	force 0,pdata
+	fetch 1,mem_le_conn_peer_addr_type
+	fetcht 1,mem_le_adv_own_addr_type
+	nbranch function_c1_irat,master
+	//conn as master
+	fetch 1,mem_le_conn_own_addr_type
+	fetcht 1,mem_le_conn_peer_addr_type
+function_c1_irat:
+	store 1,mem_le_iat
+	storet 1,mem_le_rat
+	force regidx_data,regext_index
+	arg mem_le_iat,regb
+	force 4,loopcnt
+function_c1_loop1:
+	ifetch 4,rega		
+	ifetcht 4,regb
+	ixor temp,regext
+	increase 1,regext_index
+	increase 4,rega
+	increase 4,regb
+	loop function_c1_loop1		/* p1 ^ r */
+	call aes_clear				/* k = 0 */
+	force 0x38,aes_ctrl
+	force 0xc,aes_ctrl
+	call wait_aes
+
+	call aes_clear_data
+	force 0x3a,aes_ctrl
+	force 0x8,aes_ctrl
+	branch wait_aes
+
+padding_data:
+	compare 0,loopcnt,3
+	rtn true
+	deposit contr
+	iadd loopcnt,contw
+	force 0,pdata
+padding_loop:
+	istore 1,contw
+	increase 1,loopcnt
+	compare 0,loopcnt,3
+	rtn true
+	branch padding_loop
+
+aes_load_data:
+	force regidx_data,regext_index
+load_data_loop:
+	deposit loopcnt
+	branch load_data_padding,blank
+	ifetch 4,contr
+	increase -4,loopcnt
+load_data_padding:
+	iforce regext
+	increase 1,regext_index
+	compare regidx_key,regext_index,0xf
+	rtn true
+	branch load_data_loop
+
+aes_load_xor:
+	force regidx_xor,regext_index
+	branch load_regext
+load_key:
+	force regidx_key,regext_index
+	branch load_regext
+load_data128:
+	force regidx_data,regext_index
+load_regext:
+	force 4,loopcnt
+load_regext_loop:
+	ifetch 4,contr
+	iforce regext
+	increase 1,regext_index
+	loop load_regext_loop
+	rtn
+
+load_sk:
+	arg mem_le_sk,contr
+	branch load_key
+
+clear_hidata:
+	force 4,loopcnt
+	branch clear_data_rest
+
+aes_clear_data:
+	force regidx_data,regext_index
+aes_clear:
+	force 4,loopcnt
+clear_loop:
+	force 0,regext
+clear_data_rest:
+	increase 1,regext_index
+	loop clear_loop
+	rtn
+
+store_aes_result:
+	force regidx_result,regext_index
+	force 4,loopcnt
+send_aes_result_loop:
+	deposit regext
+	istore 4,contw
+	increase 1,regext_index
+	loop send_aes_result_loop
+	rtn
+
+store_enc_data:
+	force regidx_result,regext_index
+	copy regc,contw
+	add regb,1,loopcnt
+	sub loopcnt,15,null
+	branch store_enc_loop,positive
+	force 16,loopcnt
+store_enc_loop:
+	deposit regext
+	sub loopcnt,3,null
+	branch store_enc_byte,positive
+	istore 4,contw
+	increase -4,loopcnt
+	rtn zero
+	increase 1,regext_index
+	branch store_enc_loop
+store_enc_byte:
+	istore 1,contw
+	rshift8 pdata,pdata
+	loop store_enc_byte
+	rtn
+	
+	/* contr pointers to value to be compared */
+compare_res:
+	force regidx_result,regext_index
+	force 4,loopcnt
+compare_res_loop:
+	ifetch 4,contr
+	isub regext,null
+	nrtn zero
+	increase 1,regext_index
+	loop compare_res_loop
+	force 0,null
+	rtn
+
+enable_authrom:
+	hfetch 1,core_clkoff
+	set0 CLOCK_OFF_AUTH_ROM,pdata
+	hstore 1,core_clkoff
+	rtn
+
+disable_authrom:
+	hfetch 1,core_clkoff
+	set1 CLOCK_OFF_AUTH_ROM,pdata
+	hstore 1,core_clkoff
+	rtn
+
+init_memp:
+	arg mem_p,contw
+	setsect 0,0x3ffff
+	setsect 1,0x3ffff
+	setsect 2,0x3ffff
+	setsect 3,0x3fbff
+	istore 9,contw
+	setsect 0,0x3ffff
+	setsect 1,0x3ffff
+	setsect 2,0x3ffff
+	setsect 3,0x3ffff
+	istore 9,contw
+	setsect 0,0x3ffff
+	setsect 1,0x3ffff
+	setsect 2,0x3cfff
+	setsect 3,0x3ffff
+	istore 9,contw
+	setsect 0,0x3ffff
+	setsect 1,0x3ffff
+	setsect 2,0x3ffef
+	setsect 3,0x3ffff
+	istore 9,contw
+	setsect 0,0x3ffff
+	setsect 1,0x3ffff
+	setsect 2,0x3ffff
+	setsect 3,0x3ffff
+	istore 9,contw
+	setsect 0,0x3ffff
+	setsect 1,0x26c7f
+	setsect 2,0x146b
+	setsect 3,0x37bb3
+	istore 9,contw
+	setsect 0,0x1feb8
+	setsect 1,0x10c12
+	setsect 2,0x2b722
+	setsect 3,0x29fa6
+	istore 9,contw
+	setsect 0,0xe70f
+	setsect 1,0x16720
+	setsect 2,0x519e
+	setsect 3,0x19084
+	istore 9,contw
+	setsect 0,0x31012
+	setsect 1,0x360bf
+	setsect 2,0x3f0af
+	setsect 3,0x3d3
+	istore 9,contw
+	setsect 0,0x3a188
+	setsect 1,0x3ad0
+	setsect 2,0x3cbf2
+	setsect 3,0x243d9
+	istore 9,contw
+	setsect 0,0x2b030
+	setsect 1,0x36a03
+	setsect 2,0x11188
+	setsect 3,0x1e520
+	istore 9,contw
+	setsect 0,0x3a11e
+	setsect 1,0xfe5d
+	setsect 2,0xdd57
+	setsect 3,0x1ac93
+	istore 9,contw
+	setsect 0,0x11ed
+	setsect 1,0x218c4
+	setsect 2,0x8da7
+	setsect 3,0x257ff
+	istore 9,contw
+	setsect 0,0x3192b
+	setsect 1,0x34641
+	setsect 2,0x1be0c
+	setsect 3,0x366ad
+	istore 9,contw
+	setsect 0,0x1f83
+	setsect 1,0x15a23
+	setsect 2,0x3f9b0
+	setsect 3,0x3949
+	istore 9,contw
+	setsect 0,0x13a51
+	setsect 1,0x153fd
+	setsect 2,0x3372a
+	setsect 3,0xf1bb
+	istore 9,contw
+	setsect 0,0x3ae85
+	setsect 1,0x1eed9
+	setsect 2,0x9e66
+	setsect 3,0x1a8
+	istore 8,contw
+	rtn
+
Index: btkb/program/shutter.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/shutter.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/shutter.prog	(working copy)
@@ -0,0 +1,343 @@
+
+ifdef COMPILE_SHUTTER
+
+shutter_init:	
+	setarg shutter_send_process
+	store 2,mem_cb_bt_process
+	setarg shutter_process_idle
+	store 2,mem_cb_idle_process
+	setarg shutter_process_bb_event
+	store 2,mem_cb_bb_event_process
+	setarg shutter_process_lpm_before
+	store 2,mem_cb_before_lpm
+	setarg shutter_discovery_timeout_sleep
+	store 2,mem_cb_discovry_timeout
+	set1 mark_ext_patch,mark
+	bpatch patch3f_1,mem_patch3f
+	rtn wake
+
+	hjam 0x00,core_gpio_sel1//1: GPIO[26:25] is two wire SPI, 2: GPIO[26:23] is SPI, 3: GPIO[26:23] is PCM
+	call shutter_key_and_wake_gpio_setup
+	
+	setarg shutter_before_hibernate
+	store 2,mem_cb_before_hibernate
+	
+	jam FLAG_SHUTTER_1KEY_SEND_NULL,mem_shutter_1key_send_sm
+	jam 0,mem_shutter_key
+	jam FLAG_SHUTTER_DEFAULT,mem_shutter_flag
+	setarg 0
+	store 4,mem_shutter_send_data
+	call app_check_reconn_target
+	branch app_bt_start_discovery_short,blank
+	call app_led_on	
+	call app_bt_stop_discovery
+	branch app_bt_start_reconnect
+	
+shutter_key_and_wake_gpio_setup:
+	fetcht 1,mem_shutter_iphonekey_gpio
+	call gpio_config_input
+	fetcht 1,mem_shutter_androidkey_gpio
+	branch gpio_config_input	
+
+shutter_cancel_key_shake:
+	set1 mark_ext_patch,mark
+	bpatch patch3f_2,mem_patch3f
+	fetcht 4,mem_shutter_clkn_bt_last
+	deposit clkn_bt
+	store 4,mem_shutter_clkn_bt_last
+	isub temp,pdata	
+	nrtn positive 
+	sub pdata,200,pdata
+	rtn
+	
+shutter_send_process:
+	fetch 1,mem_hid_interrupt_state
+	rtnne 0x3f	
+shutter_scan_key_start:
+	set1 mark_ext_patch,mark
+	bpatch patch3f_3,mem_patch3f
+	fetch 1,mem_device_option
+	rtnne dvc_op_shutter	
+	disable user
+	call shutter_scan_key	
+	nrtn user
+	disable user
+	fetch 1,mem_scan_mode
+	beq 0x03,shutter_reconnect_scan_2
+	
+	fetch 1,mem_shutter_flag
+	beq FLAG_SHUTTER_IPHONEKEY_SEND,shutter_iphonekey_release 
+	beq FLAG_SHUTTER_ANDROIDKEY_SEND,shutter_androidkey_release 
+	call shutter_cancel_key_shake
+	branch  shutter_send_process_end,positive
+
+	fetch 1,mem_shutter_key
+	bbit1 FLAG_SHUTTER_IPHONEKEY_PRESS,shutter_iphonekey_press
+	bbit1 FLAG_SHUTTER_ANDROIDKEY_PRESS,shutter_androidkey_press
+	
+shutter_send_process_end:
+	jam 0,mem_shutter_key
+	jam FLAG_SHUTTER_DEFAULT,mem_shutter_flag
+	rtn
+
+	
+shutter_iphonekey_release:
+	jam FLAG_SHUTTER_DEFAULT,mem_shutter_flag
+	call ui_led_blink_stop
+	fetch 1,mem_shutter_key_number
+	beq FLAG_SHUTTER_1KEY,shutter_1key_iphonekey_release
+shutter_2key_iphonekey_release:
+shutter_iphonekey_release_package:
+	jam 0x05,mem_shutter_send_length
+	jam 0x03,mem_shutter_send_data
+	branch shutter_send_keydata
+shutter_1key_iphonekey_release:
+	jam FLAG_SHUTTER_1KEY_SEND_NULL,mem_shutter_1key_send_sm
+	branch shutter_1key_send_step1
+
+shutter_1key_send_step1:
+	jam FLAG_SHUTTER_1KEY_SEND_STEP2,mem_shutter_1key_send_sm
+	branch shutter_androidkey_press_package
+shutter_1key_send_step2:
+	jam FLAG_SHUTTER_1KEY_SEND_STEP3,mem_shutter_1key_send_sm
+	branch shutter_androidkey_release_package
+shutter_1key_send_step3:
+	jam FLAG_SHUTTER_1KEY_SEND_STEP4,mem_shutter_1key_send_sm
+	branch shutter_iphonekey_press_package
+shutter_1key_send_step4:
+	jam FLAG_SHUTTER_1KEY_SEND_NULL,mem_shutter_1key_send_sm
+	branch shutter_iphonekey_release_package
+	
+shutter_iphonekey_press:
+	jam FLAG_SHUTTER_IPHONEKEY_SEND,mem_shutter_flag	
+	call ui_led_on
+	fetch 1,mem_shutter_key_number
+	beq FLAG_SHUTTER_1KEY,shutter_1key_iphonekey_press
+shutter_2key_iphonekey_press:
+shutter_iphonekey_press_package:
+	jam 0x05,mem_shutter_send_length
+	setarg 0x20003
+	store 3,mem_shutter_send_data
+	branch shutter_send_keydata
+shutter_1key_iphonekey_press:
+	rtn
+	
+shutter_androidkey_release:
+	jam FLAG_SHUTTER_DEFAULT,mem_shutter_flag
+	call ui_led_blink_stop
+shutter_androidkey_release_package:
+	jam 0x0a,mem_shutter_send_length
+	jam 0x01,mem_shutter_send_data
+	branch shutter_send_keydata
+shutter_androidkey_press:
+	jam FLAG_SHUTTER_ANDROIDKEY_SEND,mem_shutter_flag
+	call ui_led_on
+shutter_androidkey_press_package:
+	jam 0x0a,mem_shutter_send_length	
+	jam 0x01,mem_shutter_send_data	
+	setarg 0x280000
+	store 3,mem_shutter_send_data+1
+	
+shutter_send_keydata:
+	set1 mark_ext_patch,mark
+	bpatch patch3f_4,mem_patch3f
+	fetch 1,mem_shutter_send_length
+	copy pdata,rega
+	call hid_malloc_tx_buff
+	fetch 2,mem_hid_int_remote_cid
+	istore 2,contw
+	setarg 0xa1
+	istore 1,contw
+	fetcht 4,mem_shutter_send_data
+	istoret 8,contw	
+	setarg 0
+	istore 1,contw	
+	store 4,mem_shutter_send_data
+	
+	fetch 1,mem_shutter_1key_send_sm
+	beq FLAG_SHUTTER_1KEY_SEND_STEP2,shutter_1key_send_step2
+  	beq FLAG_SHUTTER_1KEY_SEND_STEP3,shutter_1key_send_step3
+ 	beq FLAG_SHUTTER_1KEY_SEND_STEP4,shutter_1key_send_step4
+	rtn			
+	
+shutter_scan_key:
+	fetcht 1, mem_shutter_iphonekey_gpio
+	call gpio_get_bit
+	setarg 0
+	setflag true,FLAG_SHUTTER_IPHONEKEY_PRESS,pdata
+	store 1,mem_shutter_key_temp
+	fetcht 1,mem_shutter_androidkey_gpio
+	call gpio_get_bit
+	setarg 0
+	setflag true,FLAG_SHUTTER_ANDROIDKEY_PRESS,pdata
+	fetcht 1,mem_shutter_key_temp
+	ior temp,pdata
+	fetcht 1,mem_shutter_key
+	store 1,mem_shutter_key
+	ixor temp,null
+	rtn zero
+	enable user
+	rtn
+
+shutter_process_bb_event:
+	copy regc,pdata
+	beq BT_EVT_SETUP_COMPLETE,shutter_bb_event_setup_complete
+	beq BT_EVT_HID_CONNECTED,shutter_bb_event_hid_connected
+	beq BT_EVT_HID_DISCONNECTED,shutter_bb_event_hid_disconn
+	beq BT_EVT_VIRTUAL_CABLE_UNPLUG,shutter_bb_event_unplug
+	beq BT_EVT_BB_DISCONNECTED,shutter_bb_event_bb_disconn
+	beq BT_EVT_RECONN_FAILED,shutter_bb_event_reconn_failed
+	beq BT_EVT_RECONN_PAGE_TIMEOUT,shutter_bb_event_reconn_failed
+	beq BT_EVT_BB_CONNECTED,shutter_process_bb_conn
+	beq BT_EVT_HID_HANDSHAKE,shutter_event_hid_handshake
+	beq BT_EVT_REMOTE_UNSNIFF,app_start_auto_sniff
+	and pdata,0x0f,temp
+	and_into BT_EVT_TIMER_MASK,pdata
+	beq BT_EVT_TIMER_INIT,shutter_bb_event_timer
+	rtn
+	
+shutter_hid_handshake_timer:
+	fetch 1,mem_hid_handshake_timer_count
+	rtn blank
+	increase -1,pdata
+	store 1,mem_hid_handshake_timer_count
+	nrtn blank
+shutter_event_hid_handshake:
+	jam APP_HANDSHAKE_DONE,mem_app_handshake_flag
+	call app_lpm_mult_enable
+	call app_bt_store_reconn_info
+	call app_bt_stop_discovery
+	call app_led_off
+	branch app_bt_enter_sniff
+
+	
+shutter_process_bb_conn:
+	jam 0,mem_shutter_hid_disconn_count
+	jam 0,mem_shutter_cable_unplug_conut	
+	rtn	
+	
+shutter_bb_event_bb_disconn:
+	set1 mark_ext_patch,mark
+	bpatch patch3f_5,mem_patch3f
+	jam 0,mem_unsniff2sniff_timer_count
+	jam 0,mem_shutter_cable_unplug_conut	
+	jam 0,mem_shutter_hid_disconn_count
+	fetch APP_DISC_RSN_SIZE,mem_app_disconn_reason
+	bbit0 APP_DISC_AFTER_SNIFF,shutter_check_pairing
+shutter_bb_event_reconn_failed:
+	//call ice_break
+	fetch 2,mem_discovery_timeout
+	store 2,mem_discovery_timeout_timer_count
+shutter_discovery_on_not_renew_timer://when pairing does not renew discovery timer
+	call app_disconn_reason_clear
+	branch app_bt_start_discovery_led_blink
+
+shutter_check_pairing:
+	bbit0 APP_DISC_AFTER_PAIRING,shutter_check_reconn
+	branch shutter_bb_event_reconn_failed
+	
+shutter_check_reconn:
+	bbit0 APP_DISC_AFTER_RECONN,shutter_discovery_on_not_renew_timer
+	branch shutter_bb_event_reconn_failed
+
+
+shutter_bb_event_setup_complete:
+	call app_bt_stop_discovery
+	branch app_led_stop_blink
+
+shutter_bb_event_hid_connected:
+	setarg HID_HANDSHAKE_TIMEOUT
+	store 1,mem_hid_handshake_timer_count
+	rtn
+	
+shutter_bb_event_hid_disconn: 
+	jam 0,mem_shutter_cable_unplug_conut	
+	setarg FLAG_SHUTTER_HID_DISCONN_TIMEOUT
+	store 1,mem_shutter_hid_disconn_count
+	rtn
+	
+shutter_bb_event_unplug:	
+	setarg FLAG_SHUTTER_CABLE_UNPLUG_TIMEOUT
+	store 1,mem_shutter_cable_unplug_conut
+	rtn
+
+shutter_bb_event_timer:
+	set1 mark_ext_patch,mark
+	bpatch patch3f_6,mem_patch3f
+	storet 1,mem_app_evt_timer_count
+shutter_bb_event_100ms_loop:
+	fetch 1,mem_app_evt_timer_count
+	rtn blank
+	increase -1,pdata
+	store 1,mem_app_evt_timer_count
+	call shutter_check_unplug_timer
+	call shutter_hid_handshake_timer
+	call shutter_check_hid_disconn_timer
+	branch shutter_bb_event_100ms_loop
+	
+shutter_check_unplug_timer:
+	fetch 1,mem_shutter_cable_unplug_conut
+	rtn blank
+	fetch 1,mem_shutter_cable_unplug_conut
+	increase -1,pdata
+	store 1,mem_shutter_cable_unplug_conut
+	nrtn blank
+	fetch 1,mem_CONTROL_tasks
+	set1  L2CAP_DISCONNECT_INTERRUPT, pdata
+	set1  L2CAP_DISCONNECT_CONTROL, pdata
+	store 1,mem_CONTROL_tasks	
+	rtn
+
+shutter_check_hid_disconn_timer:
+	fetch 1,mem_shutter_hid_disconn_count
+	rtn blank
+	fetch 1,mem_shutter_hid_disconn_count
+	increase -1,pdata
+	store 1,mem_shutter_hid_disconn_count
+	nrtn blank
+	branch app_bt_disconnect	
+ 
+shutter_reconnect_scan:
+	set1 mark_ext_patch,mark
+	bpatch patch3f_7,mem_patch3f
+	fetch 1,mem_scan_mode
+	rtnne 0x03
+	branch shutter_scan_key_start
+shutter_reconnect_scan_2:
+	call shutter_cancel_key_shake
+	rtn positive
+	fetch 1,mem_shutter_key
+	rtn blank
+	call app_check_reconn_target
+	branch app_bt_start_discovery_short,blank
+	call app_led_on		
+	call app_bt_stop_discovery
+	branch app_bt_start_reconnect
+
+
+shutter_process_idle:
+	branch shutter_reconnect_scan
+
+
+shutter_process_lpm_before:
+	fetcht 1, mem_shutter_iphonekey_gpio
+	call gpio_set_wake_by_current_state
+	fetch 1,mem_shutter_key_number
+	bne FLAG_SHUTTER_1KEY,shutter_process_lpm_before_key2
+	rtn
+shutter_process_lpm_before_key2:	
+	fetcht 1, mem_shutter_androidkey_gpio
+	branch gpio_set_wake_by_current_state
+
+shutter_before_hibernate:
+	branch shutter_key_and_wake_gpio_setup
+
+
+shutter_discovery_timeout_sleep:	
+	branch app_enter_hibernate
+		
+else
+shutter_init:
+        branch assert
+	
+endif
Index: btkb/program/sim.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/sim.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/sim.prog	(working copy)
@@ -0,0 +1,350 @@
+simstart:
+	force 8,radio_ctrl
+	force 0,radio_ctrl
+	hjam 0xe0,0x907			// set if_phase=7 for simulation environment
+	hjam 0xe0,0x90a
+	hjam 0x25,0x912
+	hjam 0xff,rfen_ck
+	hjam 5,core_clksel
+//	branch sim_usb
+//	branch sim_iic
+//	branch sim_clk
+//	call sim_uart
+//	branch sim_lpm
+//	branch sim_c1
+//	branch loop
+//	call sim_spi
+//	call sim_eep
+//	branch test_tx
+//	branch sim_le
+//	branch sim_250k
+	branch sim_main
+sim_lpm:
+	hfetch 1,1
+	bbit1 7,sim_assert
+	hfetch 1,core_lpm_xtalcnt
+	nbranch sim_lpm_sleep,blank
+	setarg 0
+	set1 31,pdata
+	store 8,mem_gpio_wakeup_low
+	branch lpm_hibernate
+sim_lpm_sleep:
+	jam 1,mem_context
+	branch sim_lpm_wait,wake
+	hjam 0x70,core_bist_ctrl
+	hjam ccnt_start,core_misc_ctrl
+sim_lpm_wait:
+	call lpo_calibration
+	fetch 3,mem_clks_per_lpo
+	branch sim_lpm_wait,blank
+	call lpm_recover_clk,wake
+	jam 0x1b,mem_lpm_ldocnt
+	setarg mem_le_att_list
+	arg sim_assert,loopcnt
+	call save_ucode
+	hfetch 1,core_gpio_wakeup_low+2
+	bbit0 2,sim_lpm_loop
+	until null,lpo_edge
+	hjam 0x20,core_misc_ctrl
+	until null,lpo_edge
+sim_lpm_loop:
+	hfetch 1,core_misc_status
+	bbit1 6,sim_lpm_loop
+	hfetch 1,core_gpio_in+3
+	compare 0x20,pdata,0x20
+	setarg 0
+	setflag true,29,pdata
+	setflag true,30,pdata
+	store 4,mem_gpio_wakeup_low
+	setarg 0
+	nsetflag true,29,pdata
+	nsetflag true,30,pdata
+	store 4,mem_gpio_wakeup_high
+	arg 300,temp
+	branch lpm_sleep
+
+sim_assert:
+	branch sim_assert
+
+
+sim_main:
+	call init_param
+	setarg 0
+	hstore 2,core_clkoff
+	setarg 0xff00
+	hstore 2,core_lpm_reg+2
+	hjam lpmreg_sel_ctrl2,core_lpm_wr
+	hfetch 1,1
+	bbit1 7,sim_slave
+	call codec_init
+	jam dvc_op_hci,mem_device_option
+	fetch 6,mem_lap
+	store 6,mem_hci_plap
+	setarg 0xbdbdbd
+	store 3,mem_lap
+	istore 3,contw
+	jam hci_cmd_create_conn,mem_hci_cmd
+	force 0x10,pdata
+	add pdata,-2,clkn_bt
+	store 4,mem_page_clk
+	rshift clkn_bt,pdata
+	store 4,mem_last_clkn
+	jam 0,mem_scan_mode
+sim_loop:
+	call codec_loop
+	call idle_dispatch
+	fetch 1,mem_context
+	bbit0 state_inconn,sim_skip
+	set1 mark_tx_l2cap,mark
+	fetch 1,mem_context + coffset_state_map
+	set1 smap_edr,pdata
+	store 1,mem_context + coffset_state_map
+	fetch 1,mem_context + coffset_op		
+	set1 op_txl2cap,pdata
+	store 1,mem_context + coffset_op
+	jam 0,mem_context + coffset_lmp_to_send
+	jam 0,mem_lmo_opcode2
+	setarg 700
+	store 2,mem_tx_len
+	setarg mem_tmp_buffer
+	store 2,mem_txptr
+	jam 6,mem_tx_lch
+	jam 1,mem_hci_conn_handle
+sim_skip:
+	call connection_dispatch
+	branch sim_loop		
+
+sim_slave:
+	jam 2,mem_scan_mode
+	call page_scan_dispatch
+	branch sim_loop
+
+codec_loop:
+	hfetch 1,core_pcminfifo_remain
+	rtn blank
+	hfetch 1,core_pcminfifo
+	hstore 1,core_pcmoutfifo
+	branch codec_loop
+
+codec_init:
+	call init_filter_ram
+	hjam 0x11,core_enc_ctrl
+	hjam 0x11,core_dec_ctrl
+	hjam 0x1,core_cvsd_ctrl
+	hjam 0x1,core_codec_ctrl
+	hjam 0x80,core_gpio_oe3
+	hjam 0x3,core_gpio_sel1
+	rtn
+
+sim_iic:
+	call iicd_init_12m
+	setarg 3
+	hstore 2,core_iicd_txlen
+	setarg 0x1f051e
+	store 3,mem_iicd_addr
+	setarg mem_iicd_addr
+	hstore 2,core_iicd_txaddr
+	setarg 1
+	hstore 2,core_iicd_rxlen
+	hjam 3,core_iicd_ctrl
+	hjam iicd_start,core_misc_ctrl
+	call wait_iicd_done
+	nop 300
+	setarg 0xd321d2
+	store 3,mem_iicd_addr
+	hjam iicd_start,core_misc_ctrl
+	call wait_iicd_done
+s_loop:
+	branch s_loop
+
+sim_usb:
+	call usb_init
+sim_usb_loop:
+	call usb_isr
+	branch sim_usb_loop
+
+ifdef NULL
+sim_250k:
+	call init_250k
+	hfetch 1,1
+	bbit1 7,sim_250k_rx
+	call tx_radio_freq
+	call start_transmitter	/* get ready for that id packet */
+	nop 600
+	enable encode_fec0
+	set1 TXGFSK,radio_ctrl
+	force 0,pdata
+	inject mod,9
+	setarg 0xaa
+	inject mod,8
+	preload access
+	inject mod,32
+	setarg 0x1da861
+	inject mod,24
+	setarg 0x94445b
+	inject mod,24
+	setarg 0x1275f
+	inject mod,24
+	branch loop
+sim_250k_rx:
+	call rx_radio_freq
+	call start_receiver	/* wait for that id packet from master */
+	enable decode_fec0
+	correlate null,never
+	parse demod,bucket,72
+	branch loop
+
+	
+
+
+
+sim_uart:
+	setarg mem_le_test_uart_rxbuf
+	hstore 2,core_uart_tsaddr
+	hstore 2,core_uart_twptr
+	hstore 2,core_uart_trptrp
+	increase 0x80,pdata
+	hstore 2,core_uart_teaddr
+	hstore 2,core_uart_rsaddr
+	hstore 2,core_uart_rrptr
+	increase 0x80,pdata
+	hstore 2,core_uart_readdr
+	increase 1,pdata
+	hjam 0x84,core_gpio_sel1
+	hjam 0x80,core_gpio_pu2
+	hjam 0xe5,core_uart_ctrl
+	setarg 0x30
+	hstore 2,core_uart_baud
+	hfetch 1,1
+	bbit1 7,sim_uart_wait
+	setarg 0x1357d9a
+	store 4,mem_le_test_uart_rxbuf
+	setarg 0x55aa69
+	istore 3,contw
+	setarg 0xfedcb3
+	istore 3,contw
+	deposit contw
+	hstore 2,core_uart_twptr
+sim_uart_wait:
+	nop 20000
+	rtn
+
+sim_spi:
+	call spid_init_flash
+	call spid_unlock_flash
+	call spid_init
+	setarg 0x35
+	call spid_read_reg
+	nop 200
+	force 4,temp
+	setarg 0x42
+	branch spid_read_regs
+
+sim_eep:
+	call iicd_init_12m
+	setarg 3
+	hstore 2,core_iicd_txlen
+	setarg 0x1f051e
+	store 3,mem_iicd_addr
+	setarg mem_iicd_addr
+	hstore 2,core_iicd_txaddr
+	setarg 1
+	hstore 2,core_iicd_rxlen
+	hjam 3,core_iicd_ctrl
+	hjam iicd_start,core_misc_ctrl
+	call wait_iicd_done
+	nop 200
+	setarg 0x18f7a3b
+	store 4,mem_iicd_addr
+	arg mem_iicd_addr,rega
+	arg 4,temp
+	setarg 0x1235
+	call iicd_write_eep
+	nop 300
+	arg mem_ucode_keybuf,rega
+	arg 1,temp
+	setarg 0x3512
+	store 2,mem_addr_mi
+	call iicd_read_eep
+	arg 1,temp
+	setarg 0x3512
+	store 2,mem_addr_mi
+	call iicd_read_eep
+	nop 200
+	setarg 0xa1
+	arg 3,temp
+	arg mem_ucode_keybuf,rega
+	branch iicd_read_data
+
+sim_otp:
+	setarg 0x123456
+	store 3,0x800
+	setarg 0x10
+	arg 0x800,rega
+	arg 0x10,loopcnt
+	branch otp_write
+
+sim_clk:
+	add lpo_time,12,alarm
+	snooze
+clock_loop:
+	nop 100
+	hjam 1,core_config
+	setflag user,0,pdata
+	random pdata
+	and_into 0x1f,pdata
+	hstore 1,core_clksel
+	nop 70
+	hjam 2,core_kick
+	nop 200
+	branch clock_loop
+	hjam 2,core_clksel
+	setarg 1500
+	call sleep
+	hjam 0x42,core_clksel
+	add lpo_time,200,alarm
+	snooze
+	branch 0x4000
+
+sim_c1:
+	setarg 0xb4b5b6
+	store 3,mem_le_lap
+	setarg 0xb1b2b3
+	istore 3,contw
+	setarg 0xa4a5a6
+	store 3,mem_le_plap
+	setarg 0xa1a2a3
+	istore 3,contw
+	setarg 0x101
+	store 4,mem_le_preq
+	setarg 0x70710
+	istore 3,contw
+	setarg 0x302
+	store 4,mem_le_pres
+	setarg 0x50008
+	istore 3,contw
+
+	arg regidx_key,regext_index
+	arg 4,loopcnt
+sim_clear_key_loop:
+	arg 0,regext
+	increase 1,regext_index
+	loop sim_clear_key_loop
+
+	setarg 0x702EE0
+	store 3,mem_le_rconfirm
+	setarg 0x274EC6
+	istore 3,contw
+	setarg 0x0E6388
+	istore 3,contw
+	setarg 0x56AD6F
+	istore 3,contw
+	setarg 0x83D521
+	istore 3,contw
+	setarg 0x57	
+	istore 1,contw
+	arg mem_le_rconfirm,rega
+	call aes_init
+	call function_c1
+	branch loop
+endif
Index: btkb/program/simple_pairing.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/simple_pairing.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/simple_pairing.prog	(working copy)
@@ -0,0 +1,1402 @@
+
+
+ifdef SIMPLE_PAIRING
+sp_initialize:
+	set1 mark_ext_patch,mark
+	bpatch patch3e_2,mem_patch3e
+	fetch 1,mem_ssp_enable	//set in ssp.rom
+	branch ssp_disable, blank
+	call ssp_enable
+	setarg 0
+	store 8,mem_sp_state_start
+	store 4,mem_sp_flag_start
+	
+	arg mem_sp_iocap_remote,contw
+	istore 7,contw
+	jam DEFAULT_STATEMACHINE,mem_sp_localsm
+	branch sp_pubkey_calc 
+
+sp_generate_local_key:
+	jam SP_FLAG_COMMIT,mem_sp_flag  
+	branch sp_generate_local_key0
+sp_master_generate_local_key:
+	fetch 1,mem_sp_local_key_invalid
+	beq SP_KEY_VALID,sp_dhkey_calc
+	branch assert
+sp_generate_local_key0:
+	fetch 1,mem_sp_local_key_invalid
+	beq SP_KEY_VALID,sp_start_send_pubkey
+	branch sp_pubkey_calc
+    
+sp_start_send_pubkey:
+	call sp_dhkey_calc
+	fetch 1,mem_master_sp_state
+	nrtn blank
+	jam SP_STAT_KEY_SEND,mem_sp_state
+	rtn
+    
+sp_calculate_commitment:
+	fetch 1,mem_sp_calc
+	bne SP_CALC_STANDBY,sp_calculate_commitment_wait_dhkey_calc
+	call sp_local_random_key_generator
+	arg mem_sp_prarm_stack,contw
+	setarg mem_sp_random_local_end
+	istore 2,contw
+	setarg mem_sp_pubkey_local_x_end
+	istore 2,contw
+	setarg mem_sp_pubkey_remote_x_end
+	istore 2,contw
+	branch sp_calculate_commitment0
+master_sp_calculate_commitment:
+	arg mem_sp_prarm_stack,contw
+	setarg mem_sp_random_remote_end
+	istore 2,contw
+	setarg mem_sp_pubkey_remote_x_end
+	istore 2,contw
+	setarg mem_sp_pubkey_local_x_end
+	istore 2,contw
+sp_calculate_commitment0:
+	call function_f1
+	fetch 1,mem_master_sp_state
+	beq SP_STAT_COMMIT_CALC,master_sp_calculate_commitment0
+	jam SP_FLAG_COMMIT,mem_sp_flag
+	jam SP_STAT_COMMIT_SEND,mem_sp_state
+	rtn
+master_sp_calculate_commitment0:
+	jam SP_STAT_COMMITMENT_COMPARE,mem_master_sp_state
+	call sp_master_generate_local_key
+	branch master_set_mem_master_sp_flag 
+
+sp_local_random_key_generator:
+	arg mem_sp_random_local,contw
+	force 8,queue
+	branch random_generator
+  
+sp_calculate_commitment_wait_dhkey_calc:
+	jam      SP_FLAG_COMMIT,mem_sp_flag
+	rtn
+    
+sp_confirm_check:
+    /* calculate Ea here */
+	arg      mem_addr_value,contw
+	fetch    6,mem_lap
+	istore   6,contw
+	fetch    6,mem_plap
+	istore   6,contw
+	fetch    3,mem_sp_iocap_remote
+	istore   3,contw 
+
+	call     function_f3a
+
+	arg      mem_sp_calc_result_high,rega
+	arg      mem_sp_check_result,regb    
+	force    4,queue 
+	call     compare4
+	nbranch  sp_confirm_check_failed,true  
+    
+sp_confirm_check_success:
+	fetch 1,mem_master_sp_state
+	beq SP_STAT_CONFIRM_CHECK,sp_confirm_check_success_master
+	jam SP_STAT_CONFIRM_CALC,mem_sp_state
+	jam SP_FLAG_COMMIT,mem_sp_flag  
+	jam LMP_ACCEPTED,mem_lmo_opcode2
+	rtn
+sp_confirm_check_success_master:
+	jam LMP_ACCEPTED,mem_lmo_opcode2
+	jam SP_STATE_END,mem_master_sp_state
+	branch master_set_mem_master_sp_flag
+	//accept opcode?
+	
+sp_confirm_check_failed:
+	fetch 1,mem_master_sp_state
+	beq SP_STAT_CONFIRM_CHECK,sp_confirm_check_failed_master
+	jam SP_STAT_NULL,mem_sp_state
+	jam LMP_NOT_ACCEPTED,mem_lmo_opcode2
+	//accept opcode?
+	jam      AUTHENTICATION_FAILURE_ERROR,mem_lmo_reason2 
+	rtn
+sp_confirm_check_failed_master:
+	jam LMP_NOT_ACCEPTED,mem_lmo_opcode2
+	jam SP_STAT_NULL,mem_master_sp_state
+	rtn
+    
+sp_confirm_calc:
+	fetch 1,mem_sp_dh_ready
+	beq SP_FLAG_COMMIT, sp_confirm_calc_ready
+	jam 	SP_STAT_CONFIRM_CALC,mem_master_sp_state
+	branch master_set_mem_master_sp_flag
+sp_confirm_calc_ready:
+	arg      mem_addr_value,contw
+	fetch    6,mem_plap
+	istore   6,contw
+	fetch    6,mem_lap
+	istore   6,contw
+	fetch    3,mem_sp_iocap_local
+	istore   3,contw 
+
+	call     function_f3b
+	fetch 1,mem_master_sp_state
+	beq SP_STAT_CONFIRM_CALC,sp_confirm_calc_master
+	jam      SP_STAT_CONFIRM_SEND,mem_sp_state
+	jam      SP_FLAG_COMMIT,mem_sp_flag
+	rtn
+sp_confirm_calc_master:
+	jam      SP_STAT_CONFIRM_SEND,mem_master_sp_state
+	jam      SP_FLAG_COMMIT,mem_master_sp_flag
+	rtn   
+
+sp_master_key_prarm_push:
+	arg mem_sp_prarm_stack,contw
+	fetch    6,mem_plap
+	istore   6,contw
+	fetch    6,mem_lap
+	istore   6,contw
+	setarg mem_sp_random_local_end
+	istore 2,contw
+	setarg mem_sp_random_remote_end
+	istore 2,contw
+	branch sp_link_key_calc
+sp_link_key_prarm_push:
+	jam      SP_STAT_DONE,mem_sp_state    
+	arg mem_sp_prarm_stack,contw
+	fetch    6,mem_lap
+	istore   6,contw
+	fetch    6,mem_plap
+	istore   6,contw
+	setarg mem_sp_random_remote_end
+	istore 2,contw
+	setarg mem_sp_random_local_end
+	istore 2,contw
+sp_link_key_calc:
+    /*calculate Link key here */
+	arg      mem_addr_value,contw
+	fetch    6,mem_sp_prarm_stack
+	istore   6,contw
+	fetch    6,mem_sp_prarm_stack+6
+	istore   6,contw
+	
+	call     function_f2    
+
+	/*handle linkkey  */
+	jam 1,mem_link_key_exists
+	arg mem_link_key,contw
+	arg mem_sp_calc_result_high,contr
+	call memcpy16
+	branch  generate_linkkey_continue
+
+    
+sp_pubkey_calc:
+	set1 mark_ext_patch,mark
+	bpatch patch3e_3,mem_patch3e
+	fetch    1,mem_sp_local_key_invalid
+	rtnne SP_KEY_INVALID
+	fetch    1,mem_sp_calc
+	rtnne  SP_CALC_STANDBY
+	arg      mem_sp_private_key,contw 
+	force    11,queue
+	call     random_generator
+	random   pdata
+	rshift   pdata,pdata
+	istore   2,contw 
+/* we don't need fixed private key,generate random key instead */ 
+	arg      mem_k,contw
+	arg      mem_sp_private_key,contr	
+	call     memcpy24 //mem_sp_private_key=>mem_k 24BYTES
+
+	arg      mem_ax,contw
+	arg      mem_gx,contr
+	call     memcpy48 //mem_gx=>mem_ax 48bytes
+
+	arg      mem_az,contw
+	call     bn_zero
+	jam      1,mem_az //0=>mem_az 24bytes
+
+	call     eckp_calc_init
+	jam SP_CALC_PUBKEY,mem_sp_calc
+	rtn    
+	
+sp_pubkey_generated:
+	arg      mem_sp_pubkey_local,contw
+	arg      mem_bx,contr
+	call     memcpy48   
+	jam      SP_KEY_VALID,mem_sp_local_key_invalid
+	jam      SP_CALC_STANDBY,mem_sp_calc
+	rtn
+
+sp_dhkey_calc:
+	set1 mark_ext_patch,mark
+	bpatch patch3e_4,mem_patch3e
+	fetch    1,mem_sp_dhkey_invalid
+	rtnne  SP_KEY_INVALID
+	fetch    1,mem_sp_calc
+	rtnne  SP_CALC_STANDBY
+
+	arg      mem_k,contw
+	arg      mem_sp_private_key,contr	
+	call     memcpy24
+
+	arg      mem_ax,contw
+	arg      mem_sp_pubkey_remote,contr
+	call     memcpy48
+
+	arg      mem_az,contw
+	call     bn_zero
+	jam      1,mem_az
+
+	call     eckp_calc_init
+	jam      SP_CALC_DHKEY,mem_sp_calc
+	rtn 	
+	
+sp_dhkey_generated:
+	jam SP_FLAG_COMMIT,mem_sp_dh_ready
+	arg mem_sp_dhkey,contw
+	arg mem_bx,contr
+	call memcpy24
+	jam SP_KEY_VALID,mem_sp_dhkey_invalid
+	jam SP_CALC_STANDBY,mem_sp_calc
+	rtn
+
+random_generator:
+	increase -1,queue
+	nrtn     positive
+	random   pdata
+	istore   2,contw  
+	branch   random_generator
+compare4:
+	increase -1,queue
+	nbranch  compare4_success,positive
+	ifetch   4,rega
+	copy     pdata,temp
+	ifetch   4,regb
+	iflip    temp,pdata
+	nbranch  compare4_failed,zero
+	increase 4,rega
+	increase 4,regb
+	branch   compare4
+compare4_failed:
+	disable  true
+	rtn
+compare4_success:
+	enable   true
+	rtn
+
+/*************************************************/
+/** Message state machine routines ***************/
+/*************************************************/
+// simple pairing support 
+
+simple_pairing_sequence:
+	set1 mark_ext_patch,mark
+	bpatch patch3e_5,mem_patch3e
+         fetch 1,mem_sp_flag
+         rtn blank
+	jam      SP_FLAG_STANDBY,mem_sp_flag
+	fetch    1,mem_sp_state
+	beq  SP_STAT_KEY_SEND,sp_send_LMP_ENCAPSULATED_HEADER
+	beq  SP_STAT_COMMIT_SEND,sp_send_LMP_SIMPLE_PAIRING_COMFIRM
+	beq  SP_STAT_RANDOM_SEND,sp_send_LMP_SIMPLE_PAIRING_NUMBER
+	beq  SP_STAT_CONFIRM_SEND,sp_send_LMP_DHKEY_CHECK
+	beq  SP_STAT_KEY_GENERATE,sp_generate_local_key
+	beq  SP_STAT_COMMIT_CALC,sp_calculate_commitment
+	beq  SP_STAT_CONFIRM_CHECK,sp_confirm_check
+	beq  SP_STAT_CONFIRM_CALC,sp_confirm_calc
+	beq  SP_STAT_LINK_KEY_CALC,sp_link_key_prarm_push
+	//beq  SP_STAT_FEATURE_EXT_SEND,send_LMP_FEATURES_REQ_EXT
+	rtn  
+
+master_simple_paring_sequence:
+	set1 mark_ext_patch,mark
+	bpatch patch3e_6,mem_patch3e
+	fetch 1,mem_master_sp_flag
+	rtn blank
+	jam SP_FLAG_STANDBY,mem_master_sp_flag
+	fetch 1,mem_master_sp_state
+	beq SP_MASTER_STAT_START_SKIP,sp_master_send_io_cap_get
+	beq SP_MASTER_STAT_START_DONE,sp_master_send_io_cap_send
+	beq SP_STAT_KEY_SEND,sp_master_send_LMP_ENCAPSULATED_HEADER
+	beq SP_STAT_COMMIT_CALC,master_sp_calculate_commitment
+	beq SP_STAT_COMMITMENT_COMPARE,sp_master_commitment_compare
+	beq SP_STAT_RANDOM_SEND,sp_master_send_LMP_SIMPLE_PAIRING_NUMBER
+	beq SP_STAT_CONFIRM_CALC,sp_confirm_calc
+	beq SP_STAT_CONFIRM_SEND,master_sp_send_lmp_dhkey_check
+	beq SP_STAT_CONFIRM_CHECK,sp_confirm_check
+	beq SP_STATE_END,master_sp_sm_end
+	rtn
+
+master_set_mem_master_sp_flag:
+	jam SP_FLAG_COMMIT,mem_master_sp_flag
+	rtn
+	
+master_clear_mem_master_sp_flag:
+	jam SP_FLAG_STANDBY,mem_master_sp_flag
+	rtn
+sp_calc_sequence:
+	set1 mark_ext_patch,mark
+	bpatch patch3e_7,mem_patch3e
+	fetch 1,mem_sp_calc
+	rtn blank
+	increase 0x80,pdata
+	store    1,mem_sp_calc
+	rtnbit1 7
+	fetch    1,mem_ec_loopc
+	branch   sp_calc_sequence_done,blank
+	branch   eckp_calc
+
+sp_calc_sequence_done:    
+	call ecunmapz
+	fetch 1,mem_sp_calc
+	beq  SP_CALC_PUBKEY,sp_pubkey_generated
+	beq  SP_CALC_DHKEY,sp_dhkey_generated
+	rtn
+
+
+bn_testbit:
+	and pdata,7,queue
+	rshift3 pdata,pdata
+	iadd contr,contr
+	ifetch 1,contr
+	qisolate0 pdata
+	rtn
+
+
+ec_copy:
+	call memcpy24
+	call memcpy24
+	branch memcpy24
+	
+	
+bn_eq_zero:
+	ifetch 8,contr
+	nrtn blank
+	ifetch 8,contr
+	nrtn blank
+	ifetch 8,contr
+	rtn
+	
+	
+	/* return zero if eq */
+bn_eq:
+	force 6,loopcnt
+bn_eq_0:	
+	ifetch 4,rega
+	iforce temp
+	ifetch 4,regb
+	isub temp,null
+	nrtn zero
+	increase 4,rega
+	increase 4,regb
+	loop bn_eq_0
+	rtn
+
+	/* return positive if A >= B */
+bn_bigeq:
+	force 6,loopcnt
+	increase 20,rega
+	increase 20,regb
+bn_bigeq_0:	
+	ifetch 4,regb
+	iforce temp
+	ifetch 4,rega
+	isub temp,pdata
+	nrtn positive
+	nrtn blank
+	increase -4,rega
+	increase -4,regb
+	loop bn_bigeq_0
+	rtn
+
+bn_add:
+	force 6,loopcnt
+	force 0,regc
+bn_add_0:	
+	ifetch 4,rega
+	iforce temp
+	ifetch 4,regb
+	iadd temp,pdata
+	iadd regc,pdata
+	istore 4,contw
+	isolate1 32,pdata
+	setflag true,0,regc
+	increase 4,rega
+	increase 4,regb
+	loop bn_add_0
+	rtn
+
+bn_sub:
+	force 6,loopcnt
+	force 0,regc
+bn_sub_0:	
+	ifetch 4,regb
+	iforce temp
+	ifetch 4,rega
+	isub temp,pdata
+	isub regc,pdata
+	istore 4,contw
+	isolate1 32,pdata
+	setflag true,0,regc
+	increase 4,rega
+	increase 4,regb
+	loop bn_sub_0
+	rtn
+
+bn_rshift6:
+	force 6,loopcnt
+	increase 20,rega
+bn_rshift:
+	force 0,regc
+bn_rshift_0:	
+	ifetch 4,rega
+	isolate1 0,pdata
+	setflag true,1,regc
+	rshift pdata,pdata
+	isolate1 0,regc
+	setflag true,31,pdata
+	istore 4,rega
+	increase -4,rega
+	rshift regc,regc
+	loop bn_rshift_0
+	rtn
+
+bn_lshift:
+	force 6,loopcnt
+	force 0,regc
+bn_lshift_0:	
+	ifetch 4,rega
+	isolate1 31,pdata
+	setflag true,1,regc
+	lshift pdata,pdata
+	isolate1 0,regc
+	setflag true,0,pdata
+	istore 4,rega
+	increase 4,rega
+	rshift regc,regc
+	loop bn_lshift_0
+	rtn
+	
+bn_lshiftmod:
+	call bn_lshift
+bn_lshiftmod_ismod:	
+	isolate1 0,regc
+	branch bn_lshiftmod_0,true
+	arg mem_p,regb
+	copy rega,regc
+	increase -24,rega
+	call bn_bigeq
+	nrtn positive
+	copy regc,rega
+bn_lshiftmod_0:
+	increase -24,rega
+	arg mem_p,regb
+	copy rega,contw
+	branch bn_sub
+	
+
+bn_addmod:
+	call bn_add
+	copy contw,rega
+	branch bn_lshiftmod_ismod
+	
+bn_submod:
+	call bn_sub
+	isolate0 0,regc
+	rtn true
+	arg mem_p,regb
+	add contw,-24,rega
+	copy rega,contw
+	branch bn_add
+	
+
+bn_p192mod:
+	copy contw,timeup				/* save result ptr */
+	copy rega,alarm				/* temp save rega */
+	arg mem_tmp2,regb
+	copy regb,contw
+	add rega,24,contr
+	ifetch 8,contr
+	istore 8,contw
+	istore 8,contw
+	force 0,pdata
+	istore 8,contw
+	copy timeup,contw
+	call bn_addmod
+	arg mem_tmp2,regb
+	copy regb,contw
+	force 0,pdata
+	istore 8,contw
+	add alarm,32,contr
+	ifetch 8,contr
+	istore 8,contw
+	istore 8,contw
+	copy timeup,rega
+	copy rega,contw
+	call bn_addmod
+	arg mem_tmp2,regb
+	copy regb,contw
+	add alarm,40,contr
+	ifetch 8,contr
+	istore 8,contw
+	istore 8,contw
+	istore 8,contw
+	copy timeup,rega
+	copy rega,contw
+	branch bn_addmod
+		
+
+bn_load:
+	force 6,loopcnt
+bn_load_0:	
+	ifetch 4,contr
+	iforce regext
+	increase 1,regext_index
+	loop bn_load_0
+	rtn
+
+
+	/* cost 1562 clks */	
+bn_mulmod:
+	copy contw,timeup					/* save result ptr */
+	arg mem_tmp1,contw
+	call bn_zero
+	arg mem_tmp1,contw
+	copy rega,contr
+	force 0,regext_index
+	call bn_load
+	copy regb,contr
+	call bn_load
+	force 0,regb
+bn_mulmod_1:	
+	force 0,temp
+	force 6,regc
+bn_mulmod_0:
+	ifetch 4,contw					/* d[i+j] */
+	iforce rega
+	copy regb,regext_index
+	deposit regext
+	copy regc,regext_index
+	imul32 regext,pdata
+	iadd rega,pdata					/* uv = a[i]*b[j] + d[i+j] */
+	iadd temp,pdata					/* uv += u */
+	istore 4,contw					/* ->d[i+j] */
+	rshift32 pdata,temp				/* temp = u = uv >> 32 */
+	increase 1,regc
+	compare 12,regc,0xff
+	nbranch bn_mulmod_0,true
+	deposit temp
+	istore 4,contw					/* d[i + 12] = u */
+	increase -24,contw
+	increase 1,regb
+	compare 6,regb,0xff
+	nbranch bn_mulmod_1,true
+	arg mem_tmp1,rega
+	copy timeup,contw
+	branch bn_p192mod
+
+	
+bn_sqrmod:
+	copy rega,regb
+	branch bn_mulmod
+
+bn_rshifteven:
+	copy rega,alarm
+bn_rshifteven_1:
+	copy alarm,rega
+	ifetch 1,rega
+	isolate1 0,pdata
+	rtn true
+	call bn_rshift6
+	ifetch 1,regb
+	isolate0 0,pdata
+	branch bn_rshifteven_0,true
+	arg mem_p,rega
+	copy regb,contw
+	call bn_add
+	ifetch 1,regb
+	iadd regc,pdata
+	istore 1,regb						/* [6] */
+	increase -24,regb
+bn_rshifteven_0:
+	add regb,24,rega
+	force 7,loopcnt
+	call bn_rshift
+	branch bn_rshifteven_1
+
+	/* cost 141910 clks */
+bn_invmod:
+	copy contw,timeup					/* save result ptr */
+	arg mem_tmp0,contw				/* x */
+	call bn_zero
+	force 0,pdata
+	store 4,mem_tmp5
+	store 4,mem_t2
+	jam 1,mem_tmp0
+	arg mem_tmp1,contw				/* y */
+	call bn_zero
+	arg mem_p,contr
+	arg mem_tmp2,contw				/* a */
+	call memcpy24
+	copy rega,contr
+	arg mem_tmp3,contw				/* b */
+	call memcpy24
+bn_invmod_2:	
+	arg mem_tmp3,contr
+	call bn_eq_zero
+	branch bn_invmod_0,blank
+	arg mem_tmp3,rega
+	arg mem_tmp0,regb
+	call bn_rshifteven
+
+	arg mem_tmp2,rega
+	arg mem_tmp1,regb
+	call bn_rshifteven
+	arg mem_tmp3,rega
+	arg mem_tmp2,regb
+	call bn_bigeq
+	branch bn_invmod_1,positive
+	arg mem_tmp2,rega
+	arg mem_tmp3,regb
+	copy rega,contw
+	call bn_sub
+	arg mem_tmp0,rega
+	arg mem_tmp1,regb
+	copy regb,contw
+	call bn_add
+	ifetch 1,rega
+	iadd regc,regc
+	ifetch 1,regb
+	iadd regc,pdata
+	istore 1,regb
+	branch bn_invmod_2
+bn_invmod_1:
+	arg mem_tmp3,rega
+	arg mem_tmp2,regb
+	copy rega,contw
+	call bn_sub
+	arg mem_tmp1,rega
+	arg mem_tmp0,regb
+	copy regb,contw
+	call bn_add
+	ifetch 1,rega
+	iadd regc,regc
+	ifetch 1,regb
+	iadd regc,pdata
+	istore 1,regb
+	branch bn_invmod_2
+bn_invmod_0:
+	arg mem_tmp0,contw
+	call bn_zero
+	fetch 1,mem_tmp5
+	store 1,mem_tmp0
+	store 1,mem_tmp0a
+	arg mem_tmp0,rega
+	arg mem_tmp1,regb
+	copy regb,contw
+	call bn_addmod
+	arg mem_p,rega
+	arg mem_tmp1,regb
+	copy timeup,contw
+	branch bn_submod
+	
+
+
+	/* cost 64742 clks */
+ecdbl:
+	arg mem_cz,rega
+	arg mem_t2,contw
+	call bn_sqrmod
+	arg mem_t2,rega
+	arg mem_t3,contw
+	call bn_sqrmod
+	arg mem_a,rega
+	arg mem_t3,regb
+	arg mem_t3,contw
+	call bn_mulmod		/* t3=a*z4	*/
+	arg mem_cx,rega
+	arg mem_t2,contw
+	call bn_sqrmod
+	arg mem_t2,contr
+	arg mem_t1,contw
+	call memcpy24
+	arg mem_t1,rega
+	call bn_lshiftmod
+	arg mem_t2,rega
+	arg mem_t1,regb
+	arg mem_t2,contw
+	call bn_addmod
+	arg mem_t2,rega
+	arg mem_t3,regb
+	arg mem_t2,contw
+	call bn_addmod		/* t2=3*x2 + z*z4		D  */
+	arg mem_cx,contr
+	arg mem_t1,contw
+	call memcpy24
+	arg mem_cy,rega
+	arg mem_t3,contw
+	call bn_sqrmod
+	arg mem_t1,rega
+	call bn_lshiftmod
+	arg mem_t1,rega
+	call bn_lshiftmod
+	arg mem_t1,rega		
+	arg mem_t3,regb
+	arg mem_t1,contw
+	call bn_mulmod		/* t1=4x*y2	B	*/
+	arg mem_t3,rega
+	arg mem_t0,contw
+	call bn_sqrmod
+	arg mem_t0,rega
+	call bn_lshiftmod
+	arg mem_t0,rega
+	call bn_lshiftmod		
+	arg mem_t0,rega		
+	call bn_lshiftmod		/* t0=8*y4		C */
+	arg mem_cy,contr
+	arg mem_t3,contw
+	call memcpy24
+	arg mem_t3,rega
+	call bn_lshiftmod
+	arg mem_t3,rega
+	arg mem_cz,regb
+	arg mem_cz,contw
+	call bn_mulmod		
+	arg mem_t2,rega
+	arg mem_t3,contw
+	call bn_sqrmod
+	arg mem_t3,rega
+	arg mem_t1,regb
+	arg mem_t3,contw
+	call bn_submod
+	arg mem_t3,rega
+	arg mem_t1,regb
+	arg mem_cx,contw
+	call bn_submod
+	arg mem_t1,rega
+	arg mem_cx,regb
+	arg mem_t3,contw
+	call bn_submod
+	arg mem_t3,rega
+	arg mem_t2,regb
+	arg mem_t3,contw
+	call bn_mulmod		
+	arg mem_t3,rega
+	arg mem_t0,regb
+	arg mem_cy,contw
+	branch bn_submod
+	
+
+	/* cost 104904	clks */
+ecadd:
+	arg mem_az,rega
+	arg mem_t7,contw
+	call bn_sqrmod
+	arg mem_cx,rega
+	arg mem_t7,regb
+	arg mem_t0,contw
+	call bn_mulmod		/* n1=t0=xa*zb2  */
+	arg mem_az,rega
+	arg mem_t7,regb
+	arg mem_t7,contw
+	call bn_mulmod	
+	arg mem_cy,rega
+	arg mem_t7,regb
+	arg mem_t1,contw
+	call bn_mulmod		/* n2=t1=ya*zb3 */
+	arg mem_cz,rega
+	arg mem_t7,contw
+	call bn_sqrmod
+	arg mem_ax,rega
+	arg mem_t7,regb
+	arg mem_t2,contw
+	call bn_mulmod		/* n3=t2=xb*za2 */
+	arg mem_cz,rega
+	arg mem_t7,regb
+	arg mem_t7,contw
+	call bn_mulmod	
+	arg mem_ay,rega
+	arg mem_t7,regb
+	arg mem_t3,contw
+	call bn_mulmod		/* n4=t3=yb*za3 */
+	arg mem_t0,rega
+	arg mem_t2,regb
+	arg mem_t7,contw
+	call bn_submod		/* n5=t7=n1-n3=t0-t2 */
+	arg mem_t0,rega
+	arg mem_t2,regb
+	arg mem_t0,contw
+	call bn_addmod		/* n7=t0=n1+n3=t0+t2 */
+	arg mem_t1,rega
+	arg mem_t3,regb
+	arg mem_t2,contw
+	call bn_submod		/* n6=t2=n2-n4=t1-t3 */
+	arg mem_t1,rega
+	arg mem_t3,regb
+	arg mem_t1,contw
+	call bn_addmod		/* n8=t1=n2+n4=t1+t3 */
+	arg mem_t1,rega
+	arg mem_t7,regb
+	arg mem_t1,contw
+	call bn_mulmod		/* t1=n8*n5 */
+	arg mem_cz,rega
+	arg mem_az,regb
+	arg mem_t3,contw
+	call bn_mulmod	
+	arg mem_t3,rega
+	arg mem_t7,regb
+	arg mem_cz,contw
+	call bn_mulmod		/* z=za*zb*n5 */
+	arg mem_t7,rega
+	arg mem_t7,contw
+	call bn_sqrmod		/* t7=n5^2 */
+	arg mem_t7,rega
+	arg mem_t0,regb
+	arg mem_t3,contw
+	call bn_mulmod		/* t3=n5^2*n7 */
+	arg mem_t7,rega
+	arg mem_t1,regb
+	arg mem_t1,contw
+	call bn_mulmod		/* t1=n8*n5^3 */
+	arg mem_t2,rega
+	arg mem_cx,contw
+	call bn_sqrmod		
+	arg mem_cx,rega
+	arg mem_t3,regb
+	arg mem_cx,contw
+	call bn_submod		/* x=n6^2-n5^2*n7 */
+	arg mem_cx,contr
+	arg mem_t7,contw
+	call memcpy24
+	arg mem_t7,rega
+	call bn_lshiftmod		/* t7=2*x */
+	arg mem_t3,rega
+	arg mem_t7,regb
+	arg mem_t3,contw
+	call bn_submod		/* t3=n9 */
+	arg mem_t3,rega
+	arg mem_t2,regb
+	arg mem_t2,contw
+	call bn_mulmod		/* t2=n9*n6 */
+	arg mem_t2,rega
+	arg mem_t1,regb
+	arg mem_cy,contw
+	call bn_submod	
+	arg mem_cy,rega
+	arg mem_p,regb
+	arg mem_cy,contw
+	force 0,regc
+	fetch 1,mem_cy
+	isolate1 0,pdata
+	call bn_add,true
+	copy regc,alarm
+	arg mem_cy,rega
+	call bn_rshift6
+	fetch 1,mem_cy5
+	isolate1 0,alarm
+	setflag true,7,pdata
+	store 1,mem_cy5
+	rtn
+
+	/* cost 22276983 clks */
+eckp:
+	jam 192,mem_ec_loopc
+	jam 1,mem_ec_infinite
+eckp_0:	
+	fetch 1,mem_ec_loopc
+	increase -1,pdata
+	nrtn positive
+	store 1,mem_ec_loopc
+	fetch 1,mem_ec_infinite
+	call ecdbl,blank
+	fetch 1,mem_ec_loopc
+	arg mem_k,contr
+	call bn_testbit
+	branch eckp_0,true
+	fetch 1,mem_ec_infinite
+	nbranch eckp_1,blank
+	call ecadd
+	branch eckp_0
+eckp_1:
+	jam 0,mem_ec_infinite
+	arg mem_ax,contr
+	arg mem_cx,contw
+	call ec_copy
+	branch eckp_0
+
+	/* cost 162522 clks */
+ecunmapz:
+	arg mem_cz,rega
+	arg mem_t3,contw
+	call bn_invmod			/* t3 = 1/z */
+	arg mem_t3,rega
+	arg mem_t1,contw		
+	call bn_sqrmod			/* t1 = 1/z2 */
+	arg mem_cx,rega
+	arg mem_t1,regb
+	arg mem_bx,contw
+	call bn_mulmod
+	arg mem_t3,rega
+	arg mem_t1,regb
+	arg mem_t2,contw			
+	call bn_mulmod			/* t2 = 1/z3 */
+	arg mem_cy,rega
+	arg mem_t2,regb
+	arg mem_by,contw
+	branch bn_mulmod		
+	
+	
+sha_endian_swap:
+	force 16,loopcnt
+sha_endian_swap2:	
+	ifetch 4,contr
+	force 4,rega
+	increase 3,contw
+sha_endian_loop:	
+	istore 1,contw
+	rshift8 pdata,pdata
+	increase -2,contw
+	increase -1,rega
+	nbranch sha_endian_loop,zero
+	increase 5,contw
+	loop sha_endian_swap2
+	rtn	
+
+
+sha_getw:
+	lshift2 queue,pdata
+	iadd timeup,contr
+	ifetch 4,contr
+	rtn
+	
+sha_r:
+	force 16,alarm
+	arg memdat,timeup
+sha_r_loop:	
+	add alarm,-7,queue
+	call sha_getw
+	iforce temp						/* W[t - 7] */
+	add alarm,-16,queue
+	call sha_getw
+	iadd temp,temp					/* W[t-7] + W[t-16] */
+	add alarm,-2,queue
+	call sha_getw
+	shasx pdata,1,pdata
+	iadd temp,temp					/* S1(W[t -  2]) + W[t-7] + W[t-16] */
+	add alarm,-15,queue
+	call sha_getw
+	shasx pdata,0,pdata
+	iadd temp,temp					/* S0(W[t - 15]) + S1(W[t -  2]) + W[t-7] + W[t-16] */
+	lshift2 alarm,pdata
+	iadd timeup,contw
+	istoret 4,contw
+	increase 1,alarm
+	compare 64,alarm,0xff
+	nbranch sha_r_loop,true
+	rtn
+	
+
+sha_init:
+	arg memh0,contr
+	force 7,regext_index
+sha_init_0:	
+	ifetch 4,contr
+	iforce regext
+	increase -1,regext_index
+	branch sha_init_0,positive
+	rtn
+
+sha:
+	set1 mark_ext_patch,mark
+	bpatch patch3f_0,mem_patch3f
+	call sha_r		/* preprocessing data into R() */
+	arg memahbak,contw
+	force 0,regext_index
+sha_0:	
+	deposit regext
+	istore 4,contw
+	increase 1,regext_index
+	compare 8,regext_index,0xff
+	nbranch sha_0,true
+	call enable_authrom
+	arg memk,timeup
+	arg memdat,alarm
+	force 64,loopcnt
+sha_loop:	
+	ifetcht 4,alarm
+	ifetch 4,timeup
+	increase 4,timeup
+	increase 4,alarm
+	iadd temp,pdata			/* x+K */
+	force 7,regext_index
+	iadd regext,temp			/* x+K+h */
+	force 4,regext_index
+	shasx regext,3,pdata
+	iadd temp,temp			/* temp = s3(e)+x+K+h */
+	force 5,regext_index
+	deposit regext
+	force 6,regext_index
+	ixor regext,pdata
+	force 4,regext_index
+	iand regext,pdata			/* (e & (f ^ g)) */
+	force 6,regext_index
+	ixor regext,pdata			/* F1(e, f, g) = g ^ (e & (f ^ g)) */
+	iadd temp,temp			/* temp1 = h + S3(e) + F1(e,f,g) + K + x */
+	force 7,regext_index
+	copy temp,regext			/* save to H */
+	force 3,regext_index
+	deposit regext
+	iadd temp,regext			/* save to D */
+	force 0,regext_index
+	deposit regext
+	force 1,regext_index
+	iand regext,temp			/* a & b */
+	ior regext,pdata			/* a | b */			
+	force 2,regext_index
+	iand regext,pdata			/* (c & (a | b)) */
+	ior temp,temp				/* F0:(a & b) | (c & (a | b)) */
+	force 0,regext_index
+	shasx regext,2,pdata
+	iadd temp,pdata			/* temp2 = S2(a) + F0(a,b,c) */
+	force 7,regext_index
+	iadd regext,regext			/* h = temp1 + temp2 */
+	regexrot					/* rotate move h,a-g => a-h */
+	loop sha_loop
+	arg memahbak,contr
+	force 0,regext_index
+sha_1:	
+	ifetch 4,contr
+	iadd regext,regext
+	increase 1,regext_index
+	compare 8,regext_index,0xff
+	nbranch sha_1,true
+	branch disable_authrom
+
+	
+sha_result:
+	arg   memresult,contw
+	force 7,regext_index
+sha_regext_save:
+	deposit regext
+	istore  4,contw 
+	increase -1,regext_index
+	branch   sha_regext_save,positive
+	rtn	
+
+pad_xor:
+//	arg memx_end,contr
+	arg      memdat,contw
+	increase -4,contr
+	sub      loopcnt,16,rega
+pad_xor_0:	    
+	ifetch   4,contr
+	ixor     temp,pdata
+	istore   4,contw	
+	increase -8,contr	
+	loop  pad_xor_0
+	copy     rega,loopcnt
+	deposit  temp
+pad_xor_1:	
+	istore 4,contw
+	loop pad_xor_1
+	rtn
+	
+g_noninit:
+ 	arg      mem_sp_pubkey_remote_x_end,contr
+	arg      memdat,contw
+	force    6,loopcnt
+	call     memcpy_dword_swap
+	arg      mem_sp_pubkey_local_x_end,contr
+	force    6,loopcnt
+	call     memcpy_dword_swap
+	arg      mem_sp_random_remote_end,contr
+	call     memcpy_dword_swap4
+	call     sha_init
+	call     sha	
+ 	arg      mem_sp_random_local_end,contr
+	arg      memdat,contw
+	branch g_common
+	
+g_init:
+ 	arg      mem_sp_pubkey_local_x_end,contr
+	arg      memdat,contw
+	force    6,loopcnt
+	call     memcpy_dword_swap
+	arg      mem_sp_pubkey_remote_x_end,contr
+	force    6,loopcnt
+	call     memcpy_dword_swap
+	arg      mem_sp_random_local_end,contr
+	call     memcpy_dword_swap4
+	call     sha_init
+	call     sha	
+ 	arg      mem_sp_random_remote_end,contr
+	arg      memdat,contw	
+g_common:	
+	call     memcpy_dword_swap4
+	setarg   0x800000
+	lshift8  pdata,pdata 
+	istore   4,contw
+	force    5,loopcnt
+	call memset0
+	setarg 640
+	istore 4,contw
+	call sha
+
+	fetch 4,memresult
+//	store 4,mem_sp_gkey
+	arg 1000,rega
+	idiv rega
+	call wait_div_end
+	remainder pdata
+	store 4,mem_sp_gkey
+	quotient pdata
+	arg 1000,rega
+	idiv rega
+	call wait_div_end
+	remainder pdata
+	arg 1000,rega
+	imul32 rega,pdata
+	fetcht 4,mem_sp_gkey
+	iadd temp,pdata
+	store 4,mem_sp_gkey
+	rtn
+	
+function_f1:
+	setarg   0x363636
+	lshift8  pdata,temp
+	or_into       0x36,temp
+	fetch 2,mem_sp_prarm_stack
+	copy pdata,contr
+	force    4,loopcnt
+	call     pad_xor
+	call     sha_init
+	call     sha
+	fetch 2,mem_sp_prarm_stack+2
+	copy pdata,contr
+	arg      memdat,contw
+	force    6,loopcnt
+	call     memcpy_dword_swap
+	fetch 2,mem_sp_prarm_stack+4
+	copy pdata,contr
+	force    6,loopcnt
+	call     memcpy_dword_swap
+	setarg   0x800000
+	istore   3,contw
+	force    0,pdata  
+	istore   1,contw
+	force    0,pdata
+	istore   8,contw
+	setarg   0x0388
+	istore   4,contw
+	call     sha
+	call     sha_result
+	arg      memresult,contr
+	arg      memahsave,contw 
+	call     memcpy32
+    
+	setarg   0x5c5c5c
+	lshift8  pdata,temp
+	or_into       0x5c,temp
+	fetch 2,mem_sp_prarm_stack
+	copy pdata,contr
+	force    4,loopcnt
+	call     pad_xor
+	call     sha_init
+	call     sha
+	arg      memahsave_end,contr
+	arg      memdat,contw
+	force    8,loopcnt
+	call     memcpy_dword_swap
+	setarg   0x800000
+	lshift8  pdata,pdata 
+	istore   4,contw
+	call		bn_zero
+	setarg   0x0300
+	istore   4,contw
+	call     sha
+	branch     sha_result
+	
+	
+function_f2:
+	setarg   0x363636
+	lshift8  pdata,temp
+	or_into       0x36,temp
+	arg      mem_sp_dhkey_end,contr
+	force    6,loopcnt
+	call     pad_xor
+	call     sha_init
+	call     sha
+	fetch 2,mem_sp_prarm_stack+12
+	copy pdata,contr
+	arg      memdat,contw
+	call     memcpy_dword_swap4
+	fetch 2,mem_sp_prarm_stack+14
+	copy pdata,contr
+	call     memcpy_dword_swap4
+
+	setarg   0x62746c
+	lshift8  pdata,pdata
+	or_into       0x6b,pdata       
+	istore   4,contw
+	arg      mem_addr_value_end,contr
+	force    3,loopcnt
+	call     memcpy_dword_swap
+	
+	setarg   0x800000
+	lshift8  pdata,pdata 
+	istore   4,contw
+	force    0,pdata
+	istore   8,contw
+	setarg   0x0380
+	istore   4,contw
+	call     sha
+
+	call     sha_result
+	arg      memresult,contr
+	arg      memahsave,contw 
+	call     memcpy32
+    
+	setarg   0x5c5c5c
+	lshift8  pdata,temp
+	or_into       0x5c,temp
+	arg      mem_sp_dhkey_end,contr 
+	force    6,loopcnt
+	call     pad_xor
+	call     sha_init
+	call     sha
+	arg      memahsave_end,contr
+	arg      memdat,contw
+	force    8,loopcnt
+	call     memcpy_dword_swap
+	setarg   0x800000
+	lshift8  pdata,pdata 
+	istore   4,contw
+	call bn_zero
+	setarg   0x0300
+	istore   4,contw
+	call     sha
+	branch     sha_result
+	
+
+function_f3a:
+	setarg   0x363636
+	lshift8  pdata,temp
+	or_into       0x36,temp
+	arg      mem_sp_dhkey_end,contr
+	force    6,loopcnt
+	call     pad_xor
+	call     sha_init
+	call     sha
+	arg      mem_sp_random_remote_end,contr
+	arg      memdat,contw
+	call     memcpy_dword_swap4
+	arg      mem_sp_random_local_end,contr
+	call     memcpy_dword_swap4
+	branch function_f3b_common
+
+function_f3b:
+	setarg   0x363636
+	lshift8  pdata,temp
+	or_into       0x36,temp
+	arg      mem_sp_dhkey_end,contr
+	force    6,loopcnt
+	call     pad_xor
+	call     sha_init
+	call     sha
+
+	arg      mem_sp_random_local_end,contr
+	arg      memdat,contw
+	call     memcpy_dword_swap4
+	arg      mem_sp_random_remote_end,contr
+	call     memcpy_dword_swap4
+function_f3b_common:    
+	setarg   0x0    
+	istore   8,contw
+	istore   8,contw
+    
+	copy     contw,temp
+	jam      0x80,mem_addr_padding
+	copy     temp,contw
+	arg      mem_addr_iocap_end,contr
+	call     memcpy_dword_swap4
+
+	call     sha
+    
+	arg      memdat,contw
+	force 7,loopcnt
+	call memset0
+	istore   4,contw
+	setarg   0x03F8
+	istore   4,contw
+	call     sha
+	call     sha_result
+	
+	arg      memresult,contr
+	arg      memahsave,contw 
+	call     memcpy32
+    
+	setarg   0x5c5c5c
+	lshift8  pdata,temp
+	or_into       0x5c,temp
+	arg      mem_sp_dhkey_end,contr 
+	force    6,loopcnt
+	call     pad_xor
+	call     sha_init
+	call     sha
+	arg      memahsave_end,contr
+	arg      memdat,contw
+	force    8,loopcnt
+	call     memcpy_dword_swap
+	setarg   0x800000
+	lshift8  pdata,pdata 
+	istore   4,contw
+	call bn_zero
+	setarg   0x0300
+	istore   4,contw
+	call     sha	
+	branch     sha_result
+		
+/*
+eckp:
+	jam 192,mem_ec_loopc
+	jam 1,mem_ec_infinite
+*/
+eckp_calc_init:
+	jam      192,mem_ec_loopc
+eckp_calc_init_1:    
+	fetch    1,mem_ec_loopc
+	rtn      blank
+	increase -1,pdata
+	store    1,mem_ec_loopc 	
+	arg      mem_k,contr
+	call     bn_testbit
+	branch eckp_calc_init_1,true
+	arg      mem_ax,contr
+	arg      mem_cx,contw
+	branch     ec_copy	
+	
+eckp_calc:
+	call     ecdbl  
+	fetch    1,mem_ec_loopc
+	increase -1,pdata
+	store    1,mem_ec_loopc
+	arg      mem_k,contr
+	call     bn_testbit
+	rtn	true
+	branch     ecadd                
+	             
+eckp_cp_1:
+	jam 0,mem_ec_infinite
+	arg mem_ax,contr
+	arg mem_cx,contw
+	branch ec_copy
+
+memcpy_dword_swap4:
+	force 4,loopcnt
+memcpy_dword_swap:
+	increase -4,contr
+memcpy_dword_swap_loop:
+	ifetch   4,contr
+	istore   4,contw
+	increase -8,contr
+	loop   memcpy_dword_swap_loop 
+    	rtn
+endif
+
+
Index: btkb/program/ui.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/ui.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/ui.prog	(working copy)
@@ -0,0 +1,435 @@
+ui_init:
+	rtn wake
+	call ui_button_init
+	call ui_timer_init
+	branch ui_led_init
+
+ui_dispatch:
+	fetch 1,mem_device_option
+	rtneq dvc_op_hci
+	call ui_led_blink_polling
+	
+	branch ui_timer_check
+	
+ui_button_init:
+	fetch 1,mem_ui_button_gpio
+	rtneq UI_BUTTON_GPIO_DISABLE
+	iforce temp
+	call gpio_config_output
+	fetcht 1,mem_ui_button_gpio
+	call gpio_out_inactive
+	nop 100
+	fetcht 1,mem_ui_button_gpio
+	call gpio_config_input
+	branch ui_button_polling
+
+ui_button_disable:
+	jam UI_BUTTON_GPIO_DISABLE,mem_ui_button_gpio
+	rtn
+	
+ui_button_polling:
+	set1 mark_ext_patch,mark
+	bpatch patch30_5,mem_patch30
+	fetch 1,mem_ui_button_gpio
+	rtneq UI_BUTTON_GPIO_DISABLE
+	copy pdata,temp
+	call gpio_get_bit
+	nbranch ui_button_up,true
+	//fall through
+ui_button_down:
+	call ui_button_check_long_press
+	fetch 2,mem_ui_state_map
+	set1 UI_STATE_BTN_DOWN
+	store 2,mem_ui_state_map
+	fetch 1,mem_ui_button_last_state
+	rtneq UI_BUTTON_STATE_DOWN
+	jam UI_BUTTON_STATE_DOWN,mem_ui_button_last_state
+	//Down Edge
+	fetch 1,mem_ui_button_timeout
+	store 1,mem_ui_button_timer //start long press timer
+	call lpm_button_get_wake_lock
+	jam BT_EVT_BUTTON_DOWN,mem_fifo_temp
+	branch ui_ipc_send_event
+ui_button_up:
+	fetch 2,mem_ui_state_map
+	set0 UI_STATE_BTN_DOWN
+	store 2,mem_ui_state_map
+	fetch 1,mem_ui_button_last_state
+	rtneq UI_BUTTON_STATE_UP
+	jam UI_BUTTON_STATE_UP,mem_ui_button_last_state
+	//Up Edge
+	jam 0,mem_ui_button_timer//stop long press timer
+	call lpm_button_clean_wake_lock
+	jam BT_EVT_BUTTON_UP,mem_fifo_temp
+	branch ui_ipc_send_event
+
+ui_button_check_long_press:
+	fetch 1,mem_ui_button_timer
+	rtn blank
+	increase -1,pdata
+	store 1,mem_ui_button_timer
+	nrtn blank
+	//Long Press
+	jam BT_EVT_BUTTON_LONG_PRESSED,mem_fifo_temp
+	branch ui_ipc_send_event
+
+lpm_button_get_wake_lock:
+	arg wake_lock_button,queue
+	branch lpm_get_wake_lock
+	
+lpm_button_clean_wake_lock:
+	arg wake_lock_button,queue
+	branch lpm_put_wake_lock
+
+ui_led_init:
+	fetch 1,mem_led_gpio
+	rtneq UI_BUTTON_GPIO_DISABLE
+	iforce temp
+	call gpio_config_output
+	branch ui_led_off
+	
+ui_led_blink_stop:
+	fetch 2,mem_ui_state_map
+	set0 UI_STATE_LED_BLINK
+	store 2,mem_ui_state_map
+	jam ui_led_stop,mem_led_switch
+ui_led_off:
+	fetch 2,mem_ui_state_map
+	set0 UI_STATE_LED_ON
+	store 2,mem_ui_state_map
+	fetcht 1,mem_led_gpio
+	branch gpio_out_inactive
+
+ui_led_on:
+	fetch 2,mem_ui_state_map
+	set1 UI_STATE_LED_ON
+	store 2,mem_ui_state_map
+	jam ui_led_stop,mem_led_switch
+	fetcht 1,mem_led_gpio
+	branch gpio_out_active
+
+ui_led_blink_start:
+	fetch 2,mem_ui_state_map
+	set1 UI_STATE_LED_BLINK
+	store 2,mem_ui_state_map
+	jam ui_led_start,mem_led_switch
+	rtn
+	
+ui_led_blink_polling:
+	set1 mark_ext_patch,mark
+	bpatch patch30_6,mem_patch30
+	fetch 1,mem_led_switch
+	rtneq ui_led_stop
+	arg ui_led_blink,queue
+	call timer_check
+	nrtn blank
+	fetch 1,mem_led_switch
+	beq ui_led_dark_time,ui_led_blink_polling_dark
+	call ui_led_on
+	jam ui_led_dark_time,mem_led_switch
+	fetch 2,mem_led_light_time
+	branch ui_led_blink_timer_start
+ui_led_blink_polling_dark:
+	call ui_led_off
+	jam ui_led_light_time,mem_led_switch
+	fetch 2,mem_led_dark_time
+ui_led_blink_timer_start:
+	arg ui_led_blink,queue
+	branch timer_init	
+
+	
+ui_timer_check:
+	set1 mark_ext_patch,mark
+	bpatch patch30_7,mem_patch30
+	arg 0,rega
+	fetcht 4,mem_ui_timer_last_btclk
+	copy clkn_bt,regb
+	//call ice_break
+ui_timer_check_loop:
+	copy regb,pdata
+	increase 160,temp    //320btclk = 100ms
+	increase 160,temp
+	isub temp,null
+	nbranch ui_timer_check_end,positive
+	increase 1,rega   //increase 1 every 100ms count
+	and rega,0x0f,pdata
+	nbranch ui_timer_check_loop,blank
+	arg 0,rega  //reset timer if it's longer than 1.5s between 2 checks
+	call ui_timer_check_send_evt
+ui_timer_init:
+	copy clkn_bt,pdata
+	store 4,mem_ui_timer_last_btclk
+	rtn
+ui_timer_check_end:
+	set1 mark_ext_patch,mark
+	bpatch patch31_0,mem_patch31
+	copy rega,pdata
+	rtn blank
+	increase -160,temp    //320btclk = 100ms
+	increase -160,temp
+	storet 4,mem_ui_timer_last_btclk
+ui_timer_check_send_evt:
+	increase BT_EVT_TIMER_INIT,pdata
+	store 1,mem_fifo_temp
+	branch ui_ipc_send_event
+	
+
+//**********************************************************//
+//************UI Inter-Processor Communication*******//
+//**********************************************************//
+ui_ipc_get_lock:
+	jam 1,mem_ipc_lock_bt
+ui_ipc_get_lock_wait:
+	fetch 1,mem_ipc_lock_c51
+	nbranch ui_ipc_get_lock_wait,blank
+	rtn
+	
+ui_ipc_put_lock:
+	jam 0,mem_ipc_lock_bt
+	rtn
+	
+ui_ipc_fifo_out:
+	branch fifo_out
+
+
+	
+ui_ipc_send_event:
+	set1 mark_ext_patch,mark
+	bpatch patch31_1,mem_patch31
+	fetch 1,mem_device_option
+	rtneq dvc_op_hci
+	call ui_ipc_get_lock
+	copy rega,pdata
+	store 4,mem_ipc_rega_temp
+	arg mem_ipc_fifo_bt2c51,rega
+	call fifo_in
+	fetch 4,mem_ipc_rega_temp
+	copy pdata,rega
+	branch ui_ipc_put_lock
+
+ui_ipc_send_cmd:
+	set1 mark_ext_patch,mark
+	bpatch patch31_2,mem_patch31
+	fetch 1,mem_device_option
+	rtneq dvc_op_hci
+	call ui_ipc_get_lock
+	copy rega,pdata
+	store 4,mem_ipc_rega_temp	
+	arg mem_ipc_fifo_c512bt,rega
+	call fifo_in
+	fetch 4,mem_ipc_rega_temp
+	copy pdata,rega	
+	branch ui_ipc_put_lock
+
+ui_ipc_clean_all_fifo:
+	set1 mark_ext_patch,mark
+	bpatch patch31_3,mem_patch31
+	setarg 0
+	store UTIL_FIFO_LEN,mem_ipc_fifo_c512bt
+	store UTIL_FIFO_LEN,mem_ipc_fifo_bt2c51
+	rtn
+	
+check_51cmd:
+	set1 mark_ext_patch,mark
+	bpatch patch31_4,mem_patch31
+	fetch 1,mem_hci_cmd
+	nrtn blank
+	arg mem_ipc_fifo_c512bt,rega
+	call fifo_is_empty
+	rtn blank
+	jam IPC_CONTINUE_PROCESS,mem_ipc_skip_continue_proc
+	call check_51cmd_once
+	fetch 1,mem_ipc_skip_continue_proc
+	branch check_51cmd,blank
+	rtn
+
+check_51cmd_once:
+	set1 mark_ext_patch,mark
+	bpatch patch31_5,mem_patch31
+	call ui_ipc_get_lock
+	arg mem_ipc_fifo_c512bt,rega
+	call fifo_out
+	copy pdata,temp
+	call ui_ipc_put_lock
+	copy temp,pdata
+	rtn blank
+ 	beq BT_CMD_START_DISCOVERY,check_51cmd_start_discovery
+  	beq BT_CMD_STOP_DISCOVERY,check_51cmd_stop_discovery
+  	beq BT_CMD_RECONNECT,check_51cmd_reconnect
+  	beq BT_CMD_ENTER_SNIFF_SUBRATING,check_51cmd_enter_sniff_subrating
+  	beq BT_CMD_EXIT_SNIFF_SUBRATING,check_51cmd_exit_sniff_subrating
+  	beq BT_CMD_SNIFF_TEST,check_51cmd_sniff_test
+	beq BT_CMD_START_INQUIRY,check_51cmd_inq
+	beq BT_CMD_STOP_INQUIRY,check_51cmd_stop_inq
+	beq BT_CMD_START_ADV,check_51cmd_adv
+	beq BT_CMD_STOP_ADV,check_51cmd_stop_adv
+	beq BT_CMD_START_DIRECT_ADV,check_51cmd_direct_adv
+	beq BT_CMD_STOP_DIRECT_ADV,check_51cmd_stop_direct_adv
+	beq BT_CMD_LE_UPDATE_CONN,check_51cmd_le_update_conn
+	beq BT_CMD_LED_BLINK,ui_led_blink_start
+	beq BT_CMD_LED_ON,ui_led_on
+	beq BT_CMD_LED_OFF,ui_led_blink_stop
+	beq BT_CMD_LE_START_CONN,check_51cmd_le_start_con
+	beq BT_CMD_LE_START_SCAN,check_51cmd_start_scan
+	beq BT_CMD_LE_STOP_SCAN,check_51cmd_stop_scan
+	beq BT_CMD_ENTER_HIBERNATE,check_51cmd_hibernate
+	beq BT_CMD_LE_SMP_SECURITY_REQUEST,check_51cmd_le_smp_sec_req
+	beq BT_CMD_LE_START_WRITE,check_51cmd_le_start_write
+	beq BT_CMD_BB_RECONN_CANCEL,check_51cmd_bb_reconn_cancel
+	//context related, process in context
+	store 1,mem_fifo_temp
+	set1 mark_ext_patch,mark
+	bpatch patch31_6,mem_patch31
+	fetch 1,mem_lmo_opcode2
+	branch check_51cmd_once_continue,blank
+	call lmo_fifo_process
+	fetch 1,mem_lmo_opcode2
+	nbranch check_51cmd_restore,blank  //process this cmd next time while lmo fifo is full
+check_51cmd_once_continue:
+	fetch 1,mem_fifo_temp
+	bmark0 mark_context,check_51cmd_check_idle
+check_51cmd_once_continue0:
+  	beq BT_CMD_ENTER_SNIFF,cmd_in_sniff
+  	beq BT_CMD_EXIT_SNIFF,cmd_exit_sniff
+  	beq BT_CMD_SET_PIN_CODE,check_51cmd_pincode
+	beq BT_CMD_DISCONNECT,check_51cmd_disconnect
+	beq BT_CMD_LE_DISCONNECT,check_51cmd_le_disconnect
+	beq BT_CMD_ROLE_SWITCH,check_51cmd_role_switch
+	beq BT_CMD_STORE_RECONN_INFO_LE,eeprom_store_le_reconn_info
+	beq BT_CMD_STORE_RECONN_INFO_BT,eeprom_store_bd_reconn_info
+	beq BT_CMD_LE_UPDATE_CONN,BT_CMD_LE_UPDATE_CONN_1
+  	rtn
+
+
+BT_CMD_LE_UPDATE_CONN_1:
+	jam XT_LL_CONNECTION_PARAM_REQ,mem_fifo_temp
+	branch le_xtype_fifo_in
+check_51cmd_check_idle:
+	store 1,mem_fifo_temp
+  	call context_check_idle
+	branch check_51cmd_restore,zero
+	call context_search_plap
+	nrtn zero
+check_51cmd_restore:
+	jam IPC_SKIP_CONTINUE_PROCESS,mem_ipc_skip_continue_proc
+	branch ui_ipc_send_cmd
+
+
+check_51cmd_role_switch:
+  	jam LMP_SLOT_OFFSET,mem_lmo_opcode2
+	set1 mark_switch_initiated,mark
+	nrtn master
+	jam SWITCH_FLAG_INIT,mem_switch_flag
+	jam LMP_SWITCH_REQ ,mem_lmo_opcode2
+	fetch 1,mem_connection_options
+	set0 CONNECTION_SWITCH,pdata
+	store 1,mem_connection_options
+	rtn
+	
+check_51cmd_start_discovery:
+	fetch 2,mem_ui_state_map
+	set1 UI_STATE_BT_DISCOVERY
+	store 2,mem_ui_state_map
+	jam 3,mem_scan_mode
+	rtn
+	
+check_51cmd_stop_discovery:
+	jam 0,mem_hid_handshake_timer_count
+	jam 0,mem_scan_mode
+	fetch 2,mem_ui_state_map
+	set0 UI_STATE_BT_DISCOVERY
+	store 2,mem_ui_state_map
+	rtn
+	
+check_51cmd_reconnect:	
+	jam hci_cmd_create_conn,mem_hci_cmd
+	rtn
+	
+check_51cmd_disconnect:
+	jam LMP_DETACH,mem_lmo_opcode2
+	jam OTHER_END_TERMINATED,mem_disconn_reason_send
+	rtn
+	
+	
+check_51cmd_enter_sniff_subrating:
+	rtn
+	
+check_51cmd_exit_sniff_subrating:
+	rtn	
+	
+check_51cmd_sniff_test:
+	rtn
+	
+check_51cmd_pincode:
+	jam pincode_state_pincode_ready,mem_pincode_state
+	branch cmd_pair
+
+check_51cmd_inq:
+	rtn
+check_51cmd_stop_inq:
+	rtn
+check_51cmd_adv:
+	jam ON,mem_le_adv_enable
+	jam ADV_IND,mem_le_adv_type
+	rtn
+check_51cmd_stop_adv:
+	jam OFF,mem_le_adv_enable
+	rtn
+check_51cmd_direct_adv:
+	jam ON,mem_le_adv_enable
+	jam ADV_DIRECT_IND,mem_le_adv_type
+	rtn
+check_51cmd_stop_direct_adv:
+	jam OFF,mem_le_adv_enable
+	rtn
+check_51cmd_le_disconnect:
+	setarg 1
+	store 2,mem_le_superto
+	rtn
+check_51cmd_le_update_conn:
+	rtn
+check_51cmd_le_start_con:
+	jam ON,mem_le_scan_enable
+	jam hci_cmd_le_create_conn,mem_hci_cmd
+	fetch 6,mem_app_peer_addr
+	store 6,mem_le_conn_peer_addr
+	rtn
+check_51cmd_start_scan:
+	jam ON,mem_le_scan_enable
+	rtn
+check_51cmd_stop_scan:
+	jam OFF,mem_le_scan_enable
+	jam 0,mem_hci_cmd
+	rtn
+check_51cmd_le_smp_sec_req:
+	jam XT_SMP_SECURITY_REQUEST,mem_fifo_temp
+	branch le_xtype_fifo_in
+check_51cmd_hibernate:
+	set1 mark_ext_patch,mark
+	bpatch patch31_7,mem_patch31
+	fetch 2,mem_cb_before_hibernate
+	call callback_func
+	fetch 1,mem_ui_button_gpio
+	beq UI_BUTTON_GPIO_DISABLE,check_51cmd_hibernate_btn_disabled
+	copy pdata,temp
+	call gpio_config_input
+check_51cmd_hibernate_btn_disabled:
+	call ui_led_off
+	call ui_ipc_clean_all_fifo
+	branch lpm_hibernate
+	
+check_51cmd_le_start_write:
+	jam 1,mem_le_switch_send_data
+	rtn
+
+check_51cmd_bb_reconn_cancel:
+	force page_length_timer,queue
+	branch timer_stop
+
+ui_check_paring_button:
+	fetch 1,mem_ui_state_map
+	rtnbit0 UI_STATE_BTN_DOWN
+	rtnbit0 UI_STATE_BT_RECONNECT
+	branch check_51cmd_bb_reconn_cancel
+
+
Index: btkb/program/usb.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/usb.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/usb.prog	(working copy)
@@ -0,0 +1,374 @@
+ifdef COMPILE_USB
+
+usb_isr:
+	set1 mark_ext_patch,mark
+	bpatch patch3a_5,mem_patch3a
+	call usb_tx_test
+	hfetch 1,core_usb_status
+	store 1,mem_usb_status
+	hfetch 1,core_usb_fifo_empty
+	store 1,mem_usb_fifo_empty
+	hjam 0xe0,core_usb_status
+	fetch 1,mem_usb_fifo_empty
+	compare 0x1,pdata,0x1 
+	call usb0_fifo_empty,true
+	set1 mark_ext_patch,mark
+	bpatch patch3a_6,mem_patch3a
+	fetch 1,mem_usb_status	
+	compare 0x1,pdata,0x1  
+	call usb_status1,true
+	fetch 1,mem_usb_state
+	bne USB_CONNECTED,usb_tx
+	fetch 2,mem_usb_idle_cnt
+	increase 1,pdata
+	store 2,mem_usb_idle_cnt
+	fetcht 2,mem_usb_idle_timeout
+	isub temp,null
+	branch usb_init,positive
+	fetch 1,mem_usb_status	
+	bbit0 USB_STATUS_NAK,usb_tx
+	setarg 0
+	store 2,mem_usb_idle_cnt
+	branch usb_tx
+	
+
+usb_status1:
+	set1 mark_ext_patch,mark
+	bpatch patch3a_7,mem_patch3a
+	hjam 0x11,core_usb_status
+	hfetch 1,core_usb_ep_len
+	store 1,mem_usb_read_len
+	copy pdata,loopcnt
+	branch usb_rx_no_data,blank
+	arg mem_usb_setup,contw
+	call usb_rx_read
+	fetch 1,mem_usb_read_len
+	sub pdata,7,null
+	rtn positive
+usb_class_type:
+	set1 mark_ext_patch,mark
+	bpatch patch3b_0,mem_patch3b
+	fetch 1,mem_usb_setup_bmRequestType
+	beq HCI_CLASS_REQUEST_TYPE,usb_hci_class_req_type
+	beq HID_CLASS_REQUEST_TYPE,usb_hid_class_req_type
+	beq ZERO_CLASS_REQUEST_TYPE,usb_zero_class_req_type
+	fetch 1,mem_usb_setup_bRequest
+	beq SET_ADDRESS,usb0_request_set_address
+	beq GET_DESCRIPTOR,usb0_request_get_descriptor
+	beq SET_CONFIGURATION,usb0_request_set_configuration
+	beq SET_INTERFACE,usb0_request_set_interface
+	branch usb0_force_stall
+
+usb_zero_class_req_type:
+	fetch 1,mem_usb_setup_bRequest
+	beq CLEAR_FEATURE,usb0_request_clear_feature
+	beq SET_FEATURE,usb0_request_set_feature
+	beq SET_CONFIGURATION,usb0_reply_zerolen
+	beq SET_ADDRESS,usb0_request_set_address
+	branch usb0_force_stall
+usb_hci_class_req_type:
+	call usb0_reply_zerolen
+	rtn
+
+usb_rx_no_data:
+	fetch 1,mem_usb_status
+	bbit1 USB_STATUS_SETUP,usb_class_type
+	rtn
+usb_set_protocol_req:
+	fetch 1,mem_usb_set_protocol_count
+	increase 1,pdata
+	store 1,mem_usb_set_protocol_count
+	compare 2,pdata,0xff
+	nbranch usb0_reply_zerolen,true	
+	jam 1,mem_usb_desc
+	branch usb0_reply_zerolen
+usb_hid_class_req_type:
+	fetch 1,mem_usb_setup_bRequest
+	beq SET_IDLE,usb_set_idle
+	beq SET_REPORT,usb_set_report
+	beq SET_PROTOCOL,usb_set_protocol_req	
+	branch usb0_force_stall
+usb_set_idle:
+	fetch 1,mem_usb_state
+	beq USB_SETIDLE_1,usb_set_idle_connected
+	bne USB_RESUME,usb0_reply_zerolen
+	jam USB_SETIDLE_1,mem_usb_state
+	branch usb0_reply_zerolen
+usb_set_idle_connected:
+	jam USB_CONNECTED,mem_usb_state
+	branch usb0_reply_zerolen
+	
+usb_set_report:
+	jam 1,mem_usb_desc
+	arg mem_usb_desc,rega
+	arg 1,regb
+	branch usb0_respond
+usb0_force_stall:
+	hjam 1,core_usb_stall
+	rtn
+usb0_reply_zerolen:
+	hjam 0x40,core_usb_clear
+	rtn
+
+usb_rx_read:
+	hfetch 1,core_usb_ep
+	istore 1,contw
+	loop usb_rx_read
+	rtn
+
+usb0_fifo_empty:
+	hjam 0x1,core_usb_fifo_empty
+	call usb0_tx
+	rtn
+
+usb0_request_get_descriptor:
+	set1 mark_ext_patch,mark
+	bpatch patch3b_1,mem_patch3b
+	set0 mark_isstr,mark
+	fetch 1,mem_usb_setup_bValueH
+	beq DSC_DEVICE,dsc_device_info
+	beq DSC_CONFIG,dsc_config_info	
+	beq DSC_STRING,dsc_string_info
+	beq DSC_HID,dsc_hid_info
+	beq DSC_HID_REPORT,dsc_hid_report_info
+	rtn
+	
+dsc_device_info:
+	arg mem_devicedesc,rega
+	branch usb0_respond_length
+dsc_config_info:
+	arg mem_confdesc,rega
+	branch usb0_respond_length
+dsc_string_info:
+	fetch 1,mem_usb_setup_bValue
+	and_into 3,pdata
+	arg mem_string0,rega
+	beq 0,usb0_respond_length	
+	set1 mark_isstr,mark
+	arg mem_string1,rega
+	beq 1,usb0_respond_length
+	arg mem_string2,rega
+	beq 2,usb0_respond_length
+	arg mem_string3,rega
+	beq 3,usb0_respond_length
+	branch assert
+dsc_hid_info:
+	arg mem_confdesc+18,rega
+	fetch 1,mem_confdesc+18
+	copy pdata,regb
+	branch usb0_respond
+dsc_hid_report_info:
+	fetch 2,mem_usb_setup_wIndex
+	beq 1,dsc_hid_report_info0
+	arg mem_hidreportdesc_kb,rega
+	branch usb0_respond_length
+dsc_hid_report_info0:
+	jam USB_GOT_REPORT_REQ,mem_usb_state
+	arg mem_hidreportdesc_m,rega
+	branch usb0_respond_length
+
+usb0_respond_length:
+	ifetch 1,rega
+	iforce regb
+	increase 1,rega
+	
+//rega=*buff,reb=size	
+usb0_respond:
+	set1 mark_ext_patch,mark
+	bpatch patch3b_2,mem_patch3b
+	bmark0 mark_isstr,usb0_respond0
+	add regb,1,pdata
+	lshift pdata,pdata
+	hstore 1,core_usb_dfifo0 
+	hjam 3,core_usb_dfifo0
+	fetch 1,mem_usb_setup_bLength
+	increase -2,pdata
+	rshift pdata,pdata
+	store 1,mem_usb_setup_bLength
+	beq 0,usb_no_respond_data
+usb0_respond0:
+	fetch 1,mem_usb_setup_bLength
+	isub regb,null
+	branch usb0_respond1,positive
+	copy pdata,regb	
+usb0_respond1:
+	copy rega,pdata
+	store 2,mem_bufptr
+	copy regb,pdata
+	store 1,mem_remain
+	branch usb0_tx
+
+usb_no_respond_data:
+	arg 0,queue
+	branch usb_trig
+
+
+//mem_bufptr=*buff,mem_remain=size,loopcnt=i,rega=len
+usb0_tx:
+	set1 mark_ext_patch,mark
+	bpatch patch3b_3,mem_patch3b
+	fetch 1,mem_remain
+	rtn blank
+	copy pdata,loopcnt
+	sub pdata,EP0_PACKET_SIZE,null
+	branch usb0_tx_info,positive
+	arg EP0_PACKET_SIZE,loopcnt	
+usb0_tx_info:
+	fetch 1,mem_remain
+	isub loopcnt,pdata
+	store 1,mem_remain//mem_remain -= len
+	fetch 2,mem_bufptr
+	copy pdata,contr	
+usb0_tx0:
+	ifetch 1,contr
+	hstore 1,core_usb_dfifo0
+	bmark0 mark_isstr,usb0_tx1
+	hjam 0,core_usb_dfifo0
+usb0_tx1:
+	loop usb0_tx0
+	copy contr,pdata
+	store 2,mem_bufptr//mem_bufptr += len
+	arg 0,queue
+	call usb_trig
+	fetch 1,mem_remain
+	nrtn blank
+	fetch 1,mem_usb_state
+	rtnne USB_GOT_REPORT_REQ
+	jam USB_CONNECTED,mem_usb_state
+	rtn
+
+
+usb0_request_set_configuration:
+	fetch 1,mem_usb_setup_bValue
+	sub pdata,1,null
+	nbranch usb0_force_stall,positive
+usb0_request_set_address:
+	fetch 1,mem_usb_setup_bmRequestType
+	bne IN_DEVICE,usb0_force_stall
+	fetch 2,mem_usb_setup_wIndex
+	bne 0,usb0_force_stall
+	fetch 1,mem_usb_setup_bLength
+	bne 0,usb0_force_stall
+	branch usb0_reply_zerolen
+
+usb0_request_set_interface:
+	fetch 1,mem_usb_setup_bmRequestType
+	bne IN_INTERFACE,usb0_force_stall
+	fetch 1,mem_usb_setup_bValue
+	bne 0,usb0_force_stall
+	fetch 1,mem_usb_setup_bValueH
+	bne 0,usb0_force_stall
+	fetch 1,mem_usb_setup_bLength
+	bne 0,usb0_force_stall
+	branch usb0_reply_zerolen
+
+usb0_request_set_feature:
+	fetch 1,mem_usb_setup_bValue
+	bne 1,usb0_force_stall
+	jam USB_SLEEP,mem_usb_state
+	branch usb0_reply_zerolen
+
+usb0_request_clear_feature:
+	fetch 1,mem_usb_setup_bValue
+	bne 1,usb0_force_stall
+	branch usb0_reply_zerolen
+	
+usb_init:
+	set1 mark_ext_patch,mark
+	bpatch patch3b_4,mem_patch3b
+	hjam 0x00,core_usb_config
+	nop 10000
+	hjam 0xc0,core_usb_trig
+	hfetch 2,core_clkoff
+	set0 CLOCK_OFF_USB,pdata
+	hstore 2,core_clkoff
+	hjam 0x3c,core_usb_config
+	hjam 0xff,core_usb_status
+	hjam 0xff,core_usb_fifo_empty
+	jam 0,mem_mcmd
+	jam 0,mem_usb_state
+	setarg 0
+	store 2,mem_usb_idle_cnt
+	rtn
+
+
+usb_tx:
+	set1 mark_ext_patch,mark
+	bpatch patch3b_5,mem_patch3b
+	fetch 1,mem_mcmd
+	rtn blank
+	fetch 1,mem_usb_state
+	beq USB_SLEEP,usb_wakeup
+	rtnne USB_CONNECTED
+	fetch 1,mem_mcmd
+	jam 0,mem_mcmd
+	arg 6,loopcnt	
+	arg mem_mouse_data,contr
+	beq SEND_KB_DATA_CMD,usb_tx_ep1
+	beq SEND_MOUSE_DATA_CMD,usb_tx_ep2
+	branch assert
+	
+usb_tx_ep1:
+	arg core_usb_dfifo1,rega
+	arg 1,queue
+usb_tx_loop:
+	ifetch 1,contr
+	istore 1,rega
+	loop usb_tx_loop
+usb_trig:
+	set1 mark_ext_patch,mark
+	bpatch patch3b_6,mem_patch3b
+	disable swfine
+	fetch 2,mem_usb_trig_timeout
+	iforce stop_watch
+	hjam 0x40,core_usb_status
+usb_trig_waitnak_loop:
+	hfetch 1,core_usb_status
+	branch usb_init,timeout
+	bbit0 USB_STATUS_NAK,usb_trig_waitnak_loop
+	fetch 2,mem_usb_trig_timeout
+	iforce stop_watch
+	arg 0,temp
+	qset1 temp
+	hstoret 1,core_usb_fifo_empty
+usb_trig_loop:
+	branch usb_init,timeout
+	hstoret 1,core_usb_trig
+	hfetch 1,core_usb_fifo_empty
+	qisolate0 pdata
+	branch usb_trig_loop,true
+	rtn
+
+
+usb_tx_ep2:
+	arg 2,queue
+	arg core_usb_dfifo2,rega
+	branch usb_tx_loop
+
+
+usb_wakeup:
+	set1 mark_ext_patch,mark
+	bpatch patch3b_7,mem_patch3b
+	hjam 0xfc,core_usb_config
+	nop 10000
+	hjam 0x3c,core_usb_config
+	jam USB_RESUME,mem_usb_state
+	rtn
+
+usb_tx_test:
+	fetch 1,mem_mcmd
+	nrtn blank
+	fetch 2,mem_usb_cnt
+	rtn blank
+	increase -1,pdata
+	store 2,mem_usb_cnt
+	jam SEND_MOUSE_DATA_CMD,mem_mcmd
+	rtn	
+	
+else
+
+usb_init:
+usb_isr:
+usb_tx:
+	rtn
+endif
Index: btkb/program/utility.prog
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/utility.prog	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/program/utility.prog	(working copy)
@@ -0,0 +1,654 @@
+
+right_shift_n: //rshiftN pdata,pdata
+	sub loopcnt,0,null
+	rtn zero
+right_shift_n_loop: 
+	rshift pdata,pdata
+	loop right_shift_n_loop
+	rtn
+	
+push_stack:
+	deposit contw
+	store 2, mem_contw
+	storet 8,mem_temp
+	deposit timeup
+	store 4,mem_timeup
+	deposit rega
+	store 4, mem_rega
+	deposit regb
+	store 4, mem_regb
+	deposit regc
+	store 3, mem_regc
+	deposit contr
+	store 2, mem_contr
+	rtn
+pop_stack:
+	fetcht 8,mem_temp
+	fetch 4,mem_timeup
+	iforce timeup
+	fetch 4, mem_rega
+	iforce rega
+	fetch 4, mem_regb
+	iforce regb
+	fetch 3,mem_regc
+	iforce regc
+	fetch 2, mem_contw
+	iforce contw
+	fetch 2, mem_contr
+	iforce contr
+	rtn
+	
+	
+	
+
+//
+save_cont_pointers:
+	copy contw,pdata
+	store 2,mem_hold_contw
+	copy contr,pdata
+	store 2,mem_hold_contr
+	rtn
+load_cont_pointers:
+	fetch 2,mem_hold_contw
+	copy pdata,contw
+	fetch 2,mem_hold_contr
+	copy pdata,contr
+	rtn
+
+
+
+delay_10ms:
+	copy clkn_bt,pdata
+	increase 16,pdata
+	increase 16,pdata
+delay_ms_wait:
+	copy clkn_bt,temp
+	isub temp,null
+	branch delay_ms_wait,positive
+	rtn
+
+memcpy48:
+	ifetch 8,contr
+	istore 8,contw
+	ifetch 8,contr
+	istore 8,contw
+memcpy32:
+	ifetch 8,contr
+	istore 8,contw
+memcpy24:
+	ifetch 8,contr
+	istore 8,contw
+memcpy16:
+	ifetch 8,contr
+	istore 8,contw
+	ifetch 8,contr
+	istore 8,contw
+	rtn
+
+bn_zero:
+	force 3,loopcnt
+memset0:
+	force 0,pdata
+memset8:
+	istore   8,contw
+	loop   memset8
+	rtn
+
+
+clear_mem:
+	deposit loopcnt
+	rtn blank
+	setarg 0
+clear_mem_loop:
+	istore 1,contw
+	loop clear_mem_loop
+	rtn
+	
+	
+
+memcpy:
+	deposit loopcnt
+	rtn blank
+memcpy_loop:
+	ifetch 1,contr
+	istore 1,contw
+	loop memcpy_loop
+	rtn
+
+timer_stop:
+	setarg 0
+timer_init:
+	arg mem_timers,contw
+	iforce temp
+	lshift queue,pdata
+	iadd contw,contw
+	istoret 2,contw
+	rtn
+
+timer_reinit:
+	arg 0,queue
+timer_check:
+	set1 mark_ext_patch,mark
+	bpatch patch37_4,mem_patch37
+	fetcht 4,mem_last_clkn
+	rshift clkn_bt,pdata
+	store 4,mem_last_clkn
+	isub temp,timeup
+	copy timeup,temp
+	arg mem_timers,contr
+	copy contr,contw
+	arg 16,loopcnt
+timer_loop:
+	ifetch 2,contr
+	isub temp,pdata
+	branch timer_counting,positive
+	force 0,pdata
+timer_counting:
+	istore 2,contw
+	loop timer_loop	
+	arg mem_timers,contr
+	lshift queue,pdata
+	iadd contr,contr
+	ifetch 2,contr
+	rtn
+
+	/* lshift pdata 8*queue */
+lshift8_queue:
+	increase 1,queue
+lshift8_queue_loop:
+	increase -1,queue
+	rtn zero
+	lshift8 pdata,pdata
+	branch lshift8_queue_loop
+
+
+	/* pdata 28+16 bit add temp 26+16 bit, result in temp */
+clk_add:
+	iadd temp,temp
+	copy temp, loopcnt
+	setarg 3750
+	isub loopcnt,pdata
+	rtn positive
+	sub pdata,0,pdata
+	rshift16 temp,temp
+	increase 1,temp
+	lshift16 temp,temp
+	ior temp,temp
+	rtn
+
+clk_diff_rt:
+	call clk_diff
+	branch clk2rt
+
+/* pdata -temp -> pdata, all are 28+16 bits, set user if negative */
+clk_diff:
+	disable user
+	isub temp,pdata
+	branch clk_diff_pos,positive
+	enable user
+	sub pdata,0,pdata
+clk_diff_pos:
+	rtnbit0 15
+	arg -61786,temp
+	iadd temp,pdata
+	set0 64,pdata
+	rtn
+
+clk2rt:
+	iforce contr
+	rshift16 pdata,pdata
+	arg 3750,temp
+	imul32 temp,pdata
+	iadd contr,pdata
+	rtn
+
+	/* pdata = clks in, temp = lpo out */
+clk2lpo:
+	lshift8 pdata,pdata
+	lshift4 pdata,pdata
+	fetcht 3,mem_clks_per_lpo
+	idiv temp
+	call wait_div_end
+	quotient temp
+	rtn
+
+	/* rt clk -> bt+rt clk */
+clk2bt:
+	arg 3750,temp
+	idiv temp
+	call wait_div_end
+	quotient pdata
+	lshift16 pdata,pdata
+	remainder temp
+	ior temp,temp
+	rtn
+
+
+mem3_hex2string_to_uart:
+	arg 3,loopcnt
+	branch hex2string_to_uart0
+mem2_hex2string_to_uart:
+	arg 2,loopcnt
+	branch hex2string_to_uart0
+//input:src:rega des:contwu
+//len of src:loopcnt
+//ex:0x123456 to str //using:temp rega regb
+adss_hex2string_to_uart:
+	arg 6,loopcnt
+hex2string_to_uart0:
+	ifetch 1,rega
+	copy pdata,temp
+	rshift4 pdata,pdata
+	call dialog2uchar
+	istore 1,contwu
+	copy temp,pdata
+	and pdata,0xf,pdata
+	call dialog2uchar
+	istore 1,contwu
+	increase 1,rega
+	loop hex2string_to_uart0
+	rtn
+dialog2uchar:
+	sub pdata,9,null
+	branch dialog2uchar0to9,positive
+	increase 87,pdata
+	rtn
+dialog2uchar0to9:
+	add pdata,0x30,pdata
+	rtn
+
+
+//input:contru 
+//output:temp
+//used register: temp regc
+string2dec_from_uart:
+	arg 0,temp
+string2dec_from_uart_done:
+         copy temp,regc
+	ifetch 1,contru
+	sub pdata,AT_COMMA,null 
+	rtn zero
+	call uchar2dialog	
+	copy regc,temp
+	call swap
+	arg 10,regb
+	imul32 regb,pdata
+	iadd temp,pdata
+	copy pdata,temp
+	branch string2dec_from_uart_done
+
+
+mem2_string2hex_from_uart:
+	arg 2,loopcnt
+	branch string2hex_from_uart
+adss_string2hex_from_uart:
+	arg 6,loopcnt
+//input:contru contw
+//len of src:loopcnt
+//ex:123456 to 0x12 0x34 0x56
+string2hex_from_uart:
+	ifetch 1,contru
+	call uchar2dialog
+	lshift4 pdata,regc
+	ifetch 1,contru
+	call uchar2dialog
+	iadd regc,pdata
+	istore 1,contw
+	loop string2hex_from_uart
+	rtn
+
+uchar2dialog:
+	arg 0x3a,temp
+	isub temp,null
+	nbranch uchar2dialog_number,positive
+	arg 0x61,temp
+	isub temp,null
+	branch uchar2dialog_a2f,positive
+	arg 0x37,temp
+	isub temp,pdata
+	rtn
+uchar2dialog_number:
+	arg 0x30,temp
+	isub temp,pdata
+	rtn
+uchar2dialog_a2f:
+	arg 0x57,temp
+	isub temp,pdata
+	rtn
+
+pn9:
+	copy temp,alarm
+	setarg 0x1ff
+	force 0,regb
+pn9_loop:	
+	rshift3 pdata,rega
+	rshift rega,rega
+	ixor rega,rega
+	isolate1 0,rega
+	setflag true,9,pdata
+	rshift temp,temp
+	isolate1 0,pdata
+	setflag true,7,temp
+	rshift pdata,pdata
+	increase 1,regb
+	compare 0,regb,0x7
+	nbranch pn9_loop,true
+	istoret 1,contw
+	loop pn9_loop
+	copy alarm,temp
+	rtn
+
+bcd_byte:
+	div pdata,10
+	call wait_div_end
+	quotient pdata
+	lshift2 pdata,rega
+	lshift2 rega,rega
+	remainder pdata
+	ior rega,pdata
+	rtn
+
+bcd_pack:
+	isolate1 0,rega
+	branch bcd_pack_hi,true
+	iforce regb
+	rtn
+bcd_pack_hi:
+	lshift2 pdata,pdata
+	lshift2 pdata,pdata
+	ior regb,pdata
+	istore 1,contw
+	increase -2,contw
+	rtn
+
+wait_div_end:	
+	rtn modone
+	branch wait_div_end
+
+
+bcd2:
+	store 8,mem_pdatatemp
+	force 0x20,pdata
+	force 8,loopcnt
+	arg mem_bcd,contw
+lpo_clear:	
+	istore 1,contw
+	loop lpo_clear
+	arg mem_bcd,contw
+	increase 7,contw
+	fetch 8,mem_pdatatemp
+bcd_loop:
+	div pdata,10
+	call wait_div_end
+	remainder pdata
+	or_into 0x30,pdata
+	istore 1,contw
+	increase -2,contw
+	quotient pdata
+	rtn blank
+	branch bcd_loop
+
+
+
+/* store as packed bcd digits */
+bcd:
+	store 8,mem_pdatatemp
+	force 0,pdata
+	store 8,mem_bcd
+	arg mem_bcd,contw
+	increase 7,contw
+	fetch 8,mem_pdatatemp
+	force 0,rega
+bcd_pack_loop:
+	div pdata,10
+	call wait_div_end
+	remainder pdata
+	call 	bcd_pack
+	increase 1,rega
+	quotient pdata
+	sub pdata,9,null
+	nbranch bcd_pack_loop,positive
+	call bcd_pack
+	isolate1 0,rega
+	rtn true
+	istore 1,contw
+	rtn
+	
+//input:
+//	count:loopcnt str1:rega str2:regb
+//output:
+//	same:set falg true ,diff set falg false
+// using:
+//	reg:temp null flag:zero
+string_compare:
+	ifetch 1,rega
+	ifetcht 1,regb
+	isub temp,null
+	nrtn zero
+	increase 1,rega
+	increase 1,regb
+	loop string_compare
+	force 0,null
+	rtn
+
+	/* pdata = temp if pdata > temp */
+ceiling:
+	isub temp,null
+	nrtn positive
+	deposit temp
+	rtn
+	
+swap:
+	iadd temp,pdata
+	isub temp,temp
+	isub temp,pdata
+	rtn
+
+clean_mem:
+	arg 0x200,loopcnt
+	arg 0x4000,contw
+	branch memset0				// clear xram at boot
+
+slave_savelist:
+	fetch 5,mem_sync_clke
+	store 5,mem_pdatatemp
+	fetch 2,mem_clks_per_lpo
+	istore 2,contw
+	setarg 0
+	setflag match,7,pdata
+	setflag wake,6,pdata
+	setflag sync,5,pdata
+	setflag attempt,4,pdata
+	istore 1,contw
+	branch savelist_2
+
+
+le_savelist:
+	fetch 5,mem_sync_clke
+	store 5,mem_pdatatemp
+	fetch 1,mem_le_ch_mapped
+	istore 1,contw
+	fetch 2,mem_le_event_count
+	arg 0x0fff,contr
+	iand contr,pdata
+	setflag match,15,pdata
+	setflag wake,14,pdata
+	setflag sync,13,pdata
+	setflag attempt,12,pdata
+	istore 2,contw
+	branch savelist_2
+savelist:		
+	store 8,mem_pdatatemp
+savelist_2:
+	fetch 1,mem_seqi
+	rtneq 0x7f
+	and_into 0x7f,pdata
+	lshift3 pdata,pdata
+	arg mem_savelist,contw
+	iadd contw,contw
+	fetch 8,mem_pdatatemp
+	istore 8,contw
+	fetch 1,mem_seqi
+	isolate1 7,pdata
+	increase 1,pdata
+	and_into 0x7f,pdata
+	setflag true,7,pdata
+	store 1,mem_seqi
+	fetch 8,mem_pdatatemp
+	rtn	
+
+dirty_mem:
+	arg 0x800,loopcnt
+	arg 0,contw
+	setarg 0x01010101
+	branch memset8
+
+	//cb function ptr in pdata
+callback_func:
+	rtn blank
+	copy pdata,pc	//rtn through cb functon.
+	//branch assert
+
+wait_uarttx:
+	hfetch 2,core_uart_txitems
+	nbranch wait_uarttx,blank
+	rtn
+
+get_uart_rrptr:
+	hfetch 2,core_uart_rrptr
+	copy pdata,contru
+	rtn 
+
+get_uart_twptr:
+	hfetch 2,core_uart_twptr
+	copy pdata,contwu
+	rtn
+//input:contr loopcnt
+send_mem_to_uart:
+	copy contr,rega
+	call get_uart_twptr
+	copy rega,contr
+send_mem_to_uart0:
+	call uart_copy_tx_bytes
+	call  uartd_send
+	branch wait_uarttx
+
+ice_break:
+	hjam 0x1,core_ice_ctrl
+	rtn
+
+ice_setbp:
+	hstore 2,core_ice_break0
+	hfetch 1,core_ice_ctrl
+	set1 4,pdata
+	hstore 1,core_ice_ctrl
+	rtn
+ice_setbp2:
+	hstore 2,core_ice_break1
+	hfetch 1,core_ice_ctrl
+	set1 6,pdata
+	hstore 1,core_ice_ctrl
+	rtn
+	
+ice_set_write_bp:
+	hstore 2,core_ice_break0
+	hjam 0x30,core_ice_ctrl
+	rtn
+	
+test_no_white:
+	hfetch 1,core_config
+	set1 whiteoff_bit,pdata
+	hstore 1,core_config			/* whitening off */
+	rtn
+
+test_enable_white:
+	hfetch 1,core_config
+	set0 whiteoff_bit,pdata
+	hstore 1,core_config			/* whitening on */
+	rtn
+
+check_uart_tx_buff:
+	hfetch 2,core_uart_txitems
+	arg UART_AIR_CONTROL_THRESHOLD,temp
+pdata_sub_temp:
+	isub temp,null
+	rtn
+
+	//fuction fifo_in
+	//rega pointer to fifo memory , *(rega+len) is the end of fifo
+	//mem_fifo_temp data into fifo
+	//assert if fifo was full
+fifo_in:
+	set1 mark_ext_patch,mark
+	bpatch patch37_5,mem_patch37
+	ifetcht UTIL_FIFO_LEN,rega
+	and temp,0xff,pdata
+	nbranch fifo_in_push,blank
+	rshift8 temp,pdata
+	istore UTIL_FIFO_LEN,rega
+fifo_in_push:
+	increase UTIL_FIFO_LEN+UTIL_FIFO_OFFSET,rega
+	ifetch 1,rega
+	nbranch assert,blank //fifo full
+	fetch 1,mem_fifo_temp
+	istore 1,rega
+	rtn
+	
+	//fuction fifo_out
+	//rega pointer to fifo memory
+	//pdata  data from fifo, blank mains fifo empty
+fifo_out:
+	set1 mark_ext_patch,mark
+	bpatch patch37_6,mem_patch37
+	arg UTIL_FIFO_LEN,loopcnt
+	ifetch UTIL_FIFO_LEN,rega
+	rtn blank
+fifo_out_loop:
+	ifetch 1,rega
+	nbranch fifo_out_end,blank
+	increase 1,rega
+	loop fifo_out_loop
+	branch assert
+fifo_out_end:
+	arg 0,temp
+	istoret 1,rega
+	rtn
+
+	//fuction fifo_is_empty
+	//rega pointer to fifo memory
+	//blank--- fifo is empty
+fifo_is_empty:
+	ifetch UTIL_FIFO_LEN,rega
+	rtn
+
+	//fuction fifo_is_full
+	//rega pointer to fifo memory
+	//blank--- fifo is NOT full
+fifo_is_full:
+	ifetch 1,rega
+	rtn
+	//rega pointer to fifo memory
+	//blank--- fifo is NOT near full
+fifo_is_near_full:
+	ifetch 2,rega
+	rtn
+
+	//rega pointer to fifo memory
+	//count output via pdata
+fifo_content_count:
+	arg 0,temp
+fifo_content_count_loop:
+	fetch 1,contr
+	loop fifo_content_count_loop,blank
+	increase 1,temp
+	loop fifo_content_count_loop
+	copy temp,pdata
+	rtn
+	
+not_greater_than:
+	isub temp,null
+	nrtn positive
+	copy temp,pdata
+	rtn
+
+
Index: btkb/sched/kb.dat
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/sched/kb.dat	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/sched/kb.dat	(working copy)
@@ -0,0 +1,358 @@
+mem_patch00:
+2d   #mem_patch00
+00   #mem_patch01
+00   #mem_patch02
+00   #mem_patch03
+00   #mem_patch04
+00   #mem_patch05
+00   #mem_patch06
+00   #mem_patch07
+00   #mem_patch08
+00   #mem_patch09
+00   #mem_patch0A
+00   #mem_patch0B
+00   #mem_patch0C
+00   #mem_patch0D
+00   #mem_patch0E
+00   #mem_patch0F
+00   #mem_patch10
+00   #mem_patch11
+35   #mem_patch12
+00   #mem_patch13
+00   #mem_patch14
+00   #mem_patch15
+4f   #mem_patch16
+02   #mem_patch17
+00   #mem_patch18
+00   #mem_patch19
+00   #mem_patch1A
+00   #mem_patch1B
+00   #mem_patch1C
+00   #mem_patch1D
+00   #mem_patch1E
+00   #mem_patch1F
+00   #mem_patch20
+00   #mem_patch21
+00   #mem_patch22
+00   #mem_patch23
+00   #mem_patch24
+00   #mem_patch25
+04   #mem_patch26
+c8   #mem_patch27
+00   #mem_patch28
+5c   #mem_patch29
+40   #mem_patch2A
+04   #mem_patch2B
+3a   #mem_patch2C
+ce   #mem_patch2D
+00   #mem_patch2E
+00   #mem_patch2F
+80   #mem_patch30
+e0   #mem_patch31
+00   #mem_patch32
+00   #mem_patch33
+00   #mem_patch34
+00   #mem_patch35
+00   #mem_patch36
+20   #mem_patch37
+00   #mem_patch38
+a0   #mem_patch39
+01   #mem_patch3A
+00   #mem_patch3B
+00   #mem_patch3C
+00   #mem_patch3D
+00   #mem_patch3E
+00   #mem_patch3F
+
+
+mem_customize_timer_setup:  20 00		# 20:10ms  30:15ms
+
+mem_lpm_mode:01
+mem_lpm_mult:40
+mem_lpm_mult_timeout:03
+mem_lpm_overhead:0a
+mem_lpm_interval:10 00
+mem_scan_mode:00
+mem_test:00 00
+
+mem_class: 40 25 00
+
+mem_lap:36 08 c2 08 66 22    
+mem_local_name_length:
+'BT3.0 Keyboard
+mem_sniff_param_interval:0e 00
+mem_sniff_param_attempt:01
+mem_sniff_param_timeout:01
+mem_unsniff2sniff_timer:0a
+mem_ssp_enable:00
+mem_ui_profile_supported:01
+
+mem_eir_enable:01
+
+#bluetootch param init
+mem_sp_flag:00
+mem_lpm_current_mult:00
+mem_master_sp_flag:00
+mem_le_ch_mapped:27
+
+mem_ui_button_gpio:ff
+mem_led_gpio:ff
+
+mem_seqi:80
+
+
+mem_ipc_tx_evt_buff:02 01
+
+
+#attribute list: handle 2bytes, uuid 2bytes, length 1bytes, attribute Nbytes
+mem_le_att_list:
+
+#Primary service: GATT
+01 00 00 28 02 01 18
+#Characteristic: Service changed
+02 00 03 28 01 20
+03 00 05 2a 01 00
+#Client Characteristic Configuration
+04 00 02 29 02 00 00
+
+#Primary Service: GAP
+05 00 00 28 02 00 18 
+#Characteristic: Device Name
+06 00 03 28 01 02 
+07 00 00 2a 
+'BT4.2 Keyboard
+
+#Characteristic: Appearance
+08 00 03 28 01 02 
+09 00 01 2a 02 c1 03 
+#Characteristic: Peripheral Preferred Connection Parameters
+0a 00 03 28 01 02
+0b 00 04 2a 08 06 00 06 00 64 00 2c 01 # interval 6ms, latency 100, timeout 300
+
+#Primary Service: Device Information
+0c 00 00 28 02 0a 18
+#Manufacturer Name
+0d 00 03 28 01 02
+0e 00 29 2a 06 59 69 43 68 69 70			#IOS 13.5.1
+#Characteristic: pnp id
+0f 00 03 28 01 02
+10 00 50 2a 07 02 e8 04 21 70 01 00		# SAMSUNG soft keyboard,setup shortcuts
+
+#Primary service: HID
+11 00 00 28 02 12 18
+#Characteristic:Protocol mode
+12 00 03 28 01 06
+13 00 4e 2a 01 01
+#Characteristic: hid report
+14 00 03 28 01 12   
+15 00 4d 2a 08 00 00 00 00 00 00 00 00	#hid report	led handle write
+16 00 02 29 02 00 00	
+17 00 08 29 02 01 01	#Report ID: 1	Report Type: Input
+#Characteristic:hid report
+18 00 03 28 01 12  
+19 00 4d 2a 05 00 00 00 00 00
+1a 00 02 29 02 00 00
+1b 00 08 29 02 03 01	#Report ID: 3	Report Type: Input
+
+#Characteristic:hid report
+1c 00 03 28 01 12   
+1d 00 4d 2a 02 00 00 	#hid report	led handle write
+1e 00 02 29 02 00 00	
+1f 00 08 29 02 02 01	#Report ID: 2	Report Type: Input
+
+#Characteristic:hid report
+20 00 03 28 01 0e   
+21 00 4d 2a 02 00	00	#hid report	led handle write
+22 00 02 29 02 00 00	
+23 00 08 29 02 01 02	#Report ID: 1	Report Type: Output
+
+#Characteristic:Report map
+24 00 03 28 01 0a
+25 00 4b 2a a0		#length 66+25+60=160=0xa0
+#66
+05 01
+09 06
+a1 01
+85 01
+75 01 
+95 08
+05 07
+19 e0 
+29 e7 
+15 00
+25 01
+81 02
+95 01 
+75 08
+81 03 
+95 05
+75 01
+05 08
+19 01
+29 05  
+91 02 
+95 01  
+75 03  
+91 03
+95 06 
+75 08 
+15 00 
+26 ff 00
+05 07
+19 00
+29 ff 
+81 00
+c0 
+
+#25
+05 0c  		
+09 01  		
+a1 01	
+85 02			
+19 00  		
+2a ff 03 
+15 00 
+26 ff 03		
+95 01  		
+75 10  			
+81 00  		
+c0
+
+#29
+#05 01
+#09 80
+#A1 01
+#85 03
+#15 00
+#25 01
+#75 01
+#95 03
+#19 81
+#29 83
+#81 02
+#95 01
+#75 05
+#81 03
+#C0
+
+#69
+05 01 # Usage Page(Generic Desktop)
+09 02 # Usage(Mouse)
+a1 01 # Collection(Application)
+85 03 # Report ID(3)
+09 01 # Usage(Pointer)
+a1 00 # Collection(Physical)
+05 09 # Usage Page(Buttons)
+19 01 # Usage Minimum(1)
+29 08 # Usage Maximum(8)
+15 00 # Logical Minimum(0)
+25 01 # Logical Maximum(1)
+75 01 # Report Size(1)
+95 08 # Report Count(8)
+81 02 # Input(Data Variable Absolute)
+05 01 # Usage Page(Generic Desktop)
+09 30 # Usage(X)
+09 31 # Usage(Y)
+16 01 80  #Logical Minimum (-32767)
+26 FF 7F #Logical Maximum (32767) 
+75 10 # Report Size(16)
+95 02 # Report Count(2)
+81 06 # Input(Data Variable Relative)
+09 38 # Usage(Wheel)
+15 81 # Logical Minimum(-127)
+25 7f # Logical Maximum(127)
+75 08 # Report Size(8)
+95 01 # Report Count(1)
+81 06 # Input(Data Variable Relative)
+
+05 0c  #USAGE_PAGE(Consumer Devices)
+0a 38 02
+95 01   #REPORT_COUNT (1)	
+81 06  #INPUT (Data,Var,Rel)
+
+c0 # End Collection
+c0 # End Collection
+
+#Characteristic:Hid information
+26 00 03 28 01 02
+27 00 4a 2a 04 11 01 00 01        
+#Characteristic
+28 00 03 28 01 04
+29 00 4c 2a 01 00
+
+#Primary Service: BAS
+2a 00 00 28 02 0f 18 
+#Characteristic: Battery Level
+2b 00 03 28 01 12 
+2c 00 19 2a 01 64 
+#Client Characteristic Configuration
+2d 00 02 29 02 00 00 
+#End of Attribute list
+00 00
+
+
+mem_le_local_mtu:17
+mem_le_transmit_window:50
+mem_le_notify_handle:14
+mem_le_lap:11 46 34 54 77 dd
+
+
+mem_empty_count:00
+mem_att_report1:15 00
+mem_att_report2:1d 00
+mem_att_report3:19 00
+mem_att_report_battery:2c 00
+mem_le_rx_window:50
+
+mem_le_connection_updata_param:
+0c 00 #Length
+05 00 #CID
+12 b4 
+08 00 
+08 00 #min interval
+08 00 #max interval
+00 00 #latency
+2c 01 #timeout
+
+mem_le_name_len:
+'BT Keyboard
+
+mem_le_adv_channel_map:07 
+mem_le_adv_direct_addr_type:01
+#mem_le_adv_interval_max:00 01
+mem_le_adv_data_len:1f
+mem_le_adv_data:
+#02 01 05 05 02 12 18 0f 18 03 19 c1 03
+02 01 05 03 19 c1 03 03 03 12 18
+mem_le_adv_swift_pair:
+#microsoft swift pair
+06 ff 06 00 03 00 80
+
+mem_le_scan_data_len:1f
+mem_le_scan_data:
+'\09BT Keyboard
+
+mem_version_yy_mm_dd:20 21 12 24		#version data 20211224
+
+mem_adc_0v:9f 3e
+mem_adc_3v:cd 4d
+mem_adc_config_flag:04    #01 VINLPM      #02 HVIN      #04 GPIO
+
+#24g init
+mem_24g_mode:01#tx
+mem_24g_data_type:02        #mouse 1,kb 2
+mem_24g_max_retry:4#max tx retry
+mem_24g_no_ack:00#with ack
+mem_24g_rx_window:c0 12     #400us 
+mem_24g_ch_map1:00 13 2c 42
+mem_24g_ch_map2:06 15 36 48
+mem_24g_ch_map3:0f 1a 3a 4c
+mem_24g_ch_map4:11 23 31 4d
+mem_24g_pairing_sm:ff
+mem_24g_paring_addr:20 15 10 05
+mem_pair_state:c2
+mem_24g_common_temp:00 00 00 00 00 00 00 00 00 00
+mem_24g_enter_hibernate:00 48 5d 00 #10 min
+mem_24g_enter_hibernate_max:ff ff ff ff
+mem_24g_short_sleep_counter:e8 fd 00 #00 00 0a
+
Index: btkb/sched/kb_keyboard.dat
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/sched/kb_keyboard.dat	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/sched/kb_keyboard.dat	(working copy)
@@ -0,0 +1,499 @@
+mem_patch00:
+2d   #mem_patch00
+00   #mem_patch01
+00   #mem_patch02
+00   #mem_patch03
+00   #mem_patch04
+00   #mem_patch05
+00   #mem_patch06
+00   #mem_patch07
+00   #mem_patch08
+00   #mem_patch09
+00   #mem_patch0A
+00   #mem_patch0B
+00   #mem_patch0C
+00   #mem_patch0D
+00   #mem_patch0E
+00   #mem_patch0F
+00   #mem_patch10
+00   #mem_patch11
+35   #mem_patch12
+00   #mem_patch13
+00   #mem_patch14
+00   #mem_patch15
+4f   #mem_patch16
+02   #mem_patch17
+00   #mem_patch18
+00   #mem_patch19
+00   #mem_patch1A
+00   #mem_patch1B
+00   #mem_patch1C
+00   #mem_patch1D
+00   #mem_patch1E
+00   #mem_patch1F
+00   #mem_patch20
+00   #mem_patch21
+00   #mem_patch22
+00   #mem_patch23
+00   #mem_patch24
+00   #mem_patch25
+04   #mem_patch26
+c8   #mem_patch27
+00   #mem_patch28
+5c   #mem_patch29
+40   #mem_patch2A
+00   #mem_patch2B
+3a   #mem_patch2C
+ce   #mem_patch2D
+00   #mem_patch2E
+00   #mem_patch2F
+80   #mem_patch30
+e0   #mem_patch31
+00   #mem_patch32
+00   #mem_patch33
+00   #mem_patch34
+00   #mem_patch35
+00   #mem_patch36
+20   #mem_patch37
+00   #mem_patch38
+a0   #mem_patch39
+01   #mem_patch3A
+00   #mem_patch3B
+00   #mem_patch3C
+00   #mem_patch3D
+00   #mem_patch3E
+00   #mem_patch3F
+
+
+mem_customize_timer_setup:  20 00		# 20:10ms  30:15ms
+
+mem_lpm_mode:01
+mem_lpm_mult:40
+mem_lpm_mult_timeout:03
+mem_lpm_overhead:0a
+mem_lpm_interval:10 00
+mem_scan_mode:00
+mem_test:00 00
+
+mem_class: 40 25 00
+
+mem_lap:36 08 c2 08 66 22    
+mem_local_name_length:
+'BT3.0 Keyboard
+mem_sniff_param_interval:0e 00
+mem_sniff_param_attempt:01
+mem_sniff_param_timeout:01
+mem_unsniff2sniff_timer:0a
+mem_ssp_enable:00
+mem_ui_profile_supported:01
+
+mem_eir_enable:01
+
+mem_all_uuid_16bits:
+06
+03#Type: Complete list of 16-bit UUIDs
+1100 0001 0210 2411  0012  0100
+
+mem_all_uuid_128bits:00
+
+#keyboard uuid
+mem_kb_uuid_list:
+#uuids
+04 0011 0100 1002 1124
+
+#handle
+00010000
+
+#total length
+360189
+
+#attribute start, first 4 digit is attribute ID
+090000 0a 00010000
+090001 3503 191124
+090004 350d 3506 190100 090011 3503 190011
+090005 3503 191002
+090006 3509 09656e 09006a 090100
+090009 3508 3506 191124 090100
+09000d 350f 350d 3506 190100 090013 3503 190011
+
+#Service Name
+#090100 2517
+#'Apple Wireless Keyboard
+#41 70 70 6c 65 20 57 69 72 65 6c 65 73 73 20 4b 65 79 62 6f 61 72 64
+#Service Name
+090100 253d
+#'Broadcom Bluetooth Wireless  Keyboard                        
+4272 6f61 6463 6f6d 2042 6c75 6574 6f6f 7468 2057 6972 656c 6573 7320 204b 6579 626f 6172 6420 
+2020 2020 2020 2020 2020 2020 2020 2020 2020 2020 2020 20
+
+#Service Description
+090101 2508
+#'Keyboard
+4b6579626f617264
+
+#Provider Name
+#090102 250a
+#'Apple Inc.
+#41 70 70 6c 65 20 49 6e 63 2e
+#Provider Name
+090102 2510
+#'Broadcom Corp.  
+4272 6f61 6463 6f6d 2043 6f72 702e 2020
+
+090200 090100
+090201 090111
+090202 0840
+090203 0821
+090204 2801
+090205 2801
+090206 3578 3576 0822 2572
+
+# hid descriptor
+0501 # Usage Page(Generic Desktop)
+0906 # Usage(Keyboard)
+a101 # Collection(Application)
+8501 # Report ID(1)
+7501 # Report Size(1)
+9508 # Report Count(8)
+0507 # Usage Page(Keyboard/Keypad)
+19e0 # Usage Minimum(224)
+29e7 # Usage Maximum(231)
+1500 # Logical Minimum(0)
+2501 # Logical Maximum(1)
+8102 # Input(Data Variable Absolute) ; Modifier byte
+9501 # Report Count(1)
+7508 # Report Size(8)
+8103 # Input(Constant Variable Absolute) ; 
+9505 # Report Count(5)
+7501 # Report Size(1)
+0508 # Usage Page(LEDs)
+1901 # Usage Minimum(1)
+2905 # Usage Maximum(5)
+9102 # Output(Data Variable Absolute) ; LED report
+9501 # Report Count(1)
+7503 # Report Size(3)
+9103 # Output(Constant Variable Absolute) ; 
+9506 # Report Count(6)
+7508 # Report Size(8)
+1500 # Logical Minimum(0)
+26ff00 # Logical Maximum(255)
+0507 # Usage Page(Keyboard/Keypad)
+1900 # Usage Minimum(0)
+29ff # Usage Maximum(255)
+8100 # Input(Data Array) ; Key arrarys 6 bytes
+c0 # End Collection
+
+05 0c  		
+09 01  		
+a1 01	
+85 02			
+19 00  		
+2a ff 03 
+15 00 
+26 ff 03		
+95 01  		
+75 10  			
+81 00  		
+c0
+
+#23
+05 01	#Usage Page (Generic Desktop),
+09 80	#USAGE (3-D Digitizer)
+a1 01	#Collection (Application),
+85 03	#Report ID (3)
+19 81	#Usage Minimum (), 
+29 88	#Usage Maximum (),
+15 00	#Logical Minimum (0),
+25 01	#Logical Maximum (1),
+95 08	#Report Count (8),
+75 01	#Report Size (1),
+81 06	#Input (Data,Var,Rel)
+#95 01	#Report Count (1),  
+#75 05	#Report Size (5),	
+#81 01	#Input (Const,Ary,Abs)
+c0		#END_COLLECTION
+
+090207 3508 3506 090409 090100
+09020b 090100
+09020c 090c80
+09020d 2800
+09020e 2801
+09020f 090318
+090210 090000
+#attribute end
+
+#uuids for pnpInformation	
+03 1002 1200 0001
+
+#handle
+00010001
+
+#total length 90 bytes
+3600a1
+
+#attribute list
+090000 0a00010001
+090001 3503 191200
+090004 350d 3506 190100 090001 3503 190001
+090006 3509 09656e 09006a 090100
+090009 3508 3506 191200 090100
+090100 252f42726f6164636f6d20426c7565746f6f746820576972656c657373204b6579626f61726420506e5020536572766572
+090101 25084b6579626f617264
+090200 090103
+090201# VendorID
+0904e8
+090202#ProductID
+097021
+090203 090001
+090204 2801
+090205 090002
+
+#attribute end
+00
+
+#Auto reconnection after power on
+
+memui_uuid_table:mem_kb_uuid_list
+#Auto reconnection after power on
+mem_device_option:43
+mem_ptt:0
+mem_features:
+ff
+ff
+8f
+f8	#fe--EDR  F8--BR
+83	#AFHclose 83
+9d
+59
+82
+
+#bluetootch param init
+mem_sp_flag:00
+mem_lpm_current_mult:00
+mem_master_sp_flag:00
+mem_le_ch_mapped:27
+
+mem_ui_button_gpio:ff
+mem_led_gpio:ff
+
+mem_seqi:80
+
+
+mem_ipc_tx_evt_buff:02 01
+
+
+#attribute list: handle 2bytes, uuid 2bytes, length 1bytes, attribute Nbytes
+mem_le_att_list:
+
+#Primary service: GATT
+01 00 00 28 02 01 18
+#Characteristic: Service changed
+02 00 03 28 01 20
+03 00 05 2a 01 00
+#Client Characteristic Configuration
+04 00 02 29 02 00 00
+
+#Primary Service: GAP
+05 00 00 28 02 00 18 
+#Characteristic: Device Name
+06 00 03 28 01 02 
+07 00 00 2a 
+'BT4.2 Keyboard
+
+#Characteristic: Appearance
+08 00 03 28 01 02 
+09 00 01 2a 02 c1 03 
+#Characteristic: Peripheral Preferred Connection Parameters
+0a 00 03 28 01 02
+0b 00 04 2a 08 06 00 06 00 64 00 2c 01 # interval 6ms, latency 100, timeout 300
+
+#Primary Service: Device Information
+0c 00 00 28 02 0a 18
+#Manufacturer Name
+0d 00 03 28 01 02
+0e 00 29 2a 06 59 69 43 68 69 70			#IOS 13.5.1
+#Characteristic: pnp id
+0f 00 03 28 01 02
+10 00 50 2a 07 02 e8 04 21 70 01 00		# SAMSUNG soft keyboard,setup shortcuts
+
+#Primary service: HID
+11 00 00 28 02 12 18
+#Characteristic:Protocol mode
+12 00 03 28 01 06
+13 00 4e 2a 01 01
+#Characteristic: hid report
+14 00 03 28 01 12   
+15 00 4d 2a 08 00 00 00 00 00 00 00 00	#hid report	led handle write
+16 00 02 29 02 00 00	
+17 00 08 29 02 01 01	#Report ID: 1	Report Type: Input
+
+#Characteristic:hid report
+18 00 03 28 01 12  
+19 00 4d 2a 02 00 00
+1a 00 02 29 02 00 00
+1b 00 08 29 02 03 01	#Report ID: 3	Report Type: Input
+
+#Characteristic:hid report
+1c 00 03 28 01 12   
+1d 00 4d 2a 02 00 00 	#hid report	led handle write
+1e 00 02 29 02 00 00	
+1f 00 08 29 02 02 01	#Report ID: 2	Report Type: Input
+
+#Characteristic:hid report
+20 00 03 28 01 0e   
+21 00 4d 2a 02 00	00	#hid report	led handle write
+22 00 02 29 02 00 00	
+23 00 08 29 02 01 02	#Report ID: 1	Report Type: output
+
+#Characteristic:Report map
+24 00 03 28 01 02
+25 00 4b 2a 72
+#66
+05 01
+09 06
+a1 01
+85 01
+75 01 
+95 08
+05 07
+19 e0 
+29 e7 
+15 00
+25 01
+81 02
+95 01 
+75 08
+81 03 
+95 05
+75 01
+05 08
+19 01
+29 05  
+91 02 
+95 01  
+75 03  
+91 03
+95 06 
+75 08 
+15 00 
+26 ff 00
+05 07
+19 00
+29 ff 
+81 00
+c0 
+
+#25
+05 0c  		
+09 01  		
+a1 01	
+85 02			
+19 00  		
+2a ff 03 
+15 00 
+26 ff 03		
+95 01  		
+75 10  			
+81 00  		
+c0
+
+#23
+05 01	#Usage Page (Generic Desktop),
+09 80	#USAGE (3-D Digitizer)
+a1 01	#Collection (Application),
+85 03	#Report ID (3)
+19 81	#Usage Minimum (), 
+29 88	#Usage Maximum (),
+15 00	#Logical Minimum (0),
+25 01	#Logical Maximum (1),
+95 08	#Report Count (8),
+75 01	#Report Size (1),
+81 06	#Input (Data,Var,Rel)
+#95 01	#Report Count (1),  
+#75 05	#Report Size (5),	
+#81 01	#Input (Const,Ary,Abs)
+c0		#END_COLLECTION
+
+#Characteristic:Hid information
+26 00 03 28 01 02
+27 00 4a 2a 04 11 01 00 01        
+#Characteristic
+28 00 03 28 01 04
+29 00 4c 2a 01 00
+
+#Primary Service: BAS
+2a 00 00 28 02 0f 18 
+#Characteristic: Battery Level
+2b 00 03 28 01 12 
+2c 00 19 2a 01 64 
+#Client Characteristic Configuration
+2d 00 02 29 02 00 00 
+#End of Attribute list
+00 00
+
+
+mem_le_local_mtu:17
+mem_le_transmit_window:50
+mem_le_notify_handle:14
+mem_le_lap:11 46 34 54 77 dd
+
+
+mem_empty_count:00
+mem_att_report1:15 00
+mem_att_report2:1d 00
+mem_att_report3:19 00
+mem_att_report_battery:2c 00
+mem_le_rx_window:50
+
+mem_le_connection_updata_param:
+0c 00 #Length
+05 00 #CID
+12 b4 
+08 00 
+08 00 #min interval
+08 00 #max interval
+00 00 #latency
+2c 01 #timeout
+
+mem_le_name_len:
+'BT Keyboard
+
+mem_le_adv_channel_map:07 
+mem_le_adv_direct_addr_type:01
+#mem_le_adv_interval_max:00 01
+mem_le_adv_data_len:1f
+mem_le_adv_data:
+#02 01 05 05 02 12 18 0f 18 03 19 c1 03
+02 01 05 03 19 c1 03 03 03 12 18
+mem_le_adv_swift_pair:
+#microsoft swift pair
+06 ff 06 00 03 00 80
+
+mem_le_scan_data_len:1f
+mem_le_scan_data:
+'\09BT Keyboard
+
+mem_version_yy_mm_dd:20 21 12 24		#version data 20211224
+
+mem_adc_0v:9f 3e
+mem_adc_3v:cd 4d
+mem_adc_config_flag:02    #01 VINLPM      #02 HVIN      #04 GPIO
+
+#24g init
+mem_24g_mode:01#tx
+mem_24g_data_type:02        #mouse 1,kb 2
+mem_24g_max_retry:4#max tx retry
+mem_24g_no_ack:00#with ack
+mem_24g_rx_window:c0 12     #400us 
+mem_24g_ch_map1:00 13 2c 42
+mem_24g_ch_map2:06 15 36 48
+mem_24g_ch_map3:0f 1a 3a 4c
+mem_24g_ch_map4:11 23 31 4d
+mem_24g_pairing_sm:ff
+mem_24g_paring_addr:20 15 10 05
+mem_pair_state:c2
+mem_24g_common_temp:00 00 00 00 00 00 00 00 00 00
+mem_24g_enter_hibernate:00 48 5d 00 #10 min
+mem_24g_enter_hibernate_max:ff ff ff ff
+mem_24g_short_sleep_counter:e8 fd 00 #00 00 0a
+
Index: btkb/sched/rf.dat
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/sched/rf.dat	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/sched/rf.dat	(working copy)
@@ -0,0 +1,107 @@
+mem_lpm_config:8f 10 ce
+mem_lpm_xtalcnt:00 0a 0b ef 0f
+mem_lpm_hibernate_switch:00
+mem_gpio_wakeup_low:00 00 00 00 00 00 00 00
+mem_fcomp_mul:02
+mem_fcomp_div:24
+mem_iscan_window:12 00
+mem_iscan_interval:00 02
+mem_pscan_window:12 00
+mem_pscan_interval:00 02
+mem_inq_window:20 00
+mem_page_window:20 00
+mem_page_to:00 20
+mem_rx_window_init:80 03
+mem_rx_window_sniff:00 06
+mem_new_supervision_to:00 13
+
+mem_eeprom_base:30 3f
+mem_eeprom_block_size:20
+#pointers to tail space of mem_le_att_list
+4f70:
+07 ff #2M_IF
+0a fb
+0b ff 
+
+#agc table
+1a fb
+1b fb
+1c fb
+1d f6
+1e f2
+1f ee
+20 ea
+21 e6
+22 e2
+23 de
+24 da
+25 d6
+26 d2
+27 ce
+28 ca
+29 c6
+2a c2
+2b bd
+2c b9
+2d b5
+2e b1
+2f ad
+30 a9
+31 80
+32 80
+33 80
+34 c0
+35 c1
+36 c2
+37 c3
+38 c4
+39 c5
+3a c6
+3b c7
+3c 06
+3d 07
+3e 46
+3f 85
+40 86
+41 87
+42 c6
+43 c7
+44 d6
+45 d7
+46 e6
+47 f5
+48 00
+49 f8
+4a 7f
+4e ec
+4f 5e
+
+# tx power
+55 d0
+56 c0
+57 4c
+58 6c
+59 50
+
+#dpll
+68 e4
+69 00
+6a 00
+6b 30
+ff
+mem_rf_init_ptr:70 4f
+
+mem_5db_tx_power_param:
+55 d0
+56 c0
+57 4c
+58 6c
+59 50
+
+mem_24g_paring_tx_power_param:
+55 d0
+56 c0
+57 4c
+58 6c
+59 50
+
Index: btkb/util/memalloc.pl
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/util/memalloc.pl	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/util/memalloc.pl	(working copy)
@@ -0,0 +1,74 @@
+#!/usr/bin/perl
+$path="output/bt_format.meta";
+open file, $path;
+@f = <file>;
+close file;
+open file, ">$path";
+$path =~ s/\/.*//;
+open file1, ">output/memmap.format";
+$xaddr = 0x4000;
+$addr = 0;
+if($#ARGV == 1) {
+	$addr = hex($ARGV[0]);
+	$xaddr = hex($ARGV[1]);
+}
+for($i = 0;$i < @f;$i++) { $cmalloc[$i] = (); }
+for($i = 0;$i < @f;$i++) { 
+	$_ = $f[$i];
+	$start = 1 if(/^\s*memalloc\s*\(\s*$/);
+	$start = 2 if(/^\s*xmemalloc\s*\(\s*$/);
+	$start = 3 if(/^\s*omemalloc\s*\(\s*$/);
+	$start = 10 + $1 if(/^\s*cmemalloc\s+([0-9])\s*\(\s*$/);
+	if($start) {
+		if(/^\s*([0-9]+)\s+([a-zA-Z0-9_]+)\s*(.*)$/) {
+			if($start == 1) {
+				$str = sprintf "0x%04x %s%s\n", $addr, $2, $3;
+				$addr += $1;
+				$bstr .= $str;
+				$sstr .= $str;
+			} elsif($start == 2) {
+				$str = sprintf "0x%04x %s%s\n", $xaddr, $2, $3;
+				$xaddr += $1;
+				$xstr .= $str;
+			} else {
+				push @ostr, $_;
+			}
+		}
+		if(/^\s*\)\s*$/) {
+			if(@ostr > 0) {
+				if($start == 3) {
+					push @omalloc,[@ostr];
+				} elsif($start > 9) {
+					$j = $start - 10;
+					push @{$cmalloc[$j]},@ostr;
+				} 
+			}
+			$start = 0;
+			@ostr = ();
+		}
+	} else {
+		$sstr .= $_;
+	}
+}
+for($i = 0;$i <= $#cmalloc;$i++) {
+	push @omalloc,$cmalloc[$i];
+#	for($j = 0;$j <= $#{$cmalloc[$i]};$j++) {		print $cmalloc[$i][$j];	}
+}
+
+$xend = $xaddr;
+for($i = 0;$i <= $#omalloc;$i++) {
+	for($j = 0, $oaddr = $xaddr;$j <= $#{$omalloc[$i]};$j++) {
+		if($omalloc[$i][$j] =~ /^\s*([0-9]+)\s+([a-zA-Z0-9_]+)\s*(.*)$/) {
+			$str = sprintf "0x%04x %s%s\n", $oaddr, $2, $3;
+			$oaddr += $1;
+			$xstr .= $str;
+		}
+	}
+}
+$xend = $oaddr if($oaddr > $xend);
+print file $xstr, $sstr;
+print file1 $bstr, $xstr;
+close file;
+close file1;
+printf "\nLast allocated address is %04x\n", $addr;
+printf "\nLast allocated xmem address is %04x\n", $xend;
\ No newline at end of file
Index: btkb/util/mergepatch.pl
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/util/mergepatch.pl	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/util/mergepatch.pl	(working copy)
@@ -0,0 +1,44 @@
+#!/usr/bin/perl
+$defs = "";
+$fmt = 0;
+
+
+sub parseif {
+	my($fname) = @_;
+	open file, $fname;
+	@f = <file>;
+	close file;
+	open file, ">$fname";
+	@valid = (1);
+	for($i = 0;$i < @f;$i++) { 
+		$_ = $f[$i];
+		$defs .= $1 . " " if(/^define\s+(\w+)\s*/);
+		if(/^ifdef\s+(\w+)\s*/) {
+			push @valid, ($defs =~ /(^|\s)$1(\s|$)/ ? 1 : 0) & $valid[$#valid];
+		} elsif(/^ifndef\s+(\w+)\s*/) {
+			push @valid, ($defs =~ /(^|\s)$1(\s|$)/ ? 0 : 1) & $valid[$#valid];
+		} elsif(/^else/) {
+			printf "%s\nelse without if at line %d\n", $f[$i - 3], $i if($#valid == 0);
+			$valid[$#valid] = (1 - $valid[$#valid]) & $valid[$#valid - 1];
+		} elsif(/^endif/) {
+			printf "%s\nendif without if at line %d\n", $_, $i if($#valid == 0);
+			pop @valid;
+		} elsif($valid[$#valid]) {
+			if(/^include\s+(.+)\s*/) {
+				open file2, "program/$1";
+				@f2 = <file2>;
+				close file2;
+				splice(@f, $i + 1, 0, @f2);
+			} else {
+				print file $_;
+			}
+		}
+	}
+	close file;
+}
+
+parseif("output/bt_program23.meta");
+$fmt = 1;
+parseif("output/bt_format.meta");
+
+
Index: btkb/util/transform_memmap2btreg.pl
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/util/transform_memmap2btreg.pl	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/btkb/util/transform_memmap2btreg.pl	(working copy)
@@ -0,0 +1,45 @@
+$memmap_path=$ARGV[0];
+$memblocks_path=$ARGV[1];
+$btreg_path=$ARGV[2];
+open(btreg,">$btreg_path");
+print btreg ("");#reset file
+close(btreg);
+open(memmap,$memmap_path);
+open(memblocks,$memblocks_path);
+open(btreg,">>$btreg_path");
+@text = <memmap>;
+print btreg ("#ifndef _BT_REG_H_\n");
+print btreg ("#define _BT_REG_H_\n");
+foreach $text (@text){
+	@word = split (/[\t ]+/,$text);
+	$reg_addr = @word[0];
+	if ($reg_addr =~ /0x[0-9abcdef]*/){#Is 0x0000~0xffff
+		$word1 = @word[1];
+		@reg_name = split(/\/[\/\*]/,$word1);#delete // or /*  */
+		$reg_name = @reg_name[0];
+		$reg_name =~ s/[\r\n]//;#delete Carriage return
+		
+		printf btreg ("#define\t%-40s\t%s\n",$reg_name,$reg_addr);
+		#print btreg ("#define \t $reg_name \t\t\t $reg_addr \n");
+		#print btreg ("@word[1]\n");
+	}
+}
+@text = <memblocks>;
+foreach $text (@text){
+	@word = split (/[\t ]+/,$text);
+	$reg_addr = @word[0];
+	if ($reg_addr =~ /0x[0-9abcdef]*/){
+		$word1 = @word[1];
+		@reg_name = split(/\/[\/\*]/,$word1);
+		$reg_name = @reg_name[0];
+		$reg_name =~ s/[\r\n]//;
+		printf btreg ("#define\t%-40s\t%s\n",$reg_name,$reg_addr);
+		#print btreg ("#define \t $reg_name \t\t\t\t $reg_addr \n");
+		#print btreg ("@word[1]\n");
+	}
+}
+print btreg ("#endif\n");
+close(memblocks);
+close(memmap);
+close(btreg);
+
Index: c51/Makefile
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/Makefile	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/Makefile	(working copy)
@@ -0,0 +1,112 @@
+	comma:= ,
+empty:=
+space:= $(empty) $(empty)
+bracketl:= (
+bracketl0:= \(
+bracketr:= )
+bracketr0:= \)
+
+
+OUTDIR = output
+ROOT_PATH =c:\keil_v5
+
+UTIL_PATH = ..\rom\util
+
+C51BIN = $(ROOT_PATH)\c51\bin
+C51   = $(C51BIN)\c51
+A51   = $(C51BIN)\ax51
+BL51  = $(C51BIN)\lx51
+OH51  = $(C51BIN)\Ohx51
+OC51  = $(C51BIN)\oc51
+LIB51 = $(C51BIN)\libx51
+
+TARGET = $(OUTDIR)\fw
+TARGETHEX = $(TARGET).hex
+
+
+RAMTARGET = $(OUTDIR)\fwram
+
+RAMTARGETHEX = $(addsuffix .hex, $(RAMTARGET))
+
+############################## IMPORTANT ####################################
+#   opt level greater than 7 cannot be used, or the ram code and the rom code will be different
+##############################################################################
+OPT_LEVEL=7
+
+LIST_FILE_CTL=PR($(@:obj=lst))
+
+C_OPTS = object($@) OBJECTADVANCED  browse DF(ENABLE_APE) $(LIST_FILE_CTL) \
+OT($(OPT_LEVEL),SPEED) large
+
+#ASM_OPTS =  $(LIST_FILE_CTL) object($@)
+ASM_OPTS = SET (large) DEBUG EP $(LIST_FILE_CTL) object($@)
+
+LINK_OPTS = \
+	CLASSES (XDATA (X:0x4dd0-X:0x4f40),\
+	CODE(C:0-C:0xffff), DATA(D:0x10-0x7f), IDATA(I:0x80-0xcf)) \
+	SEGMENTS($(DATA_MAP)) \
+	NOOVERLAY \
+	PAGELENGTH(60000) \
+	CODE
+
+DATA_MAP = ?STACK(D:0xD0)
+CODE_MAP = ?PR?RAMENTRY?JUMPTABLE(C:0x0), ?PR?*, ?C*
+
+LINK_OBJ_RAM = bluetooth global_variable kb_process keyscan led sys adc ram
+
+#LINK_OBJ_LIB = 
+
+LINK_OBJ_TMP_RAM = $(addsuffix .obj,$(LINK_OBJ_LIB) $(LINK_OBJ_RAM)) ..\patch\ipc.obj ..\patch\utilities.obj ..\patch\gpio.obj ..\patch\iic.obj
+LINK_OBJ_DEPENDENCIES_RAM = $(addprefix $(OUTDIR)/, $(LINK_OBJ_TMP_RAM))
+LINK_OBJ_FILES_RAM = $(subst $(space),$(comma),$(LINK_OBJ_DEPENDENCIES_RAM))
+
+LINK_OBJ_TMP_ROM = $(addsuffix .obj,$(LINK_OBJ_ROM))
+LINK_OBJ_DEPENDENCIES_ROM = $(addprefix $(OUTDIR)/, $(LINK_OBJ_TMP_ROM))
+LINK_OBJ_FILES_ROM = $(subst $(space),$(comma),$(LINK_OBJ_DEPENDENCIES_ROM))
+
+
+.SUFFIXES: .a51
+RAM_BIN = $(RAMTARGET).rom
+
+
+PROG_FILE = ..\rom\program\c51.prog
+RAM_FILES = $(RAM_MIF) $(RAM_BIN) $(EEPROM_FILE) $(PROG_FILE)
+
+$(OUTDIR)/%.obj : %.c hwreg.h
+	$(C51) $< "$(C_OPTS)"
+
+$(OUTDIR)/%.obj : %.a51
+	$(A51) $< "$(ASM_OPTS)"
+
+all : $(RAM_FILES) 
+
+
+$(TARGET) : $(LINK_OBJ_DEPENDENCIES_RAM)
+	$(BL51) $(LINK_OBJ_FILES_RAM) TO $@ "$(LINK_OPTS)"
+
+$(TARGETHEX) : $(TARGET)
+	$(OH51) $(TARGET)
+
+
+$(RAM_BIN) : $(TARGETHEX)
+
+
+$(RAM_MIF) : $(TARGETHEX)
+	perl $(UTIL_PATH)\hex2mif.pl < $< rammif > $@
+
+
+$(EEPROM_FILE) : $(RAM_BIN)
+	cd ..\rom\output; ..\util\geneep.exe; cp eeprom.dat ..\..\sim 
+
+$(PROG_FILE) : $(RAM_BIN)
+#	perl $(UTIL_PATH)\setarg.pl $< c51 > $@
+
+clean:  
+	del /Q $(OUTDIR)\*.* 
+
+
+lib:
+	$(LIB51) TRANSFER $(OUTDIR)\ipc.obj TO $(OUTDIR)\yichip.LIB
+	
+ext:
+	$(LIB51) EXTRACT $(OUTDIR)\yichip.LIB (ipc) TO $(OUTDIR)\ipc.obj
Index: c51/YCkbTool.bat
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/YCkbTool.bat	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/YCkbTool.bat	(working copy)
@@ -0,0 +1,76 @@
+@echo off
+title %~0
+:start
+set/p cmd=Please enter cmd, c/C for compiling, and d/D for downloading:
+if /I "%cmd%" equ "a" (goto compile_all)
+if /I "%cmd%" equ "A" (goto compile_all)
+if /I "%cmd%" equ "c" (goto compile)
+if /I "%cmd%" equ "C" (goto compile)
+if /I "%cmd%" equ "d" (goto download)
+if /I "%cmd%" equ "D" (goto download)
+if /I "%cmd%" equ "k" (goto reset)
+if /I "%cmd%" equ "K" (goto reset)
+if "%cmd%" equ "" (goto error)  else (goto error)
+
+:compile_all
+cd ..\btkb
+call do eep
+cd ..\c51
+
+:compile
+make clean
+make
+
+util\hex2mif.exe < output\fw.hex ram > output\fwram.rom
+copy .\patch\kb.dat + .\patch\rf.dat .\patch\sch.rom 
+
+cd util
+
+perl transform_name2addr.pl ..\patch\sch.rom ..\output\sched.rom ..\patch\memmap.format
+cd ..
+
+copy .\patch\ramcode.rom .\output\
+copy .\patch\geneep.exe .\output\
+copy .\output\*.obj .\patch\*.obj
+
+copy .\util\eeprom2fulleeprom.exe .\eeprom2fulleeprom.exe
+copy .\util\crc16.exe .\crc16.exe
+
+cd output
+geneep geneep ramcode.rom fwram.rom sched.rom
+del *.lst
+del *.obj
+
+copy eeprom.dat ..\eeprom.dat
+cd ..
+eeprom2fulleeprom.exe eeprom.dat 256>compare2.dat
+crc16.exe compare2.dat 2 >.\output\eeprom.dat
+del eeprom.dat
+del compare2.dat
+del eeprom2fulleeprom.exe
+del crc16.exe
+
+:end
+set cmd=0
+echo/
+goto start
+
+:error
+echo Cmd error, enter again
+goto end
+
+:reset
+e pu
+e ku
+goto end
+
+:download
+e p
+e pu
+e ep
+e k
+e ku
+e a
+e au
+goto end
+
Index: c51/adc.h
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/adc.h	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/adc.h	(working copy)
@@ -0,0 +1,53 @@
+#ifndef _ADC_H
+#define _ADC_H
+#include "common.h"
+
+#define ADC_ENABLE
+/***need to modify  mem_adc_config_flag in kb.dat at the same time****/
+//#define ADC_TYPE_VINLPM			0x01	// 1.8V~3.6V
+//#define ADC_TYPE_HVIN			0x02	// 3.0~5.5V
+#define ADC_TYPE_GPIO			0x04	// 0~1.5V
+
+
+// GPIO5 0x30,   GPIO6 0x31,   GPIO7 0x32,
+//GPIO18 0x33,   GPIO19 0x34,   GPIO20 0x35,   GPIO21 0x36,    GPIO22 0x37
+#define ADC_CHANNEL				0x33	
+
+
+#define BAT_STATUS_NONE			0
+#define BAT_STATUS_LOW				1
+#define BAT_STATUS_SHUT_DOWN		2
+
+//battery check
+#define BATTERY_CHECK_INTERVAL 		5			// 500ms*5 = 2.5s
+#define INIT_BATTERY_VALUE   				0x5454
+#define INIT_BATTERY_VALUE_GPIO			0x6262
+#define INIT_BATTERY_VALUE_VINLPM		0x5151
+#define LOW_BATTERY_FLASH_INTERVAL	10	
+
+#define BATTERY_MOTION_CHECK_INTERVAL                 20                    //500*20 = 10s
+// battery to gpio R = 1M
+#define LOW_BATTER_COEFFICIENT_1V5   	0.88
+#define LOW_BATTER_COEFFICIENT_1V1   	0.70             //2.1v
+#define LOW_BATTER_COEFFICIENT_1V0       0.27
+#define LOW_BATTER_COEFFICIENT_0V9	     0.57                   //1.9v
+
+#define LOW_BATTER_COEFFICIENT_2V2   	0.74
+#define LOW_BATTER_COEFFICIENT_2V0       0.67
+
+#define LOW_BATTER_COEFFICIENT_3V7   	1.24
+#define LOW_BATTER_COEFFICIENT_3V3   	1.11
+#define LOW_BATTER_COEFFICIENT_3V2       1.07
+#define LOW_BATTER_COEFFICIENT_3V1	1.04
+#define LOW_BATTER_COEFFICIENT_3V0	1.01
+
+
+void YC_adc_check_timer500ms();
+void YC_adc_motion_check_timer500ms();
+
+void YC_adc_check() ;
+void YC_adc_init();
+
+#endif /* YC_ADC_H */
+
+
Index: c51/adc.c
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/adc.c	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/adc.c	(working copy)
@@ -0,0 +1,135 @@
+#include "adc.h"
+
+void YC_adc_init()
+{
+#ifdef  ADC_ENABLE
+	byte i;
+	
+	g_variable.battery_check_interval = BATTERY_CHECK_INTERVAL;
+	g_variable.battery_value_index = 0;
+	g_variable.battery_motion_check_interval = BATTERY_MOTION_CHECK_INTERVAL;
+	
+#ifdef ADC_TYPE_HVIN 	
+	for (i = 0; i < BAT_ARRAY_LEN; i++)
+	{
+		g_variable.battery_value[i] = INIT_BATTERY_VALUE;
+	}
+	g_variable.battery_level_full = (m_adc3vValue - m_adc0vBase)*LOW_BATTER_COEFFICIENT_3V7+m_adc0vBase;
+	g_variable.battery_level_low = (m_adc3vValue - m_adc0vBase)*LOW_BATTER_COEFFICIENT_3V2+m_adc0vBase;
+	g_variable.battery_level_shutdown = (m_adc3vValue - m_adc0vBase)*LOW_BATTER_COEFFICIENT_3V0+m_adc0vBase;
+#endif
+#ifdef ADC_TYPE_VINLPM
+		for (i = 0; i < BAT_ARRAY_LEN; i++)
+		{
+			g_variable.battery_value[i] = INIT_BATTERY_VALUE_VINLPM;
+		}
+		g_variable.battery_level_full = m_adc3vValue;
+		g_variable.battery_level_low = (m_adc3vValue - m_adc0vBase)*LOW_BATTER_COEFFICIENT_2V2+m_adc0vBase;
+		g_variable.battery_level_shutdown = (m_adc3vValue - m_adc0vBase)*LOW_BATTER_COEFFICIENT_2V0+m_adc0vBase;
+#endif
+#ifdef ADC_TYPE_GPIO
+	m_adc_channel = ADC_CHANNEL;
+	for (i = 0; i < BAT_ARRAY_LEN; i++)
+	{
+		g_variable.battery_value[i] = INIT_BATTERY_VALUE_GPIO;
+	}
+	g_variable.battery_level_full = (m_adc3vValue - m_adc0vBase)*LOW_BATTER_COEFFICIENT_1V5+m_adc0vBase;
+	g_variable.battery_level_low = (m_adc3vValue - m_adc0vBase)*LOW_BATTER_COEFFICIENT_1V1+m_adc0vBase;
+	g_variable.battery_level_shutdown = (m_adc3vValue - m_adc0vBase)*LOW_BATTER_COEFFICIENT_0V9+m_adc0vBase;
+#endif	
+#endif
+}
+
+void YC_adc_check() 
+{
+#ifdef  ADC_ENABLE
+	byte i;
+	ulong batValue = 0;
+
+	if(!m_adcCurrentValue)
+		return;
+
+	g_variable.battery_value[g_variable.battery_value_index++] = m_adcCurrentValue;
+	if (g_variable.battery_value_index >= BAT_ARRAY_LEN)
+		g_variable.battery_value_index = 0;
+	for (i = 0; i < BAT_ARRAY_LEN; i++)
+	{
+		batValue += g_variable.battery_value[i];
+	}
+	batValue = batValue/BAT_ARRAY_LEN;
+
+	if(batValue <= g_variable.battery_level_shutdown)
+		g_variable.battery_level_percentage = 0;
+	else	if(batValue >= g_variable.battery_level_full)
+		g_variable.battery_level_percentage = 100;
+	else	
+		g_variable.battery_level_percentage = (byte)(((batValue - g_variable.battery_level_shutdown)*100)/(g_variable.battery_level_full -g_variable.battery_level_shutdown) );
+	
+	if(g_variable.battery_value[0] < g_variable.battery_level_shutdown)
+	{
+		g_variable.battery_status = BAT_STATUS_SHUT_DOWN;
+	}
+	else
+	{
+		if (batValue < g_variable.battery_level_low)
+		{
+			g_variable.battery_status = BAT_STATUS_LOW;
+			if(!g_variable.g24_long_sleep_flag)
+			{
+			m_24g_enter_hibernate[0]	= 0x00;
+			m_24g_enter_hibernate[1]	= 0x48;
+			m_24g_enter_hibernate[2]	= 0x12;		// 100ms
+			m_24g_enter_hibernate[3]	= 0x00;
+			}
+		}
+		else
+		{
+			g_variable.battery_status = BAT_STATUS_NONE;
+			if(!g_variable.g24_long_sleep_flag)
+			{
+			m_24g_enter_hibernate[0]	= 0x00;
+			m_24g_enter_hibernate[1]	= 0x48;
+			m_24g_enter_hibernate[2]   = 0x5d;		// 510ms
+			m_24g_enter_hibernate[3]	= 0x00;
+			}
+		}
+	}
+#endif	
+}
+
+void YC_adc_motion_check_timer500ms()
+{
+#ifdef  ADC_ENABLE
+	byte i = 0;
+
+	if(ksSelMapCurr[i] == 0 && g_variable.battery_motion_check_interval)
+	{
+		g_variable.battery_motion_check_interval--;
+		if (g_variable.battery_motion_check_interval == 0)
+			g_variable.battery_status = BAT_STATUS_NONE;
+		else
+			YC_adc_check_timer500ms();
+	}
+	
+
+#endif	
+}
+
+void YC_adc_check_timer500ms()
+{
+#ifdef  ADC_ENABLE
+
+	// adc check timer	
+	if (g_variable.battery_check_interval)
+	{
+		g_variable.battery_check_interval--;
+		if (g_variable.battery_check_interval == 0)
+		{
+			g_variable.battery_check_interval = BATTERY_CHECK_INTERVAL;
+			YC_adc_check();
+		}
+	}
+#endif	
+}
+
+
Index: c51/bluetooth.h
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/bluetooth.h	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/bluetooth.h	(working copy)
@@ -0,0 +1,31 @@
+#ifndef _BLUETOOTH_H
+#define _BLUETOOTH_H
+#include "common.h"
+
+
+#define BLE_FAST_CONNECT_ENABLE
+
+#define TYPE_BLE			0x01
+#define TYPE_BT			0x02
+#define TYPE_24G			0x03
+
+
+void YC_load_record_list(byte index);
+void YC_store_record_list(byte link_type,byte index);
+byte YC_check_is_connected();
+byte YC_check_need_reconnected();
+byte YC_cancel_reconnect();
+void YC_clear_reconnect_flag();
+byte YC_disconnect_all_link();
+byte YC_g24_mode_discovery();
+void YC_start_reconnect();
+void YC_update_eeprom_data();
+
+
+void YC_get_ble_ramdon_lap();
+void  YC_clear_BT_same_address_record();
+
+
+#endif /* _BLUETOOTH_H */
+
+
Index: c51/bluetooth.c
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/bluetooth.c	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/bluetooth.c	(working copy)
@@ -0,0 +1,223 @@
+#include "bluetooth.h"
+
+
+void YC_load_record_list(byte index)
+{
+	if (g_variable.recon_count == 0)
+		return;
+	g_variable.recon_count--;
+	ble_reconnect_flag = 0;
+	fast_connect_flag = 0;
+	if (bd_key_record_list[index].device_type == TYPE_BLE)		
+	{
+		xmemcpy(m_reconn_addr,bd_key_record_list[index].device_addr,6);
+		xmemcpy(m_le_ltk,bd_key_record_list[index].device_link_key,16);
+		xmemcpy(m_le_lap,bd_key_record_list[index].local_addr,6);
+		IPC_TxControlCmd(IPC_CMD_START_ADV_REC);		//ble reconnect
+		ble_reconnect_flag = 1;
+		g_variable.recon_count = 0;
+		m_ltk_exists = 1;
+	}
+	else		// ble fast connect
+	{
+		fast_connect_flag = 1;
+	#ifdef BLE_FAST_CONNECT_ENABLE
+			m_le_lap[0] = 0x0F;
+			m_le_lap[1] = 0x0F;
+			m_le_lap[2] = 0x0F;
+			m_le_lap[3] = 0x0F;
+			m_le_lap[4] = 0x0F;
+			m_le_lap[5] = 0x0F;
+			ble_fast_connect_flag =1;
+			IPC_TxControlCmd(IPC_CMD_START_ADV_REC);
+			m_link_key_exists = 1;
+	#endif
+
+	}	
+}
+
+
+
+void YC_store_record_list(byte link_type,byte index)
+{
+	if (link_type == TYPE_BLE) 
+	{
+		bd_key_record_list[index].device_type = TYPE_BLE;
+		xmemcpy(bd_key_record_list[index].device_addr,m_remote_le_addr,6);
+		xmemcpy(bd_key_record_list[index].device_link_key,m_le_ltk,16);
+		xmemcpy(bd_key_record_list[index].local_addr,m_le_lap,6);
+	}
+}
+
+
+byte YC_check_is_connected()
+{
+	if (g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTED
+		|| g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED)
+	{
+		return 1;
+	}
+	return 0;
+}
+
+byte YC_check_need_reconnected()
+{
+	byte return_val = 0;
+	 if (g_variable.ble_currentSubState == CHANGE_TO_BLE_SUB_PINCODE)
+		return return_val;
+	if ((m_ui_state_map & 0x0008) == 0x0008)		
+		return return_val;
+
+	if(g_variable.pairing_g24_timeout)
+		return return_val;
+
+	if (g_variable.ble_currentState == CHANGE_TO_BLE_DISCONNECT
+		&& g_variable.g24_currentState != CHANGE_TO_24G_CONNECTED
+	)
+	{
+		if(g_variable.recon_delay == 0)
+		{
+			g_variable.recon_delay = 10;
+			if ((g_variable.recon_count == 0)
+			&& (power_on_flag == 2))
+			{				
+				if (g_variable.current_device_num >= 1 && g_variable.current_device_num <= 3)
+				{
+					YC_key_action_handle(g_variable.current_device_num);
+				}
+				else
+				{
+					YC_key_action_handle(KEY_OPEN_24G);
+					return_val = 1;
+				}
+			}
+		}
+	}
+	else
+	{
+		g_variable.release_data = 0;
+		return_val = 1;
+	}
+	return return_val;
+}
+
+
+byte YC_cancel_reconnect()
+{
+	if (g_variable.ble_currentState == CHANGE_TO_BLE_DIRECT_ADV)
+	{
+		//stop adv
+		IPC_TxControlCmd(IPC_CMD_STOP_ADV);
+		return 1;
+	}
+	return 0;
+}
+
+
+void YC_clear_reconnect_flag()  
+{
+	g_variable.recon_count = 0;
+	ble_reconnect_flag = 0;
+}
+
+
+byte YC_disconnect_all_link()
+{
+	if (g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTED 
+		||g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTING)
+	{
+		IPC_TxControlCmd(IPC_CMD_LE_DISCONNECT);
+		return 1;
+	}
+	if (g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED 
+		||g_variable.g24_currentState == CHANGE_TO_24G_CONNECTING)
+	{
+		IPC_TxControlCmd(IPC_CMD_STOP_24G);
+		return 1;
+	}
+	return 0;
+}
+
+byte YC_g24_mode_discovery()
+{
+	if (g_variable.last_device_num == 0xfe ||g_variable.last_device_num == 0x00)
+	{
+		IPC_TxControlCmd(IPC_CMD_STOP_24G);
+		return 1;
+	}
+	return 0;
+}
+
+
+
+void YC_start_reconnect()
+{
+	power_on_flag = 2;
+	IIC_Read(EEPROM_RECON_INFO_BASE ,sizeof(BD_KEY_RECORD)*3, (byte *)bd_key_record_list);
+	Delay1ms(10);
+	IIC_Read(EEPROM_RECON_INFO_BASE_6+2,4 , (byte *)m_24g_addr);
+	Delay1ms(10);
+	IIC_Read(EEPROM_RECON_INFO_G24_FN_LOCK ,1 ,(byte *)&fn_lock_flag);
+	Delay1ms(10);
+	IIC_Read(EEPROM_RECON_INFO_G24_SYTEM_MODE ,1 ,(byte *)&g_variable.system_mode);
+	Delay1ms(10);
+	
+	if (g_variable.current_device_num <= 3 && g_variable.current_device_num >= 1)
+	{
+		g_variable.system_mode = bd_key_record_list[g_variable.current_device_num - 1].system_mode;
+		fn_lock_flag = bd_key_record_list[g_variable.current_device_num - 1].fn_lock; 
+		YC_key_action_handle(g_variable.current_device_num);
+	}
+	else	
+	{	
+		YC_key_action_handle(KEY_START_24G);
+	}
+	if(fn_lock_flag > 1)
+		fn_lock_flag = 0;
+	if(g_variable.system_mode > OSMODE_IOS)
+	{
+		g_variable.system_mode = OSMODE_WINDOWS;
+	}	
+}
+
+
+
+void YC_get_ble_ramdon_lap()		
+{
+	IIC_Read(EEPROM_RECON_INFO_RAMDON_LE_LAP1 ,2 ,(byte *)&g_variable.ble_ramdon_lap1);
+	g_variable.ble_ramdon_lap1++;
+	g_variable.ble_ramdon_lap2++;
+	m_le_lap[1] = g_variable.ble_ramdon_lap1;
+	m_le_lap[2] = g_variable.ble_ramdon_lap2;
+	m_le_lap[3] = le_lap_temp[0];
+	m_le_lap[4] = le_lap_temp[1];
+	m_le_lap[5] = le_lap_temp[2];
+}
+
+
+
+void YC_update_eeprom_data()
+{
+	if (g_variable.update_eeprom_flag)				//bt3.0  bt4.2 record information save
+	{
+		if (g_variable.update_eeprom_flag != EEPROM_STORE_TYPE_NORMAL)
+			Delay1ms(200);
+		GPIO_Setout(EEPROM_WP_GPIO,0);
+		if (g_variable.update_eeprom_flag == EEPROM_STORE_TYPE_G24)
+		{
+			IIC_WriteBlock(EEPROM_RECON_INFO_BASE_6+2,4 , (byte *)m_24g_addr);
+			IIC_WriteBlock(EEPROM_RECON_INFO_G24_SYTEM_MODE ,1 ,(byte *)&g_variable.system_mode);
+			IIC_WriteBlock(EEPROM_RECON_INFO_G24_FN_LOCK ,1 ,(byte *)&fn_lock_flag);
+		}	
+		else if (g_variable.update_eeprom_flag == EEPROM_STORE_TYPE_BT)
+			IIC_WriteBlock(EEPROM_RECON_INFO_BASE ,(sizeof(BD_KEY_RECORD)*3) , (byte *)&bd_key_record_list);
+		
+		IIC_WriteBlock(EEPROM_RECON_INFO_LAST_DEVICE ,1 ,(byte *)&g_variable.last_device_num);
+		IIC_WriteBlock(EEPROM_RECON_INFO_RAMDON_LE_LAP1 ,2 ,(byte *)&g_variable.ble_ramdon_lap1);
+
+		GPIO_Setout(EEPROM_WP_GPIO,1);
+		Delay1ms(10);
+		g_variable.update_eeprom_flag = 0;
+	}
+}
+
Index: c51/btreg.h
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/btreg.h	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/btreg.h	(working copy)
@@ -0,0 +1,1150 @@
+#ifndef _BT_REG_H_
+#define _BT_REG_H_
+#define	mem_le_adv_transmit                     	0x0000
+#define	mem_le_adv_waitcnt                      	0x0001
+#define	mem_le_adv_rcv                          	0x0002
+#define	mem_le_req_rcv                          	0x0003
+#define	mem_le_scanrsp_rcv                      	0x0004
+#define	mem_le_conn_rcv                         	0x0005
+#define	mem_inquiryscan_waitcnt                 	0x0006
+#define	mem_inquiryscan_rcvcnt                  	0x0007
+#define	mem_pagescan_waitcnt                    	0x0008
+#define	mem_pagescan_rcvcnt                     	0x0009
+#define	mem_pagescan_rcvfhscnt                  	0x000a
+#define	mem_slave_rcvcnt                        	0x000b
+#define	mem_page_transmit                       	0x000c
+#define	mem_page_rcv                            	0x000d
+#define	mem_page_rcv_fhs                        	0x000e
+#define	mem_master_rcvcnt                       	0x000f
+#define	mem_fhs_wait_counter                    	0x0010
+#define	mem_newconnto_counter                   	0x0011
+#define	mem_inquiry_transmit                    	0x0012
+#define	mem_inquiry_rcv                         	0x0013
+#define	mem_fw_ver                              	0x0014
+#define	mem_current_context                     	0x0015
+#define	mem_le_ch_mapped                        	0x0016
+#define	mem_last_freq                           	0x0017
+#define	mem_rssi                                	0x0018
+#define	mem_rx_type                             	0x0019
+#define	mem_rx_hec_err                          	0x001a
+#define	mem_rx_crc_err                          	0x001c
+#define	mem_context_ptr                         	0x001e
+#define	mem_display                             	0x0020
+#define	mem_bcd                                 	0x0028
+#define	mem_state                               	0x0030
+#define	mem_mode                                	0x0031
+#define	mem_tsniff                              	0x0032
+#define	mem_sniff_anchor                        	0x0034
+#define	mem_clk_offset                          	0x0038
+#define	mem_rx_window                           	0x003e
+#define	mem_plap                                	0x0040
+#define	mem_puap                                	0x0043
+#define	mem_pnap                                	0x0044
+#define	mem_conn_handle                         	0x0046
+#define	mem_arq                                 	0x0047
+#define	mem_lmp_to_send                         	0x0048
+#define	mem_lmi_opcode                          	0x0049
+#define	mem_lmo_reason                          	0x004a
+#define	mem_op                                  	0x004b
+#define	mem_state_map                           	0x004c
+#define	mem_supervision_timer                   	0x004d
+#define	mem_supervision_to                      	0x0051
+#define	mem_name_offset                         	0x0053
+#define	mem_key_size                            	0x0054
+#define	mem_conn_sm                             	0x0055
+#define	mem_aco                                 	0x0056
+#define	mem_kc                                  	0x0062
+#define	mem_conn_timer                          	0x0072
+#define	mem_sniff_attempt                       	0x0073
+#define	mem_sniff_timeout                       	0x0074
+#define	mem_dsniff                              	0x0075
+#define	mem_amaddr                              	0x0077
+#define	mem_lmo_opcode1                         	0x0078
+#define	mem_lmi_opcode1                         	0x0079
+#define	mem_lmo_reason1                         	0x007a
+#define	mem_lmo_tid1                            	0x007b
+#define	mem_lmo_opcode2                         	0x007c
+#define	mem_lmi_opcode2                         	0x007d
+#define	mem_lmo_reason2                         	0x007e
+#define	mem_lmo_tid2                            	0x007f
+#define	mem_hci_version                         	0x0080
+#define	mem_acl_pktlen                          	0x0083
+#define	mem_sco_pktlen                          	0x0085
+#define	mem_acl_pktcnt                          	0x0086
+#define	mem_sco_pktcnt                          	0x0088
+#define	mem_current_sniff_attempt               	0x008a
+#define	mem_current_sniff_timeout               	0x008b
+#define	mem_nfreq_index_inq                     	0x008c
+#define	mem_nfreq_index_page                    	0x008d
+#define	mem_ninqy_index                         	0x008e
+#define	mem_fhs_misc                            	0x008f
+#define	mem_tx_lch                              	0x0090
+#define	mem_tx_len                              	0x0091
+#define	mem_subsniff_instant                    	0x0093
+#define	mem_subsniff_rate                       	0x0097
+#define	mem_subsniff_tcmax                      	0x0098
+#define	mem_subsniff_tsniff                     	0x009a
+#define	mem_lpm_adjust                          	0x009b
+#define	mem_sync_clke                           	0x009c
+#define	mem_lpm_current_mult                    	0x00a2
+#define	mem_gpio_wakeup_low                     	0x00a3
+#define	mem_gpio_wakeup_high                    	0x00a7
+#define	mem_air_mode                            	0x00ab
+#define	mem_sco_asso_handle                     	0x00ac
+#define	mem_sco_handle                          	0x00ad
+#define	mem_esco_desco                          	0x00af
+#define	mem_esco_type                           	0x00b0
+#define	mem_neogotiation_state                  	0x00b1
+#define	mem_saved_amaddr                        	0x00b2
+#define	mem_esco_arq                            	0x00b3
+#define	mem_esco_saved_arq                      	0x00b4
+#define	mem_sco_obuf                            	0x00b5
+#define	mem_sco_ibuf                            	0x00d3
+#define	mem_sco_poll                            	0x00f1
+#define	mem_npage_index                         	0x00f2
+#define	mem_page_mode                           	0x00f3
+#define	mem_page_clk                            	0x00f4
+#define	mem_tst_pktcnt_sync                     	0x00f8
+#define	mem_tst_pktcnt_hec                      	0x00fa
+#define	mem_tst_pktcnt_crc                      	0x00fc
+#define	mem_tst_pktcnt_dmh                      	0x00fe
+#define	mem_tmp_buffer_head                     	0x0100
+#define	mem_tmp_buffer                          	0x0103
+#define	mem_tester_emulate                      	0x0153
+#define	mem_temp_payload                        	0x0154
+#define	test_mode_scenario                      	0x0154
+#define	test_mode_hopping_mode                  	0x0155
+#define	test_mode_tx_freq                       	0x0156
+#define	test_mode_rx_freq                       	0x0157
+#define	test_mode_power_mode                    	0x0158
+#define	test_mode_poll_period                   	0x0159
+#define	test_mode_packet_type                   	0x015a
+#define	test_mode_data_length                   	0x015b
+#define	mem_test_mode_old_debug_config          	0x015d
+#define	mem_tester_cnt                          	0x015e
+#define	mem_temp_am_addr                        	0x015f
+#define	mem_temp_arq                            	0x0160
+#define	mem_pdatatemp                           	0x0161
+#define	mem_len                                 	0x0169
+#define	mem_clkn_bt                             	0x016b
+#define	mem_clke_bt                             	0x016f
+#define	mem_dpll_clkn                           	0x0173
+#define	mem_connection_options                  	0x0177
+#define	mem_nameres_cnt                         	0x0178
+#define	mem_txptr                               	0x0179
+#define	mem_slot_offset                         	0x017b
+#define	extm_fhs_misc                           	0x017d
+#define	extm_newconn_am_addr                    	0x017e
+#define	extm_class                              	0x017f
+#define	extm_lap                                	0x0182
+#define	extm_uap                                	0x0185
+#define	extm_nap                                	0x0186
+#define	mem_debug_config                        	0x0189
+#define	mem_lch_code                            	0x018a
+#define	mem_fhs_am_addr                         	0x018b
+#define	mem_dpll_error                          	0x018c
+#define	mem_bdaddr_list_buff                    	0x018e
+#define	mem_select_list_item                    	0x01b2
+#define	mem_temp_reconn_record                  	0x01b3
+#define	mem_record_bt_mode                      	0x01b3
+#define	mem_temp_lap                            	0x01b4
+#define	mem_list_item_ptr                       	0x01ba
+#define	mem_eir                                 	0x01bc
+#define	mem_ucode_status                        	0x0220
+#define	mem_otp_ucode_flag                      	0x0221
+#define	mem_spid_tbuf                           	0x0223
+#define	mem_iicd_tbuf                           	0x0224
+#define	mem_addr_hi                             	0x0224
+#define	mem_addr_mi                             	0x0225
+#define	mem_addr_lo                             	0x0226
+#define	mem_iicd_addr                           	0x0227
+#define	mem_spid_rbuf                           	0x0228
+#define	mem_ucode_buf                           	0x022c
+#define	mem_ucode_len                           	0x022e
+#define	mem_sched_addr                          	0x0230
+#define	mem_ucode_ptr                           	0x0232
+#define	mem_ucode_keybuf                        	0x0234
+#define	mem_check_plap_temp                     	0x0244
+#define	mem_sensor_id                           	0x0256
+#define	mem_reconnect_flag                      	0x0257
+#define	mem_switch_fail_master_count            	0x0258
+#define	mem_app_evt_timer_count                 	0x0259
+#define	mem_dongle_count                        	0x025a
+#define	mem_le_addr_slave1                      	0x025b
+#define	mem_le_addr_slave2                      	0x0261
+#define	mem_le_peer_state                       	0x0267
+#define	mem_app_peer_addr                       	0x0268
+#define	mem_dongle_peers                        	0x026e
+#define	mem_dongle_pairing_cnt                  	0x026f
+#define	mem_dongle_signature                    	0x0270
+#define	mem_h5rx_ackcnt                         	0x0272
+#define	mem_check_err_acl_cont                  	0x0273
+#define	mem_rp_packets                          	0x0274
+#define	mem_packet_type                         	0x0275
+#define	mem_hci_sniff_conn_handle               	0x0277
+#define	mem_hci_sniff_max_interval              	0x0279
+#define	mem_hci_sniff_min_interval              	0x027b
+#define	mem_hci_sniff_attempt                   	0x027d
+#define	mem_hci_sniff_timeout                   	0x027f
+#define	mem_voice_setting                       	0x0281
+#define	mem_retransmission_effort               	0x0283
+#define	mem_sco_ptype                           	0x0284
+#define	mem_extm_uap_restore                    	0x0286
+#define	mem_h5rx_rptr                           	0x0289
+#define	mem_h5rx_ack                            	0x028b
+#define	mem_h5tx_ack                            	0x028c
+#define	mem_h5tx_rptr                           	0x028d
+#define	mem_h5tx_wptr                           	0x028f
+#define	mem_h5tx_free                           	0x0291
+#define	mem_h5rx_tmp                            	0x0293
+#define	mem_h5tx_seq                            	0x0294
+#define	mem_hci_acl_queue_wptr                  	0x0295
+#define	mem_hci_acl_queue_rptr                  	0x0297
+#define	mem_hci_acl_queue_end                   	0x0299
+#define	mem_hci_acl_queue_wcnt                  	0x029b
+#define	mem_hci_acl_cnt                         	0x029c
+#define	mem_hci_acl_tx_trigger_wptr             	0x029d
+#define	mem_ucode_id_local                      	0x029f
+#define	mem_temp                                	0x02a0
+#define	mem_timeup                              	0x02a8
+#define	mem_rega                                	0x02ac
+#define	mem_regb                                	0x02b0
+#define	mem_regc                                	0x02b4
+#define	mem_contr                               	0x02b7
+#define	mem_contw                               	0x02b9
+#define	mem_ucode_id_remote                     	0x02bb
+#define	mem_check_sum                           	0x02bc
+#define	mem_ucode_temp                          	0x02bd
+#define	mem_ucode_temp1                         	0x02be
+#define	mem_lock_in_enc                         	0x02bf
+#define	mem_hci_disconn_reason                  	0x02c0
+#define	mem_hci_curr_len                        	0x02c1
+#define	mem_hci_curr_target                     	0x02c2
+#define	mem_l2cap_mem_start                     	0x02c4
+#define	mem_l2cap_rxbuff1_len                   	0x02c4
+#define	mem_l2cap_rxbuff2_len                   	0x02c6
+#define	mem_l2cap_rxbuff_new                    	0x02c8
+#define	mem_l2cap_rxbuff_inuse                  	0x02ca
+#define	mem_l2cap_payload_ptr                   	0x02cb
+#define	mem_l2cap_rx_pkt_length                 	0x02cd
+#define	mem_l2cap_rx_cid                        	0x02cf
+#define	mem_l2cap_rx_done                       	0x02d1
+#define	mem_l2cap_signal_tx_buff_ptr            	0x02d2
+#define	mem_l2cap_signal_tx_payload_ptr         	0x02d4
+#define	mem_l2cap_signal_tx_length              	0x02d6
+#define	mem_sdp_tx_buff_ptr                     	0x02d8
+#define	mem_sdp_tx_payload_ptr                  	0x02da
+#define	mem_sdp_tx_pkt_length                   	0x02dc
+#define	mem_rfcomm_tx_buff_ptr                  	0x02de
+#define	mem_rfcomm_tx_payload_ptr               	0x02e0
+#define	mem_rfcomm_tx_pkt_length                	0x02e2
+#define	memL2CAP_T1                             	0x02e4
+#define	mem_CONTROL_tasks                       	0x02e6
+#define	mem_send_config_req                     	0x02e7
+#define	mem_config_identifier                   	0x02e8
+#define	mem_config_req_dest_CID                 	0x02e9
+#define	mem_rfcomm_malloc_fail_flag             	0x02eb
+#define	mem_message_to_uppersm                  	0x02ec
+#define	mem_upper_sm_remote_page                	0x02ed
+#define	mem_upper_sm_reconn                     	0x02ee
+#define	mem_upper_sm_ss                         	0x02ef
+#define	mem_tx_malloc_log                       	0x02f0
+#define	mem_l2cap_mem_end                       	0x0330
+#define	mem_scid                                	0x0330
+#define	mem_cmd_length                          	0x0332
+#define	mem_tt2                                 	0x0334
+#define	mem_tt3                                 	0x0336
+#define	mem_id                                  	0x0338
+#define	mem_psm                                 	0x033a
+#define	mem_l2cap_sdpres_delay_time             	0x033c
+#define	mem_le_rxbuf                            	0x0340
+#define	mem_le_mic                              	0x0378
+#define	mem_le_peer_mic                         	0x037c
+#define	mem_le_skdm                             	0x0380
+#define	mem_le_skds                             	0x0388
+#define	mem_le_peer_ltk                         	0x0390
+#define	mem_le_my_ltk                           	0x03a0
+#define	mem_le_mrand                            	0x03b0
+#define	mem_le_state                            	0x03c0
+#define	mem_le_mode                             	0x03c1
+#define	mem_le_tsniff                           	0x03c2
+#define	mem_le_anchor                           	0x03c4
+#define	mem_le_clk_offset                       	0x03c8
+#define	mem_le_receive_window                   	0x03ce
+#define	mem_le_plap                             	0x03d0
+#define	mem_le_conn_handle                      	0x03d6
+#define	mem_le_arq                              	0x03d7
+#define	mem_le_ch                               	0x03d8
+#define	mem_le_hop                              	0x03d9
+#define	mem_le_event_count                      	0x03da
+#define	mem_le_supervision_timer                	0x03dc
+#define	mem_le_instant                          	0x03e0
+#define	mem_le_channels                         	0x03e2
+#define	mem_le_conn_sm                          	0x03e3
+#define	mem_le_op                               	0x03e4
+#define	mem_le_access                           	0x03e5
+#define	mem_le_crcinit                          	0x03e9
+#define	mem_le_window_size                      	0x03ec
+#define	mem_le_slave_latency                    	0x03ed
+#define	mem_le_superto                          	0x03ef
+#define	mem_le_channel_map                      	0x03f1
+#define	mem_le_no_using                         	0x03f6
+#define	mem_le_peer_sca                         	0x03f8
+#define	mem_le_att_opcode                       	0x03f9
+#define	mem_le_att_handle                       	0x03fa
+#define	mem_le_err_code                         	0x03fc
+#define	mem_le_sk                               	0x03fd
+#define	mem_le_testtype                         	0x040d
+#define	mem_le_test_sync                        	0x040e
+#define	mem_le_test_pcnt                        	0x0410
+#define	mem_le_rxon_ts                          	0x0412
+#define	mem_le_rx_ll_opcode                     	0x0418
+#define	mem_le_notify_attr_start                	0x0419
+#define	mem_le_notify_len                       	0x041b
+#define	mem_cmd_le_create_conn                  	0x041c
+#define	mem_le_adv_temp                         	0x041d
+#define	mem_24g_id                              	0x0431
+#define	mem_lmo_header_length                   	0x0432
+#define	mem_lmo_header_opcode                   	0x0433
+#define	mem_lmo_payload                         	0x0434
+#define	mem_lmi_accepted_opcode                 	0x0445
+#define	mem_disconn_reason_send                 	0x0446
+#define	mem_tx_fixed_freq                       	0x0447
+#define	mem_rx_fixed_freq                       	0x0448
+#define	mem_ext_features_page                   	0x0449
+#define	mem_lmpext_ssp_enable                   	0x044a
+#define	mem_remote_sppcap                       	0x044c
+#define	mem_lmp_conn_state                      	0x044d
+#define	mem_soft_timer                          	0x044e
+#define	mem_pincode_state                       	0x0450
+#define	mem_sres_tid                            	0x0451
+#define	mem_accptsco_tid                        	0x0452
+#define	mem_auth_enable                         	0x0453
+#define	mem_wait_encryption                     	0x0454
+#define	mem_sniff_payload                       	0x0455
+#define	mem_aurand_send_delay_time              	0x0465
+#define	mem_module_temp_len                     	0x0469
+#define	mem_init_cnt                            	0x046b
+#define	mem_prcp_data                           	0x046d
+#define	mem_prcp                                	0x0481
+#define	mem_prcp_tx_len                         	0x0482
+#define	rx_buf_data_ptr                         	0x0483
+#define	memRemoteRPNBitRate                     	0x0485
+#define	memRemotePRNDataBits                    	0x0486
+#define	memRemotePRNStopBit                     	0x0487
+#define	memRemotePRNParity                      	0x0488
+#define	memRemotePRNFlowControl                 	0x0489
+#define	memRemotePRNXon                         	0x048a
+#define	memRemotePRNXoff                        	0x048b
+#define	mem_mod2div_temp                        	0x048c
+#define	mem_contw_temp                          	0x048f
+#define	mem_attrib_list                         	0x0491
+#define	mem_current_adss                        	0x0493
+#define	mem_current_channel                     	0x0494
+#define	mem_current_frame_type                  	0x0495
+#define	mem_current_fcs                         	0x0496
+#define	mem_current_length                      	0x0497
+#define	mem_rfcomm_uih_payload_ptr              	0x0499
+#define	mem_uih_cmd_type                        	0x049b
+#define	mem_uih_length                          	0x049c
+#define	mem_param_payload_ptr                   	0x049e
+#define	mem_ms_param                            	0x04a0
+#define	mem_pn_credit_flow_type_info            	0x04a1
+#define	mem_pn_priority                         	0x04a2
+#define	mem_pn_acknowledg_timer                 	0x04a3
+#define	mem_pn_max_retrans                      	0x04a4
+#define	mem_rfcomm_send_adss                    	0x04a5
+#define	mem_rfcomm_send_frame_type              	0x04a6
+#define	mem_rfcomm_send_fcs                     	0x04a7
+#define	mem_rfcomm_send_offset                  	0x04a8
+#define	mem_sdp_mem_start                       	0x04a9
+#define	mem_uuid_search_pat                     	0x04a9
+#define	mem_sdp_continue_byte                   	0x04ad
+#define	mem_sdp_pduid                           	0x04af
+#define	mem_sdp_transactionid                   	0x04b0
+#define	mem_sdp_attribute_maxbyte               	0x04b2
+#define	mem_sdp_record_maxcnt                   	0x04b4
+#define	mem_sdp_error_code                      	0x04b6
+#define	mem_sdp_record_handle                   	0x04be
+#define	mem_sdp_search_failed                   	0x04c2
+#define	mem_sdp_LACAP_found                     	0x04c3
+#define	mem_sdp_RFCOMM_found                    	0x04c4
+#define	mem_handle_list                         	0x04c5
+#define	mem_handle_humber                       	0x04dd
+#define	mem_sdp_mem_end                         	0x04de
+#define	mem_rxbuf                               	0x04de
+#define	mem_random_number                       	0x04ef
+#define	mem_round_key                           	0x04ff
+#define	mem_kinit                               	0x050f
+#define	mem_input_store                         	0x051f
+#define	mem_x                                   	0x052f
+#define	mem_y                                   	0x053f
+#define	mem_y15                                 	0x054e
+#define	mem_pin_length                          	0x054f
+#define	mem_pin                                 	0x0550
+#define	mem_key_store                           	0x0560
+#define	mem_key_store_end                       	0x0571
+#define	memp_ar_key                             	0x0572
+#define	memp_ar_input                           	0x0574
+#define	mem_ar_hround                           	0x0576
+#define	mem_ec_infinite                         	0x0580
+#define	mem_ec_loopc                            	0x0581
+#define	memdat                                  	0x0582
+#define	mem_ax                                  	0x0582
+#define	mem_ay                                  	0x059a
+#define	mem_az                                  	0x05b2
+#define	mem_bx                                  	0x05ca
+#define	mem_by                                  	0x05e2
+#define	mem_bz                                  	0x05fa
+#define	mem_cx                                  	0x0612
+#define	mem_cy                                  	0x062a
+#define	mem_cy5                                 	0x0641
+#define	mem_cz                                  	0x0642
+#define	mem_k                                   	0x065a
+#define	mem_align                               	0x0672
+#define	mem_tmp1                                	0x0682
+#define	memahbak                                	0x0682
+#define	mem_tmp5                                	0x069a
+#define	memahsave                               	0x06a2
+#define	mem_tmp2                                	0x06b2
+#define	memahsave_end                           	0x06c2
+#define	mem_addr_padding                        	0x06c2
+#define	mem_addr_value                          	0x06c3
+#define	mem_tmp3                                	0x06ca
+#define	mem_t1                                  	0x06ca
+#define	mem_addr_value_end                      	0x06cf
+#define	mem_addr_iocap_end                      	0x06d2
+#define	mem_tmp0                                	0x06e2
+#define	mem_t0                                  	0x06e2
+#define	mem_tmp0a                               	0x06ea
+#define	mem_t2                                  	0x06fa
+#define	mem_t3                                  	0x0712
+#define	mem_t7                                  	0x072a
+#define	mem_p                                   	0x0742
+#define	mem_a                                   	0x075a
+#define	mem_b                                   	0x0772
+#define	mem_gx                                  	0x078a
+#define	mem_gy                                  	0x07a2
+#define	memh0                                   	0x07ba
+#define	mem_sp_state_start                      	0x07da
+#define	mem_sp_state                            	0x07da
+#define	mem_master_sp_state                     	0x07db
+#define	mem_sp_flag                             	0x07dc
+#define	mem_master_sp_flag                      	0x07dd
+#define	mem_sp_calc                             	0x07de
+#define	mem_sp_dh_ready                         	0x07df
+#define	mem_sp_localsm                          	0x07e0
+#define	mem_pairing_auth                        	0x07e1
+#define	mem_sp_flag_start                       	0x07e2
+#define	mem_sp_local_key_send_count             	0x07e2
+#define	mem_sp_remote_key_recv_count            	0x07e3
+#define	mem_sp_remote_key_invalid               	0x07e4
+#define	mem_sp_dhkey_invalid                    	0x07e5
+#define	mem_sp_iocap_local                      	0x07e6
+#define	mem_sp_iocap_remote                     	0x07e9
+#define	mem_sp_gkey                             	0x07ec
+#define	mem_sp_pubkey_remote                    	0x07f0
+#define	mem_sp_pubkey_remote_x                  	0x07f0
+#define	mem_sp_pubkey_remote_x_end              	0x0808
+#define	mem_sp_pubkey_remote_y                  	0x0808
+#define	mem_sp_dhkey                            	0x0820
+#define	mem_sp_dhkey_end                        	0x0838
+#define	mem_sp_random_local                     	0x0838
+#define	mem_sp_random_local_end                 	0x0848
+#define	mem_sp_random_remote                    	0x0848
+#define	mem_sp_random_remote_end                	0x0858
+#define	memresult                               	0x0858
+#define	mem_sp_calc_result                      	0x0858
+#define	memh                                    	0x0858
+#define	memg                                    	0x085c
+#define	memf                                    	0x0860
+#define	meme                                    	0x0864
+#define	mem_sp_calc_result_high                 	0x0868
+#define	memd                                    	0x0868
+#define	memc                                    	0x086c
+#define	memb                                    	0x0870
+#define	mema                                    	0x0874
+#define	mem_sp_check_result                     	0x0878
+#define	mem_sp_confirm_remote                   	0x0888
+#define	mem_sp_prarm_stack                      	0x0898
+#define	mem_UI_data_txbuff_length               	0x08a8
+#define	mem_ipc_skip_continue_proc              	0x08aa
+#define	mem_ui_timer_temp                       	0x08ab
+#define	mem_ipc_rega_temp                       	0x08ab
+#define	mem_usb_status                          	0x08af
+#define	mem_usb_fifo_empty                      	0x08b0
+#define	mem_usb_read_len                        	0x08b1
+#define	mem_usb_rxbuf                           	0x08b2
+#define	mem_usb_cnt                             	0x08f2
+#define	mem_usb_tx_enable                       	0x08f4
+#define	mem_usb_tx_count                        	0x08f5
+#define	mem_usb_set_protocol_count              	0x08f6
+#define	mem_usb_desc                            	0x08f7
+#define	mem_usb_state                           	0x08f8
+#define	mem_usb_idle_cnt                        	0x08f9
+#define	mem_usb_idle_timeout                    	0x08fb
+#define	mem_usb_trig_timeout                    	0x08fd
+#define	mem_usb_setup                           	0x08ff
+#define	mem_usb_setup_bmRequestType             	0x08ff
+#define	mem_usb_setup_bRequest                  	0x0900
+#define	mem_usb_setup_bValue                    	0x0901
+#define	mem_usb_setup_bValueH                   	0x0902
+#define	mem_usb_setup_wIndex                    	0x0903
+#define	mem_usb_setup_bLength                   	0x0905
+#define	mem_usb_setup_bLengthH                  	0x0906
+#define	mem_usb0_setup                          	0x0907
+#define	mem_bufptr                              	0x090f
+#define	mem_remain                              	0x0911
+#define	mem_devicedesc                          	0x0912
+#define	mem_hidreportdesc_kb                    	0x0926
+#define	mem_hidreportdesc_m                     	0x09ee
+#define	mem_confdesc                            	0x0ab6
+#define	mem_string0                             	0x0b1a
+#define	mem_string1                             	0x0b1f
+#define	mem_string2                             	0x0b3d
+#define	mem_string3                             	0x0b5b
+#define	mem_hold_contr                          	0x0b79
+#define	mem_hold_contw                          	0x0b7b
+#define	mem_fifo_temp                           	0x0b7d
+#define	mem_c51_flag                            	0x0b7e
+#define	mem_c51_lpm_lock                        	0x0b7f
+#define	mem_c51_wait_lpm                        	0x0b80
+#define	mem_wakup_from_power_flag               	0x0b81
+#define	mem_lmp_bb_disconnect_reason            	0x0b82
+#define	mem_c51_eeprom_buf                      	0x0b83
+#define	mem_c51_ipc_txbuf                       	0x0be7
+#define	mem_c51_ipc_rxbuf                       	0x0c4b
+#define	mem_c51_iicd_buf                        	0x0caf
+#define	mem_24g_rxbuf                           	0x0cb3
+#define	mem_24g_txbuf                           	0x0cd5
+#define	mem_24g_txpayload                       	0x0cf5
+#define	mem_24g_rxpayload                       	0x0d17
+#define	mem_24g_common_temp                     	0x0d37
+#define	mem_packet_length_temp                  	0x0d57
+#define	mem_le_cur_handle_start                 	0x0d58
+#define	mem_le_cur_handle_end                   	0x0d5a
+#define	mem_le_search_res                       	0x0d5c
+#define	mem_patch00                             	0x4000
+#define	mem_patch01                             	0x4001
+#define	mem_patch02                             	0x4002
+#define	mem_patch03                             	0x4003
+#define	mem_patch04                             	0x4004
+#define	mem_patch05                             	0x4005
+#define	mem_patch06                             	0x4006
+#define	mem_patch07                             	0x4007
+#define	mem_patch08                             	0x4008
+#define	mem_patch09                             	0x4009
+#define	mem_patch0a                             	0x400a
+#define	mem_patch0b                             	0x400b
+#define	mem_patch0c                             	0x400c
+#define	mem_patch0d                             	0x400d
+#define	mem_patch0e                             	0x400e
+#define	mem_patch0f                             	0x400f
+#define	mem_patch10                             	0x4010
+#define	mem_patch11                             	0x4011
+#define	mem_patch12                             	0x4012
+#define	mem_patch13                             	0x4013
+#define	mem_patch14                             	0x4014
+#define	mem_patch15                             	0x4015
+#define	mem_patch16                             	0x4016
+#define	mem_patch17                             	0x4017
+#define	mem_patch18                             	0x4018
+#define	mem_patch19                             	0x4019
+#define	mem_patch1a                             	0x401a
+#define	mem_patch1b                             	0x401b
+#define	mem_patch1c                             	0x401c
+#define	mem_patch1d                             	0x401d
+#define	mem_patch1e                             	0x401e
+#define	mem_patch1f                             	0x401f
+#define	mem_patch20                             	0x4020
+#define	mem_patch21                             	0x4021
+#define	mem_patch22                             	0x4022
+#define	mem_patch23                             	0x4023
+#define	mem_patch24                             	0x4024
+#define	mem_patch25                             	0x4025
+#define	mem_patch26                             	0x4026
+#define	mem_patch27                             	0x4027
+#define	mem_patch28                             	0x4028
+#define	mem_patch29                             	0x4029
+#define	mem_patch2a                             	0x402a
+#define	mem_patch2b                             	0x402b
+#define	mem_patch2c                             	0x402c
+#define	mem_patch2d                             	0x402d
+#define	mem_patch2e                             	0x402e
+#define	mem_patch2f                             	0x402f
+#define	mem_patch30                             	0x4030
+#define	mem_patch31                             	0x4031
+#define	mem_patch32                             	0x4032
+#define	mem_patch33                             	0x4033
+#define	mem_patch34                             	0x4034
+#define	mem_patch35                             	0x4035
+#define	mem_patch36                             	0x4036
+#define	mem_patch37                             	0x4037
+#define	mem_patch38                             	0x4038
+#define	mem_patch39                             	0x4039
+#define	mem_patch3a                             	0x403a
+#define	mem_patch3b                             	0x403b
+#define	mem_patch3c                             	0x403c
+#define	mem_patch3d                             	0x403d
+#define	mem_patch3e                             	0x403e
+#define	mem_patch3f                             	0x403f
+#define	mem_context                             	0x4040
+#define	mem_current_amaddr                      	0x4130
+#define	mem_lpm_mode                            	0x4131
+#define	mem_device_option                       	0x4132
+#define	mem_scan_mode                           	0x4133
+#define	mem_last_clkn                           	0x4134
+#define	mem_features                            	0x4138
+#define	mem_lap                                 	0x4140
+#define	mem_uap                                 	0x4143
+#define	mem_nap                                 	0x4144
+#define	mem_npage                               	0x4146
+#define	mem_glap                                	0x4147
+#define	mem_class                               	0x414a
+#define	mem_iscan_window                        	0x414d
+#define	mem_iscan_interval                      	0x414f
+#define	mem_pscan_window                        	0x4151
+#define	mem_pscan_interval                      	0x4153
+#define	mem_page_interval                       	0x4155
+#define	mem_page_window                         	0x4157
+#define	mem_page_to                             	0x4159
+#define	mem_inq_window                          	0x415b
+#define	mem_fcomp_mul                           	0x415d
+#define	mem_fcomp_div                           	0x415e
+#define	mem_rx_window_init                      	0x415f
+#define	mem_rx_window_sniff                     	0x4161
+#define	mem_rf_init_ptr                         	0x4163
+#define	mem_last_type                           	0x4165
+#define	mem_last_type_esco                      	0x4166
+#define	mem_last_type_saved                     	0x4167
+#define	mem_retransmission_cnt                  	0x4168
+#define	mem_next_btclk                          	0x416a
+#define	mem_seqi                                	0x416e
+#define	mem_rf_rccal                            	0x416f
+#define	mem_handle_num                          	0x4170
+#define	mem_max_slot                            	0x4171
+#define	mem_eir_enable                          	0x4172
+#define	mem_afh_instant                         	0x4173
+#define	mem_afh_error_total                     	0x4177
+#define	mem_afh_cfg                             	0x4179
+#define	mem_afh_new_mod                         	0x417a
+#define	mem_afh_map_lo                          	0x417b
+#define	mem_afh_map_hi                          	0x4180
+#define	mem_afh_used                            	0x4185
+#define	mem_afh_index                           	0x4186
+#define	mem_afh_map_new                         	0x4188
+#define	mem_afh_map                             	0x4193
+#define	mem_afh_timer                           	0x41e3
+#define	mem_afh_classify_channel_map            	0x41e7
+#define	mem_chip_functions                      	0x41f1
+#define	mem_lpm_wake_lock                       	0x41f3
+#define	mem_lpm_interval                        	0x41f5
+#define	mem_lpm_overhead                        	0x41f7
+#define	mem_lpm_hibernate_switch                	0x41f8
+#define	mem_esco_addr                           	0x41f9
+#define	mem_sniff_unint_lost                    	0x41fa
+#define	mem_ptt                                 	0x41fb
+#define	mem_sleep_counter                       	0x41fc
+#define	mem_sleep_counter_all                   	0x4200
+#define	mem_sleep_clkn                          	0x4204
+#define	mem_sniff_rcv                           	0x420a
+#define	mem_sniff_lost                          	0x420d
+#define	mem_clks_per_lpo                        	0x4210
+#define	mem_lpm_mult                            	0x4213
+#define	mem_lpm_mult_timeout                    	0x4214
+#define	mem_lpm_mult_cnt                        	0x4215
+#define	mem_lpm_config                          	0x4216
+#define	mem_lpm_xtalcnt                         	0x4219
+#define	mem_lpm_buckcnt                         	0x421a
+#define	mem_lpm_ldocnt                          	0x421b
+#define	mem_lpm_isogate                         	0x421c
+#define	mem_lpm_isogate_final                   	0x421d
+#define	mem_saved_gpio                          	0x421e
+#define	mem_saved_gsel                          	0x422e
+#define	mem_saved_mark                          	0x4231
+#define	mem_saved_spidctrl                      	0x4239
+#define	mem_patch_ptr                           	0x423a
+#define	mem_patch_len                           	0x423c
+#define	mem_timers                              	0x423e
+#define	mem_link_key_exists                     	0x425e
+#define	mem_link_key_eeprom_head                	0x425f
+#define	mem_link_key                            	0x4262
+#define	mem_hci_cmd                             	0x4272
+#define	mem_hci_conn_handle                     	0x4273
+#define	mem_hci_plap                            	0x4274
+#define	mem_hci_puap                            	0x4277
+#define	mem_hci_pnap                            	0x4278
+#define	mem_uartd_rxitems_got_data              	0x427a
+#define	mem_uartd_rxitems_threshold             	0x427b
+#define	mem_uartd_rx_timeout                    	0x427c
+#define	mem_app_state                           	0x427e
+#define	mem_app_handshake_flag                  	0x427f
+#define	mem_sniff_param_interval                	0x4280
+#define	mem_sniff_param_attempt                 	0x4282
+#define	mem_sniff_param_timeout                 	0x4284
+#define	mem_cb_check_wakelock                   	0x4286
+#define	mem_cb_before_hibernate                 	0x4288
+#define	mem_cb_before_lpm                       	0x428a
+#define	mem_cb_le_process                       	0x428c
+#define	mem_cb_bt_process                       	0x428e
+#define	mem_cb_idle_process                     	0x4290
+#define	mem_cb_bb_event_process                 	0x4292
+#define	mem_cb_discovry_timeout                 	0x4294
+#define	mem_cb_att_write                        	0x4296
+#define	mem_cb_update_notify_value              	0x4298
+#define	mem_device_nums                         	0x429a
+#define	mem_eeprom_base                         	0x429b
+#define	mem_unsniff2sniff_timer_count           	0x429d
+#define	mem_wake_up_delay_timer                 	0x429e
+#define	mem_app_connection_options              	0x429f
+#define	mem_app_disconn_reason                  	0x42a0
+#define	mem_app_disconn_reason_flag             	0x42a2
+#define	mem_at_using_flag                       	0x42a4
+#define	mem_lpm_delay_after_sniff               	0x42a5
+#define	mem_xrecord_mode                        	0x42a9
+#define	mem_eeprom_block_size                   	0x42aa
+#define	mem_baud                                	0x42ac
+#define	mem_hci_lt_rx_state                     	0x42ae
+#define	mem_l2cap_xmem_start                    	0x42af
+#define	mem_l2cap_tx_multi_offset               	0x42af
+#define	mem_sdp_remote_cid                      	0x42b1
+#define	mem_rfcomm_remote_cid                   	0x42b3
+#define	mem_hid_ctrl_remote_cid                 	0x42b5
+#define	mem_hid_int_remote_cid                  	0x42b7
+#define	mem_sdp_state                           	0x42b9
+#define	mem_rfcomm_state                        	0x42ba
+#define	mem_hid_control_state                   	0x42bb
+#define	mem_hid_interrupt_state                 	0x42bc
+#define	mem_spp_state                           	0x42bd
+#define	mem_ML2CAP_comm_id                      	0x42be
+#define	mem_used_map                            	0x42bf
+#define	mem_tx_fifo0                            	0x42c0
+#define	mem_tx_fifo0_map                        	0x42c0
+#define	mem_tx_fifo0_ptr                        	0x42c1
+#define	mem_tx_fifo1                            	0x42c3
+#define	mem_tx_fifo1_map                        	0x42c3
+#define	mem_tx_fifo1_ptr                        	0x42c4
+#define	mem_tx_fifo2                            	0x42c6
+#define	mem_tx_fifo2_map                        	0x42c6
+#define	mem_tx_fifo2_ptr                        	0x42c7
+#define	mem_tx_fifo3                            	0x42c9
+#define	mem_tx_fifo3_map                        	0x42c9
+#define	mem_tx_fifo3_ptr                        	0x42ca
+#define	mem_tx_fifo_end                         	0x42cc
+#define	mem_l2cap_lpm_txbuf                     	0x42cc
+#define	mem_l2cap_flow_ctrl_flag                	0x43cc
+#define	mem_l2cap_pending_item                  	0x43cd
+#define	mem_l2cap_xmem_end                      	0x43ce
+#define	mem_le_dsniff                           	0x43ce
+#define	mem_le_conn_interval                    	0x43d0
+#define	mem_le_scan_enable                      	0x43d2
+#define	mem_le_scan_interval                    	0x43d3
+#define	mem_le_scan_window                      	0x43d5
+#define	mem_le_adv_led                          	0x43d7
+#define	mem_le_adv_enable                       	0x43d8
+#define	mem_le_adv_data_len                     	0x43d9
+#define	mem_le_adv_data                         	0x43da
+#define	mem_le_scan_data_len                    	0x43f9
+#define	mem_le_scan_data                        	0x43fa
+#define	mem_le_name_len                         	0x4419
+#define	mem_le_name                             	0x441a
+#define	mem_le_led_on_time                      	0x442e
+#define	mem_le_new_map                          	0x442f
+#define	mem_le_new_param                        	0x4434
+#define	mem_le_new_window                       	0x4434
+#define	mem_le_new_offset                       	0x4435
+#define	mem_le_new_interval                     	0x4437
+#define	mem_le_new_latency                      	0x4439
+#define	mem_le_new_timeout                      	0x443b
+#define	mem_le_temp                             	0x443d
+#define	mem_le_txheader                         	0x443e
+#define	mem_le_txlen                            	0x443f
+#define	mem_le_txpayload                        	0x4440
+#define	mem_le_txcid                            	0x4442
+#define	mem_le_l2cap                            	0x4444
+#define	mem_le_l2cap_response                   	0x4445
+#define	mem_le_txbdy                            	0x4446
+#define	mem_le_pcnt_tx                          	0x4465
+#define	mem_le_pcnt_rx                          	0x446a
+#define	mem_le_last_mic                         	0x446f
+#define	mem_le_ivm                              	0x4473
+#define	mem_le_ivs                              	0x4477
+#define	mem_le_ltk                              	0x447b
+#define	mem_ltk_exists                          	0x448b
+#define	mem_le_rconfirm                         	0x448c
+#define	mem_le_srand                            	0x449c
+#define	mem_le_iat                              	0x44ac
+#define	mem_le_rat                              	0x44ad
+#define	mem_le_preq                             	0x44ae
+#define	mem_le_pres                             	0x44b5
+#define	mem_le_search_handle_start              	0x44bc
+#define	mem_le_search_handle_end                	0x44be
+#define	mem_le_att_offset                       	0x44c0
+#define	mem_le_search_att_type                  	0x44c0
+#define	mem_le_notify_handle                    	0x44c2
+#define	mem_le_uuid                             	0x44c4
+#define	mem_le_handle_data_len                  	0x44c6
+#define	mem_le_handle_data                      	0x44c7
+#define	mem_le_adv_param                        	0x44d7
+#define	mem_le_adv_interval_min                 	0x44d7
+#define	mem_le_adv_interval_max                 	0x44d9
+#define	mem_le_adv_type                         	0x44db
+#define	mem_le_adv_own_addr_type                	0x44dc
+#define	mem_le_adv_direct_addr_type             	0x44dd
+#define	mem_le_adv_direct_addr                  	0x44de
+#define	mem_le_adv_channel_map                  	0x44e4
+#define	mem_le_adv_filter_policy                	0x44e5
+#define	mem_le_conn_param                       	0x44e6
+#define	mem_le_conn_peer_addr_type              	0x44e6
+#define	mem_le_conn_peer_addr                   	0x44e7
+#define	mem_le_conn_own_addr_type               	0x44ed
+#define	mem_le_conn_interval_min                	0x44ee
+#define	mem_le_conn_interval_max                	0x44f0
+#define	mem_le_conn_latency                     	0x44f2
+#define	mem_le_conn_superto                     	0x44f4
+#define	mem_le_scan_params                      	0x44f6
+#define	mem_le_scan_type                        	0x44f6
+#define	mem_le_scan_own_addr_type               	0x44f7
+#define	mem_le_scan_filter_policy               	0x44f8
+#define	mem_le_lap                              	0x44f9
+#define	mem_le_uap                              	0x44fc
+#define	mem_le_nap                              	0x44fd
+#define	mem_le_xtype_fifo                       	0x44ff
+#define	mem_le_att_list                         	0x4504
+#define	mem_le_switch_send_data                 	0x46f8
+#define	mem_le_transmit_window                  	0x46f9
+#define	mem_lmp_version                         	0x46fd
+#define	mem_lmp_subversion                      	0x4700
+#define	mem_local_name_length                   	0x4702
+#define	mem_local_name                          	0x4703
+#define	mem_local_name2                         	0x4706
+#define	mem_local_name_end                      	0x4746
+#define	mem_unsniff2sniff_timer                 	0x4747
+#define	mem_switch_flag                         	0x4748
+#define	mem_eeprom_ota_base_addr                	0x4749
+#define	mem_pn_dlci                             	0x474b
+#define	mem_pn_max_frame_size                   	0x474c
+#define	memFCStemp1                             	0x474e
+#define	memFCStemp2                             	0x474f
+#define	memFCStemp3                             	0x4750
+#define	mem_rfcomm_initiator                    	0x4751
+#define	mem_remote_spp_channel                  	0x4752
+#define	mem_HIUfcs_SPP                          	0x4753
+#define	mem_HIUfcs_SPP_WCredits                 	0x4754
+#define	mem_rfcomm_send_more_pkt                	0x4755
+#define	mem_remote_credits                      	0x4756
+#define	mem_credit_given                        	0x4757
+#define	mem_ms_channel                          	0x4758
+#define	memui_uuid_table                        	0x4759
+#define	mem_all_uuid_16bits                     	0x475b
+#define	mem_all_uuid_128bits                    	0x4771
+#define	mem_sp_local_key_invalid                	0x4793
+#define	mem_sp_private_key                      	0x4794
+#define	mem_sp_pubkey_local                     	0x47ac
+#define	mem_sp_pubkey_local_x                   	0x47ac
+#define	mem_sp_pubkey_local_x_end               	0x47c4
+#define	mem_sp_pubkey_local_y                   	0x47c4
+#define	mem_ssp_enable                          	0x47dc
+#define	mem_ipc_lock_bt                         	0x47dd
+#define	mem_ipc_lock_c51                        	0x47de
+#define	mem_ipc_fifo_bt2c51                     	0x47df
+#define	mem_ipc_fifo_c512bt                     	0x47e4
+#define	mem_led_switch                          	0x47e9
+#define	mem_ui_button_timer                     	0x47ea
+#define	mem_ui_button_last_state                	0x47eb
+#define	mem_ui_timer_last_btclk                 	0x47ec
+#define	mem_discovery_timeout_timer_count       	0x47f0
+#define	mem_hid_handshake_timer_count           	0x47f2
+#define	memui_reconnect_mode                    	0x47f3
+#define	mem_ui_state_map                        	0x47f4
+#define	mem_ui_profile_supported                	0x47f6
+#define	mem_led_gpio                            	0x47f7
+#define	mem_led_dark_time                       	0x47f8
+#define	mem_led_light_time                      	0x47fa
+#define	mem_ui_button_timeout                   	0x47fc
+#define	mem_ui_button_gpio                      	0x47fd
+#define	mem_discovery_timeout                   	0x47fe
+#define	mem_ir_ptr                              	0x4800
+#define	mem_ir_type                             	0x4802
+#define	mem_ir_cmd                              	0x4803
+#define	mem_ir_play_count                       	0x4804
+#define	mem_ir_report_len                       	0x4805
+#define	mem_ir_pulse_zero                       	0x4807
+#define	mem_ir_pulse_one                        	0x4808
+#define	mem_ir_pulses                           	0x4809
+#define	mem_ir_sequence_len                     	0x4825
+#define	mem_ir_sequence                         	0x4826
+#define	mem_acl_credits                         	0x4800
+#define	mem_allow_switch                        	0x4802
+#define	mem_hci_acl_queue_start                 	0x4803
+#define	mem_hci_wake_clk                        	0x4807
+#define	mem_kb_state                            	0x4800
+#define	mem_kb_report_data                      	0x4802
+#define	mem_kb_keys                             	0x4808
+#define	mem_kb_rcv_led_data                     	0x4809
+#define	mem_kb_fast_wake_last                   	0x480a
+#define	mem_led_cap_gpio                        	0x480e
+#define	mem_led_num_gpio                        	0x480f
+#define	mem_led_scl_gpio                        	0x4810
+#define	mem_kb_map                              	0x4811
+#define	mem_kb_uuid_list                        	0x4811
+#define	mem_24g_paring_tx_power_param           	0x4a87
+#define	mem_5db_tx_power_param                  	0x4a91
+#define	mem_current_event                       	0x4a9b
+#define	mem_ipc_lock_rx_data_bt                 	0x4a9c
+#define	mem_ipc_lock_rx_data_c51                	0x4a9d
+#define	mem_ipc_lock_tx_data_bt                 	0x4a9e
+#define	mem_ipc_lock_tx_data_c51                	0x4a9f
+#define	mem_ipc_2bt_fifo_head                   	0x4aa0
+#define	mem_ipc_2bt_fifo_end                    	0x4b36
+#define	mem_ipc_2C51_fifo_head                  	0x4b36
+#define	mem_ipc_2C51_fifo_end                   	0x4b9a
+#define	mem_ipc_2bt_read_index                  	0x4b9a
+#define	mem_ipc_2bt_write_index                 	0x4b9c
+#define	mem_ipc_2C51_read_index                 	0x4b9e
+#define	mem_ipc_2C51_write_index                	0x4ba0
+#define	mem_ipc_tx_evt_buff                     	0x4ba2
+#define	mem_ipc_tx_evt                          	0x4ba4
+#define	mem_ipc_bt_timer                        	0x4ba5
+#define	mem_ipc_rx_type                         	0x4ba7
+#define	mem_rfcomm_tx_buff                      	0x4ba8
+#define	mem_queue_ele_num                       	0x4ba8
+#define	mem_queue_write                         	0x4ba9
+#define	mem_queue_read                          	0x4bab
+#define	mem_queue_start                         	0x4bad
+#define	mem_uart_packet                         	0x4bad
+#define	mem_data_ele0                           	0x4bb9
+#define	mem_data_ele1                           	0x4bc5
+#define	mem_data_ele2                           	0x4bd1
+#define	mem_queue_end                           	0x4bdd
+#define	mem_queue_temp                          	0x4bdd
+#define	mem_24g_rxdata_length                   	0x4bdf
+#define	mem_24g_pid                             	0x4be0
+#define	mem_24g_datalen                         	0x4be1
+#define	mem_24g_data_type                       	0x4be2
+#define	mem_24g_txlen                           	0x4be3
+#define	mem_24g_rx_window                       	0x4be4
+#define	mem_24g_ensure                          	0x4be6
+#define	mem_24g_get_ack_fail                    	0x4be7
+#define	mem_24g_retry                           	0x4be8
+#define	mem_24g_ch                              	0x4be9
+#define	mem_24g_current_ch_number               	0x4bea
+#define	mem_24g_paring_addr                     	0x4beb
+#define	mem_24g_pairing_sm                      	0x4bef
+#define	mem_24g_ch_map1                         	0x4bf0
+#define	mem_24g_ch_map2                         	0x4bf4
+#define	mem_24g_ch_map3                         	0x4bf8
+#define	mem_24g_ch_map4                         	0x4bfc
+#define	mem_24g_addr                            	0x4c00
+#define	mem_24g_check_dongle_times              	0x4c04
+#define	mem_24g_device_addr                     	0x4c06
+#define	mem_24g_no_ack                          	0x4c0a
+#define	mem_24g_sta_crc                         	0x4c0b
+#define	mem_24g_sta_pid                         	0x4c0e
+#define	mem_24g_max_retry                       	0x4c0f
+#define	mem_24g_mode                            	0x4c10
+#define	mem_24g_hop_pac_retry                   	0x4c11
+#define	mem_24g_idle_timeout                    	0x4c12
+#define	mem_24g_idle_cnt                        	0x4c13
+#define	mem_24g_auto_paring_switch              	0x4c14
+#define	mem_24g_enter_lpm_timer                 	0x4c15
+#define	mem_24g_syncword                        	0x4c16
+#define	mem_24g_syncword_crc8                   	0x4c18
+#define	mem_24g_get_syncword_crc8               	0x4c19
+#define	mem_24g_discard_cnt                     	0x4c1a
+#define	mem_cb_24g_data                         	0x4c1c
+#define	mem_24g_lasttx                          	0x4c1e
+#define	mem_power_ctrl_pac_succ_cnt             	0x4c27
+#define	mem_power_ctrl_level                    	0x4c28
+#define	mem_rssi_avg_received                   	0x4c29
+#define	mem_rssi_hex_received                   	0x4c2a
+#define	mem_rssi_signal_buf                     	0x4c2b
+#define	mem_rssi_noise_buf                      	0x4c33
+#define	mem_rssi_noise_index                    	0x4c3b
+#define	mem_rssi_signal_index                   	0x4c3c
+#define	mem_tx_power                            	0x4c3d
+#define	mem_tx_power_temp                       	0x4c3e
+#define	mem_cnt                                 	0x4c3f
+#define	mem_last_txlch                          	0x4c42
+#define	mem_last_txlen                          	0x4c43
+#define	mem_last_txdata                         	0x4c45
+#define	mem_ipc_last_check_timer                	0x4c59
+#define	mem_prepare_write_len                   	0x4c5d
+#define	mem_ipc_c51_timer                       	0x4c5e
+#define	mem_le_rx_window                        	0x4c60
+#define	mem_le_find_type_value_start_handle     	0x4c61
+#define	mem_le_find_type_value_end_handle       	0x4c63
+#define	mem_le_cur_att_type                     	0x4c65
+#define	mem_le_search_len                       	0x4c67
+#define	mem_le_ll_unknown_type                  	0x4c68
+#define	mem_le_pairing_state                    	0x4c69
+#define	mem_le_local_mtu                        	0x4c6a
+#define	mem_le_connection_updata_param          	0x4c6c
+#define	mem_ltk_states                          	0x4c7c
+#define	mem_pair_state                          	0x4c7d
+#define	mem_empty_count                         	0x4c7e
+#define	mem_shutter_find_type_value_flag        	0x4c7f
+#define	mem_le51_payload_len                    	0x4c80
+#define	mem_le51_cmd                            	0x4c81
+#define	mem_le51_tx_length                      	0x4c82
+#define	mem_le51_txbuff_inuse                   	0x4c83
+#define	mem_le51_txbuf                          	0x4c84
+#define	mem_ipc_bt_100ms_timer                  	0x4c8d
+#define	mem_ipc_c51_100ms_timer                 	0x4c8e
+#define	mem_adc_config_flag                     	0x4c8f
+#define	mem_adc_channel                         	0x4c90
+#define	mem_adc_0v                              	0x4c91
+#define	mem_adc_3v                              	0x4c93
+#define	mem_adc_current_value                   	0x4c95
+#define	mem_hibernate_flag                      	0x4c97
+#define	mem_new_supervision_to                  	0x4c98
+#define	mem_kb_wake_timer                       	0x4c9a
+#define	mem_kb_last_data                        	0x4c9b
+#define	mem_kb_keycount                         	0x4caf
+#define	mem_led_cap_delay_timer                 	0x4cb0
+#define	mem_test                                	0x4cb1
+#define	mem_seq                                 	0x4cb4
+#define	mem_recon_index                         	0x4cb5
+#define	mem_power_on_flag                       	0x4cb6
+#define	mem_caps_num_lock                       	0x4cb7
+#define	mem_att_report1                         	0x4cb8
+#define	mem_att_report2                         	0x4cba
+#define	mem_att_report3                         	0x4cbc
+#define	mem_suspend_flag                        	0x4cbe
+#define	mem_32asm_data_end                      	0x4cbf
+#define	mem_store_ltk_timer                     	0x4d37
+#define	mem_reconnect_continue                  	0x4d38
+#define	mem_le_pin_code                         	0x4d39
+#define	mem_le_send_security_request_flag       	0x4d3d
+#define	mem_att_report_battery                  	0x4d3e
+#define	mem_24g_enter_hibernate                 	0x4d40
+#define	mem_24g_txfail_cnt                      	0x4d44
+#define	mem_mouse_retry_flag                    	0x4d45
+#define	mem_24g_led_flag                        	0x4d46
+#define	mem_ui_timer_last_btclk_temp            	0x4d47
+#define	mem_ui_check_timer_setup                	0x4d4b
+#define	mem_customize_timer_setup               	0x4d4f
+#define	mem_customize_timer                     	0x4d51
+#define	mem_ios_mode_flag                       	0x4d52
+#define	mem_version_yy_mm_dd                    	0x4d53
+#define	mem_24g_txbuf_new                       	0x4d57
+#define	mem_le_adv_swift_pair                   	0x4d6b
+#define	mem_24g_enter_hibernate_setup           	0x4d72
+#define	mem_24g_enter_hibernate_max             	0x4d76
+#define	mem_24g_short_sleep_counter             	0x4d7a
+#define	mem_pc_sleep_flag                       	0x4d7d
+#define	mem_le_pause_enc_flag                   	0x4d7e
+#define	mem_at_gpio                             	0x4800
+#define	mem_module_wake_up_gpio                 	0x4801
+#define	mem_module_state_gpio                   	0x4802
+#define	mem_module_connect_state_gpio           	0x4803
+#define	mem_module_version                      	0x4804
+#define	mem_last_uart_clock                     	0x480a
+#define	mem_current_packet_length               	0x480e
+#define	mem_module_prepare_tx_len               	0x4810
+#define	mem_module_state                        	0x4812
+#define	mem_module_task                         	0x4813
+#define	mem_cmode_addr                          	0x4814
+#define	mem_at_scan_time                        	0x481a
+#define	mem_prarm_pswd                          	0x481c
+#define	mem_prarm_uart                          	0x4820
+#define	mem_prarm_blename                       	0x4824
+#define	mem_prarm_name                          	0x4827
+#define	mem_prarm_bleadss                       	0x482b
+#define	mem_prarm_adss                          	0x482e
+#define	mem_prarm_vers                          	0x4832
+#define	mem_prarm_class                         	0x4836
+#define	mem_prarm_clrflg                        	0x483b
+#define	mem_prarm_reconn                        	0x4841
+#define	mem_prarm_bledis                        	0x4847
+#define	mem_prarm_dis                           	0x4849
+#define	mem_prarm_stsn                          	0x484c
+#define	mem_prarm_atp                           	0x4850
+#define	mem_prarm_list                          	0x4853
+#define	mem_prarm_role                          	0x4857
+#define	mem_prarm_sniff                         	0x485b
+#define	mem_prarm_ldev                          	0x4860
+#define	mem_prarm_rssi                          	0x4864
+#define	mem_prarm_cdev                          	0x4868
+#define	mem_prarm_bleinqr                       	0x486c
+#define	mem_prarm_inqr                          	0x486f
+#define	mem_prarm_cmode                         	0x4873
+#define	mem_prarm_mode                          	0x4878
+#define	mem_prarm_dmstate                       	0x487c
+#define	mem_prarm_discov                        	0x4883
+#define	mem_prarm_ota                           	0x4889
+#define	mem_prarm_bleconn                       	0x488c
+#define	mem_prarm_conn                          	0x488e
+#define	mem_prarm_pageout                       	0x4892
+#define	mem_prarm_recfail                       	0x4899
+#define	mem_module_uuid_list                    	0x48a0
+#define	mem_mouse_x                             	0x4800
+#define	mem_mouse_y                             	0x4802
+#define	mem_mouse_z                             	0x4804
+#define	mem_mouse_key                           	0x4805
+#define	mem_mouse_z_last                        	0x4806
+#define	mem_mouse_z_before                      	0x4807
+#define	mem_mouse_z_now                         	0x4808
+#define	mem_mouse_z_data                        	0x4809
+#define	mem_mouse_move_flag                     	0x480a
+#define	mem_reconnect_timeout                   	0x480b
+#define	mem_mouse_direct_timeout                	0x480c
+#define	mem_mouse_no_data_timeout               	0x480e
+#define	mem_mouse_blank_data_timeout            	0x4810
+#define	mem_mouse_discovery_timer               	0x4812
+#define	mem_mouse_direct_timer                  	0x4814
+#define	mem_mouse_no_data_timer                 	0x4816
+#define	mem_mouse_blank_data_timer              	0x4818
+#define	mem_mouse_send_blank_timer              	0x481a
+#define	mem_mouse_dpi                           	0x481b
+#define	mem_mouse_dpi_button_state              	0x481c
+#define	mem_mouse_test_cnt                      	0x481d
+#define	mem_le_hibernate_timer                  	0x481e
+#define	mem_mouse_mode_state                    	0x4820
+#define	mem_sensor_type                         	0x4821
+#define	mem_lbutton_gpio                        	0x4822
+#define	mem_rbutton_gpio                        	0x4823
+#define	mem_mbutton_gpio                        	0x4824
+#define	mem_dpi_button_gpio                     	0x4825
+#define	mem_sensor_data_gpio                    	0x4826
+#define	mem_whee_a_data_gpio                    	0x4827
+#define	mem_whee_b_data_gpio                    	0x4828
+#define	mem_conn_cnt                            	0x4829
+#define	mem_mouse_uuid_list                     	0x482a
+#define	mem_shutter_send_data                   	0x4800
+#define	mem_shutter_key_temp                    	0x4804
+#define	mem_shutter_send_length                 	0x4805
+#define	mem_shutter_clkn_bt_last                	0x4806
+#define	mem_shutter_key                         	0x480a
+#define	mem_shutter_flag                        	0x480b
+#define	mem_shutter_cable_unplug_conut          	0x480c
+#define	mem_shutter_hid_disconn_count           	0x480d
+#define	mem_shutter_1key_send_sm                	0x480e
+#define	mem_shutter_iphonekey_gpio              	0x480f
+#define	mem_shutter_androidkey_gpio             	0x4810
+#define	mem_shutter_key_number                  	0x4811
+#define	mem_shutter_uuid_list                   	0x4812
+#define	mem_mcmd                                	0xff0
+#define	mem_mouse_data                          	0xff1
+#define	mem_l2cap_rxbuff1                       	0x1000
+#define	mem_l2cap_rxbuff2                       	0x1400
+#define	mem_tx_buff0                            	0x1800
+#define	mem_tx_buff1                            	0x1880
+#define	mem_tx_buff2                            	0x1900
+#define	mem_tx_buff3                            	0x1980
+#define	mem_tx_buff4                            	0x1a00
+#define	mem_tx_buff5                            	0x1a80
+#define	mem_tx_buff6                            	0x1b00
+#define	mem_tx_buff7                            	0x1b80
+#define	mem_h5rx_buf                            	0x1800
+#define	mem_h5rx_buf_end                        	0x1bff
+#define	mem_h5tx_buf                            	0x1c00
+#define	mem_h5tx_buf_end                        	0x1fff
+#define	mem_module_rx_buf                       	0x4a00
+#define	mem_module_rx_buf_end                   	0x4fff
+#define	mem_module_tx_buf                       	0x1c00
+#define	mem_module_tx_buf_end                   	0x1fff
+#define	mem_ir_record                           	0x1800
+#define	mem_ir_record_max                       	0x1c
+#define	memk                                    	0x4b00
+#endif
Index: c51/c.bat
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/c.bat	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/c.bat	(working copy)
@@ -0,0 +1,10 @@
+perl util\hex2mif.pl < output\fw.hex ram > output\fwram.rom
+copy .\patch\kb.dat + .\patch\rf.dat .\patch\sch.rom 
+perl util\transform_name2addr.pl .\patch\sch.rom .\output\sched.rom .\patch\memmap.format
+copy .\patch\ramcode.rom .\output\
+copy .\patch\geneep.exe .\output\
+@rem copy .\patch\*.obj .\output\*.obj
+cd output
+geneep geneep ramcode.rom fwram.rom sched.rom
+cd ..
+:end
Index: c51/common.h
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/common.h	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/common.h	(working copy)
@@ -0,0 +1,19 @@
+#ifndef _YC_INCLUDE_H_
+#define _YC_INCLUDE_H_
+#include "type.h"
+#include "btreg.h"
+#include "hwreg.h"
+#include "sys.h"
+#include "utilities.h"
+#include "kbhid.h"
+#include "global_variable.h"
+#include "keyscan.h"
+#include "gpio.h"
+#include "led.h"
+#include "bluetooth.h"
+#include "kb_process.h"
+#include "ipc.h"
+#include "iic.h"
+#include "adc.h"
+#endif
+
Index: c51/global_variable.h
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/global_variable.h	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/global_variable.h	(working copy)
@@ -0,0 +1,195 @@
+#ifndef _GLOBAL_VARIABLE_H_
+#define _GLOBAL_VARIABLE_H_
+#include "common.h"
+
+#define BAT_ARRAY_LEN				4
+
+typedef struct c51_device_state
+{
+	 byte currentState ;
+	 byte currentSubState;
+	 byte currentStateBefore;
+}DEVICE_STATE;
+
+typedef enum device_mode
+{
+	DEVICE_24G_MODE,
+	DEVICE_BLE_MODE,
+	DEVICE_BR_MODE,
+	DEVICE_MODE_NUM,
+}DEVICE_CURRENT_MODE;
+
+
+typedef enum led_type
+{
+	STYLE_NONE,
+	STYLE_BT_PAIRING,
+	STYLE_LOW_BAT,
+	STYLE_DEVICE_1,
+	STYLE_DEVICE_2,
+	STYLE_DEVICE_3,
+	STYLE_24G_PAIRING,
+	STYLE_BT_RECON,
+}EVT_LED_STYLE;
+
+typedef struct device_recode{
+	byte  device_type;
+	byte  device_addr[6];
+	byte  device_link_key[16] ;
+	byte  local_addr[6];
+	byte  system_mode;
+	byte  fn_lock;
+}BD_KEY_RECORD;
+
+
+typedef struct c51_global_variable		// 0x4cbf
+{
+	 byte update_eeprom_flag;		// 0x4cbf
+	 byte last_device_num;			// 0x4cc0
+	 byte system_mode;			// 0x4cc1
+	 byte power_on_action;			// 0x4cc2
+	 byte current_device_num;		// 0x4cc3
+	 byte temp_device_num;		// 0x4cc4
+
+	 byte g24_currentState;			// 0x4cc5
+	 byte g24_currentSubState;		// 0x4cc6
+	 byte ble_currentState;			// 0x4cc7
+	 byte ble_currentSubState;		// 0x4cc8
+	 byte br_currentState;			// 0x4cc9
+	 byte br_currentSubState;		// 0x4cca
+	 byte history_state;			// 0x4ccb
+
+	 byte button_reconnect_flag;	// 0x4ccc
+	 byte button_24G_rec_flag;		// 0x4ccd
+	 byte button_flag;				// 0x4cce
+	 byte button_timer[4];			// 0x4ccf~0x4cd2
+ 
+	 byte battery_check_interval;			// 0x4cd3
+	 byte battery_value_index;				// 0x4cd4
+	 byte battery_status;					// 0x4cd5
+	 word battery_value[BAT_ARRAY_LEN];	// 0x4cd6~0x4cdd
+	 word battery_level_low;				// 0x4cde
+	 word battery_level_shutdown;			// 0x4ce0
+
+	 byte battery_low_led_flash_interval;		// 0x4ce2
+
+		 
+	 word sleepTimer;						// 0x4ce3
+	 byte powerOn_timer;					// 0x4ce5
+	 byte sys_numlockled_on_timer;			// 0x4ce6
+	 byte sys_capslockled_on_timer;			// 0x4ce7
+	 byte sys_scrolllockled_on_timer;		// 0x4ce8
+	 byte pairing_timeout;					// 0x4ce9
+	 byte delay_enter_lpm_timer;			// 0x4cea
+	 
+	 byte release_data;					// 0x4ceb
+	 byte lockLpm;	 					// 0x4cec
+	 byte key_action;						// 0x4ced
+
+	 byte pairing_g24_timeout;				//0x4cee
+	 byte recon_delay;						// 0x4cef
+	 byte recon_count;						// 0x4cf0
+	 byte recon_continue;					// 0x4cf1
+	 byte ble_ramdon_lap1;					// 0x4cf2
+	 byte ble_ramdon_lap2;					// 0x4cf3 
+	 byte key_combination_step;			// 0x4cf4
+	 byte key_combination_ctrl;				// 0x4cf5
+	 byte key_combination_keyvalue;		// 0x4cf6
+	 byte battery_low_led_flash_flag;		// 0x4cf7
+	 byte one_key_press_wait_release_timer;	// 0x4cf8
+	 byte battery_level_percentage;			// 0x4cf9
+	 word battery_level_full;				// 0x4cfa
+	 byte g24_long_sleep_flag;                    // 4cfc
+
+	
+	 byte mouse_data_send_flag;
+	 byte sensor_key;
+	 byte sensor_x_l;
+	 byte sensor_x_h;
+	 byte sensor_y_l;
+	 byte sensor_y_h;
+	 byte sensor_wheel;
+	 byte sensor_titl;
+	 byte test_buff;                                                         //4d05
+	 byte battery_motion_check_interval;	            //4d06
+// 	 byte powerOn_first_flag;	                             //4d07
+ 	
+}G_VARIABLE_MAP;
+
+
+
+extern G_VARIABLE_MAP xdata g_variable;
+
+extern BD_KEY_RECORD xdata bd_key_record_list[3] ;
+
+ extern xbyte m_caps_num_lock_last;
+
+ extern xbyte iOS_rec_pinCode;
+ extern xbyte pinCode_flag;
+ extern xbyte le_pin_code_len;
+ extern xbyte power_on_flag;
+ extern xbyte repeat_send_24g;
+ extern xbyte get_24g_led_send;
+ extern xbyte ble_reconnect_flag;
+ extern xbyte ble_fast_connect_flag;
+ extern xbyte press_long_time_flag;
+ extern xbyte long_press_flag;
+ extern xbyte standard_key_release_flag;
+ extern xbyte fast_connect_flag;
+ extern xbyte fn_flag;
+ extern xbyte fn_tx_flag;
+ extern xbyte fn_flag_last;
+ extern xbyte fn_lock_flag;
+ extern xbyte ksSelMapOld[];
+ extern xbyte ksSelMapCheck[];
+ extern xbyte ksSelMapCurr[]; 
+ extern xbyte le_lap_temp[3];
+ extern xbyte multikey[9];
+ extern xbyte mult_key_value;
+ extern  xbyte keyCount;
+ extern xbyte mult_key_status;
+ extern xbyte key_value_temp;
+ extern xbyte system_key_press;
+ extern xbyte recon_index;
+ extern xbyte le_send_battery_level_flag;
+ extern xbyte le_send_battery_level_delay_count;
+
+ extern xbyte delayChgInvTimer;
+ extern xbyte action_timeout;
+ extern xbyte switch_role_timer;
+ extern xbyte ble_send_secutiry_request_timer;
+
+
+extern xbyte hidBuff[10] ;
+extern xbyte  m_link_key_exists  ;
+extern xbyte  m_ltk_exists  ;
+extern xbyte m_remote_le_addr[6]  ;
+extern xword m_ui_state_map  ;
+extern xbyte m_linkkey[16]   ;
+extern xbyte m_remote_addr[6]  ;
+extern xbyte m_reconn_addr[6]  ;
+extern xbyte m_le_ltk[16]  ;
+extern byte m_24g_addr[4] ;
+extern byte m_24g_paring_addr[4];
+extern byte kscurrmult;
+extern xbyte m_le_lap[6];
+extern xbyte m_reset_reg;
+extern xbyte m_lpm_mode;
+extern ulong le_pin_code;
+extern xword m_adcCurrentValue;
+extern xword m_adc3vValue; 
+extern xword m_adc0vBase;
+extern volatile xbyte m_adc_config_flag;
+extern volatile xbyte m_24g_enter_hibernate[4];
+extern volatile xbyte m_24g_pairing_sm;
+extern volatile xbyte  m_power_on_flag;
+extern volatile xbyte m_caps_num_lock;
+extern volatile xbyte m_reconnect_continue;
+extern volatile xbyte m_adc_channel;
+extern volatile xbyte m_wakup_from_power_flag;
+extern volatile xbyte m_le_send_security_request_flag;
+extern volatile xbyte m_customize_timer;
+extern volatile xbyte m_24g_led_flag;
+extern volatile xbyte m_pc_sleep_flag;
+
+#endif //_GLOBAL_VARIABLE_H_
Index: c51/global_variable.c
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/global_variable.c	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/global_variable.c	(working copy)
@@ -0,0 +1,293 @@
+#include "global_variable.h"
+#include "Btreg.h"
+
+ 
+G_VARIABLE_MAP xdata g_variable _at_ mem_32asm_data_end;
+BD_KEY_RECORD xdata bd_key_record_list[3] ;
+
+
+// xbyte data random at 4dd0 to 4f40: makefile
+ xbyte m_caps_num_lock_last;
+ xbyte iOS_rec_pinCode;
+ xbyte pinCode_flag;
+ xbyte le_pin_code_len;
+ xbyte power_on_flag;
+ xbyte repeat_send_24g;
+ xbyte get_24g_led_send;
+ xbyte ble_reconnect_flag;
+ xbyte ble_fast_connect_flag;
+ xbyte press_long_time_flag;
+ xbyte long_press_flag;
+ xbyte standard_key_release_flag;
+ xbyte fast_connect_flag;
+ xbyte fn_flag;
+ xbyte fn_flag_last;
+ xbyte fn_tx_flag;
+ xbyte fn_lock_flag;
+ xbyte le_lap_temp[3];
+ xbyte multikey[9];
+ xbyte mult_key_value;
+ xbyte mult_key_status;
+ xbyte system_key_press;
+ xbyte key_value_temp;
+ xbyte keyCount;
+ xbyte recon_index;
+ xbyte le_send_battery_level_flag;
+ xbyte le_send_battery_level_delay_count; 
+
+ xbyte delayChgInvTimer;
+ xbyte action_timeout;
+ xbyte switch_role_timer;
+ xbyte ble_send_secutiry_request_timer;
+
+
+volatile xbyte ksSelMapOld[KB_KSCAN_COL_NUM] _at_ 0x4d93;
+volatile xbyte ksSelMapCheck[KB_KSCAN_COL_NUM] _at_ 0x4da8;	// 4d93+20 = 4da8
+volatile xbyte ksSelMapCurr[KB_KSCAN_COL_NUM] _at_ 0x4dbc; 	// 4da8+20 = 4dbc
+volatile xbyte hidBuff[10] _at_ mem_mouse_x;
+volatile xbyte  m_link_key_exists _at_ mem_link_key_exists;
+volatile xbyte m_linkkey[16] _at_ mem_link_key ;
+volatile xbyte  m_ltk_exists _at_ mem_ltk_exists;
+volatile xbyte m_le_ltk[16] _at_ mem_le_ltk;
+volatile xbyte m_remote_le_addr[6] _at_ mem_le_plap;
+volatile xbyte m_remote_addr[6] _at_ mem_plap;
+volatile xbyte m_reconn_addr[6] _at_ mem_hci_plap;
+volatile byte m_24g_addr[4] _at_ mem_24g_addr;
+volatile byte m_24g_paring_addr[4] _at_ mem_24g_paring_addr;
+
+volatile xbyte m_le_lap[6] _at_ mem_le_lap;
+
+volatile byte kscurrmult _at_ mem_lpm_mult;
+volatile xword m_ui_state_map _at_ mem_ui_state_map;
+volatile xbyte m_reset_reg _at_ 0x8010;
+volatile xbyte m_lpm_mode _at_ mem_lpm_mode;
+volatile ulong le_pin_code _at_ mem_le_pin_code;
+volatile xword m_adcCurrentValue _at_ mem_adc_current_value;
+volatile xword m_adc3vValue _at_ mem_adc_3v;
+volatile xword m_adc0vBase _at_ mem_adc_0v;
+volatile xbyte m_adc_config_flag _at_ mem_adc_config_flag;
+volatile xbyte m_24g_enter_hibernate[4] _at_ mem_24g_enter_hibernate;
+volatile xbyte m_24g_pairing_sm _at_ mem_24g_pairing_sm;
+volatile xbyte  m_power_on_flag _at_ mem_power_on_flag;
+volatile xbyte m_caps_num_lock _at_ mem_caps_num_lock;
+volatile xbyte m_reconnect_continue _at_ mem_reconnect_continue;
+volatile xbyte m_adc_channel _at_ mem_adc_channel;
+volatile xbyte m_wakup_from_power_flag _at_ mem_wakup_from_power_flag;
+volatile xbyte m_le_send_security_request_flag _at_ mem_le_send_security_request_flag;
+volatile xbyte m_customize_timer _at_ mem_customize_timer;
+volatile xbyte m_24g_led_flag _at_ mem_24g_led_flag;
+volatile xbyte m_pc_sleep_flag _at_ mem_pc_sleep_flag;
+
+
+
+code byte col[KB_KSCAN_COL_NUM+1]=
+{
+10,    			//C0
+28,    			//C1
+21,    		//C2
+22,    		//C3
+23,    		//C4
+24,    		//C5
+25,    		//C6
+26,    		//C7
+12,	    		//C8	
+9,    		//C9
+11,    		//C10
+15,    		//C11
+16,    		//C12
+17,    		//C13
+27,    		//C14
+14,    		//C15
+8,    		//C16
+13,    		//C17
+
+};
+
+
+code byte  ksMap[KS_KEY_MAP_LEN]=
+{
+//c0
+HID_KEY_F5, 					//R7
+HID_KEY_LEFT_CTL, 			//R6
+HID_KEY_NULL, 				//R5
+HID_KEY_RIGHT_CTL, 			//R4
+HID_SYSTEM_KEY_SLEEP,				//R3
+HID_KEY_NULL, 				//R2
+HID_KEY_POWER, 				//R1
+HID_KEY_SCROLL_LOCK, 				//R0
+
+//c1
+HID_KEY_1, 					//R7
+HID_KEY_TILDE, 				//R6
+HID_KEY_K131, 				//R5
+HID_KEY_Z,					//R4
+HID_KEY_ESC, 				//R3
+HID_KEY_A, 					//R2
+HID_KEY_TAB, 				//R1
+HID_KEY_Q, 					//R0
+
+//c2
+HID_KEY_2 , 					//R7
+HID_KEY_F1,					//R6
+HID_KEY_K132, 				//R5
+HID_KEY_X, 					//R4
+HID_KEY_K45, 				//R3
+HID_KEY_S, 					//R2
+HID_KEY_CAPS_LOCK, 		//R1
+HID_KEY_W,					//R0
+
+//C3
+HID_KEY_3,					//R7
+HID_KEY_F2,					//R6
+HID_KEY_K133,				//R5
+HID_KEY_C,					//R4
+HID_KEY_F4, 					//R3
+HID_KEY_D,					//R2
+HID_KEY_F3, 					//R1
+HID_KEY_E, 					//R0
+
+//c4
+HID_KEY_4,					//R7
+HID_KEY_5, 					//R6
+HID_KEY_B, 					//R5
+HID_KEY_V, 					//R4
+HID_KEY_G, 					//R3
+HID_KEY_F, 					//R2
+HID_KEY_T, 					//R1
+HID_KEY_R,					//R0		
+
+
+//c5
+HID_KEY_7, 					//R7
+HID_KEY_6, 					//R6
+HID_KEY_N,					//R5
+HID_KEY_M, 					//R4
+HID_KEY_H, 					//R3
+HID_KEY_J, 					//R2
+HID_KEY_Y,					//R1
+HID_KEY_U, 					//R0
+
+//c6						
+HID_KEY_8, 					//R7
+HID_KEY_EQUAL,				//R6
+HID_KEY_K56, 				//R5
+HID_KEY_LESS_THAN,			//R4
+HID_KEY_F6, 					//R3
+HID_KEY_K, 					//R2
+HID_KEY_RIGHT_BRACKET, 	//R1
+HID_KEY_I, 					//R0
+
+
+//c7
+HID_KEY_9,					//R7
+HID_KEY_F8, 					//R6
+HID_KEY_APP, 				//R5
+HID_KEY_GREAT_THAN, 		//R4
+HID_KEY_NULL, 				//R3 *********
+HID_KEY_L, 					//R2
+HID_KEY_F7,					//R1
+HID_KEY_O, 					//R0
+
+//c8
+HID_KEY_0,					//R7
+HID_KEY_MINUS, 				//R6
+HID_KEY_SLASH,				//R5
+HID_KEY_K42,				//R4
+HID_KEY_QUOTE,				//R3
+HID_KEY_SEMICOLON,		//R2
+HID_KEY_LEFT_BRACKET,		//R1
+HID_KEY_P,					//R0
+
+//c9
+HID_KEY_PAUSE,  		//R7
+HID_KEY_KP_00,				//R6
+HID_KEY_RIGHT_ALT, 			//R5
+HID_KEY_NULL,				//R4 ************
+HID_KEY_LEFT_ALT, 			//R3
+HID_KEY_FN, 				//R2
+HID_KEY_NULL,				//R1
+HID_KEY_PRINT_SCREEN,		//R0
+
+//c10 
+HID_KEY_F10, 				//R7
+HID_KEY_F9, 					//R6
+HID_KEY_F12, 				//R5
+HID_KEY_ENTER, 				//R4
+HID_KEY_F11, 				//R3
+HID_KEY_BACK_SLASH, 		//R2
+HID_KEY_BACKSPACE, 		//R1	
+HID_KEY_K14, 				//R0
+
+//c11 
+HID_KEY_POWER, 				//R7
+HID_KEY_DELETE, 			//R6
+HID_KEY_DOWN_ARROW, 		//R5
+HID_KEY_NUM_LOCK,			//R4
+HID_KEY_SPACE, 				//R3
+HID_KEY_KP_1, 				//R2
+HID_KEY_KP_4 ,				//R1
+HID_KEY_KP_7, 				//R0
+
+//c12 
+HID_SYSTEM_KEY_SLEEP, 				//R7
+HID_KEY_INSERT,				//R6
+HID_KEY_RIGHT_ARROW,		//R5
+HID_KEY_KP_SLASH,			//R4
+HID_KEY_KP_0, 				//R3
+HID_KEY_KP_2,				//R2
+HID_KEY_KP_5,				//R1
+HID_KEY_KP_8, 				//R0
+
+//c13 
+HID_KEY_PAGE_DOWN, 		//R7
+HID_KEY_PAGE_UP, 			//R6
+HID_KEY_KP_MINUS, 			//R5
+HID_KEY_KP_ASTERISK, 		//R4
+HID_KEY_KP_DEL, 			//R3
+HID_KEY_KP_3, 				//R2
+HID_KEY_KP_6, 				//R1	
+HID_KEY_KP_9, 				//R0
+
+//c14 
+HID_KEY_END,				//R7
+HID_KEY_HOME,				//R6
+HID_KEY_LEFT_ARROW, 		//R5
+HID_MULTIKEY_PALY, 			//R4
+HID_KEY_UP_ARROW, 		//R3
+HID_KEY_KP_ENTER, 			//R2
+HID_KEY_KP_COMMA, 		//R1
+HID_KEY_KP_PLUS,			//R0
+
+
+//c15 
+HID_KEY_COPY, 		//R7
+HID_MULTIKEY_OS_LOCK,	//R6
+HID_KEY_BLE_2, 	//R5
+HID_KEY_BLE_1,	//R4
+HID_KEY_PB, 		//R3
+HID_KEY_RIGHT_SHIFT, 		//R2
+HID_KEY_LEFT_SHIFT, 		//R1	
+HID_SYSTEM_KEY_WAKE_UP, 				//R0
+
+//c16
+HID_KEY_NULL,	//R7
+HID_MULTIKEY_MUTE, 		//R6
+HID_MULTIKEY_AC_REFRESH,	//R5
+HID_MULTIKEY_AC_BACK,		//R4
+HID_MULTIKEY_AC_STOP,		//R3
+HID_MULTIKEY_AC_FORWARD, 	//R2
+HID_KEY_LEFT_GUI,			//R1
+HID_KEY_CUT, 			//R0
+
+
+//c17 
+HID_KEY_KR_R , 				//R7
+HID_MULTIKEY_AC_HOME, 		//R6
+HID_KEY_PASTE, 	//R5
+HID_MULTIKEY_STOP,			//R4
+HID_KEY_NULL,	//R3
+HID_KEY_RIGHT_GUI,					//R2
+HID_MULTIKEY_AC_FAVORITES, 	//R1
+HID_KEY_KR_L, 				//R0
+};
+
Index: c51/gpio.h
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/gpio.h	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/gpio.h	(working copy)
@@ -0,0 +1,83 @@
+
+#ifndef _GPIO_H
+#define _GPIO_H
+#include "type.h"
+#include "Hwreg.h"
+
+extern volatile xbyte YC_GPIOWakeupL[4];
+extern volatile xbyte YC_GPIOWakeupH[4];
+
+#define GPIO_SetBit(gpio_num,reg_base, bit_val) if(bit_val)  \
+		*(reg_base + (gpio_num >> 3 & 3)) |= 1<<(gpio_num & 7);	\
+	else	\
+		*(reg_base + (gpio_num >> 3 & 3)) &= ~(1<<(gpio_num & 7))
+
+/**
+ * This function gpio get input status.0 low,1high
+ * 
+ * @param gpio_num
+ * 
+ * @return none.
+*/
+bool GPIO_GetInputStatus(byte gpio_num);
+/**
+ * This function set gpio out.
+ * 
+ * @param gpio_num,bit_val bit_val 0 low, 1high
+ * 
+ * @return none.
+*/
+void GPIO_Setout(byte gpio_num, bool bit_val);
+/**
+ * This function set gpio input
+ * 
+ * @param gpio_num,st 1 pull down ,0 pull up.
+ * 
+ * @return none.
+*/
+void GPIO_SetInput(byte gpio_num,bit  st);
+
+/**
+ * This function set gpio input
+ * 
+ * @param gpio_num,st 1 high ,0 low.
+ * 
+ * @return none.
+*/
+void GPIO_SetOutput(byte gpio_num,bit  st);
+/**
+ * This function set gpio wake.This function must use with GPIO_SetInput.
+ * 
+ * @param gpio_num, st 1 high wake,0 low wake.
+ * 
+ * @return none.
+*/
+void GPIO_SetWakeup(byte gpio_num,bit  st);
+
+/**
+ * This function set gpio wake by curent state for fast wake mcu.
+ * 
+ * @param gpio_num, st 1 high wake,0 low wake.
+ * 
+ * @return none.
+*/
+void GPIO_SetWakeupByCurrentState(byte gpio_num);
+
+/**
+ * This function Flip output state.
+ * 
+ * @param gpio_num.
+ * 
+ * @return none.
+*/
+void GPIO_FlipOutBit(byte gpio_num);
+
+/* make all gpios into pd state if not output or pullhigh */
+void GPIO_fillpd();
+void GPIO_SetPd(byte gpio_num, bool bit_val);
+void GPIO_Setoe(byte gpio_num, bool bit_val);
+void GPIO_SetPu(byte gpio_num, bool bit_val);
+
+#endif /* YC_GPIO_H */
+
+
Index: c51/hwreg.h
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/hwreg.h	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/hwreg.h	(working copy)
@@ -0,0 +1,214 @@
+#ifndef _HWREG_H_
+#define _HWREG_H_
+
+
+#define HWRITED(reg, dword)	do{HWRITE(reg, (dword) & 0xff); \
+							HWRITE(reg + 1, (dword) >> 8 & 0xff); \
+							HWRITE(reg + 2, (dword) >> 16 & 0xff); \
+							HWRITE(reg + 3, (dword) >> 24 & 0xff); \
+							}while(0)
+
+#define HREADD(reg)			((u32_t)HREAD(reg)  | (u32_t)HREAD(reg + 1) << 8 | (u32_t)HREAD(reg + 2) << 16 | (u32_t)HREAD(reg + 3) << 24)
+
+#define ESWAP(word)			((word) >> 8 & 0xff | (word) << 8 & 0xff00)
+#define min(x,y) 				((x) < (y) ? (x) : (y))
+#define HREADW(reg)			(*((volatile unsigned int xdata *)(reg)))
+#define HWRITEW(mem, word)	HREADW(mem) = ESWAP(word)
+#define HREADWS(reg)			ESWAP(HREADW(reg))
+
+#define HREAD(reg)			(*(volatile unsigned char xdata *)(reg))
+#define HWRITE(reg, value)		*((volatile unsigned char xdata *)(reg)) = value
+
+#define SETBIT(reg, value)		HWRITE(reg,( (HREAD(reg)) | (value)))
+#define CLRBIT(reg, value)		HWRITE(reg, (HREAD(reg) & (~(value))))
+#define READBIT(reg, value)		((HREAD(reg)) & (value))
+#define BIT(x)					(1 << (x))
+
+
+#define PWM_EN			0x8084
+
+#define GPIO_OE(X)      0x8070 + X
+#define GPIO_OUT(X)     0x8074 + X
+#define GPIO_PUP(X)     0x8078 + X
+#define GPIO_PDN(X)     0x807c + X
+#define GPIO_SEL(X)     0x8080 + X
+#define GPIO_KEY(X)     0x8083 + X
+
+#define GPIO_IN(X)      0x811c + X
+
+
+#define PWM_PCOUNT(X)	(0x80a0 + X*4)
+#define PWM_NCOUNT(X)	(0x80a2 + X*4)
+
+#define CLOCK_SEL			0x8044
+#define CLOCK_SEL_12M		9
+
+#define LPM_EXENOE		0x813e
+
+// math cordic
+#define CORDIC_TYPE    	0x8053
+#define CORDIC_A     		0x80a8
+#define CORDIC_B     		0x80ac
+#define PERF_STATUS		0x812d
+#define CORDIC_RESULT     	0x8120
+
+#define YC_TYPE_SIN		0
+#define YC_TYPE_ATAN	1
+#define YC_TYPE_MULT	2
+#define YC_TYPE_DIV		3
+#define YC_TYPE_ASIN	         4
+#define YC_TYPE_SQRT	5
+#define YC_TYPE_COS		6
+#define YC_TYPE_TAN		7
+
+// DMA UART
+#define UART_BAUD     0x8052
+#define UART_RSADDR   0x8054
+#define UART_READDR   0x8056 
+#define UART_RRPTR    0x8058
+#define UART_TSADDR   0x805a 
+#define UART_TEADDR   0x805c 
+#define UART_TWPTR    0x805e
+#define UART_TRPTRP   0x8060 
+#define UART_CTRL     0x8062 
+#define CLKN	0x8100
+
+#define UART_STATUS  0x810c
+#define UART_RBAUD   0x810d 
+#define UART_TXITEMS 0x810e 
+#define UART_TRPTR   0x8110 
+#define UART_RXITEMS 0x8112 
+#define UART_RDPTR   0x8114 
+#define UART_RWPTR   0x8116 
+
+#define KSCN_KSCTRL                 	0x8063
+#define KSCN_RCTC                    	0x8064
+#define KSCN_ROW_MASK                	0x806f
+
+#define KSCN_EVENT_BUF           	0x811a
+#define KSCN_EVENT_NUM           	0x811b
+
+
+#define  CPUA_ICE_CTRL (*(volatile unsigned char xdata *)(0x8280))
+
+#define CPUB_ICE_BK0_LO			0x8205
+#define CPUB_ICE_BK0_HI			0x8206
+
+#define IIC_ADDR_START		0x8300
+#define IIC_PRER_LOW			0x8300
+#define IIC_SLAVE_ADDR		0x8301
+#define IIC_CTR				0x8302
+#define IIC_CR				0x8303
+#define IIC_RXR				0x8304
+#define IIC_TXR				0x8305
+#define IIC_SR				0x8306
+#define IIC_FIFO				0x8307
+
+#define USB_CONFIG		0x8c00
+#define USB_INT_MASK(x)	(0x8c01 + x)
+#define USB_TRG			0x8c10
+#define USB_STALL		0x8c11
+#define USB_CLEAR		0x8c12
+#define USB_EP(x)			(0x8c18 + x)
+#define USB_EP_LEN(x)		(0x8c20 + x)
+
+
+#define USB_STATUS		0x8c26
+#define USB_FIFO_EMPTY	0x8c27
+
+sfr DFIFO0     = 0x94;
+sfr DFIFO1     = 0x95;
+sfr DFIFO2     = 0x96;
+
+
+#define PWM_CLOCK           5 
+#define REG_CLK_OFF(n)		(*(volatile unsigned char xdata *)(0x8050 + n))
+
+#define REG_PWM_ENABLE   	(*(volatile unsigned char xdata *)0x8085)
+#define REG_PWM_CLK_SEL 	(*(volatile unsigned char xdata *)0x8042)
+#define REG_PWM_PCOUNT(n) 	(*(volatile unsigned char xdata *)(0x80a0 + n*4))
+#define REG_PWM_NCOUNT(n) 	(*(volatile unsigned char xdata *)(0x80a2 + n*4))
+
+
+#define REG_UART_CLK_SEL	(*(volatile unsigned char xdata *)0x8043)
+#define REG_UART_BAUD		(*(volatile unsigned short xdata *)0x8052)
+#define REG_UART_BAUD_HI		(*(volatile unsigned char xdata *)0x8053)
+#define REG_UART_RX_ADDR_S	(*(volatile unsigned short xdata *)0x8054)
+#define REG_UART_RX_ADDR_E 	(*(volatile unsigned short xdata *)0x8056)
+#define REG_UART_RX_PTR_R	(*(volatile unsigned short xdata *)0x8058)
+#define REG_UART_TX_ADDR_S	(*(volatile unsigned short xdata *)0x805a)
+#define REG_UART_TX_ADDR_E	(*(volatile unsigned short xdata *)0x805c)
+#define REG_UART_TX_PTR_W	(*(volatile unsigned short xdata *)0x805e)
+#define REG_UART_TX_PTRP_R	(*(volatile unsigned short xdata *)0x8060)
+#define REG_UART_CTRL		(*(volatile unsigned char xdata *)0x8062)
+
+//read only
+#define REG_UART_STATUS		(*(volatile unsigned char xdata *)0x810c)
+#define REG_UART_DET_BAUD	(*(volatile unsigned char xdata *)0x810d)
+#define REG_UART_TX_ITEMS	(*(volatile unsigned short xdata *)0x810e)
+#define REG_UART_TX_PTR_R	(*(volatile unsigned short xdata *)0x8110)
+#define REG_UART_RX_ITEMS	(*(volatile unsigned short xdata *)0x8112)
+#define REG_UART_RX_DPTR_R	(*(volatile unsigned short xdata *)0x8114)
+#define REG_UART_RX_PTR_W	(*(volatile unsigned short xdata *)0x8116)
+
+#define REG_GPIO_SELECT(n)	(*(volatile unsigned char xdata *)(0x8080 + n))
+
+#define REG_GPIO_OE(n) 	(*(volatile unsigned char xdata *)(0x8070 + n))
+#define REG_GPIO_OUT(n)	(*(volatile unsigned char xdata *)(0x8074 + n))
+#define REG_GPIO_PUP(n) 	(*(volatile unsigned char xdata *)(0x8078 + n))
+#define REG_GPIO_PDN(n)	(*(volatile unsigned char xdata *)(0x807c + n))
+#define REG_GPIO_SEL(n) 	(*(volatile unsigned char xdata *)(0x8080 + n))
+#define REG_GPIO_KEY(n) 	(*(volatile unsigned char xdata *)(0x8083 + n))
+
+#define REG_GPIO_IN(n)	(*(volatile unsigned char xdata *)(0x811c + n))	//n=0,1,2,3
+
+#define REG_MISC_CTRL			(*(volatile unsigned char xdata *)(0x8006))
+
+
+#define REG_SPID_CTRL  			(*(volatile unsigned char xdata *)(0x8086))
+#define REG_SPID_DELAY  		(*(volatile unsigned char xdata *)(0x8087))
+#define REG_SPID_TXADDR			(*(volatile unsigned short xdata *)(0x808a))
+#define REG_SPID_RXADDR			(*(volatile unsigned short xdata *)(0x808c))
+#define REG_SPID_TXLEN			(*(volatile unsigned short xdata *)(0x8088))
+#define REG_SPID_RXLEN			(*(volatile unsigned short xdata *)(0x808e))
+
+#define REG_IICD_CTRL			(*(volatile unsigned char xdata *)(0x8090))
+#define REG_IICD_SCL_LOW		(*(volatile unsigned char xdata *)(0x8091))
+#define REG_IICD_SCL_HIGH		(*(volatile unsigned char xdata *)(0x8092))
+#define REG_IICD_START_SETUP		(*(volatile unsigned char xdata *)(0x8093))
+#define REG_IICD_START_HOLD		(*(volatile unsigned char xdata *)(0x8094))
+#define REG_IICD_STOP_SETUP		(*(volatile unsigned char xdata *)(0x8095))
+#define REG_IICD_DATA_SETUP		(*(volatile unsigned char xdata *)(0x8096))
+#define REG_IICD_DATA_HOLD		(*(volatile unsigned char xdata *)(0x8097))
+#define REG_IICD_TXLEN			(*(volatile unsigned short xdata *)(0x8098))
+#define REG_IICD_TXADDR			(*(volatile unsigned short xdata *)(0x809a))
+#define REG_IICD_RXADDR			(*(volatile unsigned short xdata *)(0x809c))
+#define REG_IICD_RXLEN			(*(volatile unsigned short xdata *)(0x809e))
+#define REG_CLKN					(*(volatile unsigned long xdata *)(0x8100))
+#define REG_DMA_STATUS			(*(volatile unsigned char xdata *)(0x812c))
+
+#define REG_RFEN_ADC			(*(volatile unsigned char xdata *)(0x8906))
+#define REG_ADC_IN				(*(volatile unsigned short xdata *)(0x812e))
+#define REG_RF_ADC_GC			(*(volatile unsigned char xdata *)(0x8972))
+#define REG_RFEN_CHGPUMP		(*(volatile unsigned char xdata *)(0x8973))
+#define REG_RF_ADC_MODE		(*(volatile unsigned char xdata *)(0x8971))
+#define CORE_ADC_SUM		(*(volatile unsigned short xdata *)(0x8150))
+
+#define REG_KSCAN_KSCTRL				(*(volatile unsigned char xdata *)(0x8063))
+#define REG_KSCAN_RCTC				(*(volatile unsigned char xdata *)(0x8064))
+#define REG_KSCAN_SCANCYCLE_TIMER_L	(*(volatile unsigned char xdata *)(0x8065))
+#define REG_KSCAN_SCANCYCLE_TIMER_H	(*(volatile unsigned char xdata *)(0x8066))
+
+
+#define REG_KSCAN_KSTAT				(*(volatile unsigned char xdata *)(0x8119))
+#define REG_KSCAN_EVENT				(*(volatile unsigned char xdata *)(0x811a))
+#define REG_KSCAN_EVENT_NUM			(*(volatile unsigned char xdata *)(0x811b))
+
+#define REG_KSCAN_M_DEBOUNCE		(*(volatile unsigned char xdata *)(0x8067))
+#define REG_KSCAN_MODKEY				(*(volatile unsigned char xdata *)(0x8068))
+#define REG_KSCAN_ROWMASK			(*(volatile unsigned char xdata *)(0x806f))
+#define REG_CONFIG						(*(volatile unsigned char xdata *)(0x8043))
+
+
+
+#endif
Index: c51/iic.h
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/iic.h	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/iic.h	(working copy)
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2016, yichip Semiconductor(shenzhen office)
+ * All Rights Reserved.
+ *
+ * This is UNPUBLISHED PROPRIETARY SOURCE CODE of Yichip Semiconductor;
+ * the contents of this file may not be disclosed to third parties, copied
+ * or duplicated in any form, in whole or in part, without the prior
+ * written permission of Yichip Semiconductor.
+ */
+ 
+ /** @file
+ *
+ * IIC support for application
+ */
+#ifndef __DEV_EEP_H_
+#define __DEV_EEP_H_
+#include "type.h"
+#include "btreg.h"
+#include "hwreg.h"
+
+/**
+ * This function read data by IIC,Warning:pbuff can't not piont to address > 0x4000.
+ * 
+ * @param addr IIC address ,len length to read,pbuff pointer to restore data
+ * 
+ * @return none.
+*/
+void IIC_Read(word addr, word len, byte* pbuff);
+/**
+ * This function write data by IIC,Warning:pbuff can't not piont to address > 0x4000.
+ * 
+ * @param addr IIC address ,len length to write,pbuff pointer to store data
+ * 
+ * @return none.
+*/
+void IIC_write(word addr,word len, byte* pbuff);
+/**
+ * This function write data by IIC,can't ignore page of block device,Warning:pbuff can't not piont to address > 0x4000.
+ * 
+ * @param addr IIC address ,len length to read,pbuff pointer to store data
+ * 
+ * @return none.
+*/
+void IIC_WriteBlock(word addr, word len, byte* pbuff);
+#endif/* YC_IIC_H */
+
Index: c51/ipc.h
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/ipc.h	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/ipc.h	(working copy)
@@ -0,0 +1,313 @@
+/*
+ * Copyright 2016, yichip Semiconductor(shenzhen office)
+ * All Rights Reserved.
+ *
+ * This is UNPUBLISHED PROPRIETARY SOURCE CODE of Yichip Semiconductor;
+ * the contents of this file may not be disclosed to third parties, copied
+ * or duplicated in any form, in whole or in part, without the prior
+ * written permission of Yichip Semiconductor.
+ */
+ 
+ /** @file
+ *
+ * ipc support for application
+ */
+#ifndef _YC_IPC_H_
+#define _YC_IPC_H_
+#include "type.h"
+#include "btreg.h"
+
+#define BUG_FIX
+#ifdef BUG_FIX
+#define FIX_ENTER_LPM	0x01
+#define FIX_ENTER_HIBERNATE	0x03
+#define FIX_LEAVE_LPM	0x05
+
+#endif
+
+
+/* IPC tx hardware address */
+#define IPC_TX_HEAD	mem_ipc_2bt_fifo_head
+#define IPC_TX_END	mem_ipc_2bt_fifo_end
+
+/*IPC rx hardware address*/
+#define IPC_RX_HEAD	mem_ipc_2C51_fifo_head
+#define IPC_RX_END	mem_ipc_2C51_fifo_end
+
+/*IPC data type*/
+#define IPC_CONTROL_CMD		0x01
+#define IPC_CONTROL_EVT		0x02
+#define IPC_HID_DATA			0x03
+#define IPC_SPP_DATA			0x04
+#define IPC_BLE_DATA			0x05
+#define IPC_24G_DATA			0x06
+
+/*IPC cmd type*/
+#define IPC_CMD_STANDBY                                  	0x00
+#define IPC_CMD_START_DISCOVERY                   	0x01
+#define IPC_CMD_STOP_DISCOVERY                      	0x02
+#define IPC_CMD_RECONNECT                              	0x03
+#define IPC_CMD_DISCONNECT                               0x04
+#define IPC_CMD_ENTER_SNIFF                              	0x05
+#define IPC_CMD_EXIT_SNIFF                               	0x06
+#define IPC_CMD_ENTER_SNIFF_SUBRATING         0x07
+#define IPC_CMD_EXIT_SNIFF_SUBRATING             0x08
+#define IPC_CMD_SNIFF_TEST                               	0x09
+#define IPC_CMD_SET_PIN_CODE                           	0x0a
+#define IPC_CMD_START_INQUIRY                          0x0b
+#define IPC_CMD_STOP_INQUIRY                            0x0c
+#define IPC_CMD_START_ADV                                	0x0d
+#define IPC_CMD_STOP_ADV                                 	0x0e
+#define IPC_CMD_START_DIRECT_ADV                   0x0f
+#define IPC_CMD_STOP_DIRECT_ADV                    	0x10
+#define IPC_CMD_LE_DISCONNECT                        	0x11
+#define IPC_CMD_LE_UPDATE_CONN                     	0x12
+#define IPC_CMD_LED_OFF                                  	0x13
+#define IPC_CMD_LED_ON                                   	0x14
+#define IPC_CMD_LED_BLINK                                	0x15
+#define IPC_CMD_LE_START_CONN                     	0x16
+#define IPC_CMD_LE_START_SCAN                      	0x17
+#define IPC_CMD_LE_STOP_SCAN                         	0x18
+#define IPC_CMD_ENTER_HIBERNATE                    	0x19
+#define IPC_CMD_LE_SMP_SECURITY_REQUEST   0x1b
+#define IPC_CMD_LE_START_WRITE                      	0x1c
+#define IPC_CMD_ROLE_SWITCH                          	0x1d
+#define IPC_CMD_BB_RECONN_CANCEL              	0x1e
+#define IPC_CMD_STORE_RECONN_INFO_LE        	0x1f
+#define IPC_CMD_STORE_RECONN_INFO_BT        	0x20
+#define IPC_CMD_START_24G                                	0x21
+#define IPC_CMD_STOP_24G                                 	0x22
+#define IPC_CMD_PAIR_24G                                 	0x23
+#define IPC_CMD_UPDATE_SUPERVISION_TO     	0x28
+#define IPC_CMD_LE_SET_PINCODE                      	0x29
+#define IPC_CMD_SET_RECONNECT_INIT          	0x2a
+#define IPC_CMD_START_ADV_REC                      	0x2b
+#define IPC_CMD_START_ADV_DISCOVERY            0x2c
+
+
+/*IPC event type*/
+#define IPC_EVT_NULL                                     		0x00
+#define IPC_EVT_BB_CONNECTED                       	0x01
+#define IPC_EVT_BB_DISCONNECTED                   	0x02
+#define IPC_EVT_RECONN_STARTED                     	0x03
+#define IPC_EVT_RECONN_FAILED                       	0x04
+#define IPC_EVT_SETUP_COMPLETE                     	0x05
+#define IPC_EVT_HID_CONNECTED                       	0x06
+#define IPC_EVT_HID_DISCONNECTED                   	0x07
+#define IPC_EVT_SPP_CONNECTED                     	0x08
+#define IPC_EVT_SPP_DISCONNECTED                  	0x09
+#define IPC_EVT_PINCODE_REQ                           	0x0A
+#define IPC_EVT_ENTER_SNIFF                              	0x0B
+#define IPC_EVT_EXIT_SNIFF                               	0x0C
+#define IPC_EVT_ENTER_SNIFF_SUB                     	0x0D
+#define IPC_EVT_EXIT_SNIFF_SUB                      	0x0E
+#define IPC_EVT_DISCOVERY_STOPED                 	0x0F
+#define IPC_EVT_BUTTON_LONG_PRESSED         	0x10
+#define IPC_EVT_HID_HANDSHAKE                         	0x12
+#define IPC_EVT_RECONN_PAGE_TIMEOUT          	0x13
+#define IPC_EVT_LE_CONNECTED                         	0x14
+#define IPC_EVT_LE_DISCONNECTED                    	0x15
+#define IPC_EVT_ML2CAP_CONN_REFUSED           	0x16
+#define IPC_EVT_BUTTON_ENTER_HIBERNATE     	0x17
+#define IPC_EVT_LINKKEY_GENERATE                   	0x18
+#define IPC_EVT_SWITCH_NOT_ACCEPT                	0x19
+#define IPC_EVT_SWITCH_ACCEPT                         	0x20
+#define IPC_EVT_SNIFF_NOT_ACCEPT                    0x21
+#define IPC_EVT_SNIFF_ACCEPT                             0x22
+#define IPC_EVT_UNSNIFF_ACCEPT                        	0x23
+#define IPC_EVT_UNSNIFF_NOT_ACCEPT               	0x24
+#define IPC_EVT_BUTTON_ADJUST_DPI                 	0x25
+#define IPC_EVT_SEND_UNSNIFF_ACCEPT            	0x26
+#define IPC_EVT_VIRTUAL_CABLE_UNPLUG          	0x27
+#define IPC_EVT_LE_WRITE_REQUEST                  	0x28
+#define IPC_EVT_LE_ENC_INFO                              	0x29
+#define IPC_EVT_SWITCH_FAIL_MASTER               	0x2a
+#define IPC_EVT_SWITCH_SUCCESS_MASTER       	0x2b
+#define IPC_EVT_BUTTON_DOWN                           	0x2c
+#define IPC_EVT_BUTTON_UP                                	0x2d
+#define IPC_EVT_REMOTE_UNSNIFF                      	0x2e
+#define IPC_EVT_RESET                                    	0x2f
+#define IPC_EVT_WAKEUP                                   	0x30
+#define IPC_EVT_24G_PAIRING_COMPLETE          	0x31
+#define IPC_EVT_24G_ATTEMPT_FAIL                   	0x32
+#define IPC_EVT_HIBERNATE_WAKE                      	0x33
+#define IPC_EVT_LE_PROTOCOL_CONNECTED    	0x34
+#define IPC_EVT_LE_PINCODE_REQ				0x35
+#define IPC_EVT_RECONNECT_STANDY                	0x37
+#define IPC_EVT_CLEAR_LINKKEY                         	0x39
+#define IPC_EVT_24G_ATTEMPT_SUCCESS           	0x3c
+#define IPC_EVT_TIMER_INIT                               	0x50
+#define IPC_EVT_TIMER_MASK                               	0xF0
+#define IPC_EVT_TIMER_100MS                              	0x51
+#define IPC_EVT_TIMER_200MS                             	0x52
+#define IPC_EVT_TIMER_300MS                              	0x53
+#define IPC_EVT_TIMER_400MS                              	0x54
+#define IPC_EVT_TIMER_500MS                              	0x55
+#define IPC_EVT_TIMER_600MS                              	0x56
+#define IPC_EVT_TIMER_700MS                              	0x57
+#define IPC_EVT_TIMER_800MS                              	0x58
+#define IPC_EVT_TIMER_900MS                              	0x59
+#define IPC_EVT_TIMER_1KMS                               	0x5A
+#define IPC_EVT_TIMER_1K1MS                              	0x5B
+#define IPC_EVT_TIMER_1K2MS                              	0x5C
+#define IPC_EVT_TIMER_1K3MS                              	0x5D
+#define IPC_EVT_TIMER_1K4MS                              	0x5E
+#define IPC_EVT_TIMER_1K5MS                              	0x5F
+
+
+/*IPC EVT callback function type*/
+typedef void (*tIPCEventCb)(byte);
+
+/*IPC SPP callback function type*/
+typedef void (*tIPCSppCb)(byte*, word);
+
+/*IPC BLE callback function type*/
+typedef void (*tIPCBleCb)(byte*, word);
+
+/*IPC timer(1s) callback function type*/
+typedef void (*tIPCTimer)(void);
+
+/*IPC Hid callback function type*/
+typedef void (*tIPCHidCb)(byte*, word);
+
+/*IPC control block type*/
+typedef struct IPCContolBlock {
+	tIPCEventCb evtcb;		/*<ipc evt call back*/
+	tIPCSppCb sppcb;		/*<ipc spp call back*/
+	tIPCTimer timercb;		/*<ipc timer call back*/
+	tIPCTimer stimercb;
+	tIPCBleCb blecb;
+	tIPCHidCb hidcb;
+}tIPCControlBlock;
+
+
+typedef enum IPCRejReason{
+	AUTHENTICATION_FAILURE_ERROR = 0x05,
+	KEY_MISSING = 0x06,
+	ACL_CONNECTION_ALREADY_EXISTS = 0x0b,
+	OTHER_END_TERMINATED = 0x13,
+	ABOUT_TO_POEWR_OFF = 0x15,
+	LOCAL_HOST= 0x16,
+	PAIRING_NOT_ALLOWED = 0x18,
+	UNKNOWN_LMP_PDU = 0x19,
+	UNSUPPORTED_LMP_FEATURE = 0x1A,
+	UNSPECIFIED_ERROR = 0x1F,
+	UNSUPPORTED_PARAMETERS = 0x20,
+	SWITCH_NOT_ALLOWED = 0x21,
+	TRANSACTION_COLLISION = 0x23,
+	PDU_NOT_ALLOWED = 0x24,
+	ENCRYPTION_MODE_NOT_ACCEPTABLE = 0x25,
+	NOT_SUPPORT_CHN_CLASSIFICATION = 0x2e,
+	NOT_SUPPORT_SSP = 0x37,
+}tIPCREJREASON;
+
+/*IPC syc task type*/
+
+#define BT_PIN_CODE_MAX_LEN 16
+extern xbyte ipcPinlen;
+extern xbyte ipcPin[BT_PIN_CODE_MAX_LEN];
+extern xbyte current_task;
+
+/*IPC set pincode*/
+#define IPC_SetPincode(p,l)	ipcPinlen= l,\
+							xmemcpy(ipcPin, p, ipcPinlen)
+
+/**
+ * This function rigist IPC Control Block.
+ * 
+ * @param cb the IPC control block.
+ * 
+ * @return none.
+*/
+void IPC_Initialize(tIPCControlBlock *cb);
+
+/**
+ * This function deal IPC Single process, callback the rigisted IPC control function.
+ * 
+ * @param none.
+ * 
+ * @return none.
+*/
+void IPC_DealSingleStep(void);
+
+/**
+ * This function tx control IPC command.
+ * 
+ * @param cmd IPC command want to send.
+ * 
+ * @return none.
+*/
+void IPC_TxControlCmd(byte cmd);
+/**
+ * This function tx HID IPC command,Cpu will block when TxBuffer is not Empty.
+ * 
+ * @param dt IPC HID data want to send,len length of hid data
+ * 
+ * @return none.
+*/
+void IPC_TxBREDRHidData(byte* dt, byte len);
+
+/**
+ * This function tx 24G IPC command,Cpu will block when TxBuffer is not Empty.
+ * 
+ * @param dt IPC HID data want to send,len length of hid data
+ * 
+ * @return none.
+*/
+void IPC_Tx24GData(byte* dt, byte len);
+
+/**
+ * This function tx SPP IPC command,Cpu will block when TxBuffer is not Empty.
+ * 
+ * @param dt IPC SPP data want to send,len length of SPP data
+ * 
+ * @return none.
+*/
+void IPC_TxSppData(byte* dt, byte len);
+
+/**
+ * This function tx BLE IPC command,Cpu will block when TxBuffer is not Empty.
+ * 
+ * @param dt IPC BLE data want to send,len length of BLE data
+ * 
+ * @return none.
+*/
+void IPC_TxBleData(byte* dt, byte len);
+
+/**
+ * This function will do nothing wait enter lpm.
+ * 
+ * @param none.
+ * 
+ * @return none.
+*/
+void IPC_WaitLpm(void);
+
+/**
+ * This function will do nothing abandon lpm this time.
+ * 
+ * @param none.
+ * 
+ * @return none.
+*/
+void IPC_AbandonLpm(void);
+
+/**
+ * This function will do nothing wait enter lpm.
+ * 
+ * @param none.
+ * 
+ * @return none.
+*/
+bit IPC_IsTxBuffEmpty(void);
+
+/**
+ * This function get reject reason.
+ * 
+ * @param none.
+ * 
+ * @return none.
+*/
+tIPCREJREASON IPC_GetBBDIsconnectReason();
+
+#endif /* YC_IPC_H */
Index: c51/kb_process.h
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/kb_process.h	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/kb_process.h	(working copy)
@@ -0,0 +1,99 @@
+#ifndef _KB_PROCESS_H
+#define _KB_PROCESS_H
+#include "common.h"
+
+#define KEY_STANDBY					0x00
+#define KEY_MULIT_PRESS				0x01
+#define KEY_SYSTEM_PRESS			0x04
+#define KEY_WAIT_RELEASE			0x02
+#define KEY_RELEASE					0x03
+#define KEY_2G4_FN_TX				0x04
+
+#define KB_PC_KEYSEL_NUMLOCK		0x01
+#define KB_PC_KEYSEL_CAPSLOCK		0x02
+#define KB_PC_KEYSEL_SCROLLLOCK 	0x04
+
+#define KEY_FLAG_BTKEY_PRESS				0x01
+#define KEY_FLAG_SAME_KEY_PRESS			0x02
+#define KEY_FLAG_STOP_DISCOVERY			0x04
+#define KEY_FLAG_FN_DEVICE_BUTTON			0x08
+#define KEY_FLAG_FN_24G_DEVICE_BUTTON		0x10
+#define KEY_FLAG_FN_SYSTEM_MODE_BUTTON	0x20
+
+#define CAMBINATION_KEY_FREE				0
+#define CAMBINATION_KEY_PRESS				1
+#define CAMBINATION_KEY_HOLD				2
+#define CAMBINATION_KEY_COMPLETE			3
+#define CAMBINATION_KEY_WAIT_RELEASE 		4
+#define CAMBINATION_KEY_RELEASE			5	
+#define CAMBINATION_KEY_NULL				6
+
+
+#define OSMODE_WINDOWS	0x00
+#define OSMODE_MAC			0x01
+#define OSMODE_IOS			0x02
+
+//gipo
+#define EEPROM_WP_GPIO			0xff
+
+#define NUM_LOCK_LED_GPIO    	0xFF
+#define CAPS_LED_GPIO		  	0x1D
+#define BT_LED_GPIO		  		0x1F
+#define LOWPOWER_LED_GPIO		0x14
+#define BT2_LED_GPIO				0x1E
+
+
+//eeprom address base
+#define EEPROM_RECON_INFO_BASE_6  					0x7F50
+#define EEPROM_RECON_INFO_G24_FN_LOCK			(EEPROM_RECON_INFO_BASE_6+6)
+#define EEPROM_RECON_INFO_G24_SYTEM_MODE		(EEPROM_RECON_INFO_BASE_6+7)
+#define EEPROM_RECON_INFO_BASE					0x7F60		// bd_key_record_list = 31*3 = 93
+#define EEPROM_RECON_INFO_LAST_DEVICE 			(EEPROM_RECON_INFO_BASE+93)
+//#define EEPROM_RECON_INFO_POWER_ACTION 			(EEPROM_RECON_INFO_BASE+94)
+#define EEPROM_RECON_INFO_RAMDON_LE_LAP1		(EEPROM_RECON_INFO_BASE+94)
+#define EEPROM_RECON_INFO_RAMDON_LE_LAP2		(EEPROM_RECON_INFO_BASE+95)
+
+#define EEPROM_STORE_TYPE_NORMAL	1
+#define EEPROM_STORE_TYPE_G24			2
+#define EEPROM_STORE_TYPE_BT			3
+
+
+#define KS_KEY_MAP_LEN					158
+#define KB_KSCAN_COL_NUM				20
+
+#define KB_24G_LED_ACK_TYPE			3
+
+byte key_fn_function(byte state ,byte key_value);
+
+
+typedef enum c51_user_key_action
+{
+	KEY_NONE= 0,
+	KEY_RECON_0=1,
+	KEY_RECON_1=2,
+	KEY_RECON_2=3,
+	KEY_ENTER_ADV,
+	KEY_DISCOVERY,
+	KEY_DISCONNECT_ALL,
+	KEY_CLEAR_RECORD,
+	KEY_START_24G,
+	KEY_OPEN_24G,
+	KEY_PAIRING_24G,
+	KEY_STOP_24G,
+	KEY_USB,
+	KEY_STOP_DISCOVERY,
+}C51_KEY_ACTION;
+
+
+
+void IPC_TxHidData(byte* dt, byte len);
+void kb_need_keyscan();
+void YC_key_action_handle(byte key_num);
+void kb_motion_keyscan(tKSEVENT *pEvt);
+byte kb_device_select(tKSEVENT *pEvt);
+void kb_multikey_setup(tKSEVENT *pEvt);
+byte key_fn_function(byte state ,byte key_value);
+
+
+#endif
+
Index: c51/kb_process.c
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/kb_process.c	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/kb_process.c	(working copy)
@@ -0,0 +1,907 @@
+#include "kb_process.h"
+
+void YC_key_action_handle(byte key_num)
+{
+	switch (key_num)
+	{
+	case KEY_RECON_0:
+	case KEY_RECON_1:
+	case KEY_RECON_2:
+		if (g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED 
+			||g_variable.g24_currentState == CHANGE_TO_24G_CONNECTING)
+		{
+			IPC_TxControlCmd(IPC_CMD_STOP_24G);
+			g_variable.key_action = key_num;
+		}
+		else
+		{
+			recon_index = key_num-1;
+			kscurrmult = 0x05;
+			g_variable.recon_count = 5;
+			IPC_TxControlCmd(IPC_CMD_DISCONNECT);
+			Delay1ms(10);
+			IPC_TxControlCmd(IPC_CMD_SET_RECONNECT_INIT);
+			g_variable.key_action = KEY_NONE;
+		}
+		break;
+	case KEY_STOP_DISCOVERY:
+		IPC_TxControlCmd(IPC_CMD_STOP_ADV);
+		break;
+	case KEY_DISCOVERY:
+		g_variable.recon_count = 0;
+		if (YC_disconnect_all_link() || YC_cancel_reconnect() || YC_g24_mode_discovery())
+		{
+			g_variable.key_action = key_num;
+			action_timeout = 3;
+		}
+		else
+		{
+			YC_clear_reconnect_flag();
+				ble_send_secutiry_request_timer = 0;
+				ble_fast_connect_flag = 0;
+				fast_connect_flag = 0;
+//				m_lpm_mode = 0;
+				YC_get_ble_ramdon_lap();
+				IPC_TxControlCmd(IPC_CMD_START_ADV);
+			g_variable.key_action = KEY_NONE;
+		}
+		break;
+	case KEY_DISCONNECT_ALL:
+		YC_disconnect_all_link();
+		g_variable.key_action = KEY_NONE;
+		break;
+	case KEY_CLEAR_RECORD:
+		xmemclear_ff((byte *)bd_key_record_list,sizeof(BD_KEY_RECORD)*3);
+		g_variable.last_device_num = 0xff;
+		g_variable.system_mode = 0xff;
+		Delay1ms(200);
+		GPIO_Setout(EEPROM_WP_GPIO,0);
+		IIC_WriteBlock(EEPROM_RECON_INFO_BASE ,sizeof(BD_KEY_RECORD)*3 , (byte *)&bd_key_record_list);
+		IIC_WriteBlock(EEPROM_RECON_INFO_LAST_DEVICE ,1 ,(byte *)&g_variable.last_device_num);
+		GPIO_Setout(EEPROM_WP_GPIO,1);
+		g_variable.key_action = KEY_NONE;
+		break;
+	case KEY_START_24G:
+	case KEY_OPEN_24G:
+		g_variable.recon_count = 0;
+		if ( YC_cancel_reconnect())
+		{
+			g_variable.key_action = key_num;
+		}
+		else
+		{
+			IIC_Read(EEPROM_RECON_INFO_BASE_6+2,4 , (byte *)m_24g_addr);
+			Delay1ms(10);
+			fast_connect_flag = 0;
+			if (m_24g_addr[0] == 0xff && m_24g_addr[1] == 0xff && m_24g_addr[2] == 0xff && m_24g_addr[3] == 0xff)
+			{
+				m_24g_addr[0] = 0x0f;
+				m_24g_addr[1] = 0x0f;
+				m_24g_addr[2] = 0x0f;
+				m_24g_addr[3] = 0x0f;
+				fast_connect_flag = 1;
+			}
+				
+			IPC_TxControlCmd(IPC_CMD_START_24G);
+			
+			g_variable.g24_currentState = CHANGE_TO_24G_CONNECTING;
+			g_variable.g24_currentSubState = CHANGE_TO_24G_SUB_NONE;
+			g_variable.key_action = KEY_NONE;
+		}
+		break;
+	case KEY_PAIRING_24G:
+		g_variable.recon_count = 0;
+		if (YC_disconnect_all_link() || YC_cancel_reconnect())
+		{
+			g_variable.key_action = key_num;
+		}
+		else
+		{
+			if (g_variable.g24_currentState != CHANGE_TO_24G_PAIRING)
+			{
+				fast_connect_flag = 0;
+				IPC_TxControlCmd(IPC_CMD_PAIR_24G);
+				g_variable.g24_currentState = CHANGE_TO_24G_PAIRING;
+				g_variable.g24_currentSubState = CHANGE_TO_24G_SUB_NONE;
+				g_variable.pairing_g24_timeout = G24_PAIRING_TIME_OUT_20S;
+				GPIO_Setout(LOWPOWER_LED_GPIO,LED_OFF);
+				g_variable.pairing_timeout = 0;
+			}
+			g_variable.key_action = KEY_NONE;
+		}
+		break;
+	default:
+		g_variable.key_action = KEY_NONE;
+		break;
+	}
+}
+
+
+
+void IPC_TxHidData(byte* dt, byte len)
+{
+	xbyte tx_hid_buff[10];
+	byte i=0;
+
+	for(i==0; i< len; i++)
+	{
+		tx_hid_buff[i] = dt[i];
+	}
+	
+	if(!YC_check_need_reconnected()) 
+		return;
+	if (g_variable.release_data)
+		return;
+
+	if ((g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTED) ||
+	((g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTING) && ble_fast_connect_flag))
+	{
+		if (tx_hid_buff[0] == HID_REPORTID_SYSTEM)
+			tx_hid_buff[0] = HID_REPORTID_3;
+		IPC_TxBleData(tx_hid_buff,len);
+
+	}
+	if (g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED)
+	{
+		if(tx_hid_buff[0] == HID_REPORTID_1)
+		{
+			tx_hid_buff[0] = 4;
+			if (tx_hid_buff[1] == 0 && tx_hid_buff[3] == 00 && tx_hid_buff[4] == 00 && tx_hid_buff[5] == 0)
+				repeat_send_24g = 0;
+			else
+				repeat_send_24g = 1;			
+		}
+		else if(tx_hid_buff[0] == HID_REPORTID_2)
+		{
+			tx_hid_buff[0] = 5;
+			if (tx_hid_buff[1] == 00 && tx_hid_buff[2] == 00)
+			{
+				repeat_send_24g = 0;
+			}
+			else
+			{
+				repeat_send_24g = 1;
+			}
+		}
+		else if(tx_hid_buff[0] == HID_REPORTID_3)
+		{
+			tx_hid_buff[0] = 7;
+		}
+		IPC_Tx24GData(tx_hid_buff,len);
+	}
+}
+
+
+void kb_set_multikey(word multikey_value)
+{
+	if(mult_key_status != KEY_WAIT_RELEASE)
+	{
+		mult_key_status = KEY_MULIT_PRESS;
+		multikey[0] = HID_REPORTID_2;
+		multikey[1] = (multikey_value&0xff);
+		multikey[2] = ((multikey_value>>8)&0xff);
+	}
+}
+
+void kb_set_systemkey(byte systemkey_value)
+{
+	if(mult_key_status != KEY_WAIT_RELEASE)
+	{
+		mult_key_status = KEY_SYSTEM_PRESS;
+		system_key_press = 1;
+		multikey[0] = HID_REPORTID_SYSTEM;
+		multikey[1] = systemkey_value;
+	}
+}
+
+
+void kb_send_combination_key(byte ctrl_value,byte key_value)
+{
+	xmemclear(hidBuff,9);
+	hidBuff[0] = HID_REPORTID_1;
+	hidBuff[1] |= ctrl_value;
+	hidBuff[3] = key_value; 
+	IPC_TxHidData(hidBuff, 9);
+}
+
+/*
+void kb_bt_pincode_enter()
+{
+	tKSEVENT *pEvt = NULL;
+	pEvt = KS_GetCurrentEvt();
+	if (pEvt == NULL)
+		return;
+	if (pEvt->ksPool[0] != 0) {
+		if (pEvt->ksPool[0] == HID_KEY_ENTER ||pEvt->ksPool[0] == HID_KEY_KP_ENTER) {
+			if (	g_variable.ble_currentSubState == CHANGE_TO_BLE_SUB_PINCODE)
+			{
+				IPC_TxControlCmd(IPC_CMD_LE_SET_PINCODE);
+				g_variable.ble_currentSubState = CHANGE_TO_BLE_SUB_PINCODE_OK;
+				le_pin_code_len = 0;
+			}
+		}
+		else
+		{
+			if (pEvt->ksPool[0] <=HID_KEY_KP_0 && pEvt->ksPool[0] >= HID_KEY_KP_1)
+			{
+				if (pEvt->ksPool[0] == HID_KEY_KP_0) 
+				{
+					le_pin_code = le_pin_code*10;
+					le_pin_code_len++;
+				}
+				else 
+				{
+					le_pin_code = (le_pin_code*10)+(pEvt->ksPool[0]  - 0x58);
+					le_pin_code_len++;
+				}
+			}
+			else if (pEvt->ksPool[0] <=HID_KEY_0 && pEvt->ksPool[0] >= HID_KEY_1)
+			{
+				if (pEvt->ksPool[0] == HID_KEY_0) 
+				{
+					le_pin_code = le_pin_code*10;
+					le_pin_code_len++;
+				}
+				else 
+				{
+					le_pin_code = (le_pin_code*10)+(pEvt->ksPool[0]  - (HID_KEY_1 -1));
+					le_pin_code_len++;
+				}
+			}
+			else if(pEvt->ksPool[0] == HID_KEY_BACKSPACE) 
+			{
+				if(le_pin_code_len)
+				{
+					le_pin_code = le_pin_code /10;
+					le_pin_code_len--;
+				}	
+			}
+			else
+			{
+				kb_motion_keyscan(pEvt);
+			}
+		}
+	}
+}
+*/
+
+void kb_24g_get_led_status()		//get RF Ack for get numlock/capslock status
+{
+	if((m_24g_led_flag)&& (repeat_send_24g == 0))
+	{
+		if (g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED)
+		{
+			xmemclear(hidBuff,9);
+
+			mult_key_status = 0;
+			hidBuff[0] = HID_REPORTID_1;		// standard key send
+			hidBuff[2] = m_24g_led_flag;
+			IPC_TxHidData(hidBuff, 9);
+		}	
+	}
+}
+
+
+
+static void kb_motion()
+{
+	tKSEVENT *pEvt = NULL;
+	
+	if (!IPC_IsTxBuffEmpty())
+		return;
+	pEvt = KS_GetCurrentEvt();
+
+	if (pEvt == NULL)
+	{
+		m_power_on_flag = 1;
+		kb_24g_get_led_status();
+		return;
+	}
+	kb_motion_keyscan(pEvt);
+}
+
+
+
+void kb_need_keyscan()
+{
+/*
+	 if (g_variable.ble_currentSubState == CHANGE_TO_BLE_SUB_PINCODE 
+		|| g_variable.br_currentSubState == CHANGE_TO_BR_SUB_PINCODE)
+	{
+		kb_bt_pincode_enter();
+	}
+	else
+*/	
+	{	
+		if((g_variable.key_combination_step == CAMBINATION_KEY_FREE)
+		||(g_variable.key_combination_step == CAMBINATION_KEY_COMPLETE)
+		|| (g_variable.key_combination_step == CAMBINATION_KEY_RELEASE)
+		)
+			kb_motion();
+		else
+		{
+			if(g_variable.key_combination_step == CAMBINATION_KEY_PRESS)
+			{
+				kb_send_combination_key(g_variable.key_combination_ctrl,0);
+				g_variable.key_combination_step = CAMBINATION_KEY_HOLD;
+			}
+			else if(g_variable.key_combination_step == CAMBINATION_KEY_HOLD)
+			{	
+				g_variable.key_combination_step = CAMBINATION_KEY_COMPLETE;
+				kb_send_combination_key(g_variable.key_combination_ctrl,g_variable.key_combination_keyvalue);
+			}
+			else if(g_variable.key_combination_step == CAMBINATION_KEY_WAIT_RELEASE)
+			{
+				g_variable.key_combination_keyvalue = 0;
+				kb_send_combination_key(g_variable.key_combination_ctrl,g_variable.key_combination_keyvalue);
+				g_variable.key_combination_ctrl = 0;
+				if(!g_variable.one_key_press_wait_release_timer)
+					g_variable.key_combination_step = CAMBINATION_KEY_NULL;
+				else
+					g_variable.key_combination_step = CAMBINATION_KEY_RELEASE;
+			}
+			else if(g_variable.key_combination_step == CAMBINATION_KEY_NULL)
+			{
+				g_variable.key_combination_keyvalue = 0;
+				g_variable.key_combination_ctrl = 0;
+				kb_send_combination_key(g_variable.key_combination_ctrl,g_variable.key_combination_keyvalue);
+				g_variable.key_combination_step = CAMBINATION_KEY_FREE;
+			}
+		}
+	}
+}
+
+
+
+void kb_motion_keyscan(tKSEVENT *pEvt)
+{
+	byte temp = 0;
+	byte i=0;
+	
+	fn_flag = 0;
+	for(i=0; i < KS_BUFF_POLL_LEN-1; i++)
+	{
+		if (pEvt->ksPool[i] == HID_KEY_FN) 		// Fn key check
+		{
+			fn_flag = 1;
+		}
+	}
+
+	
+	if(kb_device_select(pEvt))		// select device or discovery
+		return;
+	if (pEvt == NULL)
+		return;
+
+#ifdef PC_SLEEP_STATUS_GET
+	if(m_pc_sleep_flag)		// wake from pc sleep,get led status
+	{
+		m_pc_sleep_flag = 0;
+		m_24g_led_flag = KB_24G_LED_ACK_TYPE;	
+	}
+#endif
+	
+	if (g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTED)
+	{
+		kscurrmult = 0x3;
+	}
+	delayChgInvTimer = 10;
+	g_variable.sleepTimer = 0;
+	if(g_variable.battery_status == BAT_STATUS_LOW)
+	{
+		m_24g_enter_hibernate[0]	= 0x00;
+		m_24g_enter_hibernate[1]	= 0x48;
+		m_24g_enter_hibernate[2]	= 0x12;		// 100ms
+		m_24g_enter_hibernate[3]	= 0x00;
+	}
+	else
+	{
+		m_24g_enter_hibernate[0]	= 0x00;
+		m_24g_enter_hibernate[1]	= 0x48;
+		m_24g_enter_hibernate[2]   = 0x5d;		// 510ms
+		m_24g_enter_hibernate[3]	= 0x00;
+	}
+	xmemclear(hidBuff,9);
+	xmemclear(multikey,9);
+
+
+	////////////////////////////2.4g pairing////////////////////////////////////
+	if ((pEvt->ksPool[0]  == HID_KEY_K&& pEvt->ksPool[1]  == HID_KEY_ESC) 
+		||(pEvt->ksPool[0]  == HID_KEY_ESC && pEvt->ksPool[1]  == HID_KEY_K) 
+		)
+	{
+		m_24g_paring_addr[0] = 0x20;
+		m_24g_paring_addr[1] = 0x15;
+		m_24g_paring_addr[2] = 0x10;
+		m_24g_paring_addr[3] = 0x05;
+		if (g_variable.g24_currentState != CHANGE_TO_24G_PAIRING)
+		{
+			g_variable.button_flag |= KEY_FLAG_FN_24G_DEVICE_BUTTON;
+		}
+		else
+		{
+			g_variable.button_flag &= ~KEY_FLAG_FN_24G_DEVICE_BUTTON;
+		}
+	}
+	else
+	{
+		g_variable.button_flag &= ~KEY_FLAG_FN_24G_DEVICE_BUTTON;
+	}
+
+
+
+	m_power_on_flag = 1;
+	if( (g_variable.key_combination_step == CAMBINATION_KEY_PRESS) ||
+	    (g_variable.key_combination_step == CAMBINATION_KEY_WAIT_RELEASE) ||
+	    (g_variable.key_combination_step == CAMBINATION_KEY_HOLD))
+	{
+		return;
+	}
+
+	// get 24g led status
+	if (g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED)
+	{
+		for(i=0; i < KS_BUFF_POLL_LEN-1; i++)
+		{
+			if ((pEvt->ksPool[i] == HID_KEY_CAPS_LOCK) || (pEvt->ksPool[i] == HID_KEY_NUM_LOCK) 
+			|| (pEvt->ksPool[i] == HID_KEY_SCROLL_LOCK))
+			{
+				m_24g_led_flag = KB_24G_LED_ACK_TYPE;
+
+			}
+		}
+	}
+
+	kb_multikey_setup(pEvt);
+	
+	if (mult_key_status == KEY_MULIT_PRESS) 
+	{
+		mult_key_status = KEY_WAIT_RELEASE;
+		multikey[0] = HID_REPORTID_2;
+		IPC_TxHidData(multikey, 3);
+	}
+	else if (mult_key_status == KEY_SYSTEM_PRESS) 
+	{
+		mult_key_status = KEY_WAIT_RELEASE;
+		multikey[0] = HID_REPORTID_SYSTEM;
+		IPC_TxHidData(multikey, 3);
+	}
+	else if((mult_key_status == KEY_RELEASE) || (mult_key_status == KEY_WAIT_RELEASE && (!keyCount)))
+	{
+		mult_key_status = KEY_STANDBY;
+		mult_key_value = 0;	
+		if(system_key_press)
+		{
+			system_key_press = 0;
+			multikey[0] = HID_REPORTID_SYSTEM;
+		}
+		else	
+			multikey[0] = HID_REPORTID_2;
+		IPC_TxHidData(multikey, 3);
+	}
+	else 
+	{
+		if(!keyCount)
+			xmemclear(pEvt->ksPool,6);
+	
+		hidBuff[0] = HID_REPORTID_1;		// standard key send
+		hidBuff[1] = pEvt->standardSel;
+		if (g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED)
+			hidBuff[2] = m_24g_led_flag;
+		else
+			hidBuff[2] = 0;
+
+		standard_key_release_flag = 0;
+		if(!fast_connect_flag)
+		{
+			if (pEvt->ksPool[0] == HID_KEY_FN)
+				xmemcpy(&hidBuff[3], &pEvt->ksPool[1], 5);
+			else
+				xmemcpy(&hidBuff[3], pEvt->ksPool, 6);
+			
+			for(i = 3; i<9;i++)
+			{
+				if (hidBuff[i] == HID_KEY_FN)
+					hidBuff[i] = 0;
+			}
+		}
+		else	
+			xmemcpy(&hidBuff[3], pEvt->ksPool, 6);
+		IPC_TxHidData(hidBuff, 9);
+	}
+	return;
+}
+/////////////////////////////////////////////////////////////////
+
+
+byte kb_device_select(tKSEVENT *pEvt)
+{
+	byte temp = 0;
+	byte i=0;
+	
+	if (fn_flag == 1) 
+	{
+		i = KS_BUFF_POLL_LEN-1;
+
+		while (i--) 
+		{
+			temp = pEvt->ksPool[i];
+
+			if (temp == HID_KEY_P) 
+			{
+						g_variable.delay_enter_lpm_timer = 10;
+
+						g_variable.button_flag |= KEY_FLAG_FN_DEVICE_BUTTON;
+						g_variable.button_flag &= ~KEY_FLAG_FN_24G_DEVICE_BUTTON;
+						if((g_variable.current_device_num != (temp-(HID_KEY_P - 1))) ||(g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED))
+						{
+							g_variable.current_device_num = temp-(HID_KEY_P - 1);
+							g_variable.button_reconnect_flag = 1;		// long press = 3s enter discovery
+							g_variable.powerOn_timer = 0;
+						}
+				return 1;
+			}
+			else
+			{
+				g_variable.button_flag &= ~(KEY_FLAG_FN_DEVICE_BUTTON |KEY_FLAG_FN_24G_DEVICE_BUTTON);
+			}
+
+			
+			if((temp == HID_KEY_Q) || (temp == HID_KEY_W) || (temp == HID_KEY_O)|| (temp == HID_KEY_E))
+			{
+				g_variable.delay_enter_lpm_timer = 10;
+				key_value_temp = temp;
+				g_variable.button_flag |= KEY_FLAG_FN_SYSTEM_MODE_BUTTON;
+				return 1;
+			}
+			else
+				g_variable.button_flag &= ~KEY_FLAG_FN_SYSTEM_MODE_BUTTON;
+		}
+	}
+	else
+	{
+//		i = KS_BUFF_POLL_LEN-1;
+//		while (i--) 
+//		{
+//			temp = pEvt->ksPool[i];
+
+			if (pEvt->ksPool[0] == HID_KEY_PB)                                                                                       //24G pairing button
+			{
+				g_variable.delay_enter_lpm_timer = 10;
+				g_variable.button_flag &= ~KEY_FLAG_FN_DEVICE_BUTTON;
+				g_variable.button_flag |= KEY_FLAG_FN_24G_DEVICE_BUTTON;
+				if( (g_variable.current_device_num != 0) && (g_variable.current_device_num != 0xfe))
+				{
+					g_variable.button_24G_rec_flag = 1;
+					g_variable.current_device_num =0;
+					g_variable.powerOn_timer = 0;
+
+				}
+				return 1;
+			}
+		
+			else if (pEvt->ksPool[0] == HID_KEY_BLE_1 ||pEvt->ksPool[0] ==  HID_KEY_BLE_2)                 //ble 1 /2  pairing button
+			{
+				g_variable.delay_enter_lpm_timer = 10;
+				g_variable.button_flag |= KEY_FLAG_FN_DEVICE_BUTTON;
+				g_variable.button_flag &= ~KEY_FLAG_FN_24G_DEVICE_BUTTON;
+				if((g_variable.current_device_num != (pEvt->ksPool[0]-(HID_KEY_BLE_1 - 1))) ||(g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED))
+				{
+					g_variable.current_device_num = pEvt->ksPool[0]-(HID_KEY_BLE_1 - 1);
+					g_variable.button_reconnect_flag = 1;		// long press = 3s enter discovery
+					g_variable.powerOn_timer = 0;
+				}
+				return 1;
+			}
+
+//		}
+		g_variable.button_flag &= ~(KEY_FLAG_FN_DEVICE_BUTTON |KEY_FLAG_FN_24G_DEVICE_BUTTON) ;
+		g_variable.button_flag &= ~KEY_FLAG_FN_SYSTEM_MODE_BUTTON;
+	}
+	return 0;
+}
+
+
+
+
+void kb_combination_key_press(byte press_state,byte special_key,byte standrad_key)
+{
+	g_variable.key_combination_ctrl = special_key;	
+	g_variable.key_combination_keyvalue = standrad_key;
+
+	if(press_state & 1)
+	{
+		if(g_variable.key_combination_step == CAMBINATION_KEY_COMPLETE) 
+			g_variable.key_combination_step = CAMBINATION_KEY_HOLD;
+		else	
+			g_variable.key_combination_step = CAMBINATION_KEY_PRESS;
+	}
+	else
+	{
+		g_variable.key_combination_step = CAMBINATION_KEY_WAIT_RELEASE;
+	}
+
+}
+
+
+byte key_fn_function(byte state ,byte key_value)
+{
+	byte temp = 0;
+
+	if(state & 1)
+		g_variable.one_key_press_wait_release_timer = 0;
+
+	temp = key_value;
+	if(g_variable.system_mode != OSMODE_WINDOWS)
+	{
+		if(key_value == HID_KEY_RIGHT_ALT)
+			temp = HID_KEY_RIGHT_GUI;
+		else if(key_value == HID_KEY_RIGHT_CTL)
+			temp = HID_KEY_RIGHT_ALT;	
+		else if(key_value == HID_KEY_LEFT_GUI)
+			temp = HID_KEY_LEFT_ALT;
+		else if(key_value == HID_KEY_LEFT_ALT)
+			temp = HID_KEY_LEFT_GUI;	
+	}
+	if(g_variable.system_mode == OSMODE_WINDOWS)
+	{
+		if(key_value == HID_MULTIKEY_OS_LOCK)
+		{
+			kb_combination_key_press(state,KS_SEL_LGUI,HID_KEY_L);
+			temp = HID_KEY_NULL;
+		}
+	}
+	if(fn_flag == 1)			// Fn lock
+	{
+		if(key_value == HID_KEY_HOME)
+		{
+			temp = HID_KEY_PRINT_SCREEN;
+		}
+		else if(key_value == HID_KEY_END)
+		{
+			temp = HID_KEY_PAUSE;
+		}
+		else if(key_value == HID_KEY_DOWN_ARROW)
+		{
+			temp = HID_MULTIKEY_LIGHT_DOWN;
+		}
+		else if(key_value == HID_KEY_ENTER)
+		{
+			temp = HID_KEY_SCROLL_LOCK;
+		}
+		else if(key_value == HID_KEY_BACKSPACE)
+		{
+			temp = HID_MULTIKEY_OS_LOCK;
+		}
+		else if(key_value == HID_KEY_ESC)
+		{
+			if(state & 1)
+			{						
+				if(fn_lock_flag)
+				{
+					fn_lock_flag = 0;
+				}
+				else
+					fn_lock_flag = 1;
+					
+				if(g_variable.current_device_num == 0 || g_variable.current_device_num == 0xfe)
+				{
+					g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_G24;
+				}
+				else	if (g_variable.current_device_num <= 3 && g_variable.current_device_num >= 1)
+				{
+					bd_key_record_list[g_variable.current_device_num - 1].fn_lock = fn_lock_flag;
+					g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_BT;
+				}
+			}
+			temp = HID_KEY_NULL;
+		}		
+	}
+	
+	if((!fast_connect_flag)  && ((!fn_flag && !fn_lock_flag) || (fn_flag == 1 && fn_lock_flag == 1)))
+	{
+		switch (key_value)
+		{ 	
+			case HID_KEY_F1:
+				temp = HID_MULTIKEY_LIGHT_DOWN;	
+				break;
+			case HID_KEY_F2:
+				temp = HID_MULTIKEY_LIGHT_UP;
+				break;
+			case HID_KEY_F3:
+				temp = HID_MULTIKEY_AC_HOME;
+				break;
+			case HID_KEY_F4:
+				if(g_variable.system_mode == OSMODE_WINDOWS)
+				{
+					kb_combination_key_press(state,KS_SEL_LALT,HID_KEY_TAB);
+					if(state & 1)
+					{						
+						g_variable.one_key_press_wait_release_timer = 10;
+					}
+				}
+				else if(g_variable.system_mode == OSMODE_MAC)
+				{
+					kb_combination_key_press(state,KS_SEL_LCTRL,HID_KEY_UP_ARROW);
+				}
+				else if(g_variable.system_mode == OSMODE_IOS)
+				{
+					kb_combination_key_press(state,KS_SEL_LGUI,HID_KEY_TAB);
+					if(state & 1)
+					{						
+						g_variable.one_key_press_wait_release_timer = 10;
+					}
+				}
+				temp = HID_KEY_NULL;
+				break;
+			case HID_KEY_F5:
+				if(g_variable.system_mode == OSMODE_WINDOWS)
+				{
+					temp = HID_MULTIKEY_AC_BACK;
+				}
+				else
+				{
+					kb_combination_key_press(state,KS_SEL_LGUI,HID_KEY_LEFT_ARROW);
+					temp = HID_KEY_NULL;
+				}
+				break;
+			case HID_KEY_F6:
+				temp = HID_MULTIKEY_AC_SEARCH;
+				break;
+			case HID_KEY_F7:
+				temp = HID_MULTIKEY_PRE_TRACK;
+				break;	
+			case HID_KEY_F8:
+				temp = HID_MULTIKEY_PALY;
+				break;
+			case HID_KEY_F9:
+				temp = HID_MULTIKEY_NEXT_TRACK;
+				break;
+			case HID_KEY_F10:
+				temp = HID_MULTIKEY_MUTE;
+				break;
+			case HID_KEY_F11:
+				temp = HID_MULTIKEY_VOL_DOWN;
+				break;
+			case HID_KEY_F12:
+				temp = HID_MULTIKEY_VOL_UP;
+				break;
+			default :
+				break;
+		}
+	}
+
+	return temp;
+}
+
+
+
+void kb_multikey_setup(tKSEVENT *pEvt)
+{
+	byte i = 0;
+	
+	for (i = 0;i < 6;i++)
+	{		
+		if ((pEvt->ksPool[i] &0xF0) == 0xf0 
+			|| (pEvt->ksPool[i] &0xD0) == 0xD0)
+		{
+			
+			if (pEvt->ksPool[i] ==  HID_MULTIKEY_MEDIA) //media select
+			{
+				kb_set_multikey(0x0183); 
+			}
+			else
+			if (pEvt->ksPool[i] ==  HID_MULTIKEY_PALY) //play / pause
+			{ 
+				kb_set_multikey(0x00cd);
+			}
+			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_STOP)  //stop
+			{
+				kb_set_multikey(0x00b7);
+			}	
+			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_PRE_TRACK) //pre Track
+			{
+				kb_set_multikey(0x00b6);
+			}
+			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_NEXT_TRACK) //next Track
+			{
+				kb_set_multikey(0x00b5);
+			}
+			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_VOL_DOWN) //vol-
+			{
+				kb_set_multikey(0x00ea);
+			}
+			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_VOL_UP) //vol+
+			{
+				kb_set_multikey(0x00e9);
+			}
+			else	if (pEvt->ksPool[i] ==  HID_MULTIKEY_MUTE) //mute
+			{
+				kb_set_multikey(0x00e2);
+			}
+			else	if (pEvt->ksPool[i] ==  HID_MULTIKEY_MY_COMPUTER) 
+			{
+				kb_set_multikey(0x0194);
+			}	
+			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_MAIL)  //mail
+			{
+				kb_set_multikey(0x018a);//mail
+			}
+			else	if (pEvt->ksPool[i] ==  HID_MULTIKEY_CALCULATOR) //calculator
+			{
+				kb_set_multikey(0x0192);
+			}
+			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_AC_FAVORITES) 
+			{
+				kb_set_multikey(0x022a);//www Favorites
+			}
+			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_AC_FORWARD)  
+			{
+				kb_set_multikey(0x0225);
+			}
+			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_AC_STOP)  //www Stop
+			{
+				kb_set_multikey(0x0226);
+			}
+			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_AC_BACK)  
+			{
+				kb_set_multikey(0x0224);
+			}
+			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_AC_REFRESH) //www refresh
+			{
+				kb_set_multikey(0x0227);
+			}	
+			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_AC_SEARCH)  //www search
+			{
+				kb_set_multikey(0x0221);
+			}
+			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_AC_HOME)
+			{
+				kb_set_multikey(0x0223);
+			}
+			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_LIGHT_DOWN)
+			{
+				kb_set_multikey(0x0070);
+			}
+			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_LIGHT_UP)
+			{
+				kb_set_multikey(0x006f);
+			}	
+			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_IOS_SOFT_KB)  //IOS VIR KB
+		      	{
+		        	kb_set_multikey(0x00b8);
+		      	}
+		      else if (pEvt->ksPool[i] ==  HID_MULTIKEY_OS_LOCK)
+		      	{
+		        	kb_set_multikey(0x0030);
+		      	}	
+		      	else if (pEvt->ksPool[i] ==  HID_MULTIKEY_ANDROID_SETUP_SHORTCUTS)
+		      	{
+		        	kb_set_multikey(0x0306);
+		      	}
+		      	else if (pEvt->ksPool[i] ==  HID_MULTIKEY_ANDROID_SOFT_KB)
+		      	{
+		        	kb_set_multikey(0x0307);
+		      	}
+		      	else if (pEvt->ksPool[i] ==  HID_SYSTEM_KEY_POWER_DOWN)
+		      	{
+		        	kb_set_systemkey(0x01);
+		      	}
+		      	else if (pEvt->ksPool[i] ==  HID_SYSTEM_KEY_SLEEP)
+		      	{
+		        	kb_set_systemkey(0x02);
+		      	}
+		      	else if (pEvt->ksPool[i] ==  HID_SYSTEM_KEY_WAKE_UP)
+		      	{
+		        	kb_set_systemkey(0x04);
+		      	}
+			
+			if(mult_key_status == KEY_WAIT_RELEASE)
+			{
+				mult_key_value = pEvt->ksPool[i];
+				pEvt->ksPool[i] = 0;
+			}
+		}
+	}
+}
+
Index: c51/kbhid.h
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/kbhid.h	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/kbhid.h	(working copy)
@@ -0,0 +1,300 @@
+#ifndef _KB_KEY_HID_
+#define _KB_KEY_HID_
+
+
+    /// KB USB usages
+enum UsbUsage {
+        HID_KEY_A 	= 0x04,
+        HID_KEY_B 	= 0x05,
+        HID_KEY_C 	= 0x06,
+        HID_KEY_D 	= 0x07,
+        HID_KEY_E 	= 0x08,
+        HID_KEY_F 	= 0x09,
+        HID_KEY_G 	= 0x0a,
+        HID_KEY_H 	= 0x0b,
+        HID_KEY_I  	= 0x0c,
+        HID_KEY_J 	= 0x0d,
+        HID_KEY_K 	= 0x0e,
+        HID_KEY_L 	= 0x0f,
+        HID_KEY_M 	= 0x10,
+        HID_KEY_N 	= 0x11,
+        HID_KEY_O	= 0x12,
+        HID_KEY_P	= 0x13,
+        HID_KEY_Q	= 0x14,
+        HID_KEY_R	= 0x15,
+        HID_KEY_S	= 0x16,
+        HID_KEY_T	= 0x17,
+        HID_KEY_U	= 0x18,
+        HID_KEY_V	= 0x19,
+        HID_KEY_W 	= 0x1a,
+        HID_KEY_X	= 0x1b,
+        HID_KEY_Y	= 0x1c,
+        HID_KEY_Z	= 0x1d,
+    
+        HID_KEY_1	= 0x1e,
+        HID_KEY_2	= 0x1f,
+        HID_KEY_3	= 0x20,
+        HID_KEY_4	= 0x21,
+        HID_KEY_5	= 0x22,
+        HID_KEY_6	= 0x23,
+        HID_KEY_7	= 0x24,
+        HID_KEY_8	= 0x25,
+        HID_KEY_9	= 0x26,
+        HID_KEY_0	= 0x27,
+    
+        HID_KEY_ENTER 				= 0x28,
+        HID_KEY_ESC				= 0x29,
+        HID_KEY_BACKSPACE		= 0x2a,
+        HID_KEY_TAB				= 0x2b,
+        HID_KEY_SPACE 				= 0x2c,
+        HID_KEY_MINUS				= 0x2d,		// -_
+        HID_KEY_EQUAL				= 0x2e,		// =+
+        HID_KEY_LEFT_BRACKET 		= 0x2f,		// [{
+        HID_KEY_RIGHT_BRACKET 	= 0x30,		// ]}
+        HID_KEY_BACK_SLASH 		= 0x31,		// \|
+    
+        HID_KEY_K42				= 0x32,
+        HID_KEY_SEMICOLON			= 0x33,		// ;:
+        HID_KEY_QUOTE				= 0x34,		// ' "
+        HID_KEY_TILDE				= 0x35,		// `~
+        HID_KEY_LESS_THAN			= 0x36,		// ,<
+        HID_KEY_GREAT_THAN		= 0x37,		// .>
+        HID_KEY_SLASH				= 0x38,		// /?
+        HID_KEY_CAPS_LOCK			= 0x39,
+
+        HID_KEY_F1		= 0x3a,
+        HID_KEY_F2		= 0x3b,
+        HID_KEY_F3		= 0x3c,
+        HID_KEY_F4		= 0x3d,
+        HID_KEY_F5		= 0x3e,
+        HID_KEY_F6		= 0x3f,
+        HID_KEY_F7		= 0x40,
+        HID_KEY_F8		= 0x41,
+        HID_KEY_F9		= 0x42,
+        HID_KEY_F10	= 0x43,
+        HID_KEY_F11	= 0x44,
+        HID_KEY_F12	= 0x45,
+    
+        HID_KEY_PRINT_SCREEN	= 0x46,
+        HID_KEY_SCROLL_LOCK	= 0x47,
+        HID_KEY_PAUSE			= 0x48,
+        HID_KEY_INSERT			= 0x49,
+        HID_KEY_HOME			= 0x4a,
+        HID_KEY_PAGE_UP		= 0x4b,
+        HID_KEY_DELETE		= 0x4c,
+        HID_KEY_END			= 0x4d,
+        HID_KEY_PAGE_DOWN	= 0x4e,
+        
+        HID_KEY_RIGHT_ARROW	= 0x4f,
+        HID_KEY_LEFT_ARROW	= 0x50,
+        HID_KEY_DOWN_ARROW	= 0x51,
+        HID_KEY_UP_ARROW		= 0x52,
+        
+        HID_KEY_NUM_LOCK		= 0x53,
+        HID_KEY_KP_SLASH		= 0x54,
+        HID_KEY_KP_ASTERISK	= 0x55,
+        HID_KEY_KP_MINUS		= 0x56,
+        HID_KEY_KP_PLUS		= 0x57,
+        HID_KEY_KP_ENTER		= 0x58,
+        HID_KEY_KP_1			= 0x59,
+        HID_KEY_KP_2			= 0x5a,
+        HID_KEY_KP_3			= 0x5b,
+        HID_KEY_KP_4			= 0x5c,
+        HID_KEY_KP_5			= 0x5d,
+        HID_KEY_KP_6			= 0x5e,
+        HID_KEY_KP_7			= 0x5f,
+        HID_KEY_KP_8			= 0x60,
+        HID_KEY_KP_9			= 0x61,
+        HID_KEY_KP_0			= 0x62,
+        HID_KEY_KP_DEL		= 0x63,
+  
+        HID_KEY_K45			= 0x64,
+        HID_KEY_APP			= 0x65,
+        HID_KEY_POWER			= 0x66,
+        HID_KEY_KP_EQUAL		= 0x67,
+        
+        HID_KEY_F13			= 0x68,
+        HID_KEY_F14			= 0x69,
+        HID_KEY_F15			= 0x6A,
+        HID_KEY_F16			= 0x6B,
+        HID_KEY_F17			= 0x6C,
+        HID_KEY_F18			= 0x6D,
+        HID_KEY_F19			= 0x6E,
+        HID_KEY_F20			= 0x6F,
+        HID_KEY_F21			= 0x70,
+        HID_KEY_F22			= 0x71,
+        HID_KEY_F23			= 0x72,
+        HID_KEY_F24			= 0x73,
+        
+        HID_KEY_EXECUTE		= 0x74,
+        HID_KEY_HELP			= 0x75,
+        HID_KEY_MENU			= 0x76,
+        HID_KEY_SELECT		= 0x77,
+    
+        HID_KEY_STOP			= 0x78,
+        HID_KEY_AGAIN			= 0x79,
+        HID_KEY_UNDO			= 0x7a,
+        HID_KEY_CUT			= 0x7b,
+        HID_KEY_COPY			= 0x7c,
+        HID_KEY_PASTE			= 0x7d,
+        HID_KEY_FIND			= 0x7e,
+        HID_KEY_MUTE			= 0x7f,
+        HID_KEY_VOL_UP		= 0x80,
+        HID_KEY_VOL_DOWN		= 0x81,
+    
+        HID_KEY_LOCKING_CAPS_LOCK		= 0x82,
+        HID_KEY_LOCKING_NUM_LOCK		= 0x83,
+        HID_KEY_LOCKING_SCROLL_LOCK		= 0x84,
+        HID_KEY_KP_COMMA					= 0x85,
+        HID_KEY_KP_EQUAL_AS400			= 0x86,
+        
+        HID_KEY_K56				= 0x87,
+        HID_KEY_K133  				= 0x88,
+        HID_KEY_K14  				= 0x89,
+        HID_KEY_K132  				= 0x8a,
+        HID_KEY_K131 				= 0x8b,
+    
+        HID_KEY_INTL_6				= 0x8c,
+        HID_KEY_INTL_7				= 0x8d,
+        HID_KEY_INTL_8				= 0x8e,
+        HID_KEY_INTL_9				= 0x8f,
+        HID_KEY_KR_R  				= 0x90,
+        HID_KEY_KR_L  				= 0x91,
+        HID_KEY_LANG_3			= 0x92,
+        HID_KEY_LANG_4			= 0x93,
+        HID_KEY_LANG_5			= 0x94,
+        HID_KEY_LANG_6			= 0x95,
+    
+        HID_KEY_LANG_7			= 0x96,
+        HID_KEY_LANG_8			= 0x97,
+        HID_KEY_LANG_9			= 0x98,
+        HID_KEY_ALT_ERASE			= 0x99,
+        HID_KEY_SYS_REQ			= 0x9a,
+        HID_KEY_CANCEL			= 0x9b,
+        HID_KEY_CLEAR				= 0x9c,
+        HID_KEY_PRIOR				= 0x9d,
+        HID_KEY_RETURN			= 0x9e,
+        HID_KEY_SEPARATOR		= 0x9f,
+    
+        HID_KEY_OUT				= 0xa0,
+        HID_KEY_OPER				= 0xa1,
+        HID_KEY_CLEAR_AGAIN		= 0xa2,
+        HID_KEY_CRSEL				= 0xa3,
+        HID_KEY_EXSEL				= 0xa4,
+    
+        // Reserved 0xa5~0xaf
+        HID_KEY_KP_00						= 0xb0,
+        HID_KEY_KP_000						= 0xb1,
+        HID_KEY_THOUSANDS_SEPERATOR	= 0xb2,
+        HID_KEY_DECIMAL_SEPERATOR		= 0xb3,
+        HID_KEY_CURRENCY_UNIT			= 0xb4,
+        HID_KEY_CURRENCY_SUB_UNIT		= 0xb5,
+        HID_KEY_KP_LEFT_PAREN			= 0xb6,
+        HID_KEY_KP_RIGHT_PAREN			= 0xb7,
+        HID_KEY_KP_LEFT_CURLY_BRACE		= 0xb8,
+        HID_KEY_KP_RIGHT_CURLY_BRACE	= 0xb9,
+        HID_KEY_KP_TAB					= 0xba,
+        HID_KEY_KP_BACKSPACE				= 0xbb,
+        HID_KEY_KP_A						= 0xbc,
+        HID_KEY_KP_B						= 0xbd,
+        HID_KEY_KP_C						= 0xbe,
+        HID_KEY_KP_D						= 0xbf,
+        HID_KEY_KP_E						= 0xc0,
+        HID_KEY_KP_F						= 0xc1,
+        HID_KEY_KP_XOR					= 0xc2,
+        HID_KEY_KP_CARET					= 0xc3,
+        HID_KEY_KP_PERCENT				= 0xc4,
+        HID_KEY_KP_LESS_THAN				= 0xc5,
+        HID_KEY_KP_GREATER_THAN			= 0xc6,
+        HID_KEY_KP_AMPERSAND				= 0xc7,
+    
+        HID_KEY_KP_DOUBLE_AMPERSAND	= 0xc8,
+        HID_KEY_KP_VERTICAL_BAR			= 0xc9,
+        HID_KEY_KP_DOUBLE_VERTICAL_BAR	= 0xca,
+        HID_KEY_KP_COLON					= 0xcb,
+        HID_KEY_KP_HASH					= 0xcc,
+        HID_KEY_KP_SPACE					= 0xcd,
+        HID_KEY_KP_AT						= 0xce,
+        HID_KEY_KP_EXCLAMATION			= 0xcf,
+        HID_KEY_KP_MEM_STORE			= 0xd0,
+        HID_KEY_KP_MEM_RECALL			= 0xd1,
+    
+        HID_KEY_KP_MEM_CLEAR				= 0xd2,
+        HID_KEY_KP_MEM_ADD				= 0xd3,
+        HID_KEY_KP_MEM_SUBTRACT			= 0xd4,
+        HID_KEY_KP_MEM_MULTIPLY			= 0xd5,
+        HID_KEY_KP_MEM_DIVIDE				= 0xd6,
+        HID_KEY_KP_PLUS_MINUS				= 0xd7,
+        HID_KEY_KP_CLEAR					= 0xd8,
+        HID_KEY_KP_CLEAR_ENTRY			= 0xd9,
+        HID_KEY_KP_BINARY					= 0xda,
+        HID_KEY_KP_OCTAL					= 0xdb,
+    
+        HID_KEY_KP_DECIMAL				= 0xdc,
+        HID_KEY_KP_HEX					= 0xdd,
+        // 0xde~0xdf reserved
+        
+        HID_KEY_LEFT_CTL			= 0xe0,
+        HID_KEY_LEFT_SHIFT			= 0xe1,
+        HID_KEY_LEFT_ALT 			= 0xe2,
+        HID_KEY_LEFT_GUI 			= 0xe3,
+        HID_KEY_RIGHT_CTL			= 0xe4,
+        HID_KEY_RIGHT_SHIFT		= 0xe5,
+        HID_KEY_RIGHT_ALT			= 0xe6,
+        HID_KEY_RIGHT_GUI			= 0xe7,
+        // 0xe8~0xff reserved
+        HID_KEY_FN 					= 0x7f,
+        HID_KEY_PB					= 0xef,
+        HID_KEY_BLE_1				= 0xe9,
+        HID_KEY_BLE_2				= 0xea,
+        HID_KEY_NULL 				= 0x00,
+};
+
+enum multKey{
+//mult key
+	HID_MULTIKEY_MEDIA		= 0xF1,
+ 	HID_MULTIKEY_PALY		= 0xF2,
+ 	HID_MULTIKEY_STOP		= 0xF3,
+ 	HID_MULTIKEY_PRE_TRACK	= 0xF4,
+ 	HID_MULTIKEY_NEXT_TRACK	= 0xF5,
+ 	HID_MULTIKEY_VOL_DOWN	= 0xF6,
+ 	HID_MULTIKEY_VOL_UP		= 0xF7,
+ 	HID_MULTIKEY_MUTE			= 0xF8,
+ 	HID_MULTIKEY_MY_COMPUTER 	= 0xF9,
+ 	HID_MULTIKEY_MAIL			= 0xFA,
+ 	HID_MULTIKEY_CALCULATOR	= 0xFB,
+
+
+ 	HID_MULTIKEY_AC_FAVORITES	= 0xD0,
+ 	HID_MULTIKEY_AC_FORWARD	= 0xD1,
+ 	HID_MULTIKEY_AC_BACK		= 0xD2,
+ 	HID_MULTIKEY_AC_STOP		= 0xD3,
+ 	HID_MULTIKEY_AC_REFRESH	= 0xD4,
+ 	HID_MULTIKEY_AC_SEARCH	= 0xD5,
+ 	HID_MULTIKEY_AC_HOME		= 0xD6,
+ 	HID_MULTIKEY_LIGHT_DOWN	= 0xD7,
+ 	HID_MULTIKEY_LIGHT_UP		= 0xD8,
+ 	HID_MULTIKEY_IOS_SOFT_KB 	= 0xD9,		
+	HID_MULTIKEY_OS_LOCK 		= 0xDA,		//lock screen
+	HID_MULTIKEY_ANDROID_SETUP_SHORTCUTS = 0xDB,	
+	HID_MULTIKEY_ANDROID_SOFT_KB	= 0xDC,
+	HID_SYSTEM_KEY_POWER_DOWN 	= 0xDD,
+	HID_SYSTEM_KEY_SLEEP 			= 0xDE,
+	HID_SYSTEM_KEY_WAKE_UP		= 0xDF
+};
+
+enum hidReportId{
+	HID_REPORTID_1 = 0x01,
+	HID_REPORTID_2 = 0x02,
+	HID_REPORTID_3 = 0x03,
+	HID_REPORTID_BATTERY = 0x04,
+	HID_REPORTID_FAST_CONN_NAME = 0x05,
+	HID_REPORTID_SYSTEM = 0x06
+};
+
+enum hidReportLen{
+	HID_REPORTLEN_1 = 0x09,
+	HID_REPORTLEN_2 = 0x05
+};
+
+#endif
Index: c51/keyscan.h
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/keyscan.h	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/keyscan.h	(working copy)
@@ -0,0 +1,61 @@
+/*
+ * Copyright 2016, yichip Semiconductor(shenzhen office)
+ * All Rights Reserved.
+ *
+ * This is UNPUBLISHED PROPRIETARY SOURCE CODE of Yichip Semiconductor;
+ * the contents of this file may not be disclosed to third parties, copied
+ * or duplicated in any form, in whole or in part, without the prior
+ * written permission of Yichip Semiconductor.
+ */
+#include "common.h"
+
+#ifndef _KEYSCAN_
+#define _KEYSCAN_
+
+#define KS_SEL_RGUI					0x80
+#define KS_SEL_RALT					0x40
+#define KS_SEL_RSHIFT				0x20
+#define KS_SEL_RCTRL				0x10
+#define KS_SEL_LGUI					0x08
+#define KS_SEL_LALT					0x04
+#define KS_SEL_LSHIFT				0x02
+#define KS_SEL_LCTRL				0x01
+
+#define KS_BUFF_POLL_LEN 6
+typedef struct {
+	byte standardSel;
+	byte ksPool[KS_BUFF_POLL_LEN];
+}tKSEVENT;
+
+/**
+ * This function initlialize key scan hardware.
+ * 
+ * @param none.
+ * 
+ * @return none.
+*/
+void KS_Initialize(void);
+
+/**
+ * This function Get Keyscan event message.
+ * 
+ * @param none.
+ * 
+ * @return ptr of keyscan event.
+*/
+tKSEVENT *KS_GetCurrentEvt();
+
+/**
+ * This function scan ks matrix.
+ * 
+ * @param none.
+ * 
+ * @return ptr of keyscan event.
+*/
+void KS_ScanMatrix();
+
+void KS_Unistall();
+
+
+#endif
+ 
\ No newline at end of file
Index: c51/keyscan.c
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/keyscan.c	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/keyscan.c	(working copy)
@@ -0,0 +1,406 @@
+#include "keyscan.h"
+
+
+extern code byte col[KB_KSCAN_COL_NUM+1];
+extern code byte  ksMap[KS_KEY_MAP_LEN];
+
+
+#define GET_RAW_KEY_SEL(y, g, n)	REG_GPIO_PUP (g) &= ~n; \
+	REG_GPIO_OE(g) |= n; \
+	REG_GPIO_OUT(g) &= ~n;	\
+	y = ~ REG_GPIO_IN(0);	\
+	REG_GPIO_PUP(g) |= n;	\
+	REG_GPIO_OE(g) &= ~n
+
+
+#define GET_RAW_KEY_SEL0(y,x)		GPIO_SetOutput(x, 0); \
+		y = ~ REG_GPIO_IN(0);	\
+		GPIO_SetInput(x, 0)
+
+tKSEVENT xdata ksEvtPool;
+
+#define MAX(a,b) ((a)>(b)?(a):(b))
+
+static byte bit_count(byte v)
+{
+	unsigned char c;
+	for (c = 0; v; c++) {
+    	v &= v - 1;
+    }
+    return c;
+}
+
+
+//byte col[] = {25,26};
+static void keyIn(byte key)
+{
+	byte i = 0;
+
+	if(key >= HID_KEY_LEFT_CTL && key <= HID_KEY_RIGHT_GUI)
+	{
+		ksEvtPool.standardSel  |=  0x01 << (key & 0x07);
+		return;
+	}
+/*
+
+	if (key == HID_KEY_RIGHT_GUI)
+	{
+		ksEvtPool.standardSel |= KS_SEL_RGUI;
+		return;
+	}
+	else if (key ==HID_KEY_RIGHT_ALT) 
+	{
+		ksEvtPool.standardSel |= KS_SEL_RALT;
+		return;
+	}
+	else if (key ==HID_KEY_RIGHT_SHIFT) 
+	{
+		ksEvtPool.standardSel |= KS_SEL_RSHIFT;
+		return;
+	}
+	else if (key ==HID_KEY_RIGHT_CTL) 
+	{
+		ksEvtPool.standardSel |= KS_SEL_RCTRL;
+		return;
+	}
+	else if (key ==HID_KEY_LEFT_GUI) 
+	{
+		ksEvtPool.standardSel |= KS_SEL_LGUI;
+		return;
+	}
+	else if (key ==HID_KEY_LEFT_ALT) 
+	{
+		ksEvtPool.standardSel |= KS_SEL_LALT;
+		return;
+	}
+	else if (key ==HID_KEY_LEFT_SHIFT)
+	{
+		ksEvtPool.standardSel |= KS_SEL_LSHIFT;
+		return;
+	}
+	else if (key ==HID_KEY_LEFT_CTL) 
+	{
+		ksEvtPool.standardSel |= KS_SEL_LCTRL;
+		return;
+	}
+*/	
+	//special key
+
+	for (i=0 ; i<KS_BUFF_POLL_LEN ; i++) 
+	{
+		if (ksEvtPool.ksPool[i] == key)
+			break;
+		if (ksEvtPool.ksPool[i] == 0) 
+		{
+			if(mult_key_value != key)
+				ksEvtPool.ksPool[i] = key;
+			break;
+		}
+	}
+}
+
+static void keyOut(byte key)
+{
+	byte i = 0 ;
+	byte found = 0;
+
+	if ((key &0xF0) == 0xf0 || (key &0xD0) == 0xD0)
+	{
+		if(mult_key_status == KEY_WAIT_RELEASE)
+		{
+			mult_key_status = KEY_RELEASE;
+		}
+	}
+	else
+		standard_key_release_flag = 1;
+
+	if(key >= HID_KEY_LEFT_CTL && key <= HID_KEY_RIGHT_GUI)
+	{
+		ksEvtPool.standardSel  &= ~(0x01 << (key & 0x07));
+		return;
+	}
+	
+
+/*
+	if (key == HID_KEY_RIGHT_GUI ) 
+	{
+		ksEvtPool.standardSel &= ~KS_SEL_RGUI;
+		return;
+	}
+	else if (key ==HID_KEY_RIGHT_ALT ) 
+	{
+		ksEvtPool.standardSel &= ~KS_SEL_RALT;
+		return;
+	}
+	else if (key ==HID_KEY_RIGHT_SHIFT) 
+	{
+		ksEvtPool.standardSel &= ~KS_SEL_RSHIFT;
+		return;
+	}
+	else if (key ==HID_KEY_RIGHT_CTL) 
+	{
+		ksEvtPool.standardSel &= ~KS_SEL_RCTRL;
+		return;
+	}
+	else if (key ==HID_KEY_LEFT_GUI)
+	{
+		ksEvtPool.standardSel &= ~KS_SEL_LGUI;
+		return;
+	}
+	else if (key ==HID_KEY_LEFT_ALT)
+	{
+		ksEvtPool.standardSel &= ~KS_SEL_LALT;
+		return;
+	}
+	else if (key ==HID_KEY_LEFT_SHIFT) 
+	{
+		ksEvtPool.standardSel &= ~KS_SEL_LSHIFT;
+		return;
+	}
+	else if (key ==HID_KEY_LEFT_CTL) 
+	{
+		ksEvtPool.standardSel &= ~ KS_SEL_LCTRL;
+		return;
+	}
+*/	
+	for (i=0 ; i<KS_BUFF_POLL_LEN ; i++) 
+	{
+		if (found == 0) 
+		{
+			if (ksEvtPool.ksPool[i] == key) {
+				if (i == KS_BUFF_POLL_LEN-1) {
+					ksEvtPool.ksPool[i] = 0;
+				}
+				found = 1;
+			}
+		}
+		else 
+		{
+			ksEvtPool.ksPool[i-1] = ksEvtPool.ksPool[i];
+			if (ksEvtPool.ksPool[i] == 0)
+				break;
+			if (i == KS_BUFF_POLL_LEN-1) {
+				ksEvtPool.ksPool[i] = 0;
+			}
+		}
+	}
+}
+
+static void ksRawInitialize()
+{
+	byte i = 0;
+	
+	for (i=0; i<8; i++) {
+		GPIO_SetInput(i, 0);
+	}
+}
+
+static void ksColInitialize()
+{
+	byte i = 0;
+	for (i=0; col[i]!=0; i++) {
+		GPIO_SetInput(col[i], 0);
+	}
+}
+
+void KS_Initialize()
+{
+	REG_GPIO_SELECT(0) = 0;
+	REG_GPIO_SELECT(1) = 0;
+	REG_GPIO_SELECT(2) = 0;
+	ksRawInitialize();
+	ksColInitialize();
+}
+
+void KS_Unistall()
+{
+	byte i = 0;
+	byte temp = 0;
+	byte tgroup = 0;
+	byte tgpionum = 0;
+	for (i=0; col[i]!=0; i++) {
+		tgroup = col[i]  >> 3;
+		tgpionum = 1 << (col[i] & 7);
+		REG_GPIO_PUP (tgroup) &= ~tgpionum;
+		REG_GPIO_OE(tgroup) |= tgpionum;
+		REG_GPIO_OUT(tgroup) &= ~tgpionum;
+	}
+	
+	GPIO_fillpd();
+	
+	temp = REG_GPIO_IN(0);
+
+	if(long_press_flag)
+	{
+		GPIO_SetWakeupByCurrentState(0);
+		GPIO_SetWakeupByCurrentState(1);
+		GPIO_SetWakeupByCurrentState(2);
+		GPIO_SetWakeupByCurrentState(3);
+		GPIO_SetWakeupByCurrentState(4);
+		GPIO_SetWakeupByCurrentState(5);
+		GPIO_SetWakeupByCurrentState(6);
+		GPIO_SetWakeupByCurrentState(7);
+	}
+	else
+	{
+		YC_GPIOWakeupL[0] = temp;
+		YC_GPIOWakeupH[0] = ~temp;
+	}
+
+}
+
+
+void KS_ScanMatrix()
+{
+	byte i = 0;
+	byte j = 0;
+	byte tgroup = 0;
+	byte tgpionum = 0;
+	byte temp = 0;
+	byte check = 0;
+	for (i=0; col[i]!=0; i++) {
+		tgroup = col[i]  >> 3;
+		tgpionum = 1 << (col[i] & 7);
+		GET_RAW_KEY_SEL(ksSelMapCurr[i], tgroup, tgpionum);
+	}
+
+	for (i=0; col[i]!=0; i++) {
+		tgroup = col[i]  >> 3;
+		tgpionum = 1 << (col[i] & 7);
+		GET_RAW_KEY_SEL(ksSelMapCheck[i], tgroup, tgpionum);
+	}
+
+	for (i=0; col[i]!=0; i++) {
+		if (ksSelMapCheck[i]!=ksSelMapCurr[i]) {
+			ksSelMapCurr[i] &= ksSelMapCheck[i];
+		}
+	}
+}
+
+byte array_is_empty(byte * str1,byte len)
+{
+	byte i;
+	for (i=0;i < len;i++)
+	{
+		if (str1[i] != 0)
+			return 0x00;
+	}
+	return 0x01;
+}
+
+
+tKSEVENT *KS_GetCurrentEvt()
+{
+	//
+	byte i = 0;
+	byte j = 0;
+	byte k = 0;
+	byte temp = 0;
+	byte flag = 0;
+	byte offset = 0;
+	byte state = 0;
+	byte keyCounttemp = 0;
+	byte key_value_temp = 0;
+	byte ghost = 0;
+	byte rawCount = 0;
+	
+	KS_ScanMatrix();
+
+	if (compare_str(ksSelMapCurr,ksSelMapCheck,KB_KSCAN_COL_NUM) 
+		&& !array_is_empty(ksSelMapCurr,KB_KSCAN_COL_NUM))
+	{
+		g_variable.button_flag |= 0x02;
+		g_variable.battery_motion_check_interval = BATTERY_MOTION_CHECK_INTERVAL;
+	}
+	else
+	{	
+		g_variable.button_flag &= 0xFD;
+		g_variable.button_timer[1] = 0;
+	}
+
+	for (i=0; col[i]!=0; i++) 
+	{
+		temp = ksSelMapCurr[i];
+		rawCount = bit_count(temp);
+		if(rawCount >= 2)		// col[i] has more than two key press
+		{
+			for(j=0 ; j<8 ;j++)
+			{
+				if(temp & (1<<j))	// Ci_Rj press
+				{
+					for(k=0 ; col[k]!=0; k++)
+					{
+						if(k!= i)
+						{
+							if(ksSelMapCurr[k] & (1<<j))	// R line has another key press
+							{
+								ghost = 1;
+								break;
+							}	
+						}
+					}
+				}
+			}
+		}
+		
+		if (temp!=0)
+		{
+			keyCounttemp += bit_count(temp);
+		}
+	}
+	keyCount = keyCounttemp;
+	
+	for (i=0; col[i]!=0; i++)
+	{
+		temp = ksSelMapCurr[i] ^ ksSelMapOld[i];
+		state = ksSelMapCurr[i];
+		if (temp == 0) 
+		{
+			continue;
+		}
+		else 
+		{
+
+			if (ghost) 
+				return NULL;
+			ksSelMapOld[i] = ksSelMapCurr[i];
+			for (j = 0 ; j<8 ; j++) 
+			{
+				if (temp&1)
+				{
+					offset = i<<3 |j;
+					key_value_temp = key_fn_function(state,ksMap[offset]);
+					if (state & 1)
+					{
+						keyIn(key_value_temp);
+					}
+					else
+					{
+						keyOut(key_value_temp);
+					}
+				}
+				temp = temp >>1;
+				state = state>>1;
+			}
+			flag = 1;
+		}
+	}
+	
+	if((mult_key_status == KEY_RELEASE) && (standard_key_release_flag == 1))
+	{
+		standard_key_release_flag = 2;		//media key and standard key  release the same time
+	}
+
+	
+	if (flag || standard_key_release_flag == 2) 
+	{
+		return &ksEvtPool;
+	}
+	else
+	{
+		return NULL;
+	}
+	
+
+}
+
Index: c51/led.h
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/led.h	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/led.h	(working copy)
@@ -0,0 +1,16 @@
+#ifndef _LED_H
+#define _LED_H
+#include "common.h"
+
+#define LED_ON 1
+#define LED_OFF 0
+
+
+void LED_all_shutdown();
+void LED_handle();
+void LED_device_poweron();
+void LED_device_poweroff();
+
+#endif /* YC_LED_H */
+
+
Index: c51/output/FW
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/output/FW
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/led.c
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/led.c	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/led.c	(working copy)
@@ -0,0 +1,165 @@
+#include "led.h"
+
+
+void LED_all_shutdown()
+{
+//	GPIO_SetOutput(NUM_LOCK_LED_GPIO,LED_OFF);
+	GPIO_SetOutput(CAPS_LED_GPIO,LED_OFF);
+	GPIO_SetOutput(BT_LED_GPIO,LED_OFF);
+	GPIO_SetOutput(BT2_LED_GPIO,LED_OFF);	
+	GPIO_SetOutput(LOWPOWER_LED_GPIO,LED_OFF);
+//	GPIO_SetOutput(G24_LED_GPIO,LED_OFF);
+}
+
+
+void LED_device_poweron()
+{
+/*
+	if(g_variable.powerOn_first_flag == 0)
+	{
+		if(g_variable.current_device_num == 1)
+			GPIO_Setout(BT_LED_GPIO,LED_ON);
+		else if(g_variable.current_device_num == 2)
+			GPIO_Setout(BT2_LED_GPIO,LED_ON);
+		else if(g_variable.current_device_num == 3)
+		{	
+			GPIO_SetOutput(BT_LED_GPIO,LED_ON);
+			GPIO_SetOutput(LOWPOWER_LED_GPIO,LED_ON);
+		}
+		else if(g_variable.current_device_num == 0)
+		{
+			GPIO_Setout(LOWPOWER_LED_GPIO,LED_ON);
+		}
+	}
+*/
+//	else
+//	{
+		
+		GPIO_Setout(CAPS_LED_GPIO,LED_ON);
+		GPIO_Setout(BT_LED_GPIO,LED_ON);
+		GPIO_Setout(BT2_LED_GPIO,LED_ON);	
+		GPIO_Setout(LOWPOWER_LED_GPIO,LED_ON);
+//	}
+	
+
+}
+
+void LED_device_poweroff()
+{
+/*
+	if(g_variable.current_device_num == 1)
+		GPIO_Setout(BT_LED_GPIO,LED_OFF);
+	else if(g_variable.current_device_num == 2)
+		GPIO_Setout(BT2_LED_GPIO,LED_OFF);
+	else if(g_variable.current_device_num == 3)
+	{	
+		GPIO_Setout(BT_LED_GPIO,LED_OFF);
+		GPIO_SetOutput(LOWPOWER_LED_GPIO,LED_OFF);
+	}
+	else
+	{
+		GPIO_Setout(BT_LED_GPIO,LED_OFF);
+		GPIO_Setout(BT2_LED_GPIO,LED_OFF);
+		GPIO_Setout(LOWPOWER_LED_GPIO,LED_OFF);
+		GPIO_Setout(CAPS_LED_GPIO,LED_OFF);
+
+	}
+*/
+	GPIO_Setout(BT_LED_GPIO,LED_OFF);
+	GPIO_Setout(BT2_LED_GPIO,LED_OFF);
+	GPIO_Setout(LOWPOWER_LED_GPIO,LED_OFF);
+	GPIO_Setout(CAPS_LED_GPIO,LED_OFF);
+//	g_variable.powerOn_first_flag = 0;
+}
+
+
+void LED_handle()
+{
+	if (power_on_flag != 2)
+		return;
+
+	if(!g_variable.pairing_timeout && !g_variable.pairing_g24_timeout)
+	{
+		//low battery LED process
+		if (g_variable.battery_status == BAT_STATUS_SHUT_DOWN)
+		{
+			System_long_sleep();
+		}
+		else if (g_variable.battery_status == BAT_STATUS_LOW)
+		{
+			if (g_variable.battery_low_led_flash_flag == 0)
+			{
+				g_variable.battery_low_led_flash_interval = LOW_BATTERY_FLASH_INTERVAL;
+				g_variable.battery_low_led_flash_flag = 1;
+			}
+		}
+		else
+		{
+			if (g_variable.battery_low_led_flash_flag == 1)
+			{
+				g_variable.battery_low_led_flash_flag = 0;
+				g_variable.battery_low_led_flash_interval = 0;
+				GPIO_Setout(LOWPOWER_LED_GPIO, LED_OFF);
+			}
+		}
+
+		//capslock  numlock  scrolllock LED process
+		if (YC_check_is_connected()&& !g_variable.powerOn_timer)
+		{
+			if(m_caps_num_lock != m_caps_num_lock_last)
+			{
+				if(m_caps_num_lock & KB_PC_KEYSEL_NUMLOCK)
+				{
+					g_variable.sys_numlockled_on_timer = KB_NUM_CAPS_LED_ON_TIMER;
+					GPIO_Setout(NUM_LOCK_LED_GPIO, LED_ON);
+				}
+				else
+				{
+					GPIO_Setout(NUM_LOCK_LED_GPIO, LED_OFF);
+					g_variable.sys_numlockled_on_timer = 0;
+				}
+				
+				if(m_caps_num_lock & KB_PC_KEYSEL_CAPSLOCK)
+				{
+					g_variable.sys_capslockled_on_timer = KB_NUM_CAPS_LED_ON_TIMER;
+					GPIO_Setout(CAPS_LED_GPIO, LED_ON);
+				}
+				else 
+				{
+					GPIO_Setout(CAPS_LED_GPIO, LED_OFF);
+					g_variable.sys_capslockled_on_timer = 0;
+				}	
+
+				
+				if(m_caps_num_lock & KB_PC_KEYSEL_SCROLLLOCK)
+				{
+					g_variable.sys_scrolllockled_on_timer = KB_NUM_CAPS_LED_ON_TIMER;
+					if(!g_variable.powerOn_timer && !g_variable.battery_low_led_flash_interval)
+						GPIO_Setout(LOWPOWER_LED_GPIO, LED_ON);
+				}
+				else 
+				{
+					if(!g_variable.powerOn_timer && !g_variable.battery_low_led_flash_interval)
+						GPIO_Setout(LOWPOWER_LED_GPIO, LED_OFF);
+					g_variable.sys_scrolllockled_on_timer = 0;
+				}
+				m_24g_led_flag = 0;	
+				m_caps_num_lock_last = m_caps_num_lock;
+			}
+		}
+		else
+		{
+			GPIO_Setout(NUM_LOCK_LED_GPIO, LED_OFF);
+//			GPIO_Setout(CAPS_LED_GPIO, LED_OFF);
+		}
+	}
+	else
+	{
+		GPIO_Setout(NUM_LOCK_LED_GPIO, LED_OFF);
+
+	}
+
+}
+
+
+
Index: c51/output/FW.COD
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/FW.COD	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/FW.COD	(working copy)
@@ -0,0 +1,10649 @@
+LX51 LINKER/LOCATER V4.66.97.0                                                          07/11/2022  10:06:55  PAGE 1
+
+
+
+
+
+ASSEMBLER CODE PACKING OF MODULE:  OUTPUT\FW (BLUETOOTH)
+
+
+----- FUNCTION _YC_load_record_list (BEGIN) -----
+ FILE: 'bluetooth.c'
+    4: void YC_load_record_list(byte index)
+    5: {
+000737 904EFE            MOV      DPTR,#index
+00073A EF                MOV      A,R7
+00073B F0                MOVX     @DPTR,A
+    6: 	if (g_variable.recon_count == 0)
+    7: 		return;
+00073C 904CF0            MOV      DPTR,#g_variable+031H
+00073F E0                MOVX     A,@DPTR
+000740 7002              JNZ      $ + 4H
+000742 E1FD              AJMP     ?C0002?BLUETOOTH
+    8: 	g_variable.recon_count--;
+000744 14                DEC      A
+000745 F0                MOVX     @DPTR,A
+    9: 	ble_reconnect_flag = 0;
+000746 E4                CLR      A
+000747 904DE5            MOV      DPTR,#ble_reconnect_flag
+00074A F0                MOVX     @DPTR,A
+   10: 	fast_connect_flag = 0;
+00074B 904E55            MOV      DPTR,#fast_connect_flag
+00074E F0                MOVX     @DPTR,A
+   11: 	if (bd_key_record_list[index].device_type == TYPE_BLE)		
+00074F 904EFE            MOV      DPTR,#index
+000752 E0                MOVX     A,@DPTR
+000753 FF                MOV      R7,A
+000754 75F01F            MOV      B,#01FH
+000757 A4                MUL      AB
+000758 24EE              ADD      A,#LOW bd_key_record_list
+00075A F582              MOV      DPL,A
+00075C E4                CLR      A
+00075D 344D              ADDC     A,#HIGH bd_key_record_list
+00075F F583              MOV      DPH,A
+000761 E0                MOVX     A,@DPTR
+000762 6401              XRL      A,#01H
+000764 7070              JNZ      ?C0003?BLUETOOTH
+   12: 	{
+   13: 		xmemcpy(m_reconn_addr,bd_key_record_list[index].device_addr,6);
+000766 EF                MOV      A,R7
+000767 75F01F            MOV      B,#01FH
+00076A A4                MUL      AB
+00076B 24EF              ADD      A,#LOW bd_key_record_list+01H
+00076D F9                MOV      R1,A
+00076E 744D              MOV      A,#HIGH bd_key_record_list+01H
+000770 35F0              ADDC     A,B
+000772 FA                MOV      R2,A
+000773 7B01              MOV      R3,#01H
+000775 7E42              MOV      R6,#HIGH m_reconn_addr
+000777 7F74              MOV      R7,#LOW m_reconn_addr
+000779 904EC4            MOV      DPTR,#?_xmemcpy?BYTE+05H
+00077C 7406              MOV      A,#06H
+00077E F0                MOVX     @DPTR,A
+00077F 120878            LCALL    _xmemcpy
+   14: 		xmemcpy(m_le_ltk,bd_key_record_list[index].device_link_key,16);
+000782 904EFE            MOV      DPTR,#index
+000785 E0                MOVX     A,@DPTR
+000786 75F01F            MOV      B,#01FH
+000789 A4                MUL      AB
+00078A 24F5              ADD      A,#LOW bd_key_record_list+07H
+00078C F9                MOV      R1,A
+00078D 744D              MOV      A,#HIGH bd_key_record_list+07H
+00078F 35F0              ADDC     A,B
+000791 FA                MOV      R2,A
+000792 7B01              MOV      R3,#01H
+000794 7E44              MOV      R6,#HIGH m_le_ltk
+000796 7F7B              MOV      R7,#LOW m_le_ltk
+000798 904EC4            MOV      DPTR,#?_xmemcpy?BYTE+05H
+00079B 7410              MOV      A,#010H
+00079D F0                MOVX     @DPTR,A
+00079E 120878            LCALL    _xmemcpy
+   15: 		xmemcpy(m_le_lap,bd_key_record_list[index].local_addr,6);
+0007A1 904EFE            MOV      DPTR,#index
+0007A4 E0                MOVX     A,@DPTR
+0007A5 75F01F            MOV      B,#01FH
+0007A8 A4                MUL      AB
+0007A9 2405              ADD      A,#LOW bd_key_record_list+017H
+0007AB F9                MOV      R1,A
+0007AC 744E              MOV      A,#HIGH bd_key_record_list+017H
+0007AE 35F0              ADDC     A,B
+0007B0 FA                MOV      R2,A
+0007B1 7B01              MOV      R3,#01H
+0007B3 7E44              MOV      R6,#HIGH m_le_lap
+0007B5 7FF9              MOV      R7,#LOW m_le_lap
+0007B7 904EC4            MOV      DPTR,#?_xmemcpy?BYTE+05H
+0007BA 7406              MOV      A,#06H
+0007BC F0                MOVX     @DPTR,A
+0007BD 120878            LCALL    _xmemcpy
+   16: 		IPC_TxControlCmd(IPC_CMD_START_ADV_REC);		//ble reconnect
+0007C0 7F2B              MOV      R7,#02BH
+0007C2 12149D            LCALL    _IPC_TxControlCmd
+   17: 		ble_reconnect_flag = 1;
+0007C5 904DE5            MOV      DPTR,#ble_reconnect_flag
+0007C8 7401              MOV      A,#01H
+0007CA F0                MOVX     @DPTR,A
+   18: 		g_variable.recon_count = 0;
+0007CB E4                CLR      A
+0007CC 904CF0            MOV      DPTR,#g_variable+031H
+0007CF F0                MOVX     @DPTR,A
+   19: 		m_ltk_exists = 1;
+0007D0 90448B            MOV      DPTR,#m_ltk_exists
+0007D3 04                INC      A
+0007D4 F0                MOVX     @DPTR,A
+   20: 	}
+0007D5 22                RET      
+0007D6         ?C0003?BLUETOOTH:
+   21: 	else		// ble fast connect
+   22: 	{
+   23: 		fast_connect_flag = 1;
+0007D6 904E55            MOV      DPTR,#fast_connect_flag
+0007D9 7401              MOV      A,#01H
+0007DB F0                MOVX     @DPTR,A
+   24: 	#ifdef BLE_FAST_CONNECT_ENABLE
+   25: 			m_le_lap[0] = 0x0F;
+0007DC 9044F9            MOV      DPTR,#m_le_lap
+0007DF 740F              MOV      A,#0FH
+0007E1 F0                MOVX     @DPTR,A
+   26: 			m_le_lap[1] = 0x0F;
+0007E2 A3                INC      DPTR
+0007E3 F0                MOVX     @DPTR,A
+   27: 			m_le_lap[2] = 0x0F;
+0007E4 A3                INC      DPTR
+0007E5 F0                MOVX     @DPTR,A
+   28: 			m_le_lap[3] = 0x0F;
+0007E6 A3                INC      DPTR
+0007E7 F0                MOVX     @DPTR,A
+   29: 			m_le_lap[4] = 0x0F;
+0007E8 A3                INC      DPTR
+0007E9 F0                MOVX     @DPTR,A
+   30: 			m_le_lap[5] = 0x0F;
+0007EA A3                INC      DPTR
+0007EB F0                MOVX     @DPTR,A
+   31: 			ble_fast_connect_flag =1;
+0007EC 904DD3            MOV      DPTR,#ble_fast_connect_flag
+0007EF 7401              MOV      A,#01H
+0007F1 F0                MOVX     @DPTR,A
+   32: 			IPC_TxControlCmd(IPC_CMD_START_ADV_REC);
+0007F2 7F2B              MOV      R7,#02BH
+0007F4 12149D            LCALL    _IPC_TxControlCmd
+   33: 			m_link_key_exists = 1;
+0007F7 90425E            MOV      DPTR,#m_link_key_exists
+0007FA 7401              MOV      A,#01H
+0007FC F0                MOVX     @DPTR,A
+   34: 	#endif
+   35: 
+   36: 	}	
+   37: }
+0007FD         ?C0002?BLUETOOTH:
+0007FD 22                RET      
+----- FUNCTION _YC_load_record_list (END) -------
+
+
+----- FUNCTION _YC_store_record_list (BEGIN) -----
+ FILE: 'bluetooth.c'
+   41: void YC_store_record_list(byte link_type,byte index)
+   42: {
+0007FE 904EFF            MOV      DPTR,#index
+000801 ED                MOV      A,R5
+000802 F0                MOVX     @DPTR,A
+;---- Variable 'link_type' assigned to Register 'R7' ----
+   43: 	if (link_type == TYPE_BLE) 
+   44: 	{
+000803 EF                MOV      A,R7
+000804 6401              XRL      A,#01H
+000806 706F              JNZ      ?C0006?BLUETOOTH
+   45: 		bd_key_record_list[index].device_type = TYPE_BLE;
+   46: 		xmemcpy(bd_key_record_list[index].device_addr,m_remote_le_addr,6);
+000808 E0                MOVX     A,@DPTR
+000809 FF                MOV      R7,A
+00080A 75F01F            MOV      B,#01FH
+00080D A4                MUL      AB
+00080E 24EE              ADD      A,#LOW bd_key_record_list
+000810 F582              MOV      DPL,A
+000812 E4                CLR      A
+000813 344D              ADDC     A,#HIGH bd_key_record_list
+000815 F583              MOV      DPH,A
+000817 7401              MOV      A,#01H
+000819 F0                MOVX     @DPTR,A
+   47: 		xmemcpy(bd_key_record_list[index].device_link_key,m_le_ltk,16);
+00081A EF                MOV      A,R7
+00081B 75F01F            MOV      B,#01FH
+00081E A4                MUL      AB
+00081F 24EF              ADD      A,#LOW bd_key_record_list+01H
+000821 F582              MOV      DPL,A
+000823 E4                CLR      A
+000824 344D              ADDC     A,#HIGH bd_key_record_list+01H
+000826 AF82              MOV      R7,DPL
+000828 FE                MOV      R6,A
+000829 7B01              MOV      R3,#01H
+00082B 7A03              MOV      R2,#HIGH m_remote_le_addr
+00082D 79D0              MOV      R1,#LOW m_remote_le_addr
+00082F 904EC4            MOV      DPTR,#?_xmemcpy?BYTE+05H
+000832 7406              MOV      A,#06H
+000834 F0                MOVX     @DPTR,A
+000835 1178              ACALL    _xmemcpy
+   48: 		xmemcpy(bd_key_record_list[index].local_addr,m_le_lap,6);
+000837 904EFF            MOV      DPTR,#index
+00083A E0                MOVX     A,@DPTR
+00083B 75F01F            MOV      B,#01FH
+00083E A4                MUL      AB
+00083F 24F5              ADD      A,#LOW bd_key_record_list+07H
+000841 F582              MOV      DPL,A
+000843 E4                CLR      A
+000844 344D              ADDC     A,#HIGH bd_key_record_list+07H
+000846 AF82              MOV      R7,DPL
+000848 FE                MOV      R6,A
+000849 7B01              MOV      R3,#01H
+00084B 7A44              MOV      R2,#HIGH m_le_ltk
+00084D 797B              MOV      R1,#LOW m_le_ltk
+00084F 904EC4            MOV      DPTR,#?_xmemcpy?BYTE+05H
+000852 7410              MOV      A,#010H
+000854 F0                MOVX     @DPTR,A
+000855 1178              ACALL    _xmemcpy
+   49: 	}
+000857 904EFF            MOV      DPTR,#index
+00085A E0                MOVX     A,@DPTR
+00085B 75F01F            MOV      B,#01FH
+00085E A4                MUL      AB
+00085F 2405              ADD      A,#LOW bd_key_record_list+017H
+000861 F582              MOV      DPL,A
+000863 E4                CLR      A
+000864 344E              ADDC     A,#HIGH bd_key_record_list+017H
+000866 AF82              MOV      R7,DPL
+000868 FE                MOV      R6,A
+000869 7B01              MOV      R3,#01H
+00086B 7A44              MOV      R2,#HIGH m_le_lap
+00086D 79F9              MOV      R1,#LOW m_le_lap
+00086F 904EC4            MOV      DPTR,#?_xmemcpy?BYTE+05H
+000872 7406              MOV      A,#06H
+000874 F0                MOVX     @DPTR,A
+000875 1178              ACALL    _xmemcpy
+   50: }
+   51: 
+000877         ?C0006?BLUETOOTH:
+000877 22                RET      
+----- FUNCTION _YC_store_record_list (END) -------
+
+
+----- FUNCTION _xmemcpy (BEGIN) -----
+000878 904EBF            MOV      DPTR,#dest
+00087B EE                MOV      A,R6
+00087C F0                MOVX     @DPTR,A
+00087D A3                INC      DPTR
+00087E EF                MOV      A,R7
+00087F F0                MOVX     @DPTR,A
+000880 A3                INC      DPTR
+000881 EB                MOV      A,R3
+000882 F0                MOVX     @DPTR,A
+000883 A3                INC      DPTR
+000884 EA                MOV      A,R2
+000885 F0                MOVX     @DPTR,A
+000886 A3                INC      DPTR
+000887 E9                MOV      A,R1
+000888 F0                MOVX     @DPTR,A
+000889         ?C0002?UTILITIES:
+000889 904EC4            MOV      DPTR,#len
+00088C E0                MOVX     A,@DPTR
+00088D FF                MOV      R7,A
+00088E 14                DEC      A
+00088F F0                MOVX     @DPTR,A
+000890 EF                MOV      A,R7
+000891 6027              JZ       ?C0004?UTILITIES
+000893 904EC1            MOV      DPTR,#src
+000896 E0                MOVX     A,@DPTR
+000897 FB                MOV      R3,A
+000898 A3                INC      DPTR
+000899 E4                CLR      A
+00089A 75F001            MOV      B,#01H
+00089D 120424            LCALL    ?C?ILDIX
+0008A0 A9F0              MOV      R1,B
+0008A2 FA                MOV      R2,A
+0008A3 1203B6            LCALL    ?C?CLDPTR
+0008A6 FF                MOV      R7,A
+0008A7 904EBF            MOV      DPTR,#dest
+0008AA E4                CLR      A
+0008AB 75F001            MOV      B,#01H
+0008AE 120424            LCALL    ?C?ILDIX
+0008B1 85F082            MOV      DPL,B
+0008B4 F583              MOV      DPH,A
+0008B6 EF                MOV      A,R7
+0008B7 F0                MOVX     @DPTR,A
+0008B8 80CF              SJMP     ?C0002?UTILITIES
+0008BA         ?C0004?UTILITIES:
+0008BA 22                RET      
+----- FUNCTION _xmemcpy (END) -------
+
+
+----- FUNCTION _kb_motion_keyscan (BEGIN) -----
+ FILE: 'kb_process.c'
+  356: void kb_motion_keyscan(tKSEVENT *pEvt)
+  357: {
+0008BB 904EC5            MOV      DPTR,#pEvt
+0008BE EB                MOV      A,R3
+0008BF F0                MOVX     @DPTR,A
+0008C0 A3                INC      DPTR
+0008C1 EA                MOV      A,R2
+0008C2 F0                MOVX     @DPTR,A
+0008C3 A3                INC      DPTR
+0008C4 E9                MOV      A,R1
+0008C5 F0                MOVX     @DPTR,A
+  358: 	byte temp = 0;
+  359: 	byte i=0;
+0008C6 E4                CLR      A
+0008C7 A3                INC      DPTR
+0008C8 F0                MOVX     @DPTR,A
+  360: 	
+0008C9 A3                INC      DPTR
+0008CA F0                MOVX     @DPTR,A
+  361: 	fn_flag = 0;
+0008CB 904DE2            MOV      DPTR,#fn_flag
+0008CE F0                MOVX     @DPTR,A
+  362: 	for(i=0; i < KS_BUFF_POLL_LEN-1; i++)
+0008CF 904EC9            MOV      DPTR,#i
+0008D2 F0                MOVX     @DPTR,A
+0008D3         ?C0070?KB_PROCESS:
+0008D3 904EC9            MOV      DPTR,#i
+0008D6 E0                MOVX     A,@DPTR
+0008D7 FF                MOV      R7,A
+0008D8 C3                CLR      C
+0008D9 9405              SUBB     A,#05H
+0008DB 7480              MOV      A,#080H
+0008DD 9480              SUBB     A,#080H
+0008DF 502C              JNC      ?C0071?KB_PROCESS
+  363: 	{
+  364: 		if (pEvt->ksPool[i] == HID_KEY_FN) 		// Fn key check
+0008E1 904EC5            MOV      DPTR,#pEvt
+0008E4 E0                MOVX     A,@DPTR
+0008E5 FB                MOV      R3,A
+0008E6 A3                INC      DPTR
+0008E7 E0                MOVX     A,@DPTR
+0008E8 FA                MOV      R2,A
+0008E9 A3                INC      DPTR
+0008EA E0                MOVX     A,@DPTR
+0008EB 2401              ADD      A,#01H
+0008ED F9                MOV      R1,A
+0008EE E4                CLR      A
+0008EF 3A                ADDC     A,R2
+0008F0 FA                MOV      R2,A
+0008F1 7E00              MOV      R6,#00H
+0008F3 E9                MOV      A,R1
+0008F4 2F                ADD      A,R7
+0008F5 F9                MOV      R1,A
+0008F6 EE                MOV      A,R6
+0008F7 3A                ADDC     A,R2
+0008F8 FA                MOV      R2,A
+0008F9 1203B6            LCALL    ?C?CLDPTR
+0008FC 647F              XRL      A,#07FH
+0008FE 7005              JNZ      ?C0072?KB_PROCESS
+  365: 		{
+  366: 			fn_flag = 1;
+000900 904DE2            MOV      DPTR,#fn_flag
+000903 04                INC      A
+000904 F0                MOVX     @DPTR,A
+  367: 		}
+  368: 	}
+000905         ?C0072?KB_PROCESS:
+000905 904EC9            MOV      DPTR,#i
+000908 E0                MOVX     A,@DPTR
+000909 04                INC      A
+00090A F0                MOVX     @DPTR,A
+00090B 80C6              SJMP     ?C0070?KB_PROCESS
+00090D         ?C0071?KB_PROCESS:
+  369: 
+  370: 	
+  371: 	if(kb_device_select(pEvt))		// select device or discovery
+00090D 904EC5            MOV      DPTR,#pEvt
+000910 E0                MOVX     A,@DPTR
+000911 FB                MOV      R3,A
+000912 A3                INC      DPTR
+000913 E0                MOVX     A,@DPTR
+000914 FA                MOV      R2,A
+000915 A3                INC      DPTR
+000916 E0                MOVX     A,@DPTR
+000917 F9                MOV      R1,A
+000918 1226FB            LCALL    _kb_device_select
+00091B EF                MOV      A,R7
+00091C 6002              JZ       $ + 4H
+00091E 61DC              AJMP     ?C0075?KB_PROCESS
+  372: 		return;
+  373: 	if (pEvt == NULL)
+000920 904EC5            MOV      DPTR,#pEvt
+000923 E0                MOVX     A,@DPTR
+000924 A3                INC      DPTR
+000925 E0                MOVX     A,@DPTR
+000926 FA                MOV      R2,A
+000927 A3                INC      DPTR
+000928 E0                MOVX     A,@DPTR
+000929 4A                ORL      A,R2
+00092A 7002              JNZ      $ + 4H
+00092C 61DC              AJMP     ?C0075?KB_PROCESS
+  374: 		return;
+  375: 
+  376: #ifdef PC_SLEEP_STATUS_GET
+  377: 	if(m_pc_sleep_flag)		// wake from pc sleep,get led status
+00092E 904D7D            MOV      DPTR,#m_pc_sleep_flag
+000931 E0                MOVX     A,@DPTR
+000932 6008              JZ       ?C0077?KB_PROCESS
+  378: 	{
+  379: 		m_pc_sleep_flag = 0;
+000934 E4                CLR      A
+000935 F0                MOVX     @DPTR,A
+  380: 		m_24g_led_flag = KB_24G_LED_ACK_TYPE;	
+000936 904D46            MOV      DPTR,#m_24g_led_flag
+000939 7403              MOV      A,#03H
+00093B F0                MOVX     @DPTR,A
+  381: 	}
+00093C         ?C0077?KB_PROCESS:
+  382: #endif
+  383: 	
+  384: 	if (g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTED)
+00093C 904CC7            MOV      DPTR,#g_variable+08H
+00093F E0                MOVX     A,@DPTR
+000940 6404              XRL      A,#04H
+000942 7006              JNZ      ?C0078?KB_PROCESS
+  385: 	{
+  386: 		kscurrmult = 0x3;
+000944 904213            MOV      DPTR,#kscurrmult
+000947 7403              MOV      A,#03H
+000949 F0                MOVX     @DPTR,A
+  387: 	}
+00094A         ?C0078?KB_PROCESS:
+  388: 	delayChgInvTimer = 10;
+00094A 904DE6            MOV      DPTR,#delayChgInvTimer
+00094D 740A              MOV      A,#0AH
+00094F F0                MOVX     @DPTR,A
+  389: 	g_variable.sleepTimer = 0;
+000950 E4                CLR      A
+000951 904CE3            MOV      DPTR,#g_variable+024H
+000954 F0                MOVX     @DPTR,A
+000955 A3                INC      DPTR
+000956 F0                MOVX     @DPTR,A
+  390: 	if(g_variable.battery_status == BAT_STATUS_LOW)
+000957 904CD5            MOV      DPTR,#g_variable+016H
+00095A E0                MOVX     A,@DPTR
+00095B 6401              XRL      A,#01H
+00095D 7011              JNZ      ?C0079?KB_PROCESS
+  391: 	{
+  392: 		m_24g_enter_hibernate[0]	= 0x00;
+00095F 904D40            MOV      DPTR,#m_24g_enter_hibernate
+000962 F0                MOVX     @DPTR,A
+  393: 		m_24g_enter_hibernate[1]	= 0x48;
+000963 A3                INC      DPTR
+000964 7448              MOV      A,#048H
+000966 F0                MOVX     @DPTR,A
+  394: 		m_24g_enter_hibernate[2]	= 0x12;		// 100ms
+000967 A3                INC      DPTR
+000968 7412              MOV      A,#012H
+00096A F0                MOVX     @DPTR,A
+  395: 		m_24g_enter_hibernate[3]	= 0x00;
+00096B E4                CLR      A
+00096C A3                INC      DPTR
+00096D F0                MOVX     @DPTR,A
+  396: 	}
+00096E 8010              SJMP     ?C0080?KB_PROCESS
+000970         ?C0079?KB_PROCESS:
+  397: 	else
+  398: 	{
+  399: 		m_24g_enter_hibernate[0]	= 0x00;
+000970 E4                CLR      A
+000971 904D40            MOV      DPTR,#m_24g_enter_hibernate
+000974 F0                MOVX     @DPTR,A
+  400: 		m_24g_enter_hibernate[1]	= 0x48;
+000975 A3                INC      DPTR
+000976 7448              MOV      A,#048H
+000978 F0                MOVX     @DPTR,A
+  401: 		m_24g_enter_hibernate[2]   = 0x5d;		// 510ms
+000979 A3                INC      DPTR
+00097A 745D              MOV      A,#05DH
+00097C F0                MOVX     @DPTR,A
+  402: 		m_24g_enter_hibernate[3]	= 0x00;
+00097D E4                CLR      A
+00097E A3                INC      DPTR
+00097F F0                MOVX     @DPTR,A
+  403: 	}
+000980         ?C0080?KB_PROCESS:
+  404: 	xmemclear(hidBuff,9);
+000980 7B01              MOV      R3,#01H
+000982 7A48              MOV      R2,#HIGH hidBuff
+000984 7900              MOV      R1,#LOW hidBuff
+000986 7D09              MOV      R5,#09H
+000988 7C00              MOV      R4,#00H
+00098A B1FA              ACALL    _xmemclear
+  405: 	xmemclear(multikey,9);
+00098C 7B01              MOV      R3,#01H
+00098E 7A4E              MOV      R2,#HIGH multikey
+000990 794C              MOV      R1,#LOW multikey
+000992 7D09              MOV      R5,#09H
+000994 7C00              MOV      R4,#00H
+000996 B1FA              ACALL    _xmemclear
+  406: 
+  407: 
+  408: 	////////////////////////////2.4g pairing////////////////////////////////////
+  409: 	if ((pEvt->ksPool[0]  == HID_KEY_K&& pEvt->ksPool[1]  == HID_KEY_ESC) 
+000998 904EC5            MOV      DPTR,#pEvt
+00099B E0                MOVX     A,@DPTR
+00099C FB                MOV      R3,A
+00099D A3                INC      DPTR
+00099E E0                MOVX     A,@DPTR
+00099F FA                MOV      R2,A
+0009A0 A3                INC      DPTR
+0009A1 E0                MOVX     A,@DPTR
+0009A2 F9                MOV      R1,A
+0009A3 900001            MOV      DPTR,#01H
+0009A6 1203CF            LCALL    ?C?CLDOPTR
+0009A9 FF                MOV      R7,A
+0009AA 7E00              MOV      R6,#00H
+0009AC 640E              XRL      A,#0EH
+0009AE 700A              JNZ      ?C0083?KB_PROCESS
+0009B0 900002            MOV      DPTR,#02H
+0009B3 1203CF            LCALL    ?C?CLDOPTR
+0009B6 6429              XRL      A,#029H
+0009B8 6010              JZ       ?C0082?KB_PROCESS
+0009BA         ?C0083?KB_PROCESS:
+0009BA EF                MOV      A,R7
+0009BB 6429              XRL      A,#029H
+0009BD 4E                ORL      A,R6
+0009BE 7036              JNZ      ?C0081?KB_PROCESS
+0009C0 900002            MOV      DPTR,#02H
+0009C3 1203CF            LCALL    ?C?CLDOPTR
+0009C6 640E              XRL      A,#0EH
+0009C8 702C              JNZ      ?C0081?KB_PROCESS
+0009CA         ?C0082?KB_PROCESS:
+  410: 		||(pEvt->ksPool[0]  == HID_KEY_ESC && pEvt->ksPool[1]  == HID_KEY_K) 
+  411: 		)
+  412: 	{
+  413: 		m_24g_paring_addr[0] = 0x20;
+0009CA 904BEB            MOV      DPTR,#m_24g_paring_addr
+0009CD 7420              MOV      A,#020H
+0009CF F0                MOVX     @DPTR,A
+  414: 		m_24g_paring_addr[1] = 0x15;
+0009D0 A3                INC      DPTR
+0009D1 7415              MOV      A,#015H
+0009D3 F0                MOVX     @DPTR,A
+  415: 		m_24g_paring_addr[2] = 0x10;
+0009D4 A3                INC      DPTR
+0009D5 7410              MOV      A,#010H
+0009D7 F0                MOVX     @DPTR,A
+  416: 		m_24g_paring_addr[3] = 0x05;
+0009D8 A3                INC      DPTR
+0009D9 7405              MOV      A,#05H
+0009DB F0                MOVX     @DPTR,A
+  417: 		if (g_variable.g24_currentState != CHANGE_TO_24G_PAIRING)
+0009DC 904CC5            MOV      DPTR,#g_variable+06H
+0009DF E0                MOVX     A,@DPTR
+0009E0 6401              XRL      A,#01H
+0009E2 6009              JZ       ?C0084?KB_PROCESS
+  418: 		{
+  419: 			g_variable.button_flag |= KEY_FLAG_FN_24G_DEVICE_BUTTON;
+0009E4 904CCE            MOV      DPTR,#g_variable+0FH
+0009E7 E0                MOVX     A,@DPTR
+0009E8 4410              ORL      A,#010H
+0009EA F0                MOVX     @DPTR,A
+  420: 		}
+0009EB 8010              SJMP     ?C0086?KB_PROCESS
+0009ED         ?C0084?KB_PROCESS:
+  421: 		else
+  422: 		{
+  423: 			g_variable.button_flag &= ~KEY_FLAG_FN_24G_DEVICE_BUTTON;
+0009ED 904CCE            MOV      DPTR,#g_variable+0FH
+0009F0 E0                MOVX     A,@DPTR
+0009F1 54EF              ANL      A,#0EFH
+0009F3 F0                MOVX     @DPTR,A
+  424: 		}
+  425: 	}
+0009F4 8007              SJMP     ?C0086?KB_PROCESS
+0009F6         ?C0081?KB_PROCESS:
+  426: 	else
+  427: 	{
+  428: 		g_variable.button_flag &= ~KEY_FLAG_FN_24G_DEVICE_BUTTON;
+0009F6 904CCE            MOV      DPTR,#g_variable+0FH
+0009F9 E0                MOVX     A,@DPTR
+0009FA 54EF              ANL      A,#0EFH
+0009FC F0                MOVX     @DPTR,A
+  429: 	}
+0009FD         ?C0086?KB_PROCESS:
+  430: 
+  431: 
+  432: 
+  433: 	m_power_on_flag = 1;
+0009FD 904CB6            MOV      DPTR,#m_power_on_flag
+000A00 7401              MOV      A,#01H
+000A02 F0                MOVX     @DPTR,A
+  434: 	if( (g_variable.key_combination_step == CAMBINATION_KEY_PRESS) ||
+000A03 904CF4            MOV      DPTR,#g_variable+035H
+000A06 E0                MOVX     A,@DPTR
+000A07 FF                MOV      R7,A
+000A08 6401              XRL      A,#01H
+000A0A 7002              JNZ      $ + 4H
+000A0C 61DC              AJMP     ?C0075?KB_PROCESS
+000A0E EF                MOV      A,R7
+000A0F 6404              XRL      A,#04H
+000A11 7002              JNZ      $ + 4H
+000A13 61DC              AJMP     ?C0075?KB_PROCESS
+000A15 EF                MOV      A,R7
+000A16 6402              XRL      A,#02H
+000A18 7002              JNZ      $ + 4H
+000A1A 61DC              AJMP     ?C0075?KB_PROCESS
+  435: 	    (g_variable.key_combination_step == CAMBINATION_KEY_WAIT_RELEASE) ||
+  436: 	    (g_variable.key_combination_step == CAMBINATION_KEY_HOLD))
+  437: 	{
+  438: 		return;
+  439: 	}
+  440: 
+  441: 	// get 24g led status
+  442: 	if (g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED)
+000A1C 904CC5            MOV      DPTR,#g_variable+06H
+000A1F E0                MOVX     A,@DPTR
+000A20 6403              XRL      A,#03H
+000A22 704A              JNZ      ?C0089?KB_PROCESS
+  443: 	{
+  444: 		for(i=0; i < KS_BUFF_POLL_LEN-1; i++)
+000A24 904EC9            MOV      DPTR,#i
+000A27 F0                MOVX     @DPTR,A
+000A28         ?C0090?KB_PROCESS:
+000A28 904EC9            MOV      DPTR,#i
+000A2B E0                MOVX     A,@DPTR
+000A2C FF                MOV      R7,A
+000A2D C3                CLR      C
+000A2E 9405              SUBB     A,#05H
+000A30 7480              MOV      A,#080H
+000A32 9480              SUBB     A,#080H
+000A34 5038              JNC      ?C0089?KB_PROCESS
+  445: 		{
+  446: 			if ((pEvt->ksPool[i] == HID_KEY_CAPS_LOCK) || (pEvt->ksPool[i] == HID_KEY_NUM_LOCK) 
+000A36 904EC5            MOV      DPTR,#pEvt
+000A39 E0                MOVX     A,@DPTR
+000A3A FB                MOV      R3,A
+000A3B A3                INC      DPTR
+000A3C E0                MOVX     A,@DPTR
+000A3D FA                MOV      R2,A
+000A3E A3                INC      DPTR
+000A3F E0                MOVX     A,@DPTR
+000A40 2401              ADD      A,#01H
+000A42 F9                MOV      R1,A
+000A43 E4                CLR      A
+000A44 3A                ADDC     A,R2
+000A45 FA                MOV      R2,A
+000A46 7E00              MOV      R6,#00H
+000A48 E9                MOV      A,R1
+000A49 2F                ADD      A,R7
+000A4A F9                MOV      R1,A
+000A4B EE                MOV      A,R6
+000A4C 3A                ADDC     A,R2
+000A4D FA                MOV      R2,A
+000A4E 1203B6            LCALL    ?C?CLDPTR
+000A51 FF                MOV      R7,A
+000A52 6439              XRL      A,#039H
+000A54 600A              JZ       ?C0094?KB_PROCESS
+000A56 EF                MOV      A,R7
+000A57 6453              XRL      A,#053H
+000A59 6005              JZ       ?C0094?KB_PROCESS
+000A5B EF                MOV      A,R7
+000A5C 6447              XRL      A,#047H
+000A5E 7006              JNZ      ?C0092?KB_PROCESS
+000A60         ?C0094?KB_PROCESS:
+  447: 			|| (pEvt->ksPool[i] == HID_KEY_SCROLL_LOCK))
+  448: 			{
+  449: 				m_24g_led_flag = KB_24G_LED_ACK_TYPE;
+000A60 904D46            MOV      DPTR,#m_24g_led_flag
+000A63 7403              MOV      A,#03H
+000A65 F0                MOVX     @DPTR,A
+  450: 
+  451: 			}
+  452: 		}
+000A66         ?C0092?KB_PROCESS:
+000A66 904EC9            MOV      DPTR,#i
+000A69 E0                MOVX     A,@DPTR
+000A6A 04                INC      A
+000A6B F0                MOVX     @DPTR,A
+000A6C 80BA              SJMP     ?C0090?KB_PROCESS
+  453: 	}
+000A6E         ?C0089?KB_PROCESS:
+  454: 
+  455: 	kb_multikey_setup(pEvt);
+000A6E 904EC5            MOV      DPTR,#pEvt
+000A71 E0                MOVX     A,@DPTR
+000A72 FB                MOV      R3,A
+000A73 A3                INC      DPTR
+000A74 E0                MOVX     A,@DPTR
+000A75 FA                MOV      R2,A
+000A76 A3                INC      DPTR
+000A77 E0                MOVX     A,@DPTR
+000A78 F9                MOV      R1,A
+000A79 71DD              ACALL    _kb_multikey_setup
+  456: 	
+  457: 	if (mult_key_status == KEY_MULIT_PRESS) 
+000A7B 904E4B            MOV      DPTR,#mult_key_status
+000A7E E0                MOVX     A,@DPTR
+000A7F 6401              XRL      A,#01H
+000A81 7011              JNZ      ?C0095?KB_PROCESS
+  458: 	{
+  459: 		mult_key_status = KEY_WAIT_RELEASE;
+000A83 7402              MOV      A,#02H
+000A85 F0                MOVX     @DPTR,A
+  460: 		multikey[0] = HID_REPORTID_2;
+000A86 904E4C            MOV      DPTR,#multikey
+000A89 F0                MOVX     @DPTR,A
+  461: 		IPC_TxHidData(multikey, 3);
+000A8A 7B01              MOV      R3,#01H
+000A8C 7A4E              MOV      R2,#HIGH multikey
+000A8E 794C              MOV      R1,#LOW multikey
+000A90 7D03              MOV      R5,#03H
+000A92 C1DA              AJMP     _IPC_TxHidData
+  462: 	}
+000A94         ?C0095?KB_PROCESS:
+  463: 	else if (mult_key_status == KEY_SYSTEM_PRESS) 
+000A94 904E4B            MOV      DPTR,#mult_key_status
+000A97 E0                MOVX     A,@DPTR
+000A98 6404              XRL      A,#04H
+000A9A 7013              JNZ      ?C0097?KB_PROCESS
+  464: 	{
+  465: 		mult_key_status = KEY_WAIT_RELEASE;
+000A9C 7402              MOV      A,#02H
+000A9E F0                MOVX     @DPTR,A
+  466: 		multikey[0] = HID_REPORTID_SYSTEM;
+000A9F 904E4C            MOV      DPTR,#multikey
+000AA2 7406              MOV      A,#06H
+000AA4 F0                MOVX     @DPTR,A
+  467: 		IPC_TxHidData(multikey, 3);
+000AA5 7B01              MOV      R3,#01H
+000AA7 7A4E              MOV      R2,#HIGH multikey
+000AA9 794C              MOV      R1,#LOW multikey
+000AAB 7D03              MOV      R5,#03H
+000AAD C1DA              AJMP     _IPC_TxHidData
+  468: 	}
+000AAF         ?C0097?KB_PROCESS:
+  469: 	else if((mult_key_status == KEY_RELEASE) || (mult_key_status == KEY_WAIT_RELEASE && (!keyCount)))
+000AAF 904E4B            MOV      DPTR,#mult_key_status
+000AB2 E0                MOVX     A,@DPTR
+000AB3 6403              XRL      A,#03H
+000AB5 600B              JZ       ?C0100?KB_PROCESS
+000AB7 E0                MOVX     A,@DPTR
+000AB8 6402              XRL      A,#02H
+000ABA 702F              JNZ      ?C0099?KB_PROCESS
+000ABC 904DE4            MOV      DPTR,#keyCount
+000ABF E0                MOVX     A,@DPTR
+000AC0 7029              JNZ      ?C0099?KB_PROCESS
+000AC2         ?C0100?KB_PROCESS:
+  470: 	{
+  471: 		mult_key_status = KEY_STANDBY;
+000AC2 E4                CLR      A
+000AC3 904E4B            MOV      DPTR,#mult_key_status
+000AC6 F0                MOVX     @DPTR,A
+  472: 		mult_key_value = 0;	
+000AC7 904DED            MOV      DPTR,#mult_key_value
+000ACA F0                MOVX     @DPTR,A
+  473: 		if(system_key_press)
+000ACB 904DE9            MOV      DPTR,#system_key_press
+000ACE E0                MOVX     A,@DPTR
+000ACF 600A              JZ       ?C0101?KB_PROCESS
+  474: 		{
+  475: 			system_key_press = 0;
+000AD1 E4                CLR      A
+000AD2 F0                MOVX     @DPTR,A
+  476: 			multikey[0] = HID_REPORTID_SYSTEM;
+000AD3 904E4C            MOV      DPTR,#multikey
+000AD6 7406              MOV      A,#06H
+000AD8 F0                MOVX     @DPTR,A
+  477: 		}
+000AD9 8006              SJMP     ?C0102?KB_PROCESS
+000ADB         ?C0101?KB_PROCESS:
+  478: 		else	
+  479: 			multikey[0] = HID_REPORTID_2;
+000ADB 904E4C            MOV      DPTR,#multikey
+000ADE 7402              MOV      A,#02H
+000AE0 F0                MOVX     @DPTR,A
+000AE1         ?C0102?KB_PROCESS:
+  480: 		IPC_TxHidData(multikey, 3);
+000AE1 7B01              MOV      R3,#01H
+000AE3 7A4E              MOV      R2,#HIGH multikey
+000AE5 794C              MOV      R1,#LOW multikey
+000AE7 7D03              MOV      R5,#03H
+000AE9 C1DA              AJMP     _IPC_TxHidData
+  481: 	}
+000AEB         ?C0099?KB_PROCESS:
+  482: 	else 
+  483: 	{
+  484: 		if(!keyCount)
+000AEB 904DE4            MOV      DPTR,#keyCount
+000AEE E0                MOVX     A,@DPTR
+000AEF 7016              JNZ      ?C0104?KB_PROCESS
+  485: 			xmemclear(pEvt->ksPool,6);
+000AF1 904EC5            MOV      DPTR,#pEvt
+000AF4 E0                MOVX     A,@DPTR
+000AF5 FB                MOV      R3,A
+000AF6 A3                INC      DPTR
+000AF7 E0                MOVX     A,@DPTR
+000AF8 FA                MOV      R2,A
+000AF9 A3                INC      DPTR
+000AFA E0                MOVX     A,@DPTR
+000AFB 2401              ADD      A,#01H
+000AFD F9                MOV      R1,A
+000AFE E4                CLR      A
+000AFF 3A                ADDC     A,R2
+000B00 FA                MOV      R2,A
+000B01 7D06              MOV      R5,#06H
+000B03 7C00              MOV      R4,#00H
+000B05 B1FA              ACALL    _xmemclear
+000B07         ?C0104?KB_PROCESS:
+  486: 	
+  487: 		hidBuff[0] = HID_REPORTID_1;		// standard key send
+000B07 904800            MOV      DPTR,#hidBuff
+000B0A 7401              MOV      A,#01H
+000B0C F0                MOVX     @DPTR,A
+  488: 		hidBuff[1] = pEvt->standardSel;
+000B0D 904EC5            MOV      DPTR,#pEvt
+000B10 E0                MOVX     A,@DPTR
+000B11 FB                MOV      R3,A
+000B12 A3                INC      DPTR
+000B13 E0                MOVX     A,@DPTR
+000B14 FA                MOV      R2,A
+000B15 A3                INC      DPTR
+000B16 E0                MOVX     A,@DPTR
+000B17 F9                MOV      R1,A
+000B18 1203B6            LCALL    ?C?CLDPTR
+000B1B 904801            MOV      DPTR,#hidBuff+01H
+000B1E F0                MOVX     @DPTR,A
+  489: 		if (g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED)
+000B1F 904CC5            MOV      DPTR,#g_variable+06H
+000B22 E0                MOVX     A,@DPTR
+000B23 6403              XRL      A,#03H
+000B25 700A              JNZ      ?C0105?KB_PROCESS
+  490: 			hidBuff[2] = m_24g_led_flag;
+000B27 904D46            MOV      DPTR,#m_24g_led_flag
+000B2A E0                MOVX     A,@DPTR
+000B2B 904802            MOV      DPTR,#hidBuff+02H
+000B2E F0                MOVX     @DPTR,A
+000B2F 8005              SJMP     ?C0106?KB_PROCESS
+000B31         ?C0105?KB_PROCESS:
+  491: 		else
+  492: 			hidBuff[2] = 0;
+000B31 E4                CLR      A
+000B32 904802            MOV      DPTR,#hidBuff+02H
+000B35 F0                MOVX     @DPTR,A
+000B36         ?C0106?KB_PROCESS:
+  493: 
+  494: 		standard_key_release_flag = 0;
+000B36 E4                CLR      A
+000B37 904DDF            MOV      DPTR,#standard_key_release_flag
+000B3A F0                MOVX     @DPTR,A
+  495: 		if(!fast_connect_flag)
+000B3B 904E55            MOV      DPTR,#fast_connect_flag
+000B3E E0                MOVX     A,@DPTR
+000B3F 7075              JNZ      ?C0107?KB_PROCESS
+  496: 		{
+  497: 			if (pEvt->ksPool[0] == HID_KEY_FN)
+000B41 900001            MOV      DPTR,#01H
+000B44 1203CF            LCALL    ?C?CLDOPTR
+000B47 647F              XRL      A,#07FH
+000B49 7015              JNZ      ?C0108?KB_PROCESS
+  498: 				xmemcpy(&hidBuff[3], &pEvt->ksPool[1], 5);
+000B4B 7E48              MOV      R6,#HIGH hidBuff+03H
+000B4D 7F03              MOV      R7,#LOW hidBuff+03H
+000B4F E9                MOV      A,R1
+000B50 2402              ADD      A,#02H
+000B52 F9                MOV      R1,A
+000B53 E4                CLR      A
+000B54 3A                ADDC     A,R2
+000B55 FA                MOV      R2,A
+000B56 904EC4            MOV      DPTR,#?_xmemcpy?BYTE+05H
+000B59 7405              MOV      A,#05H
+000B5B F0                MOVX     @DPTR,A
+000B5C 1178              ACALL    _xmemcpy
+000B5E 801C              SJMP     ?C0109?KB_PROCESS
+000B60         ?C0108?KB_PROCESS:
+  499: 			else
+  500: 				xmemcpy(&hidBuff[3], pEvt->ksPool, 6);
+000B60 7E48              MOV      R6,#HIGH hidBuff+03H
+000B62 7F03              MOV      R7,#LOW hidBuff+03H
+000B64 904EC5            MOV      DPTR,#pEvt
+000B67 E0                MOVX     A,@DPTR
+000B68 FB                MOV      R3,A
+000B69 A3                INC      DPTR
+000B6A E0                MOVX     A,@DPTR
+000B6B FA                MOV      R2,A
+000B6C A3                INC      DPTR
+000B6D E0                MOVX     A,@DPTR
+000B6E 2401              ADD      A,#01H
+000B70 F9                MOV      R1,A
+000B71 E4                CLR      A
+000B72 3A                ADDC     A,R2
+000B73 FA                MOV      R2,A
+000B74 904EC4            MOV      DPTR,#?_xmemcpy?BYTE+05H
+000B77 7406              MOV      A,#06H
+000B79 F0                MOVX     @DPTR,A
+000B7A 1178              ACALL    _xmemcpy
+000B7C         ?C0109?KB_PROCESS:
+  501: 			
+  502: 			for(i = 3; i<9;i++)
+000B7C 904EC9            MOV      DPTR,#i
+000B7F 7403              MOV      A,#03H
+000B81 F0                MOVX     @DPTR,A
+000B82         ?C0110?KB_PROCESS:
+000B82 904EC9            MOV      DPTR,#i
+000B85 E0                MOVX     A,@DPTR
+000B86 FF                MOV      R7,A
+000B87 C3                CLR      C
+000B88 9409              SUBB     A,#09H
+000B8A 7480              MOV      A,#080H
+000B8C 9480              SUBB     A,#080H
+000B8E 5042              JNC      ?C0114?KB_PROCESS
+  503: 			{
+  504: 				if (hidBuff[i] == HID_KEY_FN)
+000B90 7400              MOV      A,#LOW hidBuff
+000B92 2F                ADD      A,R7
+000B93 F582              MOV      DPL,A
+000B95 E4                CLR      A
+000B96 3448              ADDC     A,#HIGH hidBuff
+000B98 F583              MOV      DPH,A
+000B9A E0                MOVX     A,@DPTR
+000B9B 647F              XRL      A,#07FH
+000B9D 700F              JNZ      ?C0112?KB_PROCESS
+  505: 					hidBuff[i] = 0;
+000B9F 904EC9            MOV      DPTR,#i
+000BA2 E0                MOVX     A,@DPTR
+000BA3 2400              ADD      A,#LOW hidBuff
+000BA5 F582              MOV      DPL,A
+000BA7 E4                CLR      A
+000BA8 3448              ADDC     A,#HIGH hidBuff
+000BAA F583              MOV      DPH,A
+000BAC E4                CLR      A
+000BAD F0                MOVX     @DPTR,A
+  506: 			}
+000BAE         ?C0112?KB_PROCESS:
+000BAE 904EC9            MOV      DPTR,#i
+000BB1 E0                MOVX     A,@DPTR
+000BB2 04                INC      A
+000BB3 F0                MOVX     @DPTR,A
+000BB4 80CC              SJMP     ?C0110?KB_PROCESS
+  507: 		}
+000BB6         ?C0107?KB_PROCESS:
+  508: 		else	
+  509: 			xmemcpy(&hidBuff[3], pEvt->ksPool, 6);
+000BB6 7E48              MOV      R6,#HIGH hidBuff+03H
+000BB8 7F03              MOV      R7,#LOW hidBuff+03H
+000BBA 904EC5            MOV      DPTR,#pEvt
+000BBD E0                MOVX     A,@DPTR
+000BBE FB                MOV      R3,A
+000BBF A3                INC      DPTR
+000BC0 E0                MOVX     A,@DPTR
+000BC1 FA                MOV      R2,A
+000BC2 A3                INC      DPTR
+000BC3 E0                MOVX     A,@DPTR
+000BC4 2401              ADD      A,#01H
+000BC6 F9                MOV      R1,A
+000BC7 E4                CLR      A
+000BC8 3A                ADDC     A,R2
+000BC9 FA                MOV      R2,A
+000BCA 904EC4            MOV      DPTR,#?_xmemcpy?BYTE+05H
+000BCD 7406              MOV      A,#06H
+000BCF F0                MOVX     @DPTR,A
+000BD0 1178              ACALL    _xmemcpy
+000BD2         ?C0114?KB_PROCESS:
+  510: 		IPC_TxHidData(hidBuff, 9);
+000BD2 7B01              MOV      R3,#01H
+000BD4 7A48              MOV      R2,#HIGH hidBuff
+000BD6 7900              MOV      R1,#LOW hidBuff
+000BD8 7D09              MOV      R5,#09H
+000BDA D1DA              ACALL    _IPC_TxHidData
+  511: 	}
+  512: 	return;
+  513: }
+000BDC         ?C0075?KB_PROCESS:
+000BDC 22                RET      
+----- FUNCTION _kb_motion_keyscan (END) -------
+
+
+----- FUNCTION _kb_multikey_setup (BEGIN) -----
+ FILE: 'kb_process.c'
+  779: void kb_multikey_setup(tKSEVENT *pEvt)
+  780: {
+000BDD 904ED4            MOV      DPTR,#pEvt
+000BE0 EB                MOV      A,R3
+000BE1 F0                MOVX     @DPTR,A
+000BE2 A3                INC      DPTR
+000BE3 EA                MOV      A,R2
+000BE4 F0                MOVX     @DPTR,A
+000BE5 A3                INC      DPTR
+000BE6 E9                MOV      A,R1
+000BE7 F0                MOVX     @DPTR,A
+  781: 	byte i = 0;
+  782: 	
+000BE8 E4                CLR      A
+000BE9 A3                INC      DPTR
+000BEA F0                MOVX     @DPTR,A
+  783: 	for (i = 0;i < 6;i++)
+000BEB F0                MOVX     @DPTR,A
+000BEC         ?C0196?KB_PROCESS:
+000BEC 904ED7            MOV      DPTR,#i
+000BEF E0                MOVX     A,@DPTR
+000BF0 FF                MOV      R7,A
+000BF1 C3                CLR      C
+000BF2 9406              SUBB     A,#06H
+000BF4 7480              MOV      A,#080H
+000BF6 9480              SUBB     A,#080H
+000BF8 4002              JC       $ + 4H
+000BFA A1DE              AJMP     ?C0255?KB_PROCESS
+  784: 	{		
+  785: 		if ((pEvt->ksPool[i] &0xF0) == 0xf0 
+000BFC 904ED4            MOV      DPTR,#pEvt
+000BFF E0                MOVX     A,@DPTR
+000C00 FB                MOV      R3,A
+000C01 A3                INC      DPTR
+000C02 E0                MOVX     A,@DPTR
+000C03 FA                MOV      R2,A
+000C04 A3                INC      DPTR
+000C05 E0                MOVX     A,@DPTR
+000C06 2401              ADD      A,#01H
+000C08 F9                MOV      R1,A
+000C09 E4                CLR      A
+000C0A 3A                ADDC     A,R2
+000C0B FA                MOV      R2,A
+000C0C 7E00              MOV      R6,#00H
+000C0E E9                MOV      A,R1
+000C0F 2F                ADD      A,R7
+000C10 F9                MOV      R1,A
+000C11 EE                MOV      A,R6
+000C12 3A                ADDC     A,R2
+000C13 FA                MOV      R2,A
+000C14 1203B6            LCALL    ?C?CLDPTR
+000C17 FF                MOV      R7,A
+000C18 54F0              ANL      A,#0F0H
+000C1A 64F0              XRL      A,#0F0H
+000C1C 6009              JZ       ?C0200?KB_PROCESS
+000C1E EF                MOV      A,R7
+000C1F 54D0              ANL      A,#0D0H
+000C21 64D0              XRL      A,#0D0H
+000C23 6002              JZ       $ + 4H
+000C25 A1D6              AJMP     ?C0198?KB_PROCESS
+000C27         ?C0200?KB_PROCESS:
+  786: 			|| (pEvt->ksPool[i] &0xD0) == 0xD0)
+  787: 		{
+  788: 			
+  789: 			if (pEvt->ksPool[i] ==  HID_MULTIKEY_MEDIA) //media select
+000C27 1203B6            LCALL    ?C?CLDPTR
+000C2A F9                MOV      R1,A
+000C2B FB                MOV      R3,A
+000C2C 7A00              MOV      R2,#00H
+000C2E 64F1              XRL      A,#0F1H
+000C30 7008              JNZ      ?C0201?KB_PROCESS
+  790: 			{
+  791: 				kb_set_multikey(0x0183); 
+000C32 7F83              MOV      R7,#083H
+000C34 7E01              MOV      R6,#01H
+000C36 B1DF              ACALL    _kb_set_multikey
+  792: 			}
+000C38 A1AA              AJMP     ?C0202?KB_PROCESS
+000C3A         ?C0201?KB_PROCESS:
+  793: 			else
+  794: 			if (pEvt->ksPool[i] ==  HID_MULTIKEY_PALY) //play / pause
+000C3A EB                MOV      A,R3
+000C3B 64F2              XRL      A,#0F2H
+000C3D 4A                ORL      A,R2
+000C3E 7007              JNZ      ?C0203?KB_PROCESS
+  795: 			{ 
+  796: 				kb_set_multikey(0x00cd);
+000C40 7FCD              MOV      R7,#0CDH
+000C42 FE                MOV      R6,A
+000C43 B1DF              ACALL    _kb_set_multikey
+  797: 			}
+000C45 A1AA              AJMP     ?C0202?KB_PROCESS
+000C47         ?C0203?KB_PROCESS:
+  798: 			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_STOP)  //stop
+000C47 E9                MOV      A,R1
+000C48 FB                MOV      R3,A
+000C49 7A00              MOV      R2,#00H
+000C4B 64F3              XRL      A,#0F3H
+000C4D 7007              JNZ      ?C0205?KB_PROCESS
+  799: 			{
+  800: 				kb_set_multikey(0x00b7);
+000C4F 7FB7              MOV      R7,#0B7H
+000C51 FE                MOV      R6,A
+000C52 B1DF              ACALL    _kb_set_multikey
+  801: 			}	
+000C54 A1AA              AJMP     ?C0202?KB_PROCESS
+000C56         ?C0205?KB_PROCESS:
+  802: 			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_PRE_TRACK) //pre Track
+000C56 EB                MOV      A,R3
+000C57 64F4              XRL      A,#0F4H
+000C59 4A                ORL      A,R2
+000C5A 7007              JNZ      ?C0207?KB_PROCESS
+  803: 			{
+  804: 				kb_set_multikey(0x00b6);
+000C5C 7FB6              MOV      R7,#0B6H
+000C5E FE                MOV      R6,A
+000C5F B1DF              ACALL    _kb_set_multikey
+  805: 			}
+000C61 A1AA              AJMP     ?C0202?KB_PROCESS
+000C63         ?C0207?KB_PROCESS:
+  806: 			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_NEXT_TRACK) //next Track
+000C63 E9                MOV      A,R1
+000C64 FB                MOV      R3,A
+000C65 7A00              MOV      R2,#00H
+000C67 64F5              XRL      A,#0F5H
+000C69 7007              JNZ      ?C0209?KB_PROCESS
+  807: 			{
+  808: 				kb_set_multikey(0x00b5);
+000C6B 7FB5              MOV      R7,#0B5H
+000C6D FE                MOV      R6,A
+000C6E B1DF              ACALL    _kb_set_multikey
+  809: 			}
+000C70 A1AA              AJMP     ?C0202?KB_PROCESS
+000C72         ?C0209?KB_PROCESS:
+  810: 			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_VOL_DOWN) //vol-
+000C72 EB                MOV      A,R3
+000C73 64F6              XRL      A,#0F6H
+000C75 4A                ORL      A,R2
+000C76 7007              JNZ      ?C0211?KB_PROCESS
+  811: 			{
+  812: 				kb_set_multikey(0x00ea);
+000C78 7FEA              MOV      R7,#0EAH
+000C7A FE                MOV      R6,A
+000C7B B1DF              ACALL    _kb_set_multikey
+  813: 			}
+000C7D A1AA              AJMP     ?C0202?KB_PROCESS
+000C7F         ?C0211?KB_PROCESS:
+  814: 			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_VOL_UP) //vol+
+000C7F E9                MOV      A,R1
+000C80 FB                MOV      R3,A
+000C81 7A00              MOV      R2,#00H
+000C83 64F7              XRL      A,#0F7H
+000C85 7007              JNZ      ?C0213?KB_PROCESS
+  815: 			{
+  816: 				kb_set_multikey(0x00e9);
+000C87 7FE9              MOV      R7,#0E9H
+000C89 FE                MOV      R6,A
+000C8A B1DF              ACALL    _kb_set_multikey
+  817: 			}
+000C8C A1AA              AJMP     ?C0202?KB_PROCESS
+000C8E         ?C0213?KB_PROCESS:
+  818: 			else	if (pEvt->ksPool[i] ==  HID_MULTIKEY_MUTE) //mute
+000C8E EB                MOV      A,R3
+000C8F 64F8              XRL      A,#0F8H
+000C91 4A                ORL      A,R2
+000C92 7007              JNZ      ?C0215?KB_PROCESS
+  819: 			{
+  820: 				kb_set_multikey(0x00e2);
+000C94 7FE2              MOV      R7,#0E2H
+000C96 FE                MOV      R6,A
+000C97 B1DF              ACALL    _kb_set_multikey
+  821: 			}
+000C99 A1AA              AJMP     ?C0202?KB_PROCESS
+000C9B         ?C0215?KB_PROCESS:
+  822: 			else	if (pEvt->ksPool[i] ==  HID_MULTIKEY_MY_COMPUTER) 
+000C9B E9                MOV      A,R1
+000C9C FB                MOV      R3,A
+000C9D 7A00              MOV      R2,#00H
+000C9F 64F9              XRL      A,#0F9H
+000CA1 7008              JNZ      ?C0217?KB_PROCESS
+  823: 			{
+  824: 				kb_set_multikey(0x0194);
+000CA3 7F94              MOV      R7,#094H
+000CA5 7E01              MOV      R6,#01H
+000CA7 B1DF              ACALL    _kb_set_multikey
+  825: 			}	
+000CA9 A1AA              AJMP     ?C0202?KB_PROCESS
+000CAB         ?C0217?KB_PROCESS:
+  826: 			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_MAIL)  //mail
+000CAB EB                MOV      A,R3
+000CAC 64FA              XRL      A,#0FAH
+000CAE 4A                ORL      A,R2
+000CAF 7008              JNZ      ?C0219?KB_PROCESS
+  827: 			{
+  828: 				kb_set_multikey(0x018a);//mail
+000CB1 7F8A              MOV      R7,#08AH
+000CB3 7E01              MOV      R6,#01H
+000CB5 B1DF              ACALL    _kb_set_multikey
+  829: 			}
+000CB7 A1AA              AJMP     ?C0202?KB_PROCESS
+000CB9         ?C0219?KB_PROCESS:
+  830: 			else	if (pEvt->ksPool[i] ==  HID_MULTIKEY_CALCULATOR) //calculator
+000CB9 E9                MOV      A,R1
+000CBA FB                MOV      R3,A
+000CBB 7A00              MOV      R2,#00H
+000CBD 64FB              XRL      A,#0FBH
+000CBF 7008              JNZ      ?C0221?KB_PROCESS
+  831: 			{
+  832: 				kb_set_multikey(0x0192);
+000CC1 7F92              MOV      R7,#092H
+000CC3 7E01              MOV      R6,#01H
+000CC5 B1DF              ACALL    _kb_set_multikey
+  833: 			}
+000CC7 A1AA              AJMP     ?C0202?KB_PROCESS
+000CC9         ?C0221?KB_PROCESS:
+  834: 			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_AC_FAVORITES) 
+000CC9 EB                MOV      A,R3
+000CCA 64D0              XRL      A,#0D0H
+000CCC 4A                ORL      A,R2
+000CCD 7008              JNZ      ?C0223?KB_PROCESS
+  835: 			{
+  836: 				kb_set_multikey(0x022a);//www Favorites
+000CCF 7F2A              MOV      R7,#02AH
+000CD1 7E02              MOV      R6,#02H
+000CD3 B1DF              ACALL    _kb_set_multikey
+  837: 			}
+000CD5 A1AA              AJMP     ?C0202?KB_PROCESS
+000CD7         ?C0223?KB_PROCESS:
+  838: 			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_AC_FORWARD)  
+000CD7 E9                MOV      A,R1
+000CD8 FB                MOV      R3,A
+000CD9 7A00              MOV      R2,#00H
+000CDB 64D1              XRL      A,#0D1H
+000CDD 7008              JNZ      ?C0225?KB_PROCESS
+  839: 			{
+  840: 				kb_set_multikey(0x0225);
+000CDF 7F25              MOV      R7,#025H
+000CE1 7E02              MOV      R6,#02H
+000CE3 B1DF              ACALL    _kb_set_multikey
+  841: 			}
+000CE5 A1AA              AJMP     ?C0202?KB_PROCESS
+000CE7         ?C0225?KB_PROCESS:
+  842: 			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_AC_STOP)  //www Stop
+000CE7 EB                MOV      A,R3
+000CE8 64D3              XRL      A,#0D3H
+000CEA 4A                ORL      A,R2
+000CEB 7008              JNZ      ?C0227?KB_PROCESS
+  843: 			{
+  844: 				kb_set_multikey(0x0226);
+000CED 7F26              MOV      R7,#026H
+000CEF 7E02              MOV      R6,#02H
+000CF1 B1DF              ACALL    _kb_set_multikey
+  845: 			}
+000CF3 A1AA              AJMP     ?C0202?KB_PROCESS
+000CF5         ?C0227?KB_PROCESS:
+  846: 			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_AC_BACK)  
+000CF5 E9                MOV      A,R1
+000CF6 FB                MOV      R3,A
+000CF7 7A00              MOV      R2,#00H
+000CF9 64D2              XRL      A,#0D2H
+000CFB 7008              JNZ      ?C0229?KB_PROCESS
+  847: 			{
+  848: 				kb_set_multikey(0x0224);
+000CFD 7F24              MOV      R7,#024H
+000CFF 7E02              MOV      R6,#02H
+000D01 B1DF              ACALL    _kb_set_multikey
+  849: 			}
+000D03 A1AA              AJMP     ?C0202?KB_PROCESS
+000D05         ?C0229?KB_PROCESS:
+  850: 			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_AC_REFRESH) //www refresh
+000D05 EB                MOV      A,R3
+000D06 64D4              XRL      A,#0D4H
+000D08 4A                ORL      A,R2
+000D09 7008              JNZ      ?C0231?KB_PROCESS
+  851: 			{
+  852: 				kb_set_multikey(0x0227);
+000D0B 7F27              MOV      R7,#027H
+000D0D 7E02              MOV      R6,#02H
+000D0F B1DF              ACALL    _kb_set_multikey
+  853: 			}	
+000D11 A1AA              AJMP     ?C0202?KB_PROCESS
+000D13         ?C0231?KB_PROCESS:
+  854: 			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_AC_SEARCH)  //www search
+000D13 E9                MOV      A,R1
+000D14 FB                MOV      R3,A
+000D15 7A00              MOV      R2,#00H
+000D17 64D5              XRL      A,#0D5H
+000D19 7008              JNZ      ?C0233?KB_PROCESS
+  855: 			{
+  856: 				kb_set_multikey(0x0221);
+000D1B 7F21              MOV      R7,#021H
+000D1D 7E02              MOV      R6,#02H
+000D1F B1DF              ACALL    _kb_set_multikey
+  857: 			}
+000D21 A1AA              AJMP     ?C0202?KB_PROCESS
+000D23         ?C0233?KB_PROCESS:
+  858: 			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_AC_HOME)
+000D23 EB                MOV      A,R3
+000D24 64D6              XRL      A,#0D6H
+000D26 4A                ORL      A,R2
+000D27 7008              JNZ      ?C0235?KB_PROCESS
+  859: 			{
+  860: 				kb_set_multikey(0x0223);
+000D29 7F23              MOV      R7,#023H
+000D2B 7E02              MOV      R6,#02H
+000D2D B1DF              ACALL    _kb_set_multikey
+  861: 			}
+000D2F 8079              SJMP     ?C0202?KB_PROCESS
+000D31         ?C0235?KB_PROCESS:
+  862: 			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_LIGHT_DOWN)
+000D31 E9                MOV      A,R1
+000D32 FB                MOV      R3,A
+000D33 7A00              MOV      R2,#00H
+000D35 64D7              XRL      A,#0D7H
+000D37 7007              JNZ      ?C0237?KB_PROCESS
+  863: 			{
+  864: 				kb_set_multikey(0x0070);
+000D39 7F70              MOV      R7,#070H
+000D3B FE                MOV      R6,A
+000D3C B1DF              ACALL    _kb_set_multikey
+  865: 			}
+000D3E 806A              SJMP     ?C0202?KB_PROCESS
+000D40         ?C0237?KB_PROCESS:
+  866: 			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_LIGHT_UP)
+000D40 EB                MOV      A,R3
+000D41 64D8              XRL      A,#0D8H
+000D43 4A                ORL      A,R2
+000D44 7007              JNZ      ?C0239?KB_PROCESS
+  867: 			{
+  868: 				kb_set_multikey(0x006f);
+000D46 7F6F              MOV      R7,#06FH
+000D48 FE                MOV      R6,A
+000D49 B1DF              ACALL    _kb_set_multikey
+  869: 			}	
+000D4B 805D              SJMP     ?C0202?KB_PROCESS
+000D4D         ?C0239?KB_PROCESS:
+  870: 			else if (pEvt->ksPool[i] ==  HID_MULTIKEY_IOS_SOFT_KB)  //IOS VIR KB
+000D4D E9                MOV      A,R1
+000D4E FB                MOV      R3,A
+000D4F 7A00              MOV      R2,#00H
+000D51 64D9              XRL      A,#0D9H
+000D53 7007              JNZ      ?C0241?KB_PROCESS
+  871: 		      	{
+  872: 		        	kb_set_multikey(0x00b8);
+000D55 7FB8              MOV      R7,#0B8H
+000D57 FE                MOV      R6,A
+000D58 B1DF              ACALL    _kb_set_multikey
+  873: 		      	}
+000D5A 804E              SJMP     ?C0202?KB_PROCESS
+000D5C         ?C0241?KB_PROCESS:
+  874: 		      else if (pEvt->ksPool[i] ==  HID_MULTIKEY_OS_LOCK)
+000D5C EB                MOV      A,R3
+000D5D 64DA              XRL      A,#0DAH
+000D5F 4A                ORL      A,R2
+000D60 7007              JNZ      ?C0243?KB_PROCESS
+  875: 		      	{
+  876: 		        	kb_set_multikey(0x0030);
+000D62 7F30              MOV      R7,#030H
+000D64 FE                MOV      R6,A
+000D65 B1DF              ACALL    _kb_set_multikey
+  877: 		      	}	
+000D67 8041              SJMP     ?C0202?KB_PROCESS
+000D69         ?C0243?KB_PROCESS:
+  878: 		      	else if (pEvt->ksPool[i] ==  HID_MULTIKEY_ANDROID_SETUP_SHORTCUTS)
+000D69 E9                MOV      A,R1
+000D6A FB                MOV      R3,A
+000D6B 7A00              MOV      R2,#00H
+000D6D 64DB              XRL      A,#0DBH
+000D6F 7008              JNZ      ?C0245?KB_PROCESS
+  879: 		      	{
+  880: 		        	kb_set_multikey(0x0306);
+000D71 7F06              MOV      R7,#06H
+000D73 7E03              MOV      R6,#03H
+000D75 B1DF              ACALL    _kb_set_multikey
+  881: 		      	}
+000D77 8031              SJMP     ?C0202?KB_PROCESS
+000D79         ?C0245?KB_PROCESS:
+  882: 		      	else if (pEvt->ksPool[i] ==  HID_MULTIKEY_ANDROID_SOFT_KB)
+000D79 EB                MOV      A,R3
+000D7A 64DC              XRL      A,#0DCH
+000D7C 4A                ORL      A,R2
+000D7D 7008              JNZ      ?C0247?KB_PROCESS
+  883: 		      	{
+  884: 		        	kb_set_multikey(0x0307);
+000D7F 7F07              MOV      R7,#07H
+000D81 7E03              MOV      R6,#03H
+000D83 B1DF              ACALL    _kb_set_multikey
+  885: 		      	}
+000D85 8023              SJMP     ?C0202?KB_PROCESS
+000D87         ?C0247?KB_PROCESS:
+  886: 		      	else if (pEvt->ksPool[i] ==  HID_SYSTEM_KEY_POWER_DOWN)
+000D87 E9                MOV      A,R1
+000D88 FD                MOV      R5,A
+000D89 7C00              MOV      R4,#00H
+000D8B 64DD              XRL      A,#0DDH
+000D8D 7006              JNZ      ?C0249?KB_PROCESS
+  887: 		      	{
+  888: 		        	kb_set_systemkey(0x01);
+000D8F 7F01              MOV      R7,#01H
+000D91 D1BF              ACALL    _kb_set_systemkey
+  889: 		      	}
+000D93 8015              SJMP     ?C0202?KB_PROCESS
+000D95         ?C0249?KB_PROCESS:
+  890: 		      	else if (pEvt->ksPool[i] ==  HID_SYSTEM_KEY_SLEEP)
+000D95 ED                MOV      A,R5
+000D96 64DE              XRL      A,#0DEH
+000D98 4C                ORL      A,R4
+000D99 7006              JNZ      ?C0251?KB_PROCESS
+  891: 		      	{
+  892: 		        	kb_set_systemkey(0x02);
+000D9B 7F02              MOV      R7,#02H
+000D9D D1BF              ACALL    _kb_set_systemkey
+  893: 		      	}
+000D9F 8009              SJMP     ?C0202?KB_PROCESS
+000DA1         ?C0251?KB_PROCESS:
+  894: 		      	else if (pEvt->ksPool[i] ==  HID_SYSTEM_KEY_WAKE_UP)
+000DA1 E9                MOV      A,R1
+000DA2 64DF              XRL      A,#0DFH
+000DA4 7004              JNZ      ?C0202?KB_PROCESS
+  895: 		      	{
+  896: 		        	kb_set_systemkey(0x04);
+000DA6 7F04              MOV      R7,#04H
+000DA8 D1BF              ACALL    _kb_set_systemkey
+  897: 		      	}
+000DAA         ?C0202?KB_PROCESS:
+  898: 			
+  899: 			if(mult_key_status == KEY_WAIT_RELEASE)
+000DAA 904E4B            MOV      DPTR,#mult_key_status
+000DAD E0                MOVX     A,@DPTR
+000DAE 6402              XRL      A,#02H
+000DB0 7024              JNZ      ?C0198?KB_PROCESS
+  900: 			{
+  901: 				mult_key_value = pEvt->ksPool[i];
+000DB2 904ED4            MOV      DPTR,#pEvt
+000DB5 E0                MOVX     A,@DPTR
+000DB6 FB                MOV      R3,A
+000DB7 A3                INC      DPTR
+000DB8 E0                MOVX     A,@DPTR
+000DB9 FA                MOV      R2,A
+000DBA A3                INC      DPTR
+000DBB E0                MOVX     A,@DPTR
+000DBC 2401              ADD      A,#01H
+000DBE F9                MOV      R1,A
+000DBF E4                CLR      A
+000DC0 3A                ADDC     A,R2
+000DC1 FA                MOV      R2,A
+000DC2 A3                INC      DPTR
+000DC3 E0                MOVX     A,@DPTR
+000DC4 7E00              MOV      R6,#00H
+000DC6 29                ADD      A,R1
+000DC7 F9                MOV      R1,A
+000DC8 EE                MOV      A,R6
+000DC9 3A                ADDC     A,R2
+000DCA FA                MOV      R2,A
+000DCB 1203B6            LCALL    ?C?CLDPTR
+000DCE 904DED            MOV      DPTR,#mult_key_value
+000DD1 F0                MOVX     @DPTR,A
+  902: 				pEvt->ksPool[i] = 0;
+000DD2 E4                CLR      A
+000DD3 1203FC            LCALL    ?C?CSTPTR
+  903: 			}
+  904: 		}
+  905: 	}
+000DD6         ?C0198?KB_PROCESS:
+000DD6 904ED7            MOV      DPTR,#i
+000DD9 E0                MOVX     A,@DPTR
+000DDA 04                INC      A
+000DDB F0                MOVX     @DPTR,A
+000DDC 61EC              AJMP     ?C0196?KB_PROCESS
+  906: }
+000DDE         ?C0255?KB_PROCESS:
+000DDE 22                RET      
+----- FUNCTION _kb_multikey_setup (END) -------
+
+
+----- FUNCTION _kb_set_multikey (BEGIN) -----
+ FILE: 'kb_process.c'
+  175: void kb_set_multikey(word multikey_value)
+  176: {
+;---- Variable 'multikey_value' assigned to Register 'R4/R5' ----
+000DDF AD07              MOV      R5,AR7
+000DE1 AC06              MOV      R4,AR6
+  177: 	if(mult_key_status != KEY_WAIT_RELEASE)
+  178: 	{
+000DE3 904E4B            MOV      DPTR,#mult_key_status
+000DE6 E0                MOVX     A,@DPTR
+000DE7 6402              XRL      A,#02H
+000DE9 600E              JZ       ?C0047?KB_PROCESS
+  179: 		mult_key_status = KEY_MULIT_PRESS;
+  180: 		multikey[0] = HID_REPORTID_2;
+000DEB 7401              MOV      A,#01H
+000DED F0                MOVX     @DPTR,A
+  181: 		multikey[1] = (multikey_value&0xff);
+000DEE 904E4C            MOV      DPTR,#multikey
+000DF1 04                INC      A
+000DF2 F0                MOVX     @DPTR,A
+  182: 		multikey[2] = ((multikey_value>>8)&0xff);
+000DF3 EF                MOV      A,R7
+000DF4 A3                INC      DPTR
+000DF5 F0                MOVX     @DPTR,A
+  183: 	}
+000DF6 EE                MOV      A,R6
+000DF7 A3                INC      DPTR
+000DF8 F0                MOVX     @DPTR,A
+  184: }
+  185: 
+000DF9         ?C0047?KB_PROCESS:
+000DF9 22                RET      
+----- FUNCTION _kb_set_multikey (END) -------
+
+
+----- FUNCTION _xmemclear (BEGIN) -----
+000DFA 904EEF            MOV      DPTR,#dest
+000DFD EB                MOV      A,R3
+000DFE F0                MOVX     @DPTR,A
+000DFF A3                INC      DPTR
+000E00 EA                MOV      A,R2
+000E01 F0                MOVX     @DPTR,A
+000E02 A3                INC      DPTR
+000E03 E9                MOV      A,R1
+000E04 F0                MOVX     @DPTR,A
+;---- Variable 'len' assigned to Register 'R4/R5' ----
+000E05         ?C0008?UTILITIES:
+000E05 ED                MOV      A,R5
+000E06 1D                DEC      R5
+000E07 AE04              MOV      R6,AR4
+000E09 7001              JNZ      ?C0026?UTILITIES
+000E0B 1C                DEC      R4
+000E0C         ?C0026?UTILITIES:
+000E0C 4E                ORL      A,R6
+000E0D 6016              JZ       ?C0010?UTILITIES
+000E0F 904EEF            MOV      DPTR,#dest
+000E12 E0                MOVX     A,@DPTR
+000E13 FB                MOV      R3,A
+000E14 A3                INC      DPTR
+000E15 E4                CLR      A
+000E16 75F001            MOV      B,#01H
+000E19 120424            LCALL    ?C?ILDIX
+000E1C A9F0              MOV      R1,B
+000E1E FA                MOV      R2,A
+000E1F E4                CLR      A
+000E20 1203FC            LCALL    ?C?CSTPTR
+000E23 80E0              SJMP     ?C0008?UTILITIES
+000E25         ?C0010?UTILITIES:
+000E25 22                RET      
+----- FUNCTION _xmemclear (END) -------
+
+
+----- FUNCTION System_clear_mem (BEGIN) -----
+ FILE: 'sys.c'
+   11: static void System_clear_mem()
+   12: {
+   13: 	xmemclear((byte *)&g_variable,sizeof(G_VARIABLE_MAP));
+   14: 	xmemclear(ksSelMapOld,KB_KSCAN_COL_NUM);
+000E26 7B01              MOV      R3,#01H
+000E28 7A4C              MOV      R2,#HIGH g_variable
+000E2A 79BF              MOV      R1,#LOW g_variable
+000E2C 7D48              MOV      R5,#048H
+000E2E 7C00              MOV      R4,#00H
+000E30 B1FA              ACALL    _xmemclear
+   15: 	xmemclear(ksSelMapCheck,KB_KSCAN_COL_NUM);
+000E32 7B01              MOV      R3,#01H
+000E34 7A4D              MOV      R2,#HIGH ksSelMapOld
+000E36 7993              MOV      R1,#LOW ksSelMapOld
+000E38 7D14              MOV      R5,#014H
+000E3A 7C00              MOV      R4,#00H
+000E3C B1FA              ACALL    _xmemclear
+   16: 	xmemclear(ksSelMapCurr,KB_KSCAN_COL_NUM);
+000E3E 7B01              MOV      R3,#01H
+000E40 7A4D              MOV      R2,#HIGH ksSelMapCheck
+000E42 79A8              MOV      R1,#LOW ksSelMapCheck
+000E44 7D14              MOV      R5,#014H
+000E46 7C00              MOV      R4,#00H
+000E48 B1FA              ACALL    _xmemclear
+   17: 	xmemclear(hidBuff,9);
+000E4A 7B01              MOV      R3,#01H
+000E4C 7A4D              MOV      R2,#HIGH ksSelMapCurr
+000E4E 79BC              MOV      R1,#LOW ksSelMapCurr
+000E50 7D14              MOV      R5,#014H
+000E52 7C00              MOV      R4,#00H
+000E54 B1FA              ACALL    _xmemclear
+   18: 	xmemclear(multikey,9);
+000E56 7B01              MOV      R3,#01H
+000E58 7A48              MOV      R2,#HIGH hidBuff
+000E5A 7900              MOV      R1,#LOW hidBuff
+000E5C 7D09              MOV      R5,#09H
+000E5E 7C00              MOV      R4,#00H
+000E60 B1FA              ACALL    _xmemclear
+   19:  
+000E62 7B01              MOV      R3,#01H
+000E64 7A4E              MOV      R2,#HIGH multikey
+000E66 794C              MOV      R1,#LOW multikey
+000E68 7D09              MOV      R5,#09H
+000E6A 7C00              MOV      R4,#00H
+000E6C B1FA              ACALL    _xmemclear
+   20: 	delayChgInvTimer = 0;
+000E6E E4                CLR      A
+000E6F 904DE6            MOV      DPTR,#delayChgInvTimer
+000E72 F0                MOVX     @DPTR,A
+   21: 	action_timeout = 0;
+000E73 904DEC            MOV      DPTR,#action_timeout
+000E76 F0                MOVX     @DPTR,A
+   22: 
+   23: 	power_on_flag = 0;
+000E77 904DEB            MOV      DPTR,#power_on_flag
+000E7A F0                MOVX     @DPTR,A
+   24: 	repeat_send_24g = 0;
+000E7B 904DDD            MOV      DPTR,#repeat_send_24g
+000E7E F0                MOVX     @DPTR,A
+   25: 	get_24g_led_send = 0;
+000E7F 904DD5            MOV      DPTR,#get_24g_led_send
+000E82 F0                MOVX     @DPTR,A
+   26: 	ble_reconnect_flag = 0;
+000E83 904DE5            MOV      DPTR,#ble_reconnect_flag
+000E86 F0                MOVX     @DPTR,A
+   27: 	press_long_time_flag = 0;
+000E87 904DE3            MOV      DPTR,#press_long_time_flag
+000E8A F0                MOVX     @DPTR,A
+   28: 	mult_key_status = 0;
+000E8B 904E4B            MOV      DPTR,#mult_key_status
+000E8E F0                MOVX     @DPTR,A
+   29: 	long_press_flag = 0;
+000E8F 904DDC            MOV      DPTR,#long_press_flag
+000E92 F0                MOVX     @DPTR,A
+   30: 	standard_key_release_flag = 0;
+000E93 904DDF            MOV      DPTR,#standard_key_release_flag
+000E96 F0                MOVX     @DPTR,A
+   31: 	fn_flag = 0;
+000E97 904DE2            MOV      DPTR,#fn_flag
+000E9A F0                MOVX     @DPTR,A
+   32: 	fn_flag_last = 0;
+000E9B 904DEA            MOV      DPTR,#fn_flag_last
+000E9E F0                MOVX     @DPTR,A
+   33: 	fn_tx_flag = 0;
+000E9F 904DD8            MOV      DPTR,#fn_tx_flag
+000EA2 F0                MOVX     @DPTR,A
+   34: 	fn_lock_flag = 0;
+000EA3 904DE7            MOV      DPTR,#fn_lock_flag
+000EA6 F0                MOVX     @DPTR,A
+   35: 
+   36: 	mult_key_value = 0;
+000EA7 904DED            MOV      DPTR,#mult_key_value
+000EAA F0                MOVX     @DPTR,A
+   37: 	m_caps_num_lock = 0xf0;
+000EAB 904CB7            MOV      DPTR,#m_caps_num_lock
+000EAE 74F0              MOV      A,#0F0H
+000EB0 F0                MOVX     @DPTR,A
+   38: 	m_caps_num_lock_last = 0xf0; 
+000EB1 904DE0            MOV      DPTR,#m_caps_num_lock_last
+000EB4 F0                MOVX     @DPTR,A
+   39: 	m_reconnect_continue = 0;
+000EB5 E4                CLR      A
+000EB6 904D38            MOV      DPTR,#m_reconnect_continue
+000EB9 F0                MOVX     @DPTR,A
+   40: 	ble_send_secutiry_request_timer = 0;
+000EBA 904DD4            MOV      DPTR,#ble_send_secutiry_request_timer
+000EBD F0                MOVX     @DPTR,A
+   41: }
+000EBE 22                RET      
+----- FUNCTION System_clear_mem (END) -------
+
+
+----- FUNCTION _kb_set_systemkey (BEGIN) -----
+ FILE: 'kb_process.c'
+  186: void kb_set_systemkey(byte systemkey_value)
+  187: {
+;---- Variable 'systemkey_value' assigned to Register 'R7' ----
+  188: 	if(mult_key_status != KEY_WAIT_RELEASE)
+  189: 	{
+000EBF 904E4B            MOV      DPTR,#mult_key_status
+000EC2 E0                MOVX     A,@DPTR
+000EC3 6402              XRL      A,#02H
+000EC5 6012              JZ       ?C0049?KB_PROCESS
+  190: 		mult_key_status = KEY_SYSTEM_PRESS;
+  191: 		system_key_press = 1;
+000EC7 7404              MOV      A,#04H
+000EC9 F0                MOVX     @DPTR,A
+  192: 		multikey[0] = HID_REPORTID_SYSTEM;
+000ECA 904DE9            MOV      DPTR,#system_key_press
+000ECD 7401              MOV      A,#01H
+000ECF F0                MOVX     @DPTR,A
+  193: 		multikey[1] = systemkey_value;
+000ED0 904E4C            MOV      DPTR,#multikey
+000ED3 7406              MOV      A,#06H
+000ED5 F0                MOVX     @DPTR,A
+  194: 	}
+000ED6 A3                INC      DPTR
+000ED7 EF                MOV      A,R7
+000ED8 F0                MOVX     @DPTR,A
+  195: }
+  196: 
+000ED9         ?C0049?KB_PROCESS:
+000ED9 22                RET      
+----- FUNCTION _kb_set_systemkey (END) -------
+
+
+----- FUNCTION _IPC_TxHidData (BEGIN) -----
+ FILE: 'kb_process.c'
+  121: void IPC_TxHidData(byte* dt, byte len)
+  122: {
+000EDA 904E7A            MOV      DPTR,#dt
+000EDD EB                MOV      A,R3
+000EDE F0                MOVX     @DPTR,A
+000EDF A3                INC      DPTR
+000EE0 EA                MOV      A,R2
+000EE1 F0                MOVX     @DPTR,A
+000EE2 A3                INC      DPTR
+000EE3 E9                MOV      A,R1
+000EE4 F0                MOVX     @DPTR,A
+000EE5 A3                INC      DPTR
+000EE6 ED                MOV      A,R5
+000EE7 F0                MOVX     @DPTR,A
+  123: 	xbyte tx_hid_buff[10];
+  124: 	byte i=0;
+;---- Variable 'i' assigned to Register 'R7' ----
+000EE8 E4                CLR      A
+000EE9 FF                MOV      R7,A
+  125: 
+  126: 	for(i==0; i< len; i++)
+000EEA         ?C0027?KB_PROCESS:
+000EEA 904E7D            MOV      DPTR,#len
+000EED E0                MOVX     A,@DPTR
+000EEE FE                MOV      R6,A
+000EEF EF                MOV      A,R7
+000EF0 C3                CLR      C
+000EF1 9E                SUBB     A,R6
+000EF2 5023              JNC      ?C0028?KB_PROCESS
+  127: 	{
+  128: 		tx_hid_buff[i] = dt[i];
+000EF4 904E7A            MOV      DPTR,#dt
+000EF7 E0                MOVX     A,@DPTR
+000EF8 FB                MOV      R3,A
+000EF9 A3                INC      DPTR
+000EFA E0                MOVX     A,@DPTR
+000EFB FA                MOV      R2,A
+000EFC A3                INC      DPTR
+000EFD E0                MOVX     A,@DPTR
+000EFE F9                MOV      R1,A
+000EFF 8F82              MOV      DPL,R7
+000F01 758300            MOV      DPH,#00H
+000F04 1203CF            LCALL    ?C?CLDOPTR
+000F07 FE                MOV      R6,A
+000F08 747E              MOV      A,#LOW tx_hid_buff
+000F0A 2F                ADD      A,R7
+000F0B F582              MOV      DPL,A
+000F0D E4                CLR      A
+000F0E 344E              ADDC     A,#HIGH tx_hid_buff
+000F10 F583              MOV      DPH,A
+000F12 EE                MOV      A,R6
+000F13 F0                MOVX     @DPTR,A
+  129: 	}
+000F14 0F                INC      R7
+000F15 80D3              SJMP     ?C0027?KB_PROCESS
+000F17         ?C0028?KB_PROCESS:
+  130: 	
+  131: 	if(!YC_check_need_reconnected()) 
+000F17 121922            LCALL    YC_check_need_reconnected
+000F1A EF                MOV      A,R7
+000F1B 7002              JNZ      $ + 4H
+000F1D E1C1              AJMP     ?C0031?KB_PROCESS
+  132: 		return;
+  133: 	if (g_variable.release_data)
+000F1F 904CEB            MOV      DPTR,#g_variable+02CH
+000F22 E0                MOVX     A,@DPTR
+000F23 6002              JZ       $ + 4H
+000F25 E1C1              AJMP     ?C0031?KB_PROCESS
+  134: 		return;
+  135: 
+  136: 	if ((g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTED) ||
+000F27 904CC7            MOV      DPTR,#g_variable+08H
+000F2A E0                MOVX     A,@DPTR
+000F2B FF                MOV      R7,A
+000F2C 6404              XRL      A,#04H
+000F2E 600B              JZ       ?C0034?KB_PROCESS
+000F30 EF                MOV      A,R7
+000F31 6403              XRL      A,#03H
+000F33 701F              JNZ      ?C0033?KB_PROCESS
+000F35 904DD3            MOV      DPTR,#ble_fast_connect_flag
+000F38 E0                MOVX     A,@DPTR
+000F39 6019              JZ       ?C0033?KB_PROCESS
+000F3B         ?C0034?KB_PROCESS:
+  137: 	((g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTING) && ble_fast_connect_flag))
+  138: 	{
+  139: 		if (tx_hid_buff[0] == HID_REPORTID_SYSTEM)
+000F3B 904E7E            MOV      DPTR,#tx_hid_buff
+000F3E E0                MOVX     A,@DPTR
+000F3F 6406              XRL      A,#06H
+000F41 7003              JNZ      ?C0035?KB_PROCESS
+  140: 			tx_hid_buff[0] = HID_REPORTID_3;
+000F43 7403              MOV      A,#03H
+000F45 F0                MOVX     @DPTR,A
+000F46         ?C0035?KB_PROCESS:
+  141: 		IPC_TxBleData(tx_hid_buff,len);
+000F46 7B01              MOV      R3,#01H
+000F48 7A4E              MOV      R2,#HIGH tx_hid_buff
+000F4A 797E              MOV      R1,#LOW tx_hid_buff
+000F4C 904E7D            MOV      DPTR,#len
+000F4F E0                MOVX     A,@DPTR
+000F50 FD                MOV      R5,A
+000F51 123523            LCALL    _IPC_TxBleData
+  142: 
+  143: 	}
+000F54         ?C0033?KB_PROCESS:
+  144: 	if (g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED)
+000F54 904CC5            MOV      DPTR,#g_variable+06H
+000F57 E0                MOVX     A,@DPTR
+000F58 6403              XRL      A,#03H
+000F5A 7065              JNZ      ?C0031?KB_PROCESS
+  145: 	{
+  146: 		if(tx_hid_buff[0] == HID_REPORTID_1)
+000F5C 904E7E            MOV      DPTR,#tx_hid_buff
+000F5F E0                MOVX     A,@DPTR
+000F60 6401              XRL      A,#01H
+000F62 7023              JNZ      ?C0037?KB_PROCESS
+  147: 		{
+  148: 			tx_hid_buff[0] = 4;
+000F64 7404              MOV      A,#04H
+000F66 F0                MOVX     @DPTR,A
+  149: 			if (tx_hid_buff[1] == 0 && tx_hid_buff[3] == 00 && tx_hid_buff[4] == 00 && tx_hid_buff[5] == 0)
+000F67 A3                INC      DPTR
+000F68 E0                MOVX     A,@DPTR
+000F69 7014              JNZ      ?C0038?KB_PROCESS
+000F6B 904E81            MOV      DPTR,#tx_hid_buff+03H
+000F6E E0                MOVX     A,@DPTR
+000F6F 700E              JNZ      ?C0038?KB_PROCESS
+000F71 A3                INC      DPTR
+000F72 E0                MOVX     A,@DPTR
+000F73 700A              JNZ      ?C0038?KB_PROCESS
+000F75 A3                INC      DPTR
+000F76 E0                MOVX     A,@DPTR
+000F77 7006              JNZ      ?C0038?KB_PROCESS
+  150: 				repeat_send_24g = 0;
+000F79 904DDD            MOV      DPTR,#repeat_send_24g
+000F7C F0                MOVX     @DPTR,A
+000F7D 8034              SJMP     ?C0040?KB_PROCESS
+000F7F         ?C0038?KB_PROCESS:
+  151: 			else
+  152: 				repeat_send_24g = 1;			
+000F7F 904DDD            MOV      DPTR,#repeat_send_24g
+000F82 7401              MOV      A,#01H
+000F84 F0                MOVX     @DPTR,A
+  153: 		}
+000F85 802C              SJMP     ?C0040?KB_PROCESS
+000F87         ?C0037?KB_PROCESS:
+  154: 		else if(tx_hid_buff[0] == HID_REPORTID_2)
+000F87 904E7E            MOV      DPTR,#tx_hid_buff
+000F8A E0                MOVX     A,@DPTR
+000F8B 6402              XRL      A,#02H
+000F8D 7019              JNZ      ?C0041?KB_PROCESS
+  155: 		{
+  156: 			tx_hid_buff[0] = 5;
+000F8F 7405              MOV      A,#05H
+000F91 F0                MOVX     @DPTR,A
+  157: 			if (tx_hid_buff[1] == 00 && tx_hid_buff[2] == 00)
+000F92 A3                INC      DPTR
+000F93 E0                MOVX     A,@DPTR
+000F94 700A              JNZ      ?C0042?KB_PROCESS
+000F96 A3                INC      DPTR
+000F97 E0                MOVX     A,@DPTR
+000F98 7006              JNZ      ?C0042?KB_PROCESS
+  158: 			{
+  159: 				repeat_send_24g = 0;
+000F9A 904DDD            MOV      DPTR,#repeat_send_24g
+000F9D F0                MOVX     @DPTR,A
+  160: 			}
+000F9E 8013              SJMP     ?C0040?KB_PROCESS
+000FA0         ?C0042?KB_PROCESS:
+  161: 			else
+  162: 			{
+  163: 				repeat_send_24g = 1;
+000FA0 904DDD            MOV      DPTR,#repeat_send_24g
+000FA3 7401              MOV      A,#01H
+000FA5 F0                MOVX     @DPTR,A
+  164: 			}
+  165: 		}
+000FA6 800B              SJMP     ?C0040?KB_PROCESS
+000FA8         ?C0041?KB_PROCESS:
+  166: 		else if(tx_hid_buff[0] == HID_REPORTID_3)
+000FA8 904E7E            MOV      DPTR,#tx_hid_buff
+000FAB E0                MOVX     A,@DPTR
+000FAC 6403              XRL      A,#03H
+000FAE 7003              JNZ      ?C0040?KB_PROCESS
+  167: 		{
+  168: 			tx_hid_buff[0] = 7;
+000FB0 7407              MOV      A,#07H
+000FB2 F0                MOVX     @DPTR,A
+  169: 		}
+000FB3         ?C0040?KB_PROCESS:
+  170: 		IPC_Tx24GData(tx_hid_buff,len);
+000FB3 7B01              MOV      R3,#01H
+000FB5 7A4E              MOV      R2,#HIGH tx_hid_buff
+000FB7 797E              MOV      R1,#LOW tx_hid_buff
+000FB9 904E7D            MOV      DPTR,#len
+000FBC E0                MOVX     A,@DPTR
+000FBD FD                MOV      R5,A
+000FBE 123511            LCALL    _IPC_Tx24GData
+  171: 	}
+  172: }
+000FC1         ?C0031?KB_PROCESS:
+000FC1 22                RET      
+----- FUNCTION _IPC_TxHidData (END) -------
+
+
+----- FUNCTION _IPC_TxData (BEGIN) -----
+000FC2 904F07            MOV      DPTR,#len
+000FC5 ED                MOV      A,R5
+000FC6 F0                MOVX     @DPTR,A
+;---- Variable 'dt' assigned to Register 'R1/R2/R3' ----
+000FC7 E0                MOVX     A,@DPTR
+000FC8 FD                MOV      R5,A
+000FC9 900BE8            MOV      DPTR,#ipcSendBuff+01H
+000FCC F0                MOVX     @DPTR,A
+000FCD 7E0B              MOV      R6,#HIGH ipcSendBuff+02H
+000FCF 7FE9              MOV      R7,#LOW ipcSendBuff+02H
+000FD1 904EC4            MOV      DPTR,#?_xmemcpy?BYTE+05H
+000FD4 ED                MOV      A,R5
+000FD5 F0                MOVX     @DPTR,A
+000FD6 1178              ACALL    _xmemcpy
+000FD8 7B01              MOV      R3,#01H
+000FDA 7A0B              MOV      R2,#HIGH ipcSendBuff
+000FDC 79E7              MOV      R1,#LOW ipcSendBuff
+000FDE 904F07            MOV      DPTR,#len
+000FE1 E0                MOVX     A,@DPTR
+000FE2 2402              ADD      A,#02H
+000FE4 FD                MOV      R5,A
+;----                  JMP      _ipcTx
+----- FUNCTION _IPC_TxData (END) -------
+
+
+----- FUNCTION _ipcTx (BEGIN) -----
+000FE5 904EB9            MOV      DPTR,#src
+000FE8 EB                MOV      A,R3
+000FE9 F0                MOVX     @DPTR,A
+000FEA A3                INC      DPTR
+000FEB EA                MOV      A,R2
+000FEC F0                MOVX     @DPTR,A
+000FED A3                INC      DPTR
+000FEE E9                MOV      A,R1
+000FEF F0                MOVX     @DPTR,A
+000FF0 A3                INC      DPTR
+000FF1 ED                MOV      A,R5
+000FF2 F0                MOVX     @DPTR,A
+000FF3 904B9C            MOV      DPTR,#ipcTxWritePtr
+000FF6 E0                MOVX     A,@DPTR
+000FF7 FF                MOV      R7,A
+000FF8 A3                INC      DPTR
+000FF9 E0                MOVX     A,@DPTR
+000FFA 904EBD            MOV      DPTR,#dest
+000FFD CF                XCH      A,R7
+000FFE F0                MOVX     @DPTR,A
+000FFF A3                INC      DPTR
+001000 EF                MOV      A,R7
+001001 F0                MOVX     @DPTR,A
+001002         ?C0008?IPC:
+001002 904B9A            MOV      DPTR,#ipcTxReadPtr
+001005 E0                MOVX     A,@DPTR
+001006 FE                MOV      R6,A
+001007 A3                INC      DPTR
+001008 E0                MOVX     A,@DPTR
+001009 FF                MOV      R7,A
+00100A 904B9C            MOV      DPTR,#ipcTxWritePtr
+00100D E0                MOVX     A,@DPTR
+00100E FC                MOV      R4,A
+00100F A3                INC      DPTR
+001010 E0                MOVX     A,@DPTR
+001011 FD                MOV      R5,A
+001012 7B64              MOV      R3,#064H
+001014 1179              ACALL    _bufsize
+001016 904EBC            MOV      DPTR,#len
+001019 E0                MOVX     A,@DPTR
+00101A FE                MOV      R6,A
+00101B EF                MOV      A,R7
+00101C C3                CLR      C
+00101D 9E                SUBB     A,R6
+00101E 40E2              JC       ?C0008?IPC
+001020         ?C0009?IPC:
+001020         ?C0010?IPC:
+001020 904EBC            MOV      DPTR,#len
+001023 E0                MOVX     A,@DPTR
+001024 FF                MOV      R7,A
+001025 14                DEC      A
+001026 F0                MOVX     @DPTR,A
+001027 EF                MOV      A,R7
+001028 603F              JZ       ?C0011?IPC
+00102A 904EB9            MOV      DPTR,#src
+00102D E0                MOVX     A,@DPTR
+00102E FB                MOV      R3,A
+00102F A3                INC      DPTR
+001030 E4                CLR      A
+001031 75F001            MOV      B,#01H
+001034 120424            LCALL    ?C?ILDIX
+001037 A9F0              MOV      R1,B
+001039 FA                MOV      R2,A
+00103A 1203B6            LCALL    ?C?CLDPTR
+00103D FF                MOV      R7,A
+00103E 904EBD            MOV      DPTR,#dest
+001041 E4                CLR      A
+001042 75F001            MOV      B,#01H
+001045 120424            LCALL    ?C?ILDIX
+001048 85F082            MOV      DPL,B
+00104B F583              MOV      DPH,A
+00104D EF                MOV      A,R7
+00104E F0                MOVX     @DPTR,A
+00104F 904EBD            MOV      DPTR,#dest
+001052 E0                MOVX     A,@DPTR
+001053 FE                MOV      R6,A
+001054 A3                INC      DPTR
+001055 E0                MOVX     A,@DPTR
+001056 FF                MOV      R7,A
+001057 BE4BC6            CJNE     R6,#04BH,?C0010?IPC
+00105A BF36C3            CJNE     R7,#036H,?C0010?IPC
+00105D 904EBD            MOV      DPTR,#dest
+001060 744A              MOV      A,#04AH
+001062 F0                MOVX     @DPTR,A
+001063 A3                INC      DPTR
+001064 74A0              MOV      A,#0A0H
+001066 F0                MOVX     @DPTR,A
+001067 80B7              SJMP     ?C0010?IPC
+001069         ?C0011?IPC:
+001069 904EBD            MOV      DPTR,#dest
+00106C E0                MOVX     A,@DPTR
+00106D FF                MOV      R7,A
+00106E A3                INC      DPTR
+00106F E0                MOVX     A,@DPTR
+001070 904B9C            MOV      DPTR,#ipcTxWritePtr
+001073 CF                XCH      A,R7
+001074 F0                MOVX     @DPTR,A
+001075 A3                INC      DPTR
+001076 EF                MOV      A,R7
+001077 F0                MOVX     @DPTR,A
+001078 22                RET      
+----- FUNCTION _ipcTx (END) -------
+
+
+----- FUNCTION _bufsize (BEGIN) -----
+001079 904ED8            MOV      DPTR,#rptr
+00107C EE                MOV      A,R6
+00107D F0                MOVX     @DPTR,A
+00107E A3                INC      DPTR
+00107F EF                MOV      A,R7
+001080 F0                MOVX     @DPTR,A
+001081 904EDA            MOV      DPTR,#wptr
+001084 EC                MOV      A,R4
+001085 F0                MOVX     @DPTR,A
+001086 A3                INC      DPTR
+001087 ED                MOV      A,R5
+001088 F0                MOVX     @DPTR,A
+;---- Variable 'buflen' assigned to Register 'R3' ----
+001089 904EDA            MOV      DPTR,#wptr
+00108C E0                MOVX     A,@DPTR
+00108D FE                MOV      R6,A
+00108E A3                INC      DPTR
+00108F E0                MOVX     A,@DPTR
+001090 FF                MOV      R7,A
+001091 D3                SETB     C
+001092 904ED9            MOV      DPTR,#rptr+01H
+001095 E0                MOVX     A,@DPTR
+001096 9F                SUBB     A,R7
+001097 904ED8            MOV      DPTR,#rptr
+00109A E0                MOVX     A,@DPTR
+00109B 9E                SUBB     A,R6
+00109C 4016              JC       ?C0001?IPC
+00109E 904EDA            MOV      DPTR,#wptr
+0010A1 E0                MOVX     A,@DPTR
+0010A2 FE                MOV      R6,A
+0010A3 A3                INC      DPTR
+0010A4 E0                MOVX     A,@DPTR
+0010A5 FF                MOV      R7,A
+0010A6 904ED9            MOV      DPTR,#rptr+01H
+0010A9 E0                MOVX     A,@DPTR
+0010AA 9F                SUBB     A,R7
+0010AB FF                MOV      R7,A
+0010AC 904ED8            MOV      DPTR,#rptr
+0010AF E0                MOVX     A,@DPTR
+0010B0 9E                SUBB     A,R6
+0010B1 FE                MOV      R6,A
+0010B2 801E              SJMP     ?C0002?IPC
+0010B4         ?C0001?IPC:
+0010B4 904ED8            MOV      DPTR,#rptr
+0010B7 E0                MOVX     A,@DPTR
+0010B8 FE                MOV      R6,A
+0010B9 A3                INC      DPTR
+0010BA E0                MOVX     A,@DPTR
+0010BB FF                MOV      R7,A
+0010BC C3                CLR      C
+0010BD 904EDB            MOV      DPTR,#wptr+01H
+0010C0 E0                MOVX     A,@DPTR
+0010C1 9F                SUBB     A,R7
+0010C2 FF                MOV      R7,A
+0010C3 904EDA            MOV      DPTR,#wptr
+0010C6 E0                MOVX     A,@DPTR
+0010C7 9E                SUBB     A,R6
+0010C8 FE                MOV      R6,A
+0010C9 AD03              MOV      R5,AR3
+0010CB C3                CLR      C
+0010CC EB                MOV      A,R3
+0010CD 9F                SUBB     A,R7
+0010CE FF                MOV      R7,A
+0010CF E4                CLR      A
+0010D0 9E                SUBB     A,R6
+0010D1 FE                MOV      R6,A
+0010D2         ?C0002?IPC:
+0010D2 22                RET      
+----- FUNCTION _bufsize (END) -------
+
+
+----- FUNCTION YC_check_is_connected (BEGIN) -----
+ FILE: 'bluetooth.c'
+   53: byte YC_check_is_connected()
+   54: {
+   55: 	if (g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTED
+   56: 		|| g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED)
+0010D3 904CC7            MOV      DPTR,#g_variable+08H
+0010D6 E0                MOVX     A,@DPTR
+0010D7 6404              XRL      A,#04H
+0010D9 6008              JZ       ?C0008?BLUETOOTH
+0010DB 904CC5            MOV      DPTR,#g_variable+06H
+0010DE E0                MOVX     A,@DPTR
+0010DF 6403              XRL      A,#03H
+0010E1 7003              JNZ      ?C0007?BLUETOOTH
+0010E3         ?C0008?BLUETOOTH:
+   57: 	{
+   58: 		return 1;
+0010E3 7F01              MOV      R7,#01H
+0010E5 22                RET      
+   59: 	}
+0010E6         ?C0007?BLUETOOTH:
+   60: 	return 0;
+0010E6 7F00              MOV      R7,#00H
+   61: }
+0010E8 22                RET      
+----- FUNCTION YC_check_is_connected (END) -------
+
+
+----- FUNCTION LED_timer500ms (BEGIN) -----
+ FILE: 'sys.c'
+  308: void LED_timer500ms()
+  309: {
+  310: 	if (power_on_flag != 2)
+  311: 		return;
+0010E9 904DEB            MOV      DPTR,#power_on_flag
+0010EC E0                MOVX     A,@DPTR
+0010ED 6402              XRL      A,#02H
+0010EF 6002              JZ       $ + 4H
+0010F1 21B1              AJMP     ?C0047?SYS
+  312: 	if (g_variable.pairing_timeout != 0) //bt  pairing
+0010F3 904CE9            MOV      DPTR,#g_variable+02AH
+0010F6 E0                MOVX     A,@DPTR
+0010F7 603A              JZ       ?C0048?SYS
+  313: 	{
+  314: 		if (g_variable.button_reconnect_flag != 1)
+0010F9 904CCC            MOV      DPTR,#g_variable+0DH
+0010FC E0                MOVX     A,@DPTR
+0010FD 6401              XRL      A,#01H
+0010FF 601E              JZ       ?C0049?SYS
+  315: 		{
+  316: 			if(g_variable.current_device_num == 1)
+001101 904CC3            MOV      DPTR,#g_variable+04H
+001104 E0                MOVX     A,@DPTR
+001105 6401              XRL      A,#01H
+001107 7007              JNZ      ?C0050?SYS
+  317: 				GPIO_FlipOutBit(BT_LED_GPIO);
+001109 7F1F              MOV      R7,#01FH
+00110B 1235B1            LCALL    _GPIO_FlipOutBit
+00110E 802E              SJMP     ?C0054?SYS
+001110         ?C0050?SYS:
+  318: 			else if(g_variable.current_device_num == 2)
+001110 904CC3            MOV      DPTR,#g_variable+04H
+001113 E0                MOVX     A,@DPTR
+001114 6402              XRL      A,#02H
+001116 7026              JNZ      ?C0054?SYS
+  319: 				GPIO_FlipOutBit(BT2_LED_GPIO);
+001118 7F1E              MOV      R7,#01EH
+00111A 1235B1            LCALL    _GPIO_FlipOutBit
+  320: 		}
+00111D 801F              SJMP     ?C0054?SYS
+00111F         ?C0049?SYS:
+  321: 		else
+  322: 		{
+  323: 			GPIO_Setout(BT_LED_GPIO,LED_OFF);
+00111F C201              CLR      ?_GPIO_Setout?BIT
+001121 7F1F              MOV      R7,#01FH
+001123 31B2              ACALL    _GPIO_Setout
+  324: 			GPIO_Setout(BT2_LED_GPIO,LED_OFF);
+001125 C201              CLR      ?_GPIO_Setout?BIT
+001127 7F1E              MOV      R7,#01EH
+001129 31B2              ACALL    _GPIO_Setout
+  325: 			GPIO_Setout(LOWPOWER_LED_GPIO,LED_OFF);
+00112B C201              CLR      ?_GPIO_Setout?BIT
+00112D 7F14              MOV      R7,#014H
+00112F 31B2              ACALL    _GPIO_Setout
+  326: 		}
+  327: 	}
+001131 800B              SJMP     ?C0054?SYS
+001133         ?C0048?SYS:
+  328: 	else if (g_variable.pairing_g24_timeout != 0)
+001133 904CEE            MOV      DPTR,#g_variable+02FH
+001136 E0                MOVX     A,@DPTR
+001137 6005              JZ       ?C0054?SYS
+  329: 	{
+  330: 		GPIO_FlipOutBit(LOWPOWER_LED_GPIO);
+001139 7F14              MOV      R7,#014H
+00113B 1235B1            LCALL    _GPIO_FlipOutBit
+  331: 	}
+  332: 	else
+  333: 	{
+  334: 		
+  335: 	}
+00113E         ?C0054?SYS:
+  336: 
+  337: 	
+  338: 	if (YC_check_is_connected()&& !g_variable.powerOn_timer)
+00113E 11D3              ACALL    YC_check_is_connected
+001140 EF                MOV      A,R7
+001141 606E              JZ       ?C0047?SYS
+001143 904CE5            MOV      DPTR,#g_variable+026H
+001146 E0                MOVX     A,@DPTR
+001147 7068              JNZ      ?C0047?SYS
+  339: 	{
+  340: 		if(g_variable.sys_numlockled_on_timer)
+001149 A3                INC      DPTR
+00114A E0                MOVX     A,@DPTR
+00114B 6016              JZ       ?C0058?SYS
+  341: 		{
+  342: 			g_variable.sys_numlockled_on_timer--;
+00114D 14                DEC      A
+00114E F0                MOVX     @DPTR,A
+  343: 			GPIO_Setout(NUM_LOCK_LED_GPIO, LED_ON);
+00114F D201              SETB     ?_GPIO_Setout?BIT
+001151 7FFF              MOV      R7,#0FFH
+001153 31B2              ACALL    _GPIO_Setout
+  344: 			if(!g_variable.sys_numlockled_on_timer)
+001155 904CE6            MOV      DPTR,#g_variable+027H
+001158 E0                MOVX     A,@DPTR
+001159 700E              JNZ      ?C0060?SYS
+  345: 				GPIO_Setout(NUM_LOCK_LED_GPIO, LED_OFF);
+00115B C201              CLR      ?_GPIO_Setout?BIT
+00115D 7FFF              MOV      R7,#0FFH
+00115F 31B2              ACALL    _GPIO_Setout
+  346: 		}
+001161 8006              SJMP     ?C0060?SYS
+001163         ?C0058?SYS:
+  347: 		else 
+  348: 			GPIO_Setout(NUM_LOCK_LED_GPIO, LED_OFF);
+001163 C201              CLR      ?_GPIO_Setout?BIT
+001165 7FFF              MOV      R7,#0FFH
+001167 31B2              ACALL    _GPIO_Setout
+001169         ?C0060?SYS:
+  349: 
+  350: 		if(g_variable.sys_capslockled_on_timer)
+001169 904CE7            MOV      DPTR,#g_variable+028H
+00116C E0                MOVX     A,@DPTR
+00116D 6016              JZ       ?C0061?SYS
+  351: 		{
+  352: 			g_variable.sys_capslockled_on_timer--;
+00116F 14                DEC      A
+001170 F0                MOVX     @DPTR,A
+  353: 			GPIO_Setout(CAPS_LED_GPIO, LED_ON);
+001171 D201              SETB     ?_GPIO_Setout?BIT
+001173 7F1D              MOV      R7,#01DH
+001175 31B2              ACALL    _GPIO_Setout
+  354: 			if(!g_variable.sys_capslockled_on_timer)
+001177 904CE7            MOV      DPTR,#g_variable+028H
+00117A E0                MOVX     A,@DPTR
+00117B 700E              JNZ      ?C0063?SYS
+  355: 				GPIO_Setout(CAPS_LED_GPIO, LED_OFF);
+00117D C201              CLR      ?_GPIO_Setout?BIT
+00117F 7F1D              MOV      R7,#01DH
+001181 31B2              ACALL    _GPIO_Setout
+  356: 		}
+001183 8006              SJMP     ?C0063?SYS
+001185         ?C0061?SYS:
+  357: 		else
+  358: 			GPIO_Setout(CAPS_LED_GPIO, LED_OFF);
+001185 C201              CLR      ?_GPIO_Setout?BIT
+001187 7F1D              MOV      R7,#01DH
+001189 31B2              ACALL    _GPIO_Setout
+00118B         ?C0063?SYS:
+  359: 
+  360: 
+  361: 		if(g_variable.sys_scrolllockled_on_timer)
+00118B 904CE8            MOV      DPTR,#g_variable+029H
+00118E E0                MOVX     A,@DPTR
+00118F 6020              JZ       ?C0047?SYS
+  362: 		{
+  363: 			g_variable.sys_scrolllockled_on_timer--;
+001191 14                DEC      A
+001192 F0                MOVX     @DPTR,A
+  364: 			if(!g_variable.powerOn_timer && !g_variable.battery_low_led_flash_interval)
+001193 904CE5            MOV      DPTR,#g_variable+026H
+001196 E0                MOVX     A,@DPTR
+001197 7018              JNZ      ?C0047?SYS
+001199 904CE2            MOV      DPTR,#g_variable+023H
+00119C E0                MOVX     A,@DPTR
+00119D 7012              JNZ      ?C0047?SYS
+  365: 			{
+  366: 				GPIO_Setout(LOWPOWER_LED_GPIO, LED_ON);
+00119F D201              SETB     ?_GPIO_Setout?BIT
+0011A1 7F14              MOV      R7,#014H
+0011A3 31B2              ACALL    _GPIO_Setout
+  367: 				if(!g_variable.sys_scrolllockled_on_timer)
+0011A5 904CE8            MOV      DPTR,#g_variable+029H
+0011A8 E0                MOVX     A,@DPTR
+0011A9 7006              JNZ      ?C0047?SYS
+  368: 					GPIO_Setout(LOWPOWER_LED_GPIO, LED_OFF);
+0011AB C201              CLR      ?_GPIO_Setout?BIT
+0011AD 7F14              MOV      R7,#014H
+0011AF 31B2              ACALL    _GPIO_Setout
+  369: 			}
+  370: 		}		
+  371: 		
+  372: 	}	
+  373: }
+0011B1         ?C0047?SYS:
+0011B1 22                RET      
+----- FUNCTION LED_timer500ms (END) -------
+
+
+----- FUNCTION _GPIO_Setout (BEGIN) -----
+;---- Variable 'gpio_num' assigned to Register 'R7' ----
+0011B2 EF                MOV      A,R7
+0011B3 F4                CPL      A
+0011B4 600D              JZ       ?C0007?GPIO
+0011B6         ?C0006?GPIO:
+0011B6 7B01              MOV      R3,#01H
+0011B8 7A80              MOV      R2,#080H
+0011BA 7974              MOV      R1,#074H
+0011BC A201              MOV      C,bit_val
+0011BE 9200              MOV      ?_gpioSetBit?BIT,C
+0011C0 121875            LCALL    _gpioSetBit
+0011C3         ?C0007?GPIO:
+0011C3 22                RET      
+----- FUNCTION _GPIO_Setout (END) -------
+
+
+----- FUNCTION LED_handle (BEGIN) -----
+ FILE: 'led.c'
+   76: void LED_handle()
+   77: {
+   78: 	if (power_on_flag != 2)
+   79: 		return;
+0011C4 904DEB            MOV      DPTR,#power_on_flag
+0011C7 E0                MOVX     A,@DPTR
+0011C8 6402              XRL      A,#02H
+0011CA 6002              JZ       $ + 4H
+0011CC 41C5              AJMP     ?C0005?LED
+   80: 
+   81: 	if(!g_variable.pairing_timeout && !g_variable.pairing_g24_timeout)
+0011CE 904CE9            MOV      DPTR,#g_variable+02AH
+0011D1 E0                MOVX     A,@DPTR
+0011D2 6002              JZ       $ + 4H
+0011D4 41BF              AJMP     ?C0006?LED
+0011D6 904CEE            MOV      DPTR,#g_variable+02FH
+0011D9 E0                MOVX     A,@DPTR
+0011DA 6002              JZ       $ + 4H
+0011DC 41BF              AJMP     ?C0006?LED
+   82: 	{
+   83: 		//low battery LED process
+   84: 		if (g_variable.battery_status == BAT_STATUS_SHUT_DOWN)
+0011DE 904CD5            MOV      DPTR,#g_variable+016H
+0011E1 E0                MOVX     A,@DPTR
+0011E2 6402              XRL      A,#02H
+0011E4 7004              JNZ      ?C0007?LED
+   85: 		{
+   86: 			System_long_sleep();
+0011E6 F18F              ACALL    System_long_sleep
+   87: 		}
+0011E8 802F              SJMP     ?C0008?LED
+0011EA         ?C0007?LED:
+   88: 		else if (g_variable.battery_status == BAT_STATUS_LOW)
+0011EA 904CD5            MOV      DPTR,#g_variable+016H
+0011ED E0                MOVX     A,@DPTR
+0011EE 6401              XRL      A,#01H
+0011F0 7014              JNZ      ?C0009?LED
+   89: 		{
+   90: 			if (g_variable.battery_low_led_flash_flag == 0)
+0011F2 904CF7            MOV      DPTR,#g_variable+038H
+0011F5 E0                MOVX     A,@DPTR
+0011F6 7021              JNZ      ?C0008?LED
+   91: 			{
+   92: 				g_variable.battery_low_led_flash_interval = LOW_BATTERY_FLASH_INTERVAL;
+0011F8 904CE2            MOV      DPTR,#g_variable+023H
+0011FB 740A              MOV      A,#0AH
+0011FD F0                MOVX     @DPTR,A
+   93: 				g_variable.battery_low_led_flash_flag = 1;
+0011FE 904CF7            MOV      DPTR,#g_variable+038H
+001201 7401              MOV      A,#01H
+001203 F0                MOVX     @DPTR,A
+   94: 			}
+   95: 		}
+001204 8013              SJMP     ?C0008?LED
+001206         ?C0009?LED:
+   96: 		else
+   97: 		{
+   98: 			if (g_variable.battery_low_led_flash_flag == 1)
+001206 904CF7            MOV      DPTR,#g_variable+038H
+001209 E0                MOVX     A,@DPTR
+00120A 6401              XRL      A,#01H
+00120C 700B              JNZ      ?C0008?LED
+   99: 			{
+  100: 				g_variable.battery_low_led_flash_flag = 0;
+00120E F0                MOVX     @DPTR,A
+  101: 				g_variable.battery_low_led_flash_interval = 0;
+00120F 904CE2            MOV      DPTR,#g_variable+023H
+001212 F0                MOVX     @DPTR,A
+  102: 				GPIO_Setout(LOWPOWER_LED_GPIO, LED_OFF);
+001213 C201              CLR      ?_GPIO_Setout?BIT
+001215 7F14              MOV      R7,#014H
+001217 31B2              ACALL    _GPIO_Setout
+  103: 			}
+  104: 		}
+001219         ?C0008?LED:
+  105: 
+  106: 		//capslock  numlock  scrolllock LED process
+  107: 		if (YC_check_is_connected()&& !g_variable.powerOn_timer)
+001219 11D3              ACALL    YC_check_is_connected
+00121B EF                MOV      A,R7
+00121C 7002              JNZ      $ + 4H
+00121E 41B9              AJMP     ?C0013?LED
+001220 904CE5            MOV      DPTR,#g_variable+026H
+001223 E0                MOVX     A,@DPTR
+001224 6002              JZ       $ + 4H
+001226 41B9              AJMP     ?C0013?LED
+  108: 		{
+  109: 			if(m_caps_num_lock != m_caps_num_lock_last)
+001228 904DE0            MOV      DPTR,#m_caps_num_lock_last
+00122B E0                MOVX     A,@DPTR
+00122C FF                MOV      R7,A
+00122D 904CB7            MOV      DPTR,#m_caps_num_lock
+001230 E0                MOVX     A,@DPTR
+001231 6F                XRL      A,R7
+001232 7002              JNZ      $ + 4H
+001234 41C5              AJMP     ?C0005?LED
+  110: 			{
+  111: 				if(m_caps_num_lock & KB_PC_KEYSEL_NUMLOCK)
+001236 E0                MOVX     A,@DPTR
+001237 30E00E            JNB      ACC.0,?C0015?LED
+  112: 				{
+  113: 					g_variable.sys_numlockled_on_timer = KB_NUM_CAPS_LED_ON_TIMER;
+00123A 904CE6            MOV      DPTR,#g_variable+027H
+00123D 7414              MOV      A,#014H
+00123F F0                MOVX     @DPTR,A
+  114: 					GPIO_Setout(NUM_LOCK_LED_GPIO, LED_ON);
+001240 D201              SETB     ?_GPIO_Setout?BIT
+001242 7FFF              MOV      R7,#0FFH
+001244 31B2              ACALL    _GPIO_Setout
+  115: 				}
+001246 800B              SJMP     ?C0016?LED
+001248         ?C0015?LED:
+  116: 				else
+  117: 				{
+  118: 					GPIO_Setout(NUM_LOCK_LED_GPIO, LED_OFF);
+001248 C201              CLR      ?_GPIO_Setout?BIT
+00124A 7FFF              MOV      R7,#0FFH
+00124C 31B2              ACALL    _GPIO_Setout
+  119: 					g_variable.sys_numlockled_on_timer = 0;
+00124E E4                CLR      A
+00124F 904CE6            MOV      DPTR,#g_variable+027H
+001252 F0                MOVX     @DPTR,A
+  120: 				}
+001253         ?C0016?LED:
+  121: 				
+  122: 				if(m_caps_num_lock & KB_PC_KEYSEL_CAPSLOCK)
+001253 904CB7            MOV      DPTR,#m_caps_num_lock
+001256 E0                MOVX     A,@DPTR
+001257 30E10E            JNB      ACC.1,?C0017?LED
+  123: 				{
+  124: 					g_variable.sys_capslockled_on_timer = KB_NUM_CAPS_LED_ON_TIMER;
+00125A 904CE7            MOV      DPTR,#g_variable+028H
+00125D 7414              MOV      A,#014H
+00125F F0                MOVX     @DPTR,A
+  125: 					GPIO_Setout(CAPS_LED_GPIO, LED_ON);
+001260 D201              SETB     ?_GPIO_Setout?BIT
+001262 7F1D              MOV      R7,#01DH
+001264 31B2              ACALL    _GPIO_Setout
+  126: 				}
+001266 800B              SJMP     ?C0018?LED
+001268         ?C0017?LED:
+  127: 				else 
+  128: 				{
+  129: 					GPIO_Setout(CAPS_LED_GPIO, LED_OFF);
+001268 C201              CLR      ?_GPIO_Setout?BIT
+00126A 7F1D              MOV      R7,#01DH
+00126C 31B2              ACALL    _GPIO_Setout
+  130: 					g_variable.sys_capslockled_on_timer = 0;
+00126E E4                CLR      A
+00126F 904CE7            MOV      DPTR,#g_variable+028H
+001272 F0                MOVX     @DPTR,A
+  131: 				}	
+001273         ?C0018?LED:
+  132: 
+  133: 				
+  134: 				if(m_caps_num_lock & KB_PC_KEYSEL_SCROLLLOCK)
+001273 904CB7            MOV      DPTR,#m_caps_num_lock
+001276 E0                MOVX     A,@DPTR
+001277 30E21A            JNB      ACC.2,?C0019?LED
+  135: 				{
+  136: 					g_variable.sys_scrolllockled_on_timer = KB_NUM_CAPS_LED_ON_TIMER;
+00127A 904CE8            MOV      DPTR,#g_variable+029H
+00127D 7414              MOV      A,#014H
+00127F F0                MOVX     @DPTR,A
+  137: 					if(!g_variable.powerOn_timer && !g_variable.battery_low_led_flash_interval)
+001280 904CE5            MOV      DPTR,#g_variable+026H
+001283 E0                MOVX     A,@DPTR
+001284 7025              JNZ      ?C0021?LED
+001286 904CE2            MOV      DPTR,#g_variable+023H
+001289 E0                MOVX     A,@DPTR
+00128A 701F              JNZ      ?C0021?LED
+  138: 						GPIO_Setout(LOWPOWER_LED_GPIO, LED_ON);
+00128C D201              SETB     ?_GPIO_Setout?BIT
+00128E 7F14              MOV      R7,#014H
+001290 31B2              ACALL    _GPIO_Setout
+  139: 				}
+001292 8017              SJMP     ?C0021?LED
+001294         ?C0019?LED:
+  140: 				else 
+  141: 				{
+  142: 					if(!g_variable.powerOn_timer && !g_variable.battery_low_led_flash_interval)
+001294 904CE5            MOV      DPTR,#g_variable+026H
+001297 E0                MOVX     A,@DPTR
+001298 700C              JNZ      ?C0022?LED
+00129A 904CE2            MOV      DPTR,#g_variable+023H
+00129D E0                MOVX     A,@DPTR
+00129E 7006              JNZ      ?C0022?LED
+  143: 						GPIO_Setout(LOWPOWER_LED_GPIO, LED_OFF);
+0012A0 C201              CLR      ?_GPIO_Setout?BIT
+0012A2 7F14              MOV      R7,#014H
+0012A4 31B2              ACALL    _GPIO_Setout
+0012A6         ?C0022?LED:
+  144: 					g_variable.sys_scrolllockled_on_timer = 0;
+0012A6 E4                CLR      A
+0012A7 904CE8            MOV      DPTR,#g_variable+029H
+0012AA F0                MOVX     @DPTR,A
+  145: 				}
+0012AB         ?C0021?LED:
+  146: 				m_24g_led_flag = 0;	
+0012AB E4                CLR      A
+0012AC 904D46            MOV      DPTR,#m_24g_led_flag
+0012AF F0                MOVX     @DPTR,A
+  147: 				m_caps_num_lock_last = m_caps_num_lock;
+0012B0 904CB7            MOV      DPTR,#m_caps_num_lock
+0012B3 E0                MOVX     A,@DPTR
+0012B4 904DE0            MOV      DPTR,#m_caps_num_lock_last
+0012B7 F0                MOVX     @DPTR,A
+  148: 			}
+  149: 		}
+0012B8 22                RET      
+0012B9         ?C0013?LED:
+  150: 		else
+  151: 		{
+  152: 			GPIO_Setout(NUM_LOCK_LED_GPIO, LED_OFF);
+0012B9 C201              CLR      ?_GPIO_Setout?BIT
+0012BB 7FFF              MOV      R7,#0FFH
+0012BD 21B2              AJMP     _GPIO_Setout
+  153: //			GPIO_Setout(CAPS_LED_GPIO, LED_OFF);
+  154: 		}
+  155: 	}
+0012BF         ?C0006?LED:
+  156: 	else
+  157: 	{
+  158: 		GPIO_Setout(NUM_LOCK_LED_GPIO, LED_OFF);
+0012BF C201              CLR      ?_GPIO_Setout?BIT
+0012C1 7FFF              MOV      R7,#0FFH
+0012C3 31B2              ACALL    _GPIO_Setout
+  159: 
+  160: 	}
+  161: 
+  162: }
+0012C5         ?C0005?LED:
+0012C5 22                RET      
+----- FUNCTION LED_handle (END) -------
+
+
+----- FUNCTION _YC_key_action_handle (BEGIN) -----
+ FILE: 'kb_process.c'
+    3: void YC_key_action_handle(byte key_num)
+    4: {
+0012C6 904F01            MOV      DPTR,#key_num
+0012C9 EF                MOV      A,R7
+0012CA F0                MOVX     @DPTR,A
+    5: 	switch (key_num)
+    6: 	{
+0012CB 14                DEC      A
+0012CC B40D00            CJNE     A,#0DH,?C0256?KB_PROCESS
+0012CF         ?C0256?KB_PROCESS:
+0012CF 4002              JC       $ + 4H
+0012D1 8197              AJMP     ?C0025?KB_PROCESS
+0012D3 9012E1            MOV      DPTR,#012E1H
+0012D6 75F003            MOV      B,#03H
+0012D9 A4                MUL      AB
+0012DA C583              XCH      A,DPH
+0012DC 25F0              ADD      A,B
+0012DE C583              XCH      A,DPH
+0012E0 73                JMP      @A+DPTR
+0012E1         ?C0257?KB_PROCESS:
+0012E1 021308            LJMP     ?C0004?KB_PROCESS
+0012E4 021308            LJMP     ?C0004?KB_PROCESS
+0012E7 021308            LJMP     ?C0004?KB_PROCESS
+0012EA 021497            LJMP     ?C0025?KB_PROCESS
+0012ED 02134C            LJMP     ?C0009?KB_PROCESS
+0012F0 02138E            LJMP     ?C0013?KB_PROCESS
+0012F3 021397            LJMP     ?C0014?KB_PROCESS
+0012F6 0213E4            LJMP     ?C0016?KB_PROCESS
+0012F9 0213E4            LJMP     ?C0016?KB_PROCESS
+0012FC 02144C            LJMP     ?C0020?KB_PROCESS
+0012FF 021497            LJMP     ?C0025?KB_PROCESS
+001302 021497            LJMP     ?C0025?KB_PROCESS
+001305 021348            LJMP     ?C0008?KB_PROCESS
+    7: 	case KEY_RECON_0:
+    8: 	case KEY_RECON_1:
+    9: 	case KEY_RECON_2:
+   10: 		if (g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED 
+001308         ?C0004?KB_PROCESS:
+   11: 			||g_variable.g24_currentState == CHANGE_TO_24G_CONNECTING)
+001308 904CC5            MOV      DPTR,#g_variable+06H
+00130B E0                MOVX     A,@DPTR
+00130C FF                MOV      R7,A
+00130D 6403              XRL      A,#03H
+00130F 6005              JZ       ?C0006?KB_PROCESS
+001311 EF                MOV      A,R7
+001312 6402              XRL      A,#02H
+001314 700D              JNZ      ?C0005?KB_PROCESS
+001316         ?C0006?KB_PROCESS:
+   12: 		{
+   13: 			IPC_TxControlCmd(IPC_CMD_STOP_24G);
+001316 7F22              MOV      R7,#022H
+001318 919D              ACALL    _IPC_TxControlCmd
+   14: 			g_variable.key_action = key_num;
+00131A 904F01            MOV      DPTR,#key_num
+00131D E0                MOVX     A,@DPTR
+00131E 904CED            MOV      DPTR,#g_variable+02EH
+001321 F0                MOVX     @DPTR,A
+   15: 		}
+001322 22                RET      
+001323         ?C0005?KB_PROCESS:
+   16: 		else
+   17: 		{
+   18: 			recon_index = key_num-1;
+001323 904F01            MOV      DPTR,#key_num
+001326 E0                MOVX     A,@DPTR
+001327 14                DEC      A
+001328 904DD6            MOV      DPTR,#recon_index
+00132B F0                MOVX     @DPTR,A
+   19: 			kscurrmult = 0x05;
+00132C 904213            MOV      DPTR,#kscurrmult
+00132F 7405              MOV      A,#05H
+001331 F0                MOVX     @DPTR,A
+   20: 			g_variable.recon_count = 5;
+001332 904CF0            MOV      DPTR,#g_variable+031H
+001335 F0                MOVX     @DPTR,A
+   21: 			IPC_TxControlCmd(IPC_CMD_DISCONNECT);
+001336 7F04              MOV      R7,#04H
+001338 919D              ACALL    _IPC_TxControlCmd
+   22: 			Delay1ms(10);
+00133A 7F0A              MOV      R7,#0AH
+00133C F198              ACALL    _Delay1ms
+   23: 			IPC_TxControlCmd(IPC_CMD_SET_RECONNECT_INIT);
+00133E 7F2A              MOV      R7,#02AH
+001340 919D              ACALL    _IPC_TxControlCmd
+   24: 			g_variable.key_action = KEY_NONE;
+001342 E4                CLR      A
+001343 904CED            MOV      DPTR,#g_variable+02EH
+001346 F0                MOVX     @DPTR,A
+   25: 		}
+   26: 		break;
+001347 22                RET      
+   27: 	case KEY_STOP_DISCOVERY:
+001348         ?C0008?KB_PROCESS:
+   28: 		IPC_TxControlCmd(IPC_CMD_STOP_ADV);
+001348 7F0E              MOV      R7,#0EH
+00134A 819D              AJMP     _IPC_TxControlCmd
+   29: 		break;
+   30: 	case KEY_DISCOVERY:
+00134C         ?C0009?KB_PROCESS:
+   31: 		g_variable.recon_count = 0;
+00134C E4                CLR      A
+00134D 904CF0            MOV      DPTR,#g_variable+031H
+001350 F0                MOVX     @DPTR,A
+   32: 		if (YC_disconnect_all_link() || YC_cancel_reconnect() || YC_g24_mode_discovery())
+001351 1219C1            LCALL    YC_disconnect_all_link
+001354 EF                MOV      A,R7
+001355 700C              JNZ      ?C0011?KB_PROCESS
+001357 1219AE            LCALL    YC_cancel_reconnect
+00135A EF                MOV      A,R7
+00135B 7006              JNZ      ?C0011?KB_PROCESS
+00135D 121FED            LCALL    YC_g24_mode_discovery
+001360 EF                MOV      A,R7
+001361 600F              JZ       ?C0010?KB_PROCESS
+001363         ?C0011?KB_PROCESS:
+   33: 		{
+   34: 			g_variable.key_action = key_num;
+001363 904F01            MOV      DPTR,#key_num
+001366 E0                MOVX     A,@DPTR
+001367 904CED            MOV      DPTR,#g_variable+02EH
+00136A F0                MOVX     @DPTR,A
+   35: 			action_timeout = 3;
+00136B 904DEC            MOV      DPTR,#action_timeout
+00136E 7403              MOV      A,#03H
+001370 F0                MOVX     @DPTR,A
+   36: 		}
+001371 22                RET      
+001372         ?C0010?KB_PROCESS:
+   37: 		else
+   38: 		{
+   39: 			YC_clear_reconnect_flag();
+001372 F1E0              ACALL    YC_clear_reconnect_flag
+   40: 				ble_send_secutiry_request_timer = 0;
+001374 E4                CLR      A
+001375 904DD4            MOV      DPTR,#ble_send_secutiry_request_timer
+001378 F0                MOVX     @DPTR,A
+   41: 				ble_fast_connect_flag = 0;
+001379 904DD3            MOV      DPTR,#ble_fast_connect_flag
+00137C F0                MOVX     @DPTR,A
+   42: 				fast_connect_flag = 0;
+00137D 904E55            MOV      DPTR,#fast_connect_flag
+001380 F0                MOVX     @DPTR,A
+   43: //				m_lpm_mode = 0;
+   44: 				YC_get_ble_ramdon_lap();
+001381 12221C            LCALL    YC_get_ble_ramdon_lap
+   45: 				IPC_TxControlCmd(IPC_CMD_START_ADV);
+001384 7F0D              MOV      R7,#0DH
+001386 919D              ACALL    _IPC_TxControlCmd
+   46: 			g_variable.key_action = KEY_NONE;
+001388 E4                CLR      A
+001389 904CED            MOV      DPTR,#g_variable+02EH
+00138C F0                MOVX     @DPTR,A
+   47: 		}
+   48: 		break;
+00138D 22                RET      
+   49: 	case KEY_DISCONNECT_ALL:
+00138E         ?C0013?KB_PROCESS:
+   50: 		YC_disconnect_all_link();
+00138E 1219C1            LCALL    YC_disconnect_all_link
+   51: 		g_variable.key_action = KEY_NONE;
+001391 E4                CLR      A
+001392 904CED            MOV      DPTR,#g_variable+02EH
+001395 F0                MOVX     @DPTR,A
+   52: 		break;
+001396 22                RET      
+   53: 	case KEY_CLEAR_RECORD:
+001397         ?C0014?KB_PROCESS:
+   54: 		xmemclear_ff((byte *)bd_key_record_list,sizeof(BD_KEY_RECORD)*3);
+001397 7B01              MOV      R3,#01H
+001399 7A4D              MOV      R2,#HIGH bd_key_record_list
+00139B 79EE              MOV      R1,#LOW bd_key_record_list
+00139D 7D5D              MOV      R5,#05DH
+00139F 7C00              MOV      R4,#00H
+0013A1 123545            LCALL    _xmemclear_ff
+   55: 		g_variable.last_device_num = 0xff;
+0013A4 904CC0            MOV      DPTR,#g_variable+01H
+0013A7 74FF              MOV      A,#0FFH
+0013A9 F0                MOVX     @DPTR,A
+   56: 		g_variable.system_mode = 0xff;
+0013AA A3                INC      DPTR
+0013AB F0                MOVX     @DPTR,A
+   57: 		Delay1ms(200);
+0013AC 7FC8              MOV      R7,#0C8H
+0013AE F198              ACALL    _Delay1ms
+   58: 		GPIO_Setout(EEPROM_WP_GPIO,0);
+0013B0 C201              CLR      ?_GPIO_Setout?BIT
+0013B2 7FFF              MOV      R7,#0FFH
+0013B4 31B2              ACALL    _GPIO_Setout
+   59: 		IIC_WriteBlock(EEPROM_RECON_INFO_BASE ,sizeof(BD_KEY_RECORD)*3 , (byte *)&bd_key_record_list);
+0013B6 7B01              MOV      R3,#01H
+0013B8 7A4D              MOV      R2,#HIGH bd_key_record_list
+0013BA 79EE              MOV      R1,#LOW bd_key_record_list
+0013BC 7D5D              MOV      R5,#05DH
+0013BE 7C00              MOV      R4,#00H
+0013C0 7F60              MOV      R7,#060H
+0013C2 7E7F              MOV      R6,#07FH
+0013C4 121C84            LCALL    _IIC_WriteBlock
+   60: 		IIC_WriteBlock(EEPROM_RECON_INFO_LAST_DEVICE ,1 ,(byte *)&g_variable.last_device_num);
+0013C7 7B01              MOV      R3,#01H
+0013C9 7A4C              MOV      R2,#HIGH g_variable+01H
+0013CB 79C0              MOV      R1,#LOW g_variable+01H
+0013CD 7D01              MOV      R5,#01H
+0013CF 7C00              MOV      R4,#00H
+0013D1 7FBD              MOV      R7,#0BDH
+0013D3 7E7F              MOV      R6,#07FH
+0013D5 121C84            LCALL    _IIC_WriteBlock
+   61: 		GPIO_Setout(EEPROM_WP_GPIO,1);
+0013D8 D201              SETB     ?_GPIO_Setout?BIT
+0013DA 7FFF              MOV      R7,#0FFH
+0013DC 31B2              ACALL    _GPIO_Setout
+   62: 		g_variable.key_action = KEY_NONE;
+0013DE E4                CLR      A
+0013DF 904CED            MOV      DPTR,#g_variable+02EH
+0013E2 F0                MOVX     @DPTR,A
+   63: 		break;
+0013E3 22                RET      
+   64: 	case KEY_START_24G:
+   65: 	case KEY_OPEN_24G:
+0013E4         ?C0016?KB_PROCESS:
+   66: 		g_variable.recon_count = 0;
+0013E4 E4                CLR      A
+0013E5 904CF0            MOV      DPTR,#g_variable+031H
+0013E8 F0                MOVX     @DPTR,A
+   67: 		if ( YC_cancel_reconnect())
+0013E9 1219AE            LCALL    YC_cancel_reconnect
+0013EC EF                MOV      A,R7
+0013ED 6009              JZ       ?C0017?KB_PROCESS
+   68: 		{
+   69: 			g_variable.key_action = key_num;
+0013EF 904F01            MOV      DPTR,#key_num
+0013F2 E0                MOVX     A,@DPTR
+0013F3 904CED            MOV      DPTR,#g_variable+02EH
+0013F6 F0                MOVX     @DPTR,A
+   70: 		}
+0013F7 22                RET      
+0013F8         ?C0017?KB_PROCESS:
+   71: 		else
+   72: 		{
+   73: 			IIC_Read(EEPROM_RECON_INFO_BASE_6+2,4 , (byte *)m_24g_addr);
+0013F8 7B01              MOV      R3,#01H
+0013FA 7A4C              MOV      R2,#HIGH m_24g_addr
+0013FC 7900              MOV      R1,#LOW m_24g_addr
+0013FE 7D04              MOV      R5,#04H
+001400 7C00              MOV      R4,#00H
+001402 7F52              MOV      R7,#052H
+001404 7E7F              MOV      R6,#07FH
+001406 1220CA            LCALL    _IIC_Read
+   74: 			Delay1ms(10);
+001409 7F0A              MOV      R7,#0AH
+00140B F198              ACALL    _Delay1ms
+   75: 			fast_connect_flag = 0;
+00140D E4                CLR      A
+00140E 904E55            MOV      DPTR,#fast_connect_flag
+001411 F0                MOVX     @DPTR,A
+   76: 			if (m_24g_addr[0] == 0xff && m_24g_addr[1] == 0xff && m_24g_addr[2] == 0xff && m_24g_addr[3] == 0xff)
+001412 904C00            MOV      DPTR,#m_24g_addr
+001415 E0                MOVX     A,@DPTR
+001416 F4                CPL      A
+001417 7021              JNZ      ?C0019?KB_PROCESS
+001419 A3                INC      DPTR
+00141A E0                MOVX     A,@DPTR
+00141B F4                CPL      A
+00141C 701C              JNZ      ?C0019?KB_PROCESS
+00141E A3                INC      DPTR
+00141F E0                MOVX     A,@DPTR
+001420 F4                CPL      A
+001421 7017              JNZ      ?C0019?KB_PROCESS
+001423 A3                INC      DPTR
+001424 E0                MOVX     A,@DPTR
+001425 F4                CPL      A
+001426 7012              JNZ      ?C0019?KB_PROCESS
+   77: 			{
+   78: 				m_24g_addr[0] = 0x0f;
+001428 904C00            MOV      DPTR,#m_24g_addr
+00142B 740F              MOV      A,#0FH
+00142D F0                MOVX     @DPTR,A
+   79: 				m_24g_addr[1] = 0x0f;
+00142E A3                INC      DPTR
+00142F F0                MOVX     @DPTR,A
+   80: 				m_24g_addr[2] = 0x0f;
+001430 A3                INC      DPTR
+001431 F0                MOVX     @DPTR,A
+   81: 				m_24g_addr[3] = 0x0f;
+001432 A3                INC      DPTR
+001433 F0                MOVX     @DPTR,A
+   82: 				fast_connect_flag = 1;
+001434 904E55            MOV      DPTR,#fast_connect_flag
+001437 7401              MOV      A,#01H
+001439 F0                MOVX     @DPTR,A
+   83: 			}
+00143A         ?C0019?KB_PROCESS:
+   84: 				
+   85: 			IPC_TxControlCmd(IPC_CMD_START_24G);
+00143A 7F21              MOV      R7,#021H
+00143C 919D              ACALL    _IPC_TxControlCmd
+   86: 			
+   87: 			g_variable.g24_currentState = CHANGE_TO_24G_CONNECTING;
+00143E 904CC5            MOV      DPTR,#g_variable+06H
+001441 7402              MOV      A,#02H
+001443 F0                MOVX     @DPTR,A
+   88: 			g_variable.g24_currentSubState = CHANGE_TO_24G_SUB_NONE;
+001444 E4                CLR      A
+001445 A3                INC      DPTR
+001446 F0                MOVX     @DPTR,A
+   89: 			g_variable.key_action = KEY_NONE;
+001447 904CED            MOV      DPTR,#g_variable+02EH
+00144A F0                MOVX     @DPTR,A
+   90: 		}
+   91: 		break;
+00144B 22                RET      
+   92: 	case KEY_PAIRING_24G:
+00144C         ?C0020?KB_PROCESS:
+   93: 		g_variable.recon_count = 0;
+00144C E4                CLR      A
+00144D 904CF0            MOV      DPTR,#g_variable+031H
+001450 F0                MOVX     @DPTR,A
+   94: 		if (YC_disconnect_all_link() || YC_cancel_reconnect())
+001451 1219C1            LCALL    YC_disconnect_all_link
+001454 EF                MOV      A,R7
+001455 7006              JNZ      ?C0022?KB_PROCESS
+001457 1219AE            LCALL    YC_cancel_reconnect
+00145A EF                MOV      A,R7
+00145B 6009              JZ       ?C0021?KB_PROCESS
+00145D         ?C0022?KB_PROCESS:
+   95: 		{
+   96: 			g_variable.key_action = key_num;
+00145D 904F01            MOV      DPTR,#key_num
+001460 E0                MOVX     A,@DPTR
+001461 904CED            MOV      DPTR,#g_variable+02EH
+001464 F0                MOVX     @DPTR,A
+   97: 		}
+001465 22                RET      
+001466         ?C0021?KB_PROCESS:
+   98: 		else
+   99: 		{
+  100: 			if (g_variable.g24_currentState != CHANGE_TO_24G_PAIRING)
+001466 904CC5            MOV      DPTR,#g_variable+06H
+001469 E0                MOVX     A,@DPTR
+00146A 6401              XRL      A,#01H
+00146C 6023              JZ       ?C0024?KB_PROCESS
+  101: 			{
+  102: 				fast_connect_flag = 0;
+00146E E4                CLR      A
+00146F 904E55            MOV      DPTR,#fast_connect_flag
+001472 F0                MOVX     @DPTR,A
+  103: 				IPC_TxControlCmd(IPC_CMD_PAIR_24G);
+001473 7F23              MOV      R7,#023H
+001475 919D              ACALL    _IPC_TxControlCmd
+  104: 				g_variable.g24_currentState = CHANGE_TO_24G_PAIRING;
+001477 904CC5            MOV      DPTR,#g_variable+06H
+00147A 7401              MOV      A,#01H
+00147C F0                MOVX     @DPTR,A
+  105: 				g_variable.g24_currentSubState = CHANGE_TO_24G_SUB_NONE;
+00147D E4                CLR      A
+00147E A3                INC      DPTR
+00147F F0                MOVX     @DPTR,A
+  106: 				g_variable.pairing_g24_timeout = G24_PAIRING_TIME_OUT_20S;
+001480 904CEE            MOV      DPTR,#g_variable+02FH
+001483 7428              MOV      A,#028H
+001485 F0                MOVX     @DPTR,A
+  107: 				GPIO_Setout(LOWPOWER_LED_GPIO,LED_OFF);
+001486 C201              CLR      ?_GPIO_Setout?BIT
+001488 7F14              MOV      R7,#014H
+00148A 31B2              ACALL    _GPIO_Setout
+  108: 				g_variable.pairing_timeout = 0;
+00148C E4                CLR      A
+00148D 904CE9            MOV      DPTR,#g_variable+02AH
+001490 F0                MOVX     @DPTR,A
+  109: 			}
+001491         ?C0024?KB_PROCESS:
+  110: 			g_variable.key_action = KEY_NONE;
+001491 E4                CLR      A
+001492 904CED            MOV      DPTR,#g_variable+02EH
+001495 F0                MOVX     @DPTR,A
+  111: 		}
+  112: 		break;
+001496 22                RET      
+  113: 	default:
+001497         ?C0025?KB_PROCESS:
+  114: 		g_variable.key_action = KEY_NONE;
+001497 E4                CLR      A
+001498 904CED            MOV      DPTR,#g_variable+02EH
+00149B F0                MOVX     @DPTR,A
+  115: 		break;
+  116: 	}
+  117: }
+00149C 22                RET      
+----- FUNCTION _YC_key_action_handle (END) -------
+
+
+----- FUNCTION _IPC_TxControlCmd (BEGIN) -----
+00149D 904EDC            MOV      DPTR,#cmd
+0014A0 EF                MOV      A,R7
+0014A1 F0                MOVX     @DPTR,A
+0014A2 78DD              MOV      R0,#LOW cmdBuff
+0014A4 7C4E              MOV      R4,#HIGH cmdBuff
+0014A6 7D01              MOV      R5,#01H
+0014A8 7BFF              MOV      R3,#0FFH
+0014AA 7A07              MOV      R2,#HIGH _?ix1000
+0014AC 7934              MOV      R1,#LOW _?ix1000
+0014AE 7E00              MOV      R6,#00H
+0014B0 7F03              MOV      R7,#03H
+0014B2 120390            LCALL    ?C?COPY
+0014B5 904EDC            MOV      DPTR,#cmd
+0014B8 E0                MOVX     A,@DPTR
+0014B9 904EDF            MOV      DPTR,#cmdBuff+02H
+0014BC F0                MOVX     @DPTR,A
+0014BD 7B01              MOV      R3,#01H
+0014BF 7A4E              MOV      R2,#HIGH cmdBuff
+0014C1 79DD              MOV      R1,#LOW cmdBuff
+0014C3 7D03              MOV      R5,#03H
+0014C5 020FE5            LJMP     _ipcTx
+----- FUNCTION _IPC_TxControlCmd (END) -------
+
+
+----- FUNCTION _kb_cb_event (BEGIN) -----
+ FILE: 'sys.c'
+  124: static void kb_cb_event(byte evt)
+  125: {
+0014C8 904F06            MOV      DPTR,#evt
+0014CB EF                MOV      A,R7
+0014CC F0                MOVX     @DPTR,A
+  126: 
+  127: 	switch (evt) 
+0014CD 1205B3            LCALL    ?C?CCASE
+0014D0 167B              DW       ?C0034?SYS
+0014D2 14                DB       014H
+0014D3 174A              DW       ?C0041?SYS
+0014D5 15                DB       015H
+0014D6 1571              DW       ?C0020?SYS
+0014D8 27                DB       027H
+0014D9 1711              DW       ?C0039?SYS
+0014DB 29                DB       029H
+0014DC 14FE              DW       ?C0015?SYS
+0014DE 2F                DB       02FH
+0014DF 1565              DW       ?C0018?SYS
+0014E1 30                DB       030H
+0014E2 15CA              DW       ?C0024?SYS
+0014E4 31                DB       031H
+0014E5 163F              DW       ?C0030?SYS
+0014E7 32                DB       032H
+0014E8 14FE              DW       ?C0015?SYS
+0014EA 33                DB       033H
+0014EB 16EC              DW       ?C0038?SYS
+0014ED 34                DB       034H
+0014EE 172B              DW       ?C0040?SYS
+0014F0 35                DB       035H
+0014F1 15C2              DW       ?C0022?SYS
+0014F3 37                DB       037H
+0014F4 1571              DW       ?C0020?SYS
+0014F6 39                DB       039H
+0014F7 15CA              DW       ?C0024?SYS
+0014F9 3C                DB       03CH
+0014FA 0000              DW       00H
+0014FC 178E              DW       ?C0045?SYS
+  128: 	{
+  129: 	case IPC_EVT_HIBERNATE_WAKE:
+  130: 	case IPC_EVT_RESET:
+0014FE         ?C0015?SYS:
+  131: 		System_Hardware_init();
+0014FE F1EA              ACALL    System_Hardware_init
+  132: 		System_Software_init();
+001500 12304D            LCALL    System_Software_init
+  133: 		IIC_Read(EEPROM_RECON_INFO_LAST_DEVICE ,1 ,(byte *)&g_variable.last_device_num);
+001503 7B01              MOV      R3,#01H
+001505 7A4C              MOV      R2,#HIGH g_variable+01H
+001507 79C0              MOV      R1,#LOW g_variable+01H
+001509 7D01              MOV      R5,#01H
+00150B 7C00              MOV      R4,#00H
+00150D 7FBD              MOV      R7,#0BDH
+00150F 7E7F              MOV      R6,#07FH
+001511 1220CA            LCALL    _IIC_Read
+  134: 		if(g_variable.last_device_num > 3)
+001514 904CC0            MOV      DPTR,#g_variable+01H
+001517 E0                MOVX     A,@DPTR
+001518 D3                SETB     C
+001519 9403              SUBB     A,#03H
+00151B 7480              MOV      A,#080H
+00151D 9480              SUBB     A,#080H
+00151F 4002              JC       ?C0016?SYS
+  135: 			g_variable.last_device_num = 0;
+001521 E4                CLR      A
+001522 F0                MOVX     @DPTR,A
+001523         ?C0016?SYS:
+  136: 		g_variable.current_device_num = g_variable.last_device_num;
+001523 904CC0            MOV      DPTR,#g_variable+01H
+001526 E0                MOVX     A,@DPTR
+001527 904CC3            MOV      DPTR,#g_variable+04H
+00152A F0                MOVX     @DPTR,A
+  137: 		LED_device_poweron();
+00152B F1B0              ACALL    LED_device_poweron
+  138: 		Delay1ms(10);
+00152D 7F0A              MOV      R7,#0AH
+00152F F198              ACALL    _Delay1ms
+  139: 		IIC_Read(EEPROM_RECON_INFO_RAMDON_LE_LAP1 ,2 ,(byte *)&g_variable.ble_ramdon_lap1);
+001531 7B01              MOV      R3,#01H
+001533 7A4C              MOV      R2,#HIGH g_variable+033H
+001535 79F2              MOV      R1,#LOW g_variable+033H
+001537 7D02              MOV      R5,#02H
+001539 7C00              MOV      R4,#00H
+00153B 7FBE              MOV      R7,#0BEH
+00153D 7E7F              MOV      R6,#07FH
+00153F 1220CA            LCALL    _IIC_Read
+  140: 		if(g_variable.ble_ramdon_lap1 == 0xff && g_variable.ble_ramdon_lap2 == 0xff)
+001542 904CF2            MOV      DPTR,#g_variable+033H
+001545 E0                MOVX     A,@DPTR
+001546 F4                CPL      A
+001547 7019              JNZ      ?C0017?SYS
+001549 A3                INC      DPTR
+00154A E0                MOVX     A,@DPTR
+00154B F4                CPL      A
+00154C 7014              JNZ      ?C0017?SYS
+  141: 		{
+  142: 			g_variable.ble_ramdon_lap1 = m_adc3vValue;
+00154E 904C93            MOV      DPTR,#m_adc3vValue
+001551 E0                MOVX     A,@DPTR
+001552 A3                INC      DPTR
+001553 E0                MOVX     A,@DPTR
+001554 904CF2            MOV      DPTR,#g_variable+033H
+001557 F0                MOVX     @DPTR,A
+  143: 			g_variable.ble_ramdon_lap2 = m_adc0vBase;
+001558 904C91            MOV      DPTR,#m_adc0vBase
+00155B E0                MOVX     A,@DPTR
+00155C A3                INC      DPTR
+00155D E0                MOVX     A,@DPTR
+00155E 904CF3            MOV      DPTR,#g_variable+034H
+001561 F0                MOVX     @DPTR,A
+  144: 		}
+001562         ?C0017?SYS:
+  145: 		YC_start_reconnect();
+001562 022004            LJMP     YC_start_reconnect
+  146: 		break;
+  147: 	case IPC_EVT_WAKEUP:
+001565         ?C0018?SYS:
+  148: 		System_IIC_clk_setup();
+001565 12303A            LCALL    System_IIC_clk_setup
+  149: 		KS_Initialize();
+001568 1218F4            LCALL    KS_Initialize
+  150: 		g_variable.g24_long_sleep_flag = 0;
+00156B E4                CLR      A
+00156C 904CFC            MOV      DPTR,#g_variable+03DH
+00156F F0                MOVX     @DPTR,A
+  151: 		break;
+001570 22                RET      
+  152: 
+  153: // connection event
+  154: 	case IPC_EVT_VIRTUAL_CABLE_UNPLUG:
+  155: 	case IPC_EVT_CLEAR_LINKKEY:
+001571         ?C0020?SYS:
+  156: 		if ((g_variable.current_device_num > 0) && (g_variable.current_device_num < 4))
+001571 904CC3            MOV      DPTR,#g_variable+04H
+001574 E0                MOVX     A,@DPTR
+001575 D3                SETB     C
+001576 9400              SUBB     A,#00H
+001578 7480              MOV      A,#080H
+00157A 9480              SUBB     A,#080H
+00157C 5002              JNC      $ + 4H
+00157E E18E              AJMP     ?C0045?SYS
+001580 E0                MOVX     A,@DPTR
+001581 9404              SUBB     A,#04H
+001583 7480              MOV      A,#080H
+001585 9480              SUBB     A,#080H
+001587 4002              JC       $ + 4H
+001589 E18E              AJMP     ?C0045?SYS
+  157: 		{
+  158: 			xmemclear_ff((byte *)&bd_key_record_list[g_variable.current_device_num-1],sizeof(BD_KEY_RECORD));	
+00158B E0                MOVX     A,@DPTR
+00158C 75F01F            MOV      B,#01FH
+00158F A4                MUL      AB
+001590 24CF              ADD      A,#LOW bd_key_record_list-01FH
+001592 F9                MOV      R1,A
+001593 744D              MOV      A,#HIGH bd_key_record_list-01FH
+001595 35F0              ADDC     A,B
+001597 FA                MOV      R2,A
+001598 7B01              MOV      R3,#01H
+00159A 7D1F              MOV      R5,#01FH
+00159C 7C00              MOV      R4,#00H
+00159E 123545            LCALL    _xmemclear_ff
+  159: 			Delay1ms(200);
+0015A1 7FC8              MOV      R7,#0C8H
+0015A3 F198              ACALL    _Delay1ms
+  160: 			GPIO_Setout(EEPROM_WP_GPIO,0);
+0015A5 C201              CLR      ?_GPIO_Setout?BIT
+0015A7 7FFF              MOV      R7,#0FFH
+0015A9 31B2              ACALL    _GPIO_Setout
+  161: 			IIC_WriteBlock(EEPROM_RECON_INFO_BASE ,sizeof(BD_KEY_RECORD)*3 , (byte *)bd_key_record_list);		
+0015AB 7B01              MOV      R3,#01H
+0015AD 7A4D              MOV      R2,#HIGH bd_key_record_list
+0015AF 79EE              MOV      R1,#LOW bd_key_record_list
+0015B1 7D5D              MOV      R5,#05DH
+0015B3 7C00              MOV      R4,#00H
+0015B5 7F60              MOV      R7,#060H
+0015B7 7E7F              MOV      R6,#07FH
+0015B9 121C84            LCALL    _IIC_WriteBlock
+  162: 			GPIO_Setout(EEPROM_WP_GPIO,1);
+0015BC D201              SETB     ?_GPIO_Setout?BIT
+0015BE 7FFF              MOV      R7,#0FFH
+0015C0 21B2              AJMP     _GPIO_Setout
+  163: 		}
+  164: 		break;
+  165: 	case IPC_EVT_RECONNECT_STANDY:
+0015C2         ?C0022?SYS:
+  166: 		YC_load_record_list(recon_index);
+0015C2 904DD6            MOV      DPTR,#recon_index
+0015C5 E0                MOVX     A,@DPTR
+0015C6 FF                MOV      R7,A
+0015C7 020737            LJMP     _YC_load_record_list
+  167: 		break;		
+  168: 		
+  169: // 2.4G event	
+  170: 	case IPC_EVT_24G_PAIRING_COMPLETE:
+  171: 	case IPC_EVT_24G_ATTEMPT_SUCCESS:
+0015CA         ?C0024?SYS:
+  172: 		g_variable.g24_currentState =  CHANGE_TO_24G_CONNECTED;
+0015CA 904CC5            MOV      DPTR,#g_variable+06H
+0015CD 7403              MOV      A,#03H
+0015CF F0                MOVX     @DPTR,A
+  173: 		g_variable.g24_currentSubState = CHANGE_TO_24G_SUB_NONE;
+0015D0 E4                CLR      A
+0015D1 A3                INC      DPTR
+0015D2 F0                MOVX     @DPTR,A
+  174: 		YC_clear_reconnect_flag();
+0015D3 F1E0              ACALL    YC_clear_reconnect_flag
+  175: 		g_variable.pairing_g24_timeout = 0;
+0015D5 E4                CLR      A
+0015D6 904CEE            MOV      DPTR,#g_variable+02FH
+0015D9 F0                MOVX     @DPTR,A
+  176: 		g_variable.release_data = 0;
+0015DA 904CEB            MOV      DPTR,#g_variable+02CH
+0015DD F0                MOVX     @DPTR,A
+  177: 		g_variable.last_device_num = 0xfe;
+0015DE 904CC0            MOV      DPTR,#g_variable+01H
+0015E1 74FE              MOV      A,#0FEH
+0015E3 F0                MOVX     @DPTR,A
+  178: 		g_variable.current_device_num = 0xfe;
+0015E4 904CC3            MOV      DPTR,#g_variable+04H
+0015E7 F0                MOVX     @DPTR,A
+  179: 		m_24g_led_flag = KB_24G_LED_ACK_TYPE;
+0015E8 904D46            MOV      DPTR,#m_24g_led_flag
+0015EB 7403              MOV      A,#03H
+0015ED F0                MOVX     @DPTR,A
+  180: 		delayChgInvTimer = 10;
+0015EE 904DE6            MOV      DPTR,#delayChgInvTimer
+0015F1 740A              MOV      A,#0AH
+0015F3 F0                MOVX     @DPTR,A
+  181: 
+  182: 		if(evt == IPC_EVT_24G_PAIRING_COMPLETE)
+0015F4 904F06            MOV      DPTR,#evt
+0015F7 E0                MOVX     A,@DPTR
+0015F8 6431              XRL      A,#031H
+0015FA 703A              JNZ      ?C0025?SYS
+  183: 		{
+  184: 			fn_lock_flag = 0;
+0015FC 904DE7            MOV      DPTR,#fn_lock_flag
+0015FF F0                MOVX     @DPTR,A
+  185: 			fast_connect_flag = 0;
+001600 904E55            MOV      DPTR,#fast_connect_flag
+001603 F0                MOVX     @DPTR,A
+  186: 			g_variable.system_mode = OSMODE_WINDOWS;
+001604 904CC1            MOV      DPTR,#g_variable+02H
+001607 F0                MOVX     @DPTR,A
+  187: 			g_variable.powerOn_timer = KB_POWERON_LED_ON_TIMER;
+001608 904CE5            MOV      DPTR,#g_variable+026H
+00160B 740A              MOV      A,#0AH
+00160D F0                MOVX     @DPTR,A
+  188: 			if(m_24g_paring_addr[0] != 0x0f || m_24g_paring_addr[1] != 0x0f ||
+00160E 904BEB            MOV      DPTR,#m_24g_paring_addr
+001611 E0                MOVX     A,@DPTR
+001612 640F              XRL      A,#0FH
+001614 7014              JNZ      ?C0027?SYS
+001616 A3                INC      DPTR
+001617 E0                MOVX     A,@DPTR
+001618 640F              XRL      A,#0FH
+00161A 700E              JNZ      ?C0027?SYS
+00161C A3                INC      DPTR
+00161D E0                MOVX     A,@DPTR
+00161E 640F              XRL      A,#0FH
+001620 7008              JNZ      ?C0027?SYS
+001622 A3                INC      DPTR
+001623 E0                MOVX     A,@DPTR
+001624 640F              XRL      A,#0FH
+001626 7002              JNZ      $ + 4H
+001628 E18E              AJMP     ?C0045?SYS
+00162A         ?C0027?SYS:
+  189: 				m_24g_paring_addr[2] != 0x0f || m_24g_paring_addr[3] != 0x0f)
+  190: 				{
+  191: 					g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_G24;
+00162A 904CBF            MOV      DPTR,#g_variable
+00162D 7402              MOV      A,#02H
+00162F F0                MOVX     @DPTR,A
+  192: 					YC_update_eeprom_data();
+001630 121BEA            LCALL    YC_update_eeprom_data
+  193: 					System_Hardware_reset();
+001633 021D33            LJMP     System_Hardware_reset
+  194: 				}
+  195: 		}
+001636         ?C0025?SYS:
+  196: 		else
+  197: 		{
+  198: 			if(!g_variable.powerOn_timer)
+001636 904CE5            MOV      DPTR,#g_variable+026H
+001639 E0                MOVX     A,@DPTR
+00163A 6002              JZ       $ + 4H
+00163C E18E              AJMP     ?C0045?SYS
+  199: 			;//GPIO_Setout(G24_LED_GPIO,LED_OFF);
+  200: 		}
+  201: 		break;
+00163E 22                RET      
+  202: 	
+  203: 	case IPC_EVT_24G_ATTEMPT_FAIL:	
+00163F         ?C0030?SYS:
+  204: 		g_variable.g24_currentState =  CHANGE_TO_24G_DISCONNECTED;
+00163F E4                CLR      A
+001640 904CC5            MOV      DPTR,#g_variable+06H
+001643 F0                MOVX     @DPTR,A
+  205: 		g_variable.g24_currentSubState = CHANGE_TO_24G_SUB_NONE;
+001644 A3                INC      DPTR
+001645 F0                MOVX     @DPTR,A
+  206: 		g_variable.sleepTimer = 0;
+001646 904CE3            MOV      DPTR,#g_variable+024H
+001649 F0                MOVX     @DPTR,A
+00164A A3                INC      DPTR
+00164B F0                MOVX     @DPTR,A
+  207: 		g_variable.release_data = 1;
+00164C 904CEB            MOV      DPTR,#g_variable+02CH
+00164F 04                INC      A
+001650 F0                MOVX     @DPTR,A
+  208: 
+  209: 		if (g_variable.key_action != KEY_NONE)
+001651 904CED            MOV      DPTR,#g_variable+02EH
+001654 E0                MOVX     A,@DPTR
+001655 6009              JZ       ?C0031?SYS
+  210: 		{
+  211: 			YC_clear_reconnect_flag();
+001657 F1E0              ACALL    YC_clear_reconnect_flag
+  212: 			YC_key_action_handle(g_variable.key_action);
+001659 904CED            MOV      DPTR,#g_variable+02EH
+00165C E0                MOVX     A,@DPTR
+00165D FF                MOV      R7,A
+00165E 41C6              AJMP     _YC_key_action_handle
+  213: 			break;
+  214: 		}
+001660         ?C0031?SYS:
+  215: 
+  216: 		if (g_variable.lockLpm == 1)
+001660 904CEC            MOV      DPTR,#g_variable+02DH
+001663 E0                MOVX     A,@DPTR
+001664 6401              XRL      A,#01H
+001666 7003              JNZ      ?C0032?SYS
+  217: 		{
+  218: 			g_variable.lockLpm =0;
+001668 F0                MOVX     @DPTR,A
+  219: 			System_long_sleep();
+001669 E18F              AJMP     System_long_sleep
+  220: 			break;
+  221: 		}
+00166B         ?C0032?SYS:
+  222: 		if (g_variable.recon_count != 0)
+00166B 904CF0            MOV      DPTR,#g_variable+031H
+00166E E0                MOVX     A,@DPTR
+00166F 7002              JNZ      $ + 4H
+001671 E18E              AJMP     ?C0045?SYS
+  223: 		{
+  224: 			YC_load_record_list(recon_index);
+001673 904DD6            MOV      DPTR,#recon_index
+001676 E0                MOVX     A,@DPTR
+001677 FF                MOV      R7,A
+001678 020737            LJMP     _YC_load_record_list
+  225: 		}
+  226: 		break;
+  227: 
+  228: 
+  229: 
+  230: // BT 4.2 event
+  231: 	case IPC_EVT_LE_CONNECTED:
+00167B         ?C0034?SYS:
+  232: 		g_variable.ble_currentState = CHANGE_TO_BLE_CONNECTING;
+00167B 904CC7            MOV      DPTR,#g_variable+08H
+00167E 7403              MOV      A,#03H
+001680 F0                MOVX     @DPTR,A
+  233: 		g_variable.ble_currentSubState = CHANGE_TO_BLE_SUB_INIT;
+001681 A3                INC      DPTR
+001682 7401              MOV      A,#01H
+001684 F0                MOVX     @DPTR,A
+  234: 		g_variable.br_currentState = CHANGE_TO_BR_DISCONNECT;
+001685 E4                CLR      A
+001686 A3                INC      DPTR
+001687 F0                MOVX     @DPTR,A
+  235: 		g_variable.br_currentSubState = CHANGE_TO_BR_SUB_NONE;
+001688 A3                INC      DPTR
+001689 F0                MOVX     @DPTR,A
+  236: 		IPC_TxControlCmd(IPC_CMD_STOP_ADV);
+00168A 7F0E              MOV      R7,#0EH
+00168C 919D              ACALL    _IPC_TxControlCmd
+  237: 		IPC_TxControlCmd(IPC_CMD_STOP_DISCOVERY);
+00168E 7F02              MOV      R7,#02H
+001690 919D              ACALL    _IPC_TxControlCmd
+  238: 		if(g_variable.pairing_timeout)
+001692 904CE9            MOV      DPTR,#g_variable+02AH
+001695 E0                MOVX     A,@DPTR
+001696 6034              JZ       ?C0035?SYS
+  239: 		{
+  240: 			fn_lock_flag = 0;
+001698 E4                CLR      A
+001699 904DE7            MOV      DPTR,#fn_lock_flag
+00169C F0                MOVX     @DPTR,A
+  241: 			g_variable.system_mode = OSMODE_WINDOWS;
+00169D 904CC1            MOV      DPTR,#g_variable+02H
+0016A0 F0                MOVX     @DPTR,A
+  242: 			bd_key_record_list[g_variable.current_device_num - 1].system_mode = g_variable.system_mode;
+0016A1 904CC3            MOV      DPTR,#g_variable+04H
+0016A4 E0                MOVX     A,@DPTR
+0016A5 75F01F            MOV      B,#01FH
+0016A8 A4                MUL      AB
+0016A9 24EC              ADD      A,#LOW bd_key_record_list-02H
+0016AB F582              MOV      DPL,A
+0016AD E4                CLR      A
+0016AE 344D              ADDC     A,#HIGH bd_key_record_list-02H
+0016B0 F583              MOV      DPH,A
+0016B2 E4                CLR      A
+0016B3 F0                MOVX     @DPTR,A
+  243: 			bd_key_record_list[g_variable.current_device_num - 1].fn_lock = fn_lock_flag;
+0016B4 904DE7            MOV      DPTR,#fn_lock_flag
+0016B7 E0                MOVX     A,@DPTR
+0016B8 FF                MOV      R7,A
+0016B9 904CC3            MOV      DPTR,#g_variable+04H
+0016BC E0                MOVX     A,@DPTR
+0016BD 75F01F            MOV      B,#01FH
+0016C0 A4                MUL      AB
+0016C1 24ED              ADD      A,#LOW bd_key_record_list-01H
+0016C3 F582              MOV      DPL,A
+0016C5 E4                CLR      A
+0016C6 344D              ADDC     A,#HIGH bd_key_record_list-01H
+0016C8 F583              MOV      DPH,A
+0016CA EF                MOV      A,R7
+0016CB F0                MOVX     @DPTR,A
+  244: 		}
+0016CC         ?C0035?SYS:
+  245: 		if(!ble_reconnect_flag)
+0016CC 904DE5            MOV      DPTR,#ble_reconnect_flag
+0016CF E0                MOVX     A,@DPTR
+0016D0 7006              JNZ      ?C0036?SYS
+  246: 			ble_send_secutiry_request_timer = 20;
+0016D2 904DD4            MOV      DPTR,#ble_send_secutiry_request_timer
+0016D5 7414              MOV      A,#014H
+0016D7 F0                MOVX     @DPTR,A
+0016D8         ?C0036?SYS:
+  247: 		if(!g_variable.powerOn_timer)
+0016D8 904CE5            MOV      DPTR,#g_variable+026H
+0016DB E0                MOVX     A,@DPTR
+0016DC 7002              JNZ      ?C0037?SYS
+  248: 			LED_device_poweroff();
+0016DE F1C8              ACALL    LED_device_poweroff
+0016E0         ?C0037?SYS:
+  249: 		g_variable.pairing_timeout = 0;
+0016E0 E4                CLR      A
+0016E1 904CE9            MOV      DPTR,#g_variable+02AH
+0016E4 F0                MOVX     @DPTR,A
+  250: 		g_variable.sleepTimer = 0;
+0016E5 904CE3            MOV      DPTR,#g_variable+024H
+0016E8 F0                MOVX     @DPTR,A
+0016E9 A3                INC      DPTR
+0016EA F0                MOVX     @DPTR,A
+  251: 		break;
+0016EB 22                RET      
+  252: 	case IPC_EVT_LE_PROTOCOL_CONNECTED:
+0016EC         ?C0038?SYS:
+  253: 	    	g_variable.ble_currentState = CHANGE_TO_BLE_CONNECTED;
+0016EC 904CC7            MOV      DPTR,#g_variable+08H
+0016EF 7404              MOV      A,#04H
+0016F1 F0                MOVX     @DPTR,A
+  254: 		g_variable.ble_currentSubState = CHANGE_TO_BLE_SUB_NONE;
+0016F2 E4                CLR      A
+0016F3 A3                INC      DPTR
+0016F4 F0                MOVX     @DPTR,A
+  255: 		YC_clear_reconnect_flag();
+0016F5 F1E0              ACALL    YC_clear_reconnect_flag
+  256: 		g_variable.release_data = 0;
+0016F7 E4                CLR      A
+0016F8 904CEB            MOV      DPTR,#g_variable+02CH
+0016FB F0                MOVX     @DPTR,A
+  257: 		le_send_battery_level_delay_count = 10;
+0016FC 904DDB            MOV      DPTR,#le_send_battery_level_delay_count
+0016FF 740A              MOV      A,#0AH
+001701 F0                MOVX     @DPTR,A
+  258: 		g_variable.last_device_num = g_variable.current_device_num;
+001702 904CC3            MOV      DPTR,#g_variable+04H
+001705 E0                MOVX     A,@DPTR
+001706 904CC0            MOV      DPTR,#g_variable+01H
+001709 F0                MOVX     @DPTR,A
+  259: 		g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_BT;
+00170A 904CBF            MOV      DPTR,#g_variable
+00170D 7403              MOV      A,#03H
+00170F F0                MOVX     @DPTR,A
+  260: 		break;
+001710 22                RET      
+  261: 	case IPC_EVT_LE_ENC_INFO:
+001711         ?C0039?SYS:
+  262: 		YC_store_record_list(1, g_variable.current_device_num-1);
+001711 904CC3            MOV      DPTR,#g_variable+04H
+001714 E0                MOVX     A,@DPTR
+001715 14                DEC      A
+001716 FD                MOV      R5,A
+001717 7F01              MOV      R7,#01H
+001719 1207FE            LCALL    _YC_store_record_list
+  263: 		g_variable.last_device_num = g_variable.current_device_num;
+00171C 904CC3            MOV      DPTR,#g_variable+04H
+00171F E0                MOVX     A,@DPTR
+001720 904CC0            MOV      DPTR,#g_variable+01H
+001723 F0                MOVX     @DPTR,A
+  264: 		g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_BT;
+001724 904CBF            MOV      DPTR,#g_variable
+001727 7403              MOV      A,#03H
+001729 F0                MOVX     @DPTR,A
+  265: 		break;
+00172A 22                RET      
+  266: 
+  267: 	case IPC_EVT_LE_PINCODE_REQ:
+00172B         ?C0040?SYS:
+  268: 		le_pin_code = 0;
+00172B 904D39            MOV      DPTR,#le_pin_code
+00172E 120582            LCALL    ?C?LSTKXDATA
+001731 00                DB       00H
+001732 00                DB       00H
+001733 00                DB       00H
+001734 00                DB       00H
+  269: 		le_pin_code_len = 0;
+001735 E4                CLR      A
+001736 904DD7            MOV      DPTR,#le_pin_code_len
+001739 F0                MOVX     @DPTR,A
+  270: 		pinCode_flag = 1;
+00173A 904DDE            MOV      DPTR,#pinCode_flag
+00173D 04                INC      A
+00173E F0                MOVX     @DPTR,A
+  271: 		g_variable.ble_currentSubState =  CHANGE_TO_BLE_SUB_PINCODE;
+00173F 904CC8            MOV      DPTR,#g_variable+09H
+001742 04                INC      A
+001743 F0                MOVX     @DPTR,A
+  272: 		g_variable.ble_currentState = CHANGE_TO_BLE_CONNECTING;
+001744 904CC7            MOV      DPTR,#g_variable+08H
+001747 04                INC      A
+001748 F0                MOVX     @DPTR,A
+  273: 		break;
+001749 22                RET      
+  274: 		
+  275: 	case IPC_EVT_LE_DISCONNECTED:	
+00174A         ?C0041?SYS:
+  276: 		g_variable.history_state = g_variable.ble_currentState ;
+00174A 904CC7            MOV      DPTR,#g_variable+08H
+00174D E0                MOVX     A,@DPTR
+00174E 904CCB            MOV      DPTR,#g_variable+0CH
+001751 F0                MOVX     @DPTR,A
+  277: 		g_variable.ble_currentState = CHANGE_TO_BLE_DISCONNECT;
+001752 E4                CLR      A
+001753 904CC7            MOV      DPTR,#g_variable+08H
+001756 F0                MOVX     @DPTR,A
+  278: 		g_variable.ble_currentSubState = CHANGE_TO_BLE_SUB_NONE;
+001757 A3                INC      DPTR
+001758 F0                MOVX     @DPTR,A
+  279: 		g_variable.release_data = 1;
+001759 904CEB            MOV      DPTR,#g_variable+02CH
+00175C 04                INC      A
+00175D F0                MOVX     @DPTR,A
+  280: 		m_le_send_security_request_flag = 0;
+00175E E4                CLR      A
+00175F 904D3D            MOV      DPTR,#m_le_send_security_request_flag
+001762 F0                MOVX     @DPTR,A
+  281: 		if (g_variable.lockLpm == 1)
+001763 904CEC            MOV      DPTR,#g_variable+02DH
+001766 E0                MOVX     A,@DPTR
+001767 6401              XRL      A,#01H
+001769 7003              JNZ      ?C0042?SYS
+  282: 		{
+  283: 			g_variable.lockLpm =0;
+00176B F0                MOVX     @DPTR,A
+  284: 			System_long_sleep();
+00176C 8021              SJMP     System_long_sleep
+  285: 			break;
+  286: 		}
+00176E         ?C0042?SYS:
+  287: 
+  288: 		if (g_variable.key_action != KEY_NONE)
+00176E 904CED            MOV      DPTR,#g_variable+02EH
+001771 E0                MOVX     A,@DPTR
+001772 6003              JZ       ?C0043?SYS
+  289: 		{
+  290: 			YC_key_action_handle(g_variable.key_action);
+001774 FF                MOV      R7,A
+001775 41C6              AJMP     _YC_key_action_handle
+  291: 			break;
+  292: 		}
+001777         ?C0043?SYS:
+  293: 
+  294: 
+  295: 		if (g_variable.recon_count != 0)
+001777 904CF0            MOV      DPTR,#g_variable+031H
+00177A E0                MOVX     A,@DPTR
+00177B 6008              JZ       ?C0044?SYS
+  296: 		{
+  297: 			YC_load_record_list(recon_index);
+00177D 904DD6            MOV      DPTR,#recon_index
+001780 E0                MOVX     A,@DPTR
+001781 FF                MOV      R7,A
+001782 020737            LJMP     _YC_load_record_list
+  298: 			break;
+  299: 		}
+001785         ?C0044?SYS:
+  300: 
+  301: 		System_long_sleep();		
+001785 F18F              ACALL    System_long_sleep
+  302: 		g_variable.sleepTimer = 0;
+001787 E4                CLR      A
+001788 904CE3            MOV      DPTR,#g_variable+024H
+00178B F0                MOVX     @DPTR,A
+00178C A3                INC      DPTR
+00178D F0                MOVX     @DPTR,A
+  303: 		break;
+  304: 	}
+  305: }
+00178E         ?C0045?SYS:
+00178E 22                RET      
+----- FUNCTION _kb_cb_event (END) -------
+
+
+----- FUNCTION System_long_sleep (BEGIN) -----
+ FILE: 'sys.c'
+   81: void System_long_sleep()
+   82: { 
+   83: 	m_reconnect_continue = 0;
+   84: 	IPC_TxControlCmd(IPC_CMD_ENTER_HIBERNATE);
+00178F E4                CLR      A
+001790 904D38            MOV      DPTR,#m_reconnect_continue
+001793 F0                MOVX     @DPTR,A
+   85: }
+001794 7F19              MOV      R7,#019H
+001796 819D              AJMP     _IPC_TxControlCmd
+----- FUNCTION System_long_sleep (END) -------
+
+
+----- FUNCTION _Delay1ms (BEGIN) -----
+;---- Variable 'Time' assigned to Register 'R7' ----
+001798         ?C0014?UTILITIES:
+001798 EF                MOV      A,R7
+001799 D3                SETB     C
+00179A 9400              SUBB     A,#00H
+00179C 4011              JC       ?C0020?UTILITIES
+;---- Variable 'j' assigned to Register 'R4/R5' ----
+00179E E4                CLR      A
+00179F FD                MOV      R5,A
+0017A0 FC                MOV      R4,A
+0017A1         ?C0017?UTILITIES:
+0017A1 0D                INC      R5
+0017A2 BD0001            CJNE     R5,#00H,?C0028?UTILITIES
+0017A5 0C                INC      R4
+0017A6         ?C0028?UTILITIES:
+0017A6 BC04F8            CJNE     R4,#04H,?C0017?UTILITIES
+0017A9 BDA6F5            CJNE     R5,#0A6H,?C0017?UTILITIES
+0017AC         ?C0016?UTILITIES:
+0017AC 1F                DEC      R7
+0017AD 80E9              SJMP     ?C0014?UTILITIES
+0017AF         ?C0020?UTILITIES:
+0017AF 22                RET      
+----- FUNCTION _Delay1ms (END) -------
+
+
+----- FUNCTION LED_device_poweron (BEGIN) -----
+ FILE: 'led.c'
+   15: void LED_device_poweron()
+   16: {
+   17: /*
+   18: 	if(g_variable.powerOn_first_flag == 0)
+   19: 	{
+   20: 		if(g_variable.current_device_num == 1)
+   21: 			GPIO_Setout(BT_LED_GPIO,LED_ON);
+   22: 		else if(g_variable.current_device_num == 2)
+   23: 			GPIO_Setout(BT2_LED_GPIO,LED_ON);
+   24: 		else if(g_variable.current_device_num == 3)
+   25: 		{	
+   26: 			GPIO_SetOutput(BT_LED_GPIO,LED_ON);
+   27: 			GPIO_SetOutput(LOWPOWER_LED_GPIO,LED_ON);
+   28: 		}
+   29: 		else if(g_variable.current_device_num == 0)
+   30: 		{
+   31: 			GPIO_Setout(LOWPOWER_LED_GPIO,LED_ON);
+   32: 		}
+   33: 	}
+   34: */
+   35: //	else
+   36: //	{
+   37: 		
+   38: 		GPIO_Setout(CAPS_LED_GPIO,LED_ON);
+0017B0 D201              SETB     ?_GPIO_Setout?BIT
+0017B2 7F1D              MOV      R7,#01DH
+0017B4 31B2              ACALL    _GPIO_Setout
+   39: 		GPIO_Setout(BT_LED_GPIO,LED_ON);
+0017B6 D201              SETB     ?_GPIO_Setout?BIT
+0017B8 7F1F              MOV      R7,#01FH
+0017BA 31B2              ACALL    _GPIO_Setout
+   40: 		GPIO_Setout(BT2_LED_GPIO,LED_ON);	
+0017BC D201              SETB     ?_GPIO_Setout?BIT
+0017BE 7F1E              MOV      R7,#01EH
+0017C0 31B2              ACALL    _GPIO_Setout
+   41: 		GPIO_Setout(LOWPOWER_LED_GPIO,LED_ON);
+0017C2 D201              SETB     ?_GPIO_Setout?BIT
+0017C4 7F14              MOV      R7,#014H
+0017C6 21B2              AJMP     _GPIO_Setout
+   42: //	}
+   43: 	
+   44: 
+----- FUNCTION LED_device_poweron (END) -------
+
+
+----- FUNCTION LED_device_poweroff (BEGIN) -----
+ FILE: 'led.c'
+   47: void LED_device_poweroff()
+   48: {
+   49: /*
+   50: 	if(g_variable.current_device_num == 1)
+   51: 		GPIO_Setout(BT_LED_GPIO,LED_OFF);
+   52: 	else if(g_variable.current_device_num == 2)
+   53: 		GPIO_Setout(BT2_LED_GPIO,LED_OFF);
+   54: 	else if(g_variable.current_device_num == 3)
+   55: 	{	
+   56: 		GPIO_Setout(BT_LED_GPIO,LED_OFF);
+   57: 		GPIO_SetOutput(LOWPOWER_LED_GPIO,LED_OFF);
+   58: 	}
+   59: 	else
+   60: 	{
+   61: 		GPIO_Setout(BT_LED_GPIO,LED_OFF);
+   62: 		GPIO_Setout(BT2_LED_GPIO,LED_OFF);
+   63: 		GPIO_Setout(LOWPOWER_LED_GPIO,LED_OFF);
+   64: 		GPIO_Setout(CAPS_LED_GPIO,LED_OFF);
+   65: 
+   66: 	}
+   67: */
+   68: 	GPIO_Setout(BT_LED_GPIO,LED_OFF);
+0017C8 C201              CLR      ?_GPIO_Setout?BIT
+0017CA 7F1F              MOV      R7,#01FH
+0017CC 31B2              ACALL    _GPIO_Setout
+   69: 	GPIO_Setout(BT2_LED_GPIO,LED_OFF);
+0017CE C201              CLR      ?_GPIO_Setout?BIT
+0017D0 7F1E              MOV      R7,#01EH
+0017D2 31B2              ACALL    _GPIO_Setout
+   70: 	GPIO_Setout(LOWPOWER_LED_GPIO,LED_OFF);
+0017D4 C201              CLR      ?_GPIO_Setout?BIT
+0017D6 7F14              MOV      R7,#014H
+0017D8 31B2              ACALL    _GPIO_Setout
+   71: 	GPIO_Setout(CAPS_LED_GPIO,LED_OFF);
+0017DA C201              CLR      ?_GPIO_Setout?BIT
+0017DC 7F1D              MOV      R7,#01DH
+0017DE 21B2              AJMP     _GPIO_Setout
+   72: //	g_variable.powerOn_first_flag = 0;
+----- FUNCTION LED_device_poweroff (END) -------
+
+
+----- FUNCTION YC_clear_reconnect_flag (BEGIN) -----
+ FILE: 'bluetooth.c'
+  117: void YC_clear_reconnect_flag()  
+  118: {
+  119: 	g_variable.recon_count = 0;
+  120: 	ble_reconnect_flag = 0;
+0017E0 E4                CLR      A
+0017E1 904CF0            MOV      DPTR,#g_variable+031H
+0017E4 F0                MOVX     @DPTR,A
+  121: }
+0017E5 904DE5            MOV      DPTR,#ble_reconnect_flag
+0017E8 F0                MOVX     @DPTR,A
+  122: 
+0017E9 22                RET      
+----- FUNCTION YC_clear_reconnect_flag (END) -------
+
+
+----- FUNCTION System_Hardware_init (BEGIN) -----
+ FILE: 'sys.c'
+   53: static void System_Hardware_init()
+   54: {
+   55: 	System_IIC_clk_setup();
+   56: 	KS_Initialize();
+0017EA 12303A            LCALL    System_IIC_clk_setup
+   57: 	LED_all_shutdown();
+0017ED 1218F4            LCALL    KS_Initialize
+;----                  JMP      LED_all_shutdown
+   58: }
+----- FUNCTION System_Hardware_init (END) -------
+
+
+----- FUNCTION LED_all_shutdown (BEGIN) -----
+ FILE: 'led.c'
+    4: void LED_all_shutdown()
+    5: {
+    6: //	GPIO_SetOutput(NUM_LOCK_LED_GPIO,LED_OFF);
+    7: 	GPIO_SetOutput(CAPS_LED_GPIO,LED_OFF);
+0017F0 C206              CLR      ?_GPIO_SetOutput?BIT
+0017F2 7F1D              MOV      R7,#01DH
+0017F4 121808            LCALL    _GPIO_SetOutput
+    8: 	GPIO_SetOutput(BT_LED_GPIO,LED_OFF);
+0017F7 C206              CLR      ?_GPIO_SetOutput?BIT
+0017F9 7F1F              MOV      R7,#01FH
+0017FB 121808            LCALL    _GPIO_SetOutput
+    9: 	GPIO_SetOutput(BT2_LED_GPIO,LED_OFF);	
+0017FE C206              CLR      ?_GPIO_SetOutput?BIT
+001800 7F1E              MOV      R7,#01EH
+001802 1108              ACALL    _GPIO_SetOutput
+   10: 	GPIO_SetOutput(LOWPOWER_LED_GPIO,LED_OFF);
+001804 C206              CLR      ?_GPIO_SetOutput?BIT
+001806 7F14              MOV      R7,#014H
+;----                  JMP      _GPIO_SetOutput
+   11: //	GPIO_SetOutput(G24_LED_GPIO,LED_OFF);
+----- FUNCTION LED_all_shutdown (END) -------
+
+
+----- FUNCTION _GPIO_SetOutput (BEGIN) -----
+;---- Variable 'gpio_num' assigned to Register 'R4' ----
+001808 AC07              MOV      R4,AR7
+00180A EC                MOV      A,R4
+00180B F4                CPL      A
+00180C 6015              JZ       ?C0017?GPIO
+00180E         ?C0016?GPIO:
+00180E AF04              MOV      R7,AR4
+001810 D204              SETB     ?_GPIO_Setoe?BIT
+001812 1135              ACALL    _GPIO_Setoe
+001814 AF04              MOV      R7,AR4
+001816 A206              MOV      C,st
+001818 9201              MOV      ?_GPIO_Setout?BIT,C
+00181A 1211B2            LCALL    _GPIO_Setout
+00181D AF04              MOV      R7,AR4
+00181F C202              CLR      ?_GPIO_SetPu?BIT
+001821 1124              ACALL    _GPIO_SetPu
+001823         ?C0017?GPIO:
+001823 22                RET      
+----- FUNCTION _GPIO_SetOutput (END) -------
+
+
+----- FUNCTION _GPIO_SetPu (BEGIN) -----
+;---- Variable 'gpio_num' assigned to Register 'R7' ----
+001824 EF                MOV      A,R7
+001825 F4                CPL      A
+001826 600C              JZ       ?C0009?GPIO
+001828         ?C0008?GPIO:
+001828 7B01              MOV      R3,#01H
+00182A 7A80              MOV      R2,#080H
+00182C 7978              MOV      R1,#078H
+00182E A202              MOV      C,bit_val
+001830 9200              MOV      ?_gpioSetBit?BIT,C
+001832 1175              ACALL    _gpioSetBit
+001834         ?C0009?GPIO:
+001834 22                RET      
+----- FUNCTION _GPIO_SetPu (END) -------
+
+
+----- FUNCTION _GPIO_Setoe (BEGIN) -----
+;---- Variable 'gpio_num' assigned to Register 'R7' ----
+001835 EF                MOV      A,R7
+001836 F4                CPL      A
+001837 600C              JZ       ?C0013?GPIO
+001839         ?C0012?GPIO:
+001839 7B01              MOV      R3,#01H
+00183B 7A80              MOV      R2,#080H
+00183D 7970              MOV      R1,#070H
+00183F A204              MOV      C,bit_val
+001841 9200              MOV      ?_gpioSetBit?BIT,C
+001843 1175              ACALL    _gpioSetBit
+001845         ?C0013?GPIO:
+001845 22                RET      
+----- FUNCTION _GPIO_Setoe (END) -------
+
+
+----- FUNCTION _GPIO_SetInput (BEGIN) -----
+;---- Variable 'gpio_num' assigned to Register 'R4' ----
+001846 AC07              MOV      R4,AR7
+001848 EC                MOV      A,R4
+001849 F4                CPL      A
+00184A 6017              JZ       ?C0015?GPIO
+00184C         ?C0014?GPIO:
+00184C AF04              MOV      R7,AR4
+00184E A205              MOV      C,st
+001850 9203              MOV      ?_GPIO_SetPd?BIT,C
+001852 1164              ACALL    _GPIO_SetPd
+001854 AF04              MOV      R7,AR4
+001856 A205              MOV      C,st
+001858 B3                CPL      C
+001859 9202              MOV      ?_GPIO_SetPu?BIT,C
+00185B 1124              ACALL    _GPIO_SetPu
+00185D AF04              MOV      R7,AR4
+00185F C204              CLR      ?_GPIO_Setoe?BIT
+001861 1135              ACALL    _GPIO_Setoe
+001863         ?C0015?GPIO:
+001863 22                RET      
+----- FUNCTION _GPIO_SetInput (END) -------
+
+
+----- FUNCTION _GPIO_SetPd (BEGIN) -----
+;---- Variable 'gpio_num' assigned to Register 'R7' ----
+001864 EF                MOV      A,R7
+001865 F4                CPL      A
+001866 600C              JZ       ?C0011?GPIO
+001868         ?C0010?GPIO:
+001868 7B01              MOV      R3,#01H
+00186A 7A80              MOV      R2,#080H
+00186C 797C              MOV      R1,#07CH
+00186E A203              MOV      C,bit_val
+001870 9200              MOV      ?_gpioSetBit?BIT,C
+001872 1175              ACALL    _gpioSetBit
+001874         ?C0011?GPIO:
+001874 22                RET      
+----- FUNCTION _GPIO_SetPd (END) -------
+
+
+----- FUNCTION _gpioSetBit (BEGIN) -----
+001875 904EF5            MOV      DPTR,#reg_base
+001878 EB                MOV      A,R3
+001879 F0                MOVX     @DPTR,A
+00187A A3                INC      DPTR
+00187B EA                MOV      A,R2
+00187C F0                MOVX     @DPTR,A
+00187D A3                INC      DPTR
+00187E E9                MOV      A,R1
+00187F F0                MOVX     @DPTR,A
+;---- Variable 'gpio_num' assigned to Register 'R7' ----
+;---- Variable 'queue' assigned to Register 'R6' ----
+001880 E4                CLR      A
+001881 FE                MOV      R6,A
+;---- Variable 'group' assigned to Register 'R5' ----
+001882 FD                MOV      R5,A
+001883 EF                MOV      A,R7
+001884 5407              ANL      A,#07H
+001886 FE                MOV      R6,A
+001887 EF                MOV      A,R7
+001888 13                RRC      A
+001889 13                RRC      A
+00188A 13                RRC      A
+00188B 5403              ANL      A,#03H
+00188D FD                MOV      R5,A
+00188E 300022            JNB      bit_val,?C0001?GPIO
+001891 904EF5            MOV      DPTR,#reg_base
+001894 E0                MOVX     A,@DPTR
+001895 FB                MOV      R3,A
+001896 A3                INC      DPTR
+001897 E0                MOVX     A,@DPTR
+001898 FA                MOV      R2,A
+001899 A3                INC      DPTR
+00189A E0                MOVX     A,@DPTR
+00189B 2D                ADD      A,R5
+00189C F9                MOV      R1,A
+00189D E4                CLR      A
+00189E 3A                ADDC     A,R2
+00189F FA                MOV      R2,A
+0018A0 1203B6            LCALL    ?C?CLDPTR
+0018A3 FF                MOV      R7,A
+0018A4 7401              MOV      A,#01H
+0018A6 A806              MOV      R0,AR6
+0018A8 08                INC      R0
+0018A9 8002              SJMP     ?C0031?GPIO
+0018AB         ?C0030?GPIO:
+0018AB C3                CLR      C
+0018AC 33                RLC      A
+0018AD         ?C0031?GPIO:
+0018AD D8FC              DJNZ     R0,?C0030?GPIO
+0018AF 4F                ORL      A,R7
+0018B0 0203FC            LJMP     ?C?CSTPTR
+0018B3         ?C0001?GPIO:
+0018B3 904EF5            MOV      DPTR,#reg_base
+0018B6 E0                MOVX     A,@DPTR
+0018B7 FB                MOV      R3,A
+0018B8 A3                INC      DPTR
+0018B9 E0                MOVX     A,@DPTR
+0018BA FA                MOV      R2,A
+0018BB A3                INC      DPTR
+0018BC E0                MOVX     A,@DPTR
+0018BD 2D                ADD      A,R5
+0018BE F9                MOV      R1,A
+0018BF E4                CLR      A
+0018C0 3A                ADDC     A,R2
+0018C1 FA                MOV      R2,A
+0018C2 1203B6            LCALL    ?C?CLDPTR
+0018C5 FF                MOV      R7,A
+0018C6 7401              MOV      A,#01H
+0018C8 A806              MOV      R0,AR6
+0018CA 08                INC      R0
+0018CB 8002              SJMP     ?C0033?GPIO
+0018CD         ?C0032?GPIO:
+0018CD C3                CLR      C
+0018CE 33                RLC      A
+0018CF         ?C0033?GPIO:
+0018CF D8FC              DJNZ     R0,?C0032?GPIO
+0018D1 F4                CPL      A
+0018D2 5F                ANL      A,R7
+0018D3 0203FC            LJMP     ?C?CSTPTR
+----- FUNCTION _gpioSetBit (END) -------
+
+
+----- FUNCTION ksColInitialize (BEGIN) -----
+ FILE: 'keyscan.c'
+  198: static void ksColInitialize()
+  199: {
+  200: 	byte i = 0;
+  201: 	for (i=0; col[i]!=0; i++) {
+0018D6 E4                CLR      A
+0018D7 904F04            MOV      DPTR,#i
+0018DA F0                MOVX     @DPTR,A
+  202: 		GPIO_SetInput(col[i], 0);
+0018DB F0                MOVX     @DPTR,A
+0018DC         ?C0032?KEYSCAN:
+0018DC 904F04            MOV      DPTR,#i
+0018DF E0                MOVX     A,@DPTR
+0018E0 900681            MOV      DPTR,#col
+0018E3 93                MOVC     A,@A+DPTR
+0018E4 FF                MOV      R7,A
+0018E5 600C              JZ       ?C0035?KEYSCAN
+  203: 	}
+0018E7 C205              CLR      ?_GPIO_SetInput?BIT
+0018E9 1146              ACALL    _GPIO_SetInput
+  204: }
+0018EB 904F04            MOV      DPTR,#i
+0018EE E0                MOVX     A,@DPTR
+0018EF 04                INC      A
+0018F0 F0                MOVX     @DPTR,A
+0018F1 80E9              SJMP     ?C0032?KEYSCAN
+  205: 
+0018F3         ?C0035?KEYSCAN:
+0018F3 22                RET      
+----- FUNCTION ksColInitialize (END) -------
+
+
+----- FUNCTION KS_Initialize (BEGIN) -----
+ FILE: 'keyscan.c'
+  206: void KS_Initialize()
+  207: {
+  208: 	REG_GPIO_SELECT(0) = 0;
+  209: 	REG_GPIO_SELECT(1) = 0;
+0018F4 908080            MOV      DPTR,#08080H
+0018F7 E4                CLR      A
+0018F8 F0                MOVX     @DPTR,A
+  210: 	REG_GPIO_SELECT(2) = 0;
+0018F9 A3                INC      DPTR
+0018FA F0                MOVX     @DPTR,A
+  211: 	ksRawInitialize();
+0018FB A3                INC      DPTR
+0018FC F0                MOVX     @DPTR,A
+  212: 	ksColInitialize();
+0018FD 3101              ACALL    ksRawInitialize
+  213: }
+0018FF 80D5              SJMP     ksColInitialize
+----- FUNCTION KS_Initialize (END) -------
+
+
+----- FUNCTION ksRawInitialize (BEGIN) -----
+ FILE: 'keyscan.c'
+  189: static void ksRawInitialize()
+  190: {
+  191: 	byte i = 0;
+  192: 	
+001901 E4                CLR      A
+001902 904F03            MOV      DPTR,#i
+001905 F0                MOVX     @DPTR,A
+  193: 	for (i=0; i<8; i++) {
+001906 F0                MOVX     @DPTR,A
+001907         ?C0028?KEYSCAN:
+001907 904F03            MOV      DPTR,#i
+00190A E0                MOVX     A,@DPTR
+00190B FF                MOV      R7,A
+00190C C3                CLR      C
+00190D 9408              SUBB     A,#08H
+00190F 7480              MOV      A,#080H
+001911 9480              SUBB     A,#080H
+001913 500C              JNC      ?C0031?KEYSCAN
+  194: 		GPIO_SetInput(i, 0);
+001915 C205              CLR      ?_GPIO_SetInput?BIT
+001917 1146              ACALL    _GPIO_SetInput
+  195: 	}
+001919 904F03            MOV      DPTR,#i
+00191C E0                MOVX     A,@DPTR
+00191D 04                INC      A
+00191E F0                MOVX     @DPTR,A
+00191F 80E6              SJMP     ?C0028?KEYSCAN
+  196: }
+001921         ?C0031?KEYSCAN:
+001921 22                RET      
+----- FUNCTION ksRawInitialize (END) -------
+
+
+----- FUNCTION YC_check_need_reconnected (BEGIN) -----
+ FILE: 'bluetooth.c'
+   63: byte YC_check_need_reconnected()
+   64: {
+   65: 	byte return_val = 0;
+   66: 	 if (g_variable.ble_currentSubState == CHANGE_TO_BLE_SUB_PINCODE)
+001922 E4                CLR      A
+001923 904F00            MOV      DPTR,#return_val
+001926 F0                MOVX     @DPTR,A
+   67: 		return return_val;
+001927 904CC8            MOV      DPTR,#g_variable+09H
+00192A E0                MOVX     A,@DPTR
+00192B 6402              XRL      A,#02H
+00192D 7006              JNZ      ?C0010?BLUETOOTH
+   68: 	if ((m_ui_state_map & 0x0008) == 0x0008)		
+00192F 904F00            MOV      DPTR,#return_val
+001932 E0                MOVX     A,@DPTR
+001933 FF                MOV      R7,A
+001934 22                RET      
+001935         ?C0010?BLUETOOTH:
+   69: 		return return_val;
+001935 9047F5            MOV      DPTR,#m_ui_state_map+01H
+001938 E0                MOVX     A,@DPTR
+001939 30E306            JNB      ACC.3,?C0012?BLUETOOTH
+   70: 
+00193C 904F00            MOV      DPTR,#return_val
+00193F E0                MOVX     A,@DPTR
+001940 FF                MOV      R7,A
+001941 22                RET      
+001942         ?C0012?BLUETOOTH:
+   71: 	if(g_variable.pairing_g24_timeout)
+001942 904CEE            MOV      DPTR,#g_variable+02FH
+001945 E0                MOVX     A,@DPTR
+001946 6006              JZ       ?C0013?BLUETOOTH
+   72: 		return return_val;
+001948 904F00            MOV      DPTR,#return_val
+00194B E0                MOVX     A,@DPTR
+00194C FF                MOV      R7,A
+00194D 22                RET      
+00194E         ?C0013?BLUETOOTH:
+   73: 
+   74: 	if (g_variable.ble_currentState == CHANGE_TO_BLE_DISCONNECT
+00194E 904CC7            MOV      DPTR,#g_variable+08H
+001951 E0                MOVX     A,@DPTR
+001952 704A              JNZ      ?C0014?BLUETOOTH
+001954 904CC5            MOV      DPTR,#g_variable+06H
+001957 E0                MOVX     A,@DPTR
+001958 6403              XRL      A,#03H
+00195A 6042              JZ       ?C0014?BLUETOOTH
+   75: 		&& g_variable.g24_currentState != CHANGE_TO_24G_CONNECTED
+   76: 	)
+   77: 	{
+   78: 		if(g_variable.recon_delay == 0)
+00195C 904CEF            MOV      DPTR,#g_variable+030H
+00195F E0                MOVX     A,@DPTR
+001960 7046              JNZ      ?C0019?BLUETOOTH
+   79: 		{
+   80: 			g_variable.recon_delay = 10;
+001962 740A              MOV      A,#0AH
+001964 F0                MOVX     @DPTR,A
+   81: 			if ((g_variable.recon_count == 0)
+001965 A3                INC      DPTR
+001966 E0                MOVX     A,@DPTR
+001967 703F              JNZ      ?C0019?BLUETOOTH
+001969 904DEB            MOV      DPTR,#power_on_flag
+00196C E0                MOVX     A,@DPTR
+00196D 6402              XRL      A,#02H
+00196F 7037              JNZ      ?C0019?BLUETOOTH
+   82: 			&& (power_on_flag == 2))
+   83: 			{				
+   84: 				if (g_variable.current_device_num >= 1 && g_variable.current_device_num <= 3)
+001971 904CC3            MOV      DPTR,#g_variable+04H
+001974 E0                MOVX     A,@DPTR
+001975 FF                MOV      R7,A
+001976 7E00              MOV      R6,#00H
+001978 C3                CLR      C
+001979 9401              SUBB     A,#01H
+00197B 7480              MOV      A,#080H
+00197D 9480              SUBB     A,#080H
+00197F 4010              JC       ?C0017?BLUETOOTH
+001981 D3                SETB     C
+001982 EF                MOV      A,R7
+001983 9403              SUBB     A,#03H
+001985 7480              MOV      A,#080H
+001987 9480              SUBB     A,#080H
+001989 5006              JNC      ?C0017?BLUETOOTH
+   85: 				{
+   86: 					YC_key_action_handle(g_variable.current_device_num);
+00198B E0                MOVX     A,@DPTR
+00198C 1212C6            LCALL    _YC_key_action_handle
+   87: 				}
+00198F 8017              SJMP     ?C0019?BLUETOOTH
+001991         ?C0017?BLUETOOTH:
+   88: 				else
+   89: 				{
+   90: 					YC_key_action_handle(KEY_OPEN_24G);
+001991 7F09              MOV      R7,#09H
+001993 1212C6            LCALL    _YC_key_action_handle
+   91: 					return_val = 1;
+001996 904F00            MOV      DPTR,#return_val
+001999 7401              MOV      A,#01H
+00199B F0                MOVX     @DPTR,A
+   92: 				}
+   93: 			}
+   94: 		}
+   95: 	}
+00199C 800A              SJMP     ?C0019?BLUETOOTH
+00199E         ?C0014?BLUETOOTH:
+   96: 	else
+   97: 	{
+   98: 		g_variable.release_data = 0;
+00199E E4                CLR      A
+00199F 904CEB            MOV      DPTR,#g_variable+02CH
+0019A2 F0                MOVX     @DPTR,A
+   99: 		return_val = 1;
+0019A3 904F00            MOV      DPTR,#return_val
+0019A6 04                INC      A
+0019A7 F0                MOVX     @DPTR,A
+  100: 	}
+0019A8         ?C0019?BLUETOOTH:
+  101: 	return return_val;
+0019A8 904F00            MOV      DPTR,#return_val
+0019AB E0                MOVX     A,@DPTR
+0019AC FF                MOV      R7,A
+  102: }
+0019AD 22                RET      
+----- FUNCTION YC_check_need_reconnected (END) -------
+
+
+----- FUNCTION YC_cancel_reconnect (BEGIN) -----
+ FILE: 'bluetooth.c'
+  105: byte YC_cancel_reconnect()
+  106: {
+  107: 	if (g_variable.ble_currentState == CHANGE_TO_BLE_DIRECT_ADV)
+  108: 	{
+0019AE 904CC7            MOV      DPTR,#g_variable+08H
+0019B1 E0                MOVX     A,@DPTR
+0019B2 6402              XRL      A,#02H
+0019B4 7008              JNZ      ?C0020?BLUETOOTH
+  109: 		//stop adv
+  110: 		IPC_TxControlCmd(IPC_CMD_STOP_ADV);
+0019B6 7F0E              MOV      R7,#0EH
+0019B8 12149D            LCALL    _IPC_TxControlCmd
+  111: 		return 1;
+0019BB 7F01              MOV      R7,#01H
+0019BD 22                RET      
+  112: 	}
+0019BE         ?C0020?BLUETOOTH:
+  113: 	return 0;
+0019BE 7F00              MOV      R7,#00H
+  114: }
+0019C0 22                RET      
+----- FUNCTION YC_cancel_reconnect (END) -------
+
+
+----- FUNCTION YC_disconnect_all_link (BEGIN) -----
+ FILE: 'bluetooth.c'
+  124: byte YC_disconnect_all_link()
+  125: {
+  126: 	if (g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTED 
+  127: 		||g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTING)
+0019C1 904CC7            MOV      DPTR,#g_variable+08H
+0019C4 E0                MOVX     A,@DPTR
+0019C5 FF                MOV      R7,A
+0019C6 6404              XRL      A,#04H
+0019C8 6005              JZ       ?C0024?BLUETOOTH
+0019CA EF                MOV      A,R7
+0019CB 6403              XRL      A,#03H
+0019CD 7008              JNZ      ?C0023?BLUETOOTH
+0019CF         ?C0024?BLUETOOTH:
+  128: 	{
+  129: 		IPC_TxControlCmd(IPC_CMD_LE_DISCONNECT);
+0019CF 7F11              MOV      R7,#011H
+0019D1 12149D            LCALL    _IPC_TxControlCmd
+  130: 		return 1;
+0019D4 7F01              MOV      R7,#01H
+0019D6 22                RET      
+  131: 	}
+0019D7         ?C0023?BLUETOOTH:
+  132: 	if (g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED 
+0019D7 904CC5            MOV      DPTR,#g_variable+06H
+0019DA E0                MOVX     A,@DPTR
+0019DB FF                MOV      R7,A
+0019DC 6403              XRL      A,#03H
+0019DE 6005              JZ       ?C0027?BLUETOOTH
+0019E0 EF                MOV      A,R7
+0019E1 6402              XRL      A,#02H
+0019E3 7008              JNZ      ?C0026?BLUETOOTH
+0019E5         ?C0027?BLUETOOTH:
+  133: 		||g_variable.g24_currentState == CHANGE_TO_24G_CONNECTING)
+  134: 	{
+  135: 		IPC_TxControlCmd(IPC_CMD_STOP_24G);
+0019E5 7F22              MOV      R7,#022H
+0019E7 12149D            LCALL    _IPC_TxControlCmd
+  136: 		return 1;
+0019EA 7F01              MOV      R7,#01H
+0019EC 22                RET      
+  137: 	}
+0019ED         ?C0026?BLUETOOTH:
+  138: 	return 0;
+0019ED 7F00              MOV      R7,#00H
+  139: }
+0019EF 22                RET      
+----- FUNCTION YC_disconnect_all_link (END) -------
+
+
+----- FUNCTION kb_button_press_timer500ms (BEGIN) -----
+ FILE: 'sys.c'
+  509: void kb_button_press_timer500ms()
+  510: {
+  511: 	
+  512: //key status 
+  513: /*
+  514: 	if (g_variable.button_flag & KEY_FLAG_BTKEY_PRESS)		//press BT key
+  515: 	{
+  516: 		if (g_variable.button_timer[0] < 250)
+  517: 			g_variable.button_timer[0]++;
+  518: 		if (g_variable.button_timer[0] == 2)
+  519: 		{
+  520: 			YC_key_action_handle(KEY_DISCOVERY);
+  521: 		}
+  522: 	}
+  523: 	else
+  524: 		g_variable.button_timer[0] = 0;
+  525: */		
+  526: 	
+  527: 	if (g_variable.button_flag & KEY_FLAG_SAME_KEY_PRESS)
+0019F0 904CCE            MOV      DPTR,#g_variable+0FH
+0019F3 E0                MOVX     A,@DPTR
+0019F4 30E146            JNB      ACC.1,?C0095?SYS
+  528: 	{
+  529: 		if (g_variable.button_timer[1] < 250)
+0019F7 904CD0            MOV      DPTR,#g_variable+011H
+0019FA E0                MOVX     A,@DPTR
+0019FB C3                CLR      C
+0019FC 94FA              SUBB     A,#0FAH
+0019FE 7480              MOV      A,#080H
+001A00 9480              SUBB     A,#080H
+001A02 5003              JNC      ?C0096?SYS
+  530: 			g_variable.button_timer[1]++;
+001A04 E0                MOVX     A,@DPTR
+001A05 04                INC      A
+001A06 F0                MOVX     @DPTR,A
+001A07         ?C0096?SYS:
+  531: 		if (g_variable.button_timer[1] == 180)			// 500ms*180*3 = 4min30s
+001A07 904CD0            MOV      DPTR,#g_variable+011H
+001A0A E0                MOVX     A,@DPTR
+001A0B 64B4              XRL      A,#0B4H
+001A0D 703B              JNZ      ?C0101?SYS
+  532: 		{
+  533: 			press_long_time_flag++;
+001A0F 904DE3            MOV      DPTR,#press_long_time_flag
+001A12 E0                MOVX     A,@DPTR
+001A13 04                INC      A
+001A14 F0                MOVX     @DPTR,A
+  534: 			if(press_long_time_flag <= 2)
+001A15 E0                MOVX     A,@DPTR
+001A16 D3                SETB     C
+001A17 9402              SUBB     A,#02H
+001A19 7480              MOV      A,#080H
+001A1B 9480              SUBB     A,#080H
+001A1D 5007              JNC      ?C0098?SYS
+  535: 			{
+  536: 				g_variable.button_timer[1] = 0;
+001A1F E4                CLR      A
+001A20 904CD0            MOV      DPTR,#g_variable+011H
+001A23 F0                MOVX     @DPTR,A
+  537: 			}
+001A24 8024              SJMP     ?C0101?SYS
+001A26         ?C0098?SYS:
+  538: 			else if(press_long_time_flag == 3)
+001A26 904DE3            MOV      DPTR,#press_long_time_flag
+001A29 E0                MOVX     A,@DPTR
+001A2A 6403              XRL      A,#03H
+001A2C 701C              JNZ      ?C0101?SYS
+  539: 			{
+  540: 				long_press_flag = 1;
+001A2E 904DDC            MOV      DPTR,#long_press_flag
+001A31 04                INC      A
+001A32 F0                MOVX     @DPTR,A
+  541: 				g_variable.button_timer[1] = 0;
+001A33 E4                CLR      A
+001A34 904CD0            MOV      DPTR,#g_variable+011H
+001A37 F0                MOVX     @DPTR,A
+  542: 				System_long_sleep();
+001A38 12178F            LCALL    System_long_sleep
+  543: 			}
+  544: 		}
+  545: 	}
+001A3B 800D              SJMP     ?C0101?SYS
+001A3D         ?C0095?SYS:
+  546: 	else
+  547: 	{
+  548: 		press_long_time_flag = 0;
+001A3D E4                CLR      A
+001A3E 904DE3            MOV      DPTR,#press_long_time_flag
+001A41 F0                MOVX     @DPTR,A
+  549: 		long_press_flag = 0;
+001A42 904DDC            MOV      DPTR,#long_press_flag
+001A45 F0                MOVX     @DPTR,A
+  550: 		g_variable.button_timer[1] = 0;
+001A46 904CD0            MOV      DPTR,#g_variable+011H
+001A49 F0                MOVX     @DPTR,A
+  551: 	}
+001A4A         ?C0101?SYS:
+  552: 
+  553: 				
+  554: 	if (g_variable.button_flag & KEY_FLAG_FN_24G_DEVICE_BUTTON)		// G24 pairing
+001A4A 904CCE            MOV      DPTR,#g_variable+0FH
+001A4D E0                MOVX     A,@DPTR
+001A4E 30E43E            JNB      ACC.4,?C0102?SYS
+  555: 	{
+  556: 		g_variable.delay_enter_lpm_timer = 10;
+001A51 904CEA            MOV      DPTR,#g_variable+02BH
+001A54 740A              MOV      A,#0AH
+001A56 F0                MOVX     @DPTR,A
+  557: 		if (g_variable.button_timer[2] < 250)
+001A57 904CD1            MOV      DPTR,#g_variable+012H
+001A5A E0                MOVX     A,@DPTR
+001A5B C3                CLR      C
+001A5C 94FA              SUBB     A,#0FAH
+001A5E 7480              MOV      A,#080H
+001A60 9480              SUBB     A,#080H
+001A62 5003              JNC      ?C0103?SYS
+  558: 			g_variable.button_timer[2]++;
+001A64 E0                MOVX     A,@DPTR
+001A65 04                INC      A
+001A66 F0                MOVX     @DPTR,A
+001A67         ?C0103?SYS:
+  559: 		if (g_variable.button_timer[2] == 6)
+001A67 904CD1            MOV      DPTR,#g_variable+012H
+001A6A E0                MOVX     A,@DPTR
+001A6B 6406              XRL      A,#06H
+001A6D 704A              JNZ      ?C0107?SYS
+  560: 		{
+  561: 			if( !g_variable.current_device_num || (g_variable.current_device_num == 0xfe))
+001A6F 904CC3            MOV      DPTR,#g_variable+04H
+001A72 E0                MOVX     A,@DPTR
+001A73 6004              JZ       ?C0106?SYS
+001A75 64FE              XRL      A,#0FEH
+001A77 7040              JNZ      ?C0107?SYS
+001A79         ?C0106?SYS:
+  562: 			{
+  563: 				g_variable.button_24G_rec_flag = 0;
+001A79 E4                CLR      A
+001A7A 904CCD            MOV      DPTR,#g_variable+0EH
+001A7D F0                MOVX     @DPTR,A
+  564: 				YC_disconnect_all_link();
+001A7E 31C1              ACALL    YC_disconnect_all_link
+  565: 				Delay1ms(10);
+001A80 7F0A              MOV      R7,#0AH
+001A82 121798            LCALL    _Delay1ms
+  566: 				YC_key_action_handle(KEY_PAIRING_24G);
+001A85 7F0A              MOV      R7,#0AH
+001A87 1212C6            LCALL    _YC_key_action_handle
+  567: 				LED_all_shutdown();
+001A8A 1217F0            LCALL    LED_all_shutdown
+  568: 
+  569: 			}
+  570: 		}
+  571: 	}
+001A8D 802A              SJMP     ?C0107?SYS
+001A8F         ?C0102?SYS:
+  572: 	else
+  573: 	{
+  574: 		if(g_variable.button_24G_rec_flag)
+001A8F 904CCD            MOV      DPTR,#g_variable+0EH
+001A92 E0                MOVX     A,@DPTR
+001A93 601F              JZ       ?C0108?SYS
+  575: 		{
+  576: 			g_variable.button_24G_rec_flag = 0;
+001A95 E4                CLR      A
+001A96 F0                MOVX     @DPTR,A
+  577: 			YC_key_action_handle(KEY_STOP_DISCOVERY);
+001A97 7F0D              MOV      R7,#0DH
+001A99 1212C6            LCALL    _YC_key_action_handle
+  578: 			g_variable.release_data = 1;
+001A9C 904CEB            MOV      DPTR,#g_variable+02CH
+001A9F 7401              MOV      A,#01H
+001AA1 F0                MOVX     @DPTR,A
+  579: 			g_variable.last_device_num = g_variable.current_device_num;
+001AA2 904CC3            MOV      DPTR,#g_variable+04H
+001AA5 E0                MOVX     A,@DPTR
+001AA6 904CC0            MOV      DPTR,#g_variable+01H
+001AA9 F0                MOVX     @DPTR,A
+  580: 			g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_NORMAL;
+001AAA 904CBF            MOV      DPTR,#g_variable
+001AAD 7401              MOV      A,#01H
+001AAF F0                MOVX     @DPTR,A
+  581: 			YC_update_eeprom_data();
+001AB0 71EA              ACALL    YC_update_eeprom_data
+  582: 			System_Reset_Connect();
+001AB2 B133              ACALL    System_Reset_Connect
+  583: 		}
+001AB4         ?C0108?SYS:
+  584: 		g_variable.button_timer[2] = 0;
+001AB4 E4                CLR      A
+001AB5 904CD1            MOV      DPTR,#g_variable+012H
+001AB8 F0                MOVX     @DPTR,A
+  585: 	}
+001AB9         ?C0107?SYS:
+  586: 
+  587: 	
+  588: 	if (g_variable.button_flag & KEY_FLAG_FN_DEVICE_BUTTON)
+001AB9 904CCE            MOV      DPTR,#g_variable+0FH
+001ABC E0                MOVX     A,@DPTR
+001ABD 30E34D            JNB      ACC.3,?C0109?SYS
+  589: 	{
+  590: 		g_variable.delay_enter_lpm_timer = 10;
+001AC0 904CEA            MOV      DPTR,#g_variable+02BH
+001AC3 740A              MOV      A,#0AH
+001AC5 F0                MOVX     @DPTR,A
+  591: 		if (g_variable.button_timer[3] < 250)
+001AC6 904CD2            MOV      DPTR,#g_variable+013H
+001AC9 E0                MOVX     A,@DPTR
+001ACA C3                CLR      C
+001ACB 94FA              SUBB     A,#0FAH
+001ACD 7480              MOV      A,#080H
+001ACF 9480              SUBB     A,#080H
+001AD1 5003              JNC      ?C0110?SYS
+  592: 			g_variable.button_timer[3]++;
+001AD3 E0                MOVX     A,@DPTR
+001AD4 04                INC      A
+001AD5 F0                MOVX     @DPTR,A
+001AD6         ?C0110?SYS:
+  593: 		if (g_variable.button_timer[3] == 6)
+001AD6 904CD2            MOV      DPTR,#g_variable+013H
+001AD9 E0                MOVX     A,@DPTR
+001ADA 6406              XRL      A,#06H
+001ADC 7065              JNZ      ?C0112?SYS
+  594: 		{
+  595: 			//do discoverable
+  596: 			g_variable.pairing_timeout = BT_PAIRING_TIME_OUT_2MIN;
+001ADE 904CE9            MOV      DPTR,#g_variable+02AH
+001AE1 74F0              MOV      A,#0F0H
+001AE3 F0                MOVX     @DPTR,A
+  597: 			g_variable.pairing_g24_timeout = 0;
+001AE4 E4                CLR      A
+001AE5 904CEE            MOV      DPTR,#g_variable+02FH
+001AE8 F0                MOVX     @DPTR,A
+  598: 			YC_key_action_handle(KEY_DISCOVERY);
+001AE9 7F05              MOV      R7,#05H
+001AEB 1212C6            LCALL    _YC_key_action_handle
+  599: 			LED_all_shutdown();
+001AEE 1217F0            LCALL    LED_all_shutdown
+  600: 			g_variable.button_reconnect_flag = 0;
+001AF1 E4                CLR      A
+001AF2 904CCC            MOV      DPTR,#g_variable+0DH
+001AF5 F0                MOVX     @DPTR,A
+  601: 			g_variable.release_data = 1;
+001AF6 904CEB            MOV      DPTR,#g_variable+02CH
+001AF9 04                INC      A
+001AFA F0                MOVX     @DPTR,A
+  602: 			g_variable.temp_device_num = g_variable.last_device_num;
+001AFB 904CC0            MOV      DPTR,#g_variable+01H
+001AFE E0                MOVX     A,@DPTR
+001AFF 904CC4            MOV      DPTR,#g_variable+05H
+001B02 F0                MOVX     @DPTR,A
+  603: 			g_variable.last_device_num = g_variable.current_device_num;
+001B03 904CC3            MOV      DPTR,#g_variable+04H
+001B06 E0                MOVX     A,@DPTR
+001B07 904CC0            MOV      DPTR,#g_variable+01H
+001B0A F0                MOVX     @DPTR,A
+  604: 		}
+  605: 	}
+001B0B 8036              SJMP     ?C0112?SYS
+001B0D         ?C0109?SYS:
+  606: 	else
+  607: 	{
+  608: 		if (g_variable.button_reconnect_flag)
+001B0D 904CCC            MOV      DPTR,#g_variable+0DH
+001B10 E0                MOVX     A,@DPTR
+001B11 602B              JZ       ?C0113?SYS
+  609: 		{
+  610: 			g_variable.button_reconnect_flag = 0;
+001B13 E4                CLR      A
+001B14 F0                MOVX     @DPTR,A
+  611: 
+  612: 			if(g_variable.last_device_num !=g_variable.current_device_num)		//switch device,
+001B15 904CC3            MOV      DPTR,#g_variable+04H
+001B18 E0                MOVX     A,@DPTR
+001B19 FF                MOV      R7,A
+001B1A 904CC0            MOV      DPTR,#g_variable+01H
+001B1D E0                MOVX     A,@DPTR
+001B1E 6F                XRL      A,R7
+001B1F 601D              JZ       ?C0113?SYS
+  613: 			{
+  614: 				g_variable.release_data = 1;
+001B21 904CEB            MOV      DPTR,#g_variable+02CH
+001B24 7401              MOV      A,#01H
+001B26 F0                MOVX     @DPTR,A
+  615: 				LED_all_shutdown();
+001B27 1217F0            LCALL    LED_all_shutdown
+  616: 				g_variable.last_device_num = g_variable.current_device_num;
+001B2A 904CC3            MOV      DPTR,#g_variable+04H
+001B2D E0                MOVX     A,@DPTR
+001B2E 904CC0            MOV      DPTR,#g_variable+01H
+001B31 F0                MOVX     @DPTR,A
+  617: 				g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_NORMAL;
+001B32 904CBF            MOV      DPTR,#g_variable
+001B35 7401              MOV      A,#01H
+001B37 F0                MOVX     @DPTR,A
+  618: 				
+  619: 				YC_disconnect_all_link();
+001B38 31C1              ACALL    YC_disconnect_all_link
+  620: 				YC_update_eeprom_data();
+001B3A 71EA              ACALL    YC_update_eeprom_data
+  621: 				System_Reset_Connect();
+001B3C B133              ACALL    System_Reset_Connect
+  622: 			}
+  623: 		}
+001B3E         ?C0113?SYS:
+  624: 		g_variable.button_timer[3] = 0;
+001B3E E4                CLR      A
+001B3F 904CD2            MOV      DPTR,#g_variable+013H
+001B42 F0                MOVX     @DPTR,A
+  625: 	}
+001B43         ?C0112?SYS:
+  626: 		
+  627: 
+  628: 
+  629: 	if (g_variable.button_flag & KEY_FLAG_FN_SYSTEM_MODE_BUTTON)
+001B43 904CCE            MOV      DPTR,#g_variable+0FH
+001B46 E0                MOVX     A,@DPTR
+001B47 20E502            JB       ACC.5,$ + 5H
+001B4A 61E4              AJMP     ?C0115?SYS
+  630: 	{
+  631: 		if (g_variable.button_timer[0] < 250)
+001B4C A3                INC      DPTR
+001B4D E0                MOVX     A,@DPTR
+001B4E C3                CLR      C
+001B4F 94FA              SUBB     A,#0FAH
+001B51 7480              MOV      A,#080H
+001B53 9480              SUBB     A,#080H
+001B55 5003              JNC      ?C0116?SYS
+  632: 			g_variable.button_timer[0]++;
+001B57 E0                MOVX     A,@DPTR
+001B58 04                INC      A
+001B59 F0                MOVX     @DPTR,A
+001B5A         ?C0116?SYS:
+  633: 		if (g_variable.button_timer[0] == 6)
+001B5A 904CCF            MOV      DPTR,#g_variable+010H
+001B5D E0                MOVX     A,@DPTR
+001B5E 6406              XRL      A,#06H
+001B60 6002              JZ       $ + 4H
+001B62 61E9              AJMP     ?C0129?SYS
+  634: 		{
+  635: 			if(key_value_temp == HID_KEY_Q)
+001B64 904DE8            MOV      DPTR,#key_value_temp
+001B67 E0                MOVX     A,@DPTR
+001B68 6414              XRL      A,#014H
+001B6A 7008              JNZ      ?C0118?SYS
+  636: 			{
+  637: 				g_variable.system_mode = OSMODE_IOS;
+001B6C 904CC1            MOV      DPTR,#g_variable+02H
+001B6F 7402              MOV      A,#02H
+001B71 F0                MOVX     @DPTR,A
+  638: 			}
+001B72 8021              SJMP     ?C0119?SYS
+001B74         ?C0118?SYS:
+  639: 			else if(key_value_temp == HID_KEY_O)
+001B74 904DE8            MOV      DPTR,#key_value_temp
+001B77 E0                MOVX     A,@DPTR
+001B78 6412              XRL      A,#012H
+001B7A 7007              JNZ      ?C0120?SYS
+  640: 			{
+  641: 				g_variable.system_mode = OSMODE_MAC;
+001B7C 904CC1            MOV      DPTR,#g_variable+02H
+001B7F 04                INC      A
+001B80 F0                MOVX     @DPTR,A
+  642: 
+  643: 			}
+001B81 8012              SJMP     ?C0119?SYS
+001B83         ?C0120?SYS:
+  644: 			else if(key_value_temp == HID_KEY_W ||key_value_temp == HID_KEY_E )
+001B83 904DE8            MOV      DPTR,#key_value_temp
+001B86 E0                MOVX     A,@DPTR
+001B87 641A              XRL      A,#01AH
+001B89 6005              JZ       ?C0123?SYS
+001B8B E0                MOVX     A,@DPTR
+001B8C 6408              XRL      A,#08H
+001B8E 7005              JNZ      ?C0119?SYS
+001B90         ?C0123?SYS:
+  645: 			{
+  646: 				g_variable.system_mode = OSMODE_WINDOWS;
+001B90 E4                CLR      A
+001B91 904CC1            MOV      DPTR,#g_variable+02H
+001B94 F0                MOVX     @DPTR,A
+  647: 
+  648: 			}
+001B95         ?C0119?SYS:
+  649: 			g_variable.powerOn_timer = 10;
+001B95 904CE5            MOV      DPTR,#g_variable+026H
+001B98 740A              MOV      A,#0AH
+001B9A F0                MOVX     @DPTR,A
+  650: 			if(g_variable.current_device_num == 0 || g_variable.current_device_num == 0xfe)
+001B9B 904CC3            MOV      DPTR,#g_variable+04H
+001B9E E0                MOVX     A,@DPTR
+001B9F FF                MOV      R7,A
+001BA0 7E00              MOV      R6,#00H
+001BA2 6004              JZ       ?C0125?SYS
+001BA4 64FE              XRL      A,#0FEH
+001BA6 7007              JNZ      ?C0124?SYS
+001BA8         ?C0125?SYS:
+  651: 			{
+  652: 				g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_G24;
+001BA8 904CBF            MOV      DPTR,#g_variable
+001BAB 7402              MOV      A,#02H
+001BAD F0                MOVX     @DPTR,A
+  653: 			}
+001BAE 22                RET      
+001BAF         ?C0124?SYS:
+  654: 			else	if (g_variable.current_device_num <= 3 && g_variable.current_device_num >= 1)
+001BAF D3                SETB     C
+001BB0 EF                MOV      A,R7
+001BB1 9403              SUBB     A,#03H
+001BB3 EE                MOV      A,R6
+001BB4 6480              XRL      A,#080H
+001BB6 9480              SUBB     A,#080H
+001BB8 502F              JNC      ?C0129?SYS
+001BBA C3                CLR      C
+001BBB EF                MOV      A,R7
+001BBC 9401              SUBB     A,#01H
+001BBE EE                MOV      A,R6
+001BBF 6480              XRL      A,#080H
+001BC1 9480              SUBB     A,#080H
+001BC3 4024              JC       ?C0129?SYS
+  655: 			{
+  656: 				bd_key_record_list[g_variable.current_device_num - 1].system_mode = g_variable.system_mode;
+001BC5 904CC1            MOV      DPTR,#g_variable+02H
+001BC8 E0                MOVX     A,@DPTR
+001BC9 FF                MOV      R7,A
+001BCA 904CC3            MOV      DPTR,#g_variable+04H
+001BCD E0                MOVX     A,@DPTR
+001BCE 75F01F            MOV      B,#01FH
+001BD1 A4                MUL      AB
+001BD2 24EC              ADD      A,#LOW bd_key_record_list-02H
+001BD4 F582              MOV      DPL,A
+001BD6 E4                CLR      A
+001BD7 344D              ADDC     A,#HIGH bd_key_record_list-02H
+001BD9 F583              MOV      DPH,A
+001BDB EF                MOV      A,R7
+001BDC F0                MOVX     @DPTR,A
+  657: 				g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_BT;
+001BDD 904CBF            MOV      DPTR,#g_variable
+001BE0 7403              MOV      A,#03H
+001BE2 F0                MOVX     @DPTR,A
+  658: 			}
+  659: 		}
+  660: 	}
+001BE3 22                RET      
+001BE4         ?C0115?SYS:
+  661: 	else
+  662: 	{
+  663: 		g_variable.button_timer[0] = 0;
+001BE4 E4                CLR      A
+001BE5 904CCF            MOV      DPTR,#g_variable+010H
+001BE8 F0                MOVX     @DPTR,A
+  664: 	}		
+  665: 
+  666: }
+001BE9         ?C0129?SYS:
+001BE9 22                RET      
+----- FUNCTION kb_button_press_timer500ms (END) -------
+
+
+----- FUNCTION YC_update_eeprom_data (BEGIN) -----
+ FILE: 'bluetooth.c'
+  199: void YC_update_eeprom_data()
+  200: {
+  201: 	if (g_variable.update_eeprom_flag)				//bt3.0  bt4.2 record information save
+  202: 	{
+001BEA 904CBF            MOV      DPTR,#g_variable
+001BED E0                MOVX     A,@DPTR
+001BEE 7002              JNZ      $ + 4H
+001BF0 8183              AJMP     ?C0042?BLUETOOTH
+  203: 		if (g_variable.update_eeprom_flag != EEPROM_STORE_TYPE_NORMAL)
+  204: 			Delay1ms(200);
+001BF2 6401              XRL      A,#01H
+001BF4 6005              JZ       ?C0038?BLUETOOTH
+  205: 		GPIO_Setout(EEPROM_WP_GPIO,0);
+001BF6 7FC8              MOV      R7,#0C8H
+001BF8 121798            LCALL    _Delay1ms
+001BFB         ?C0038?BLUETOOTH:
+  206: 		if (g_variable.update_eeprom_flag == EEPROM_STORE_TYPE_G24)
+001BFB C201              CLR      ?_GPIO_Setout?BIT
+001BFD 7FFF              MOV      R7,#0FFH
+001BFF 1211B2            LCALL    _GPIO_Setout
+  207: 		{
+001C02 904CBF            MOV      DPTR,#g_variable
+001C05 E0                MOVX     A,@DPTR
+001C06 6402              XRL      A,#02H
+001C08 7031              JNZ      ?C0039?BLUETOOTH
+  208: 			IIC_WriteBlock(EEPROM_RECON_INFO_BASE_6+2,4 , (byte *)m_24g_addr);
+  209: 			IIC_WriteBlock(EEPROM_RECON_INFO_G24_SYTEM_MODE ,1 ,(byte *)&g_variable.system_mode);
+001C0A 7B01              MOV      R3,#01H
+001C0C 7A4C              MOV      R2,#HIGH m_24g_addr
+001C0E 7900              MOV      R1,#LOW m_24g_addr
+001C10 7D04              MOV      R5,#04H
+001C12 FC                MOV      R4,A
+001C13 7F52              MOV      R7,#052H
+001C15 7E7F              MOV      R6,#07FH
+001C17 9184              ACALL    _IIC_WriteBlock
+  210: 			IIC_WriteBlock(EEPROM_RECON_INFO_G24_FN_LOCK ,1 ,(byte *)&fn_lock_flag);
+001C19 7B01              MOV      R3,#01H
+001C1B 7A4C              MOV      R2,#HIGH g_variable+02H
+001C1D 79C1              MOV      R1,#LOW g_variable+02H
+001C1F 7D01              MOV      R5,#01H
+001C21 7C00              MOV      R4,#00H
+001C23 7F57              MOV      R7,#057H
+001C25 7E7F              MOV      R6,#07FH
+001C27 9184              ACALL    _IIC_WriteBlock
+  211: 		}	
+001C29 7B01              MOV      R3,#01H
+001C2B 7A4D              MOV      R2,#HIGH fn_lock_flag
+001C2D 79E7              MOV      R1,#LOW fn_lock_flag
+001C2F 7D01              MOV      R5,#01H
+001C31 7C00              MOV      R4,#00H
+001C33 7F56              MOV      R7,#056H
+001C35 7E7F              MOV      R6,#07FH
+001C37 9184              ACALL    _IIC_WriteBlock
+  212: 		else if (g_variable.update_eeprom_flag == EEPROM_STORE_TYPE_BT)
+001C39 8017              SJMP     ?C0040?BLUETOOTH
+001C3B         ?C0039?BLUETOOTH:
+  213: 			IIC_WriteBlock(EEPROM_RECON_INFO_BASE ,(sizeof(BD_KEY_RECORD)*3) , (byte *)&bd_key_record_list);
+001C3B 904CBF            MOV      DPTR,#g_variable
+001C3E E0                MOVX     A,@DPTR
+001C3F 6403              XRL      A,#03H
+001C41 700F              JNZ      ?C0040?BLUETOOTH
+  214: 		
+001C43 7B01              MOV      R3,#01H
+001C45 7A4D              MOV      R2,#HIGH bd_key_record_list
+001C47 79EE              MOV      R1,#LOW bd_key_record_list
+001C49 7D5D              MOV      R5,#05DH
+001C4B FC                MOV      R4,A
+001C4C 7F60              MOV      R7,#060H
+001C4E 7E7F              MOV      R6,#07FH
+001C50 9184              ACALL    _IIC_WriteBlock
+001C52         ?C0040?BLUETOOTH:
+  215: 		IIC_WriteBlock(EEPROM_RECON_INFO_LAST_DEVICE ,1 ,(byte *)&g_variable.last_device_num);
+001C52 7B01              MOV      R3,#01H
+001C54 7A4C              MOV      R2,#HIGH g_variable+01H
+001C56 79C0              MOV      R1,#LOW g_variable+01H
+001C58 7D01              MOV      R5,#01H
+001C5A 7C00              MOV      R4,#00H
+001C5C 7FBD              MOV      R7,#0BDH
+001C5E 7E7F              MOV      R6,#07FH
+001C60 9184              ACALL    _IIC_WriteBlock
+  216: 		IIC_WriteBlock(EEPROM_RECON_INFO_RAMDON_LE_LAP1 ,2 ,(byte *)&g_variable.ble_ramdon_lap1);
+001C62 7B01              MOV      R3,#01H
+001C64 7A4C              MOV      R2,#HIGH g_variable+033H
+001C66 79F2              MOV      R1,#LOW g_variable+033H
+001C68 7D02              MOV      R5,#02H
+001C6A 7C00              MOV      R4,#00H
+001C6C 7FBE              MOV      R7,#0BEH
+001C6E 7E7F              MOV      R6,#07FH
+001C70 9184              ACALL    _IIC_WriteBlock
+  217: 
+  218: 		GPIO_Setout(EEPROM_WP_GPIO,1);
+001C72 D201              SETB     ?_GPIO_Setout?BIT
+001C74 7FFF              MOV      R7,#0FFH
+001C76 1211B2            LCALL    _GPIO_Setout
+  219: 		Delay1ms(10);
+001C79 7F0A              MOV      R7,#0AH
+001C7B 121798            LCALL    _Delay1ms
+  220: 		g_variable.update_eeprom_flag = 0;
+001C7E E4                CLR      A
+001C7F 904CBF            MOV      DPTR,#g_variable
+001C82 F0                MOVX     @DPTR,A
+  221: 	}
+  222: }
+001C83         ?C0042?BLUETOOTH:
+001C83 22                RET      
+----- FUNCTION YC_update_eeprom_data (END) -------
+
+
+----- FUNCTION _IIC_WriteBlock (BEGIN) -----
+001C84 904E93            MOV      DPTR,#addr
+001C87 EE                MOV      A,R6
+001C88 F0                MOVX     @DPTR,A
+001C89 A3                INC      DPTR
+001C8A EF                MOV      A,R7
+001C8B F0                MOVX     @DPTR,A
+001C8C A3                INC      DPTR
+001C8D EC                MOV      A,R4
+001C8E F0                MOVX     @DPTR,A
+001C8F A3                INC      DPTR
+001C90 ED                MOV      A,R5
+001C91 F0                MOVX     @DPTR,A
+001C92 A3                INC      DPTR
+001C93 EB                MOV      A,R3
+001C94 F0                MOVX     @DPTR,A
+001C95 A3                INC      DPTR
+001C96 EA                MOV      A,R2
+001C97 F0                MOVX     @DPTR,A
+001C98 A3                INC      DPTR
+001C99 E9                MOV      A,R1
+001C9A F0                MOVX     @DPTR,A
+001C9B         ?C0007?IIC:
+001C9B 904E95            MOV      DPTR,#len
+001C9E E0                MOVX     A,@DPTR
+001C9F 7002              JNZ      ?C0012?IIC
+001CA1 A3                INC      DPTR
+001CA2 E0                MOVX     A,@DPTR
+001CA3         ?C0012?IIC:
+001CA3 7002              JNZ      $ + 4H
+001CA5 A132              AJMP     ?C0011?IIC
+001CA7 904E93            MOV      DPTR,#addr
+001CAA E0                MOVX     A,@DPTR
+001CAB FE                MOV      R6,A
+001CAC A3                INC      DPTR
+001CAD E0                MOVX     A,@DPTR
+001CAE FF                MOV      R7,A
+001CAF 440F              ORL      A,#0FH
+001CB1 2401              ADD      A,#01H
+001CB3 FD                MOV      R5,A
+001CB4 E4                CLR      A
+001CB5 3E                ADDC     A,R6
+001CB6 FC                MOV      R4,A
+;---- Variable 'cris' assigned to Register 'R4/R5' ----
+001CB7 C3                CLR      C
+001CB8 ED                MOV      A,R5
+001CB9 9F                SUBB     A,R7
+001CBA FF                MOV      R7,A
+001CBB EC                MOV      A,R4
+001CBC 9E                SUBB     A,R6
+001CBD FE                MOV      R6,A
+001CBE 904E9A            MOV      DPTR,#curr_len
+001CC1 F0                MOVX     @DPTR,A
+001CC2 A3                INC      DPTR
+001CC3 EF                MOV      A,R7
+001CC4 F0                MOVX     @DPTR,A
+001CC5 904E95            MOV      DPTR,#len
+001CC8 E0                MOVX     A,@DPTR
+001CC9 FC                MOV      R4,A
+001CCA A3                INC      DPTR
+001CCB E0                MOVX     A,@DPTR
+001CCC FD                MOV      R5,A
+001CCD D3                SETB     C
+001CCE 9F                SUBB     A,R7
+001CCF EC                MOV      A,R4
+001CD0 9E                SUBB     A,R6
+001CD1 400A              JC       ?C0009?IIC
+001CD3 904E9A            MOV      DPTR,#curr_len
+001CD6 E0                MOVX     A,@DPTR
+001CD7 FE                MOV      R6,A
+001CD8 A3                INC      DPTR
+001CD9 E0                MOVX     A,@DPTR
+001CDA FF                MOV      R7,A
+001CDB 8004              SJMP     ?C0010?IIC
+001CDD         ?C0009?IIC:
+001CDD AE04              MOV      R6,AR4
+001CDF AF05              MOV      R7,AR5
+001CE1         ?C0010?IIC:
+001CE1 904E9A            MOV      DPTR,#curr_len
+001CE4 EE                MOV      A,R6
+001CE5 F0                MOVX     @DPTR,A
+001CE6 FC                MOV      R4,A
+001CE7 A3                INC      DPTR
+001CE8 EF                MOV      A,R7
+001CE9 F0                MOVX     @DPTR,A
+001CEA FD                MOV      R5,A
+001CEB C3                CLR      C
+001CEC 904E96            MOV      DPTR,#len+01H
+001CEF E0                MOVX     A,@DPTR
+001CF0 9D                SUBB     A,R5
+001CF1 F0                MOVX     @DPTR,A
+001CF2 904E95            MOV      DPTR,#len
+001CF5 E0                MOVX     A,@DPTR
+001CF6 9C                SUBB     A,R4
+001CF7 F0                MOVX     @DPTR,A
+001CF8 904E93            MOV      DPTR,#addr
+001CFB E0                MOVX     A,@DPTR
+001CFC FE                MOV      R6,A
+001CFD A3                INC      DPTR
+001CFE E0                MOVX     A,@DPTR
+001CFF FF                MOV      R7,A
+001D00 904E97            MOV      DPTR,#pbuff
+001D03 E0                MOVX     A,@DPTR
+001D04 FB                MOV      R3,A
+001D05 A3                INC      DPTR
+001D06 E0                MOVX     A,@DPTR
+001D07 FA                MOV      R2,A
+001D08 A3                INC      DPTR
+001D09 E0                MOVX     A,@DPTR
+001D0A F9                MOV      R1,A
+001D0B 122182            LCALL    _IIC_write
+001D0E 7F0A              MOV      R7,#0AH
+001D10 121798            LCALL    _Delay1ms
+001D13 904E9A            MOV      DPTR,#curr_len
+001D16 E0                MOVX     A,@DPTR
+001D17 FE                MOV      R6,A
+001D18 A3                INC      DPTR
+001D19 E0                MOVX     A,@DPTR
+001D1A FF                MOV      R7,A
+001D1B 904E98            MOV      DPTR,#pbuff+01H
+001D1E EE                MOV      A,R6
+001D1F 8FF0              MOV      B,R7
+001D21 12040E            LCALL    ?C?IILDX
+001D24 904E94            MOV      DPTR,#addr+01H
+001D27 E0                MOVX     A,@DPTR
+001D28 2F                ADD      A,R7
+001D29 F0                MOVX     @DPTR,A
+001D2A 904E93            MOV      DPTR,#addr
+001D2D E0                MOVX     A,@DPTR
+001D2E 3E                ADDC     A,R6
+001D2F F0                MOVX     @DPTR,A
+001D30 819B              AJMP     ?C0007?IIC
+001D32         ?C0011?IIC:
+001D32 22                RET      
+----- FUNCTION _IIC_WriteBlock (END) -------
+
+
+----- FUNCTION System_Reset_Connect (BEGIN) -----
+ FILE: 'sys.c'
+  105: void System_Reset_Connect()
+;----                  JMP      System_Hardware_reset
+  106: {
+  107: 	System_Hardware_reset();
+----- FUNCTION System_Reset_Connect (END) -------
+
+
+----- FUNCTION System_Hardware_reset (BEGIN) -----
+ FILE: 'sys.c'
+   75: static void System_Hardware_reset()
+   76: {
+   77: 	m_reset_reg = 1;
+   78: 	while(1);
+001D33 908010            MOV      DPTR,#m_reset_reg
+001D36 7401              MOV      A,#01H
+001D38 F0                MOVX     @DPTR,A
+001D39         ?C0005?SYS:
+   79: }
+001D39 80FE              SJMP     ?C0005?SYS
+001D3B 22                RET      
+----- FUNCTION System_Hardware_reset (END) -------
+
+
+----- FUNCTION YC_System_Main (BEGIN) -----
+ FILE: 'sys.c'
+  814: void YC_System_Main(void)
+  815: {
+  816: 
+  817: 	kb_cb_init();
+001D3C F193              ACALL    kb_cb_init
+001D3E         ?C0159?SYS:
+  818: 	while(1) {
+  819: 		IPC_DealSingleStep();
+001D3E 1232FB            LCALL    IPC_DealSingleStep
+  820: 		kb_need_keyscan();
+001D41 D1D0              ACALL    kb_need_keyscan
+  821: 		YC_update_eeprom_data();
+001D43 71EA              ACALL    YC_update_eeprom_data
+  822: 		LED_handle();
+001D45 1211C4            LCALL    LED_handle
+  823: #ifdef PC_SLEEP_STATUS_GET		
+  824: 		if(m_pc_sleep_flag)
+001D48 904D7D            MOV      DPTR,#m_pc_sleep_flag
+001D4B E0                MOVX     A,@DPTR
+001D4C 6003              JZ       ?C0161?SYS
+  825: 		{
+  826: 			System_G24_long_lpm();
+001D4E 122433            LCALL    System_G24_long_lpm
+  827: 		}
+001D51         ?C0161?SYS:
+  828: #endif		
+  829: 		switch (current_task) {
+001D51 900B7E            MOV      DPTR,#current_task
+001D54 E0                MOVX     A,@DPTR
+001D55 14                DEC      A
+001D56 600D              JZ       ?C0166?SYS
+001D58 24FE              ADD      A,#0FEH
+001D5A 70E2              JNZ      ?C0159?SYS
+  830: 		case FIX_ENTER_HIBERNATE:
+001D5C         ?C0163?SYS:
+  831: 			KS_Unistall();
+001D5C B18B              ACALL    KS_Unistall
+  832: 			//GPIO_SetWakeupByCurrentState(BT_BUTTON_GPIO);
+  833: 			LED_all_shutdown();
+001D5E 1217F0            LCALL    LED_all_shutdown
+  834: 			IPC_WaitLpm();	/*<wait enter lpm,do nothing*/
+001D61 D1C2              ACALL    IPC_WaitLpm
+001D63         ?C0164?SYS:
+  835: 			while(1);
+001D63 80FE              SJMP     ?C0164?SYS
+  836: 			break;
+  837: 			
+  838: 		case FIX_ENTER_LPM:
+001D65         ?C0166?SYS:
+  839: 			if (g_variable.delay_enter_lpm_timer ||g_variable.lockLpm ||g_variable.powerOn_timer ||g_variable.one_key_pres
+>> s_wait_release_timer
+001D65 904CEA            MOV      DPTR,#g_variable+02BH
+001D68 E0                MOVX     A,@DPTR
+001D69 7012              JNZ      ?C0168?SYS
+001D6B 904CEC            MOV      DPTR,#g_variable+02DH
+001D6E E0                MOVX     A,@DPTR
+001D6F 700C              JNZ      ?C0168?SYS
+001D71 904CE5            MOV      DPTR,#g_variable+026H
+001D74 E0                MOVX     A,@DPTR
+001D75 7006              JNZ      ?C0168?SYS
+001D77 904CF8            MOV      DPTR,#g_variable+039H
+001D7A E0                MOVX     A,@DPTR
+001D7B 6005              JZ       ?C0167?SYS
+001D7D         ?C0168?SYS:
+  840: 			) 
+  841: 			{
+  842: 				IPC_AbandonLpm();
+001D7D 123532            LCALL    IPC_AbandonLpm
+  843: 				break;
+001D80 80BC              SJMP     ?C0159?SYS
+  844: 			}
+001D82         ?C0167?SYS:
+  845: 			else
+  846: 			{
+  847: 				KS_Unistall();
+001D82 B18B              ACALL    KS_Unistall
+  848: 				IPC_WaitLpm();	/*<wait enter lpm,do nothing*/
+001D84 D1C2              ACALL    IPC_WaitLpm
+  849: 				break;
+001D86 80B6              SJMP     ?C0159?SYS
+  850: 			}
+  851: 		}
+  852: 	}
+001D88 80B4              SJMP     ?C0159?SYS
+001D8A 22                RET      
+----- FUNCTION YC_System_Main (END) -------
+
+
+----- FUNCTION KS_Unistall (BEGIN) -----
+ FILE: 'keyscan.c'
+  215: void KS_Unistall()
+  216: {
+  217: 	byte i = 0;
+  218: 	byte temp = 0;
+;---- Variable 'i' assigned to Register 'R7' ----
+001D8B E4                CLR      A
+001D8C FF                MOV      R7,A
+  219: 	byte tgroup = 0;
+001D8D 904F05            MOV      DPTR,#temp
+001D90 F0                MOVX     @DPTR,A
+  220: 	byte tgpionum = 0;
+;---- Variable 'tgroup' assigned to Register 'R6' ----
+001D91 FE                MOV      R6,A
+  221: 	for (i=0; col[i]!=0; i++) {
+;---- Variable 'tgpionum' assigned to Register 'R5' ----
+001D92 FD                MOV      R5,A
+  222: 		tgroup = col[i]  >> 3;
+001D93         ?C0037?KEYSCAN:
+001D93 EF                MOV      A,R7
+001D94 900681            MOV      DPTR,#col
+001D97 93                MOVC     A,@A+DPTR
+001D98 6048              JZ       ?C0038?KEYSCAN
+  223: 		tgpionum = 1 << (col[i] & 7);
+001D9A EF                MOV      A,R7
+001D9B 93                MOVC     A,@A+DPTR
+001D9C FD                MOV      R5,A
+001D9D 13                RRC      A
+001D9E 13                RRC      A
+001D9F 13                RRC      A
+001DA0 541F              ANL      A,#01FH
+001DA2 FE                MOV      R6,A
+  224: 		REG_GPIO_PUP (tgroup) &= ~tgpionum;
+001DA3 ED                MOV      A,R5
+001DA4 5407              ANL      A,#07H
+001DA6 FD                MOV      R5,A
+001DA7 F8                MOV      R0,A
+001DA8 7401              MOV      A,#01H
+001DAA 08                INC      R0
+001DAB 8002              SJMP     ?C0097?KEYSCAN
+001DAD         ?C0096?KEYSCAN:
+001DAD C3                CLR      C
+001DAE 33                RLC      A
+001DAF         ?C0097?KEYSCAN:
+001DAF D8FC              DJNZ     R0,?C0096?KEYSCAN
+001DB1 FD                MOV      R5,A
+  225: 		REG_GPIO_OE(tgroup) |= tgpionum;
+001DB2 EE                MOV      A,R6
+001DB3 2478              ADD      A,#078H
+001DB5 FB                MOV      R3,A
+001DB6 E4                CLR      A
+001DB7 3480              ADDC     A,#080H
+001DB9 8B82              MOV      DPL,R3
+001DBB F583              MOV      DPH,A
+001DBD E0                MOVX     A,@DPTR
+001DBE FC                MOV      R4,A
+001DBF ED                MOV      A,R5
+001DC0 F4                CPL      A
+001DC1 FB                MOV      R3,A
+001DC2 EC                MOV      A,R4
+001DC3 5B                ANL      A,R3
+001DC4 F0                MOVX     @DPTR,A
+  226: 		REG_GPIO_OUT(tgroup) &= ~tgpionum;
+001DC5 EE                MOV      A,R6
+001DC6 2470              ADD      A,#070H
+001DC8 F582              MOV      DPL,A
+001DCA E4                CLR      A
+001DCB 3480              ADDC     A,#080H
+001DCD F583              MOV      DPH,A
+001DCF E0                MOVX     A,@DPTR
+001DD0 4D                ORL      A,R5
+001DD1 F0                MOVX     @DPTR,A
+  227: 	}
+001DD2 EE                MOV      A,R6
+001DD3 2474              ADD      A,#074H
+001DD5 F582              MOV      DPL,A
+001DD7 E4                CLR      A
+001DD8 3480              ADDC     A,#080H
+001DDA F583              MOV      DPH,A
+001DDC E0                MOVX     A,@DPTR
+001DDD 5B                ANL      A,R3
+001DDE F0                MOVX     @DPTR,A
+  228: 	
+001DDF 0F                INC      R7
+001DE0 80B1              SJMP     ?C0037?KEYSCAN
+001DE2         ?C0038?KEYSCAN:
+  229: 	GPIO_fillpd();
+001DE2 1235CE            LCALL    GPIO_fillpd
+  230: 	
+  231: 	temp = REG_GPIO_IN(0);
+001DE5 90811C            MOV      DPTR,#0811CH
+001DE8 E0                MOVX     A,@DPTR
+001DE9 904F05            MOV      DPTR,#temp
+001DEC F0                MOVX     @DPTR,A
+  232: 
+  233: 	if(long_press_flag)
+001DED 904DDC            MOV      DPTR,#long_press_flag
+001DF0 E0                MOVX     A,@DPTR
+001DF1 6020              JZ       ?C0040?KEYSCAN
+  234: 	{
+  235: 		GPIO_SetWakeupByCurrentState(0);
+001DF3 E4                CLR      A
+001DF4 FF                MOV      R7,A
+001DF5 D123              ACALL    _GPIO_SetWakeupByCurrentState
+  236: 		GPIO_SetWakeupByCurrentState(1);
+001DF7 7F01              MOV      R7,#01H
+001DF9 D123              ACALL    _GPIO_SetWakeupByCurrentState
+  237: 		GPIO_SetWakeupByCurrentState(2);
+001DFB 7F02              MOV      R7,#02H
+001DFD D123              ACALL    _GPIO_SetWakeupByCurrentState
+  238: 		GPIO_SetWakeupByCurrentState(3);
+001DFF 7F03              MOV      R7,#03H
+001E01 D123              ACALL    _GPIO_SetWakeupByCurrentState
+  239: 		GPIO_SetWakeupByCurrentState(4);
+001E03 7F04              MOV      R7,#04H
+001E05 D123              ACALL    _GPIO_SetWakeupByCurrentState
+  240: 		GPIO_SetWakeupByCurrentState(5);
+001E07 7F05              MOV      R7,#05H
+001E09 D123              ACALL    _GPIO_SetWakeupByCurrentState
+  241: 		GPIO_SetWakeupByCurrentState(6);
+001E0B 7F06              MOV      R7,#06H
+001E0D D123              ACALL    _GPIO_SetWakeupByCurrentState
+  242: 		GPIO_SetWakeupByCurrentState(7);
+001E0F 7F07              MOV      R7,#07H
+001E11 8010              SJMP     _GPIO_SetWakeupByCurrentState
+  243: 	}
+001E13         ?C0040?KEYSCAN:
+  244: 	else
+  245: 	{
+  246: 		YC_GPIOWakeupL[0] = temp;
+001E13 904F05            MOV      DPTR,#temp
+001E16 E0                MOVX     A,@DPTR
+001E17 FF                MOV      R7,A
+001E18 9000A3            MOV      DPTR,#YC_GPIOWakeupL
+001E1B F0                MOVX     @DPTR,A
+  247: 		YC_GPIOWakeupH[0] = ~temp;
+001E1C EF                MOV      A,R7
+001E1D F4                CPL      A
+001E1E 9000A7            MOV      DPTR,#YC_GPIOWakeupH
+001E21 F0                MOVX     @DPTR,A
+  248: 	}
+  249: 
+  250: }
+001E22 22                RET      
+----- FUNCTION KS_Unistall (END) -------
+
+
+----- FUNCTION _GPIO_SetWakeupByCurrentState (BEGIN) -----
+001E23 904F09            MOV      DPTR,#gpio_num
+001E26 EF                MOV      A,R7
+001E27 F0                MOVX     @DPTR,A
+001E28 F1A6              ACALL    _GPIO_GetInputStatus
+001E2A 9208              MOV      st,C
+001E2C 904F09            MOV      DPTR,#gpio_num
+001E2F E0                MOVX     A,@DPTR
+001E30 FF                MOV      R7,A
+001E31 A208              MOV      C,st
+001E33 B3                CPL      C
+001E34 9207              MOV      ?_GPIO_SetWakeup?BIT,C
+;----                  JMP      _GPIO_SetWakeup
+----- FUNCTION _GPIO_SetWakeupByCurrentState (END) -------
+
+
+----- FUNCTION _GPIO_SetWakeup (BEGIN) -----
+;---- Variable 'gpio_num' assigned to Register 'R7' ----
+001E36 EF                MOV      A,R7
+001E37 F4                CPL      A
+001E38 7002              JNZ      $ + 4H
+001E3A C1C1              AJMP     ?C0019?GPIO
+001E3C         ?C0018?GPIO:
+001E3C EF                MOV      A,R7
+001E3D 5407              ANL      A,#07H
+001E3F FE                MOV      R6,A
+;---- Variable 'queue' assigned to Register 'R6' ----
+001E40 EF                MOV      A,R7
+001E41 13                RRC      A
+001E42 13                RRC      A
+001E43 13                RRC      A
+001E44 5403              ANL      A,#03H
+001E46 FF                MOV      R7,A
+;---- Variable 'group' assigned to Register 'R7' ----
+001E47 300743            JNB      st,?C0020?GPIO
+001E4A 24A3              ADD      A,#LOW YC_GPIOWakeupL
+001E4C F582              MOV      DPL,A
+001E4E E4                CLR      A
+001E4F 3400              ADDC     A,#HIGH YC_GPIOWakeupL
+001E51 F583              MOV      DPH,A
+001E53 C083              PUSH     DPH
+001E55 C082              PUSH     DPL
+001E57 E0                MOVX     A,@DPTR
+001E58 FD                MOV      R5,A
+001E59 7401              MOV      A,#01H
+001E5B A806              MOV      R0,AR6
+001E5D 08                INC      R0
+001E5E 8002              SJMP     ?C0037?GPIO
+001E60         ?C0036?GPIO:
+001E60 C3                CLR      C
+001E61 33                RLC      A
+001E62         ?C0037?GPIO:
+001E62 D8FC              DJNZ     R0,?C0036?GPIO
+001E64 F4                CPL      A
+001E65 5D                ANL      A,R5
+001E66 D082              POP      DPL
+001E68 D083              POP      DPH
+001E6A F0                MOVX     @DPTR,A
+001E6B 74A7              MOV      A,#LOW YC_GPIOWakeupH
+001E6D 2F                ADD      A,R7
+001E6E F582              MOV      DPL,A
+001E70 E4                CLR      A
+001E71 3400              ADDC     A,#HIGH YC_GPIOWakeupH
+001E73 F583              MOV      DPH,A
+001E75 C083              PUSH     DPH
+001E77 C082              PUSH     DPL
+001E79 E0                MOVX     A,@DPTR
+001E7A FF                MOV      R7,A
+001E7B 7401              MOV      A,#01H
+001E7D A806              MOV      R0,AR6
+001E7F 08                INC      R0
+001E80 8002              SJMP     ?C0039?GPIO
+001E82         ?C0038?GPIO:
+001E82 C3                CLR      C
+001E83 33                RLC      A
+001E84         ?C0039?GPIO:
+001E84 D8FC              DJNZ     R0,?C0038?GPIO
+001E86 4F                ORL      A,R7
+001E87 D082              POP      DPL
+001E89 D083              POP      DPH
+001E8B F0                MOVX     @DPTR,A
+001E8C 22                RET      
+001E8D         ?C0020?GPIO:
+001E8D 74A3              MOV      A,#LOW YC_GPIOWakeupL
+001E8F 2F                ADD      A,R7
+001E90 F582              MOV      DPL,A
+001E92 E4                CLR      A
+001E93 3400              ADDC     A,#HIGH YC_GPIOWakeupL
+001E95 F583              MOV      DPH,A
+001E97 C083              PUSH     DPH
+001E99 C082              PUSH     DPL
+001E9B E0                MOVX     A,@DPTR
+001E9C FD                MOV      R5,A
+001E9D 7401              MOV      A,#01H
+001E9F A806              MOV      R0,AR6
+001EA1 08                INC      R0
+001EA2 8002              SJMP     ?C0041?GPIO
+001EA4         ?C0040?GPIO:
+001EA4 C3                CLR      C
+001EA5 33                RLC      A
+001EA6         ?C0041?GPIO:
+001EA6 D8FC              DJNZ     R0,?C0040?GPIO
+001EA8 FC                MOV      R4,A
+001EA9 4D                ORL      A,R5
+001EAA D082              POP      DPL
+001EAC D083              POP      DPH
+001EAE F0                MOVX     @DPTR,A
+001EAF 74A7              MOV      A,#LOW YC_GPIOWakeupH
+001EB1 2F                ADD      A,R7
+001EB2 F582              MOV      DPL,A
+001EB4 E4                CLR      A
+001EB5 3400              ADDC     A,#HIGH YC_GPIOWakeupH
+001EB7 F583              MOV      DPH,A
+001EB9 E0                MOVX     A,@DPTR
+001EBA FF                MOV      R7,A
+001EBB EC                MOV      A,R4
+001EBC F4                CPL      A
+001EBD FE                MOV      R6,A
+001EBE EF                MOV      A,R7
+001EBF 5E                ANL      A,R6
+001EC0 F0                MOVX     @DPTR,A
+001EC1         ?C0019?GPIO:
+001EC1 22                RET      
+----- FUNCTION _GPIO_SetWakeup (END) -------
+
+
+----- FUNCTION IPC_WaitLpm (BEGIN) -----
+001EC2 E4                CLR      A
+001EC3 900B7F            MOV      DPTR,#lpm_flag
+001EC6 F0                MOVX     @DPTR,A
+001EC7 900B7E            MOV      DPTR,#current_task
+001ECA F0                MOVX     @DPTR,A
+001ECB 7F01              MOV      R7,#01H
+001ECD 021798            LJMP     _Delay1ms
+----- FUNCTION IPC_WaitLpm (END) -------
+
+
+----- FUNCTION kb_need_keyscan (BEGIN) -----
+ FILE: 'kb_process.c'
+  305: void kb_need_keyscan()
+  306: {
+  307: /*
+  308: 	 if (g_variable.ble_currentSubState == CHANGE_TO_BLE_SUB_PINCODE 
+  309: 		|| g_variable.br_currentSubState == CHANGE_TO_BR_SUB_PINCODE)
+  310: 	{
+  311: 		kb_bt_pincode_enter();
+  312: 	}
+  313: 	else
+  314: */	
+  315: 	{	
+  316: 		if((g_variable.key_combination_step == CAMBINATION_KEY_FREE)
+001ED0 904CF4            MOV      DPTR,#g_variable+035H
+001ED3 E0                MOVX     A,@DPTR
+001ED4 FF                MOV      R7,A
+001ED5 6009              JZ       ?C0058?KB_PROCESS
+001ED7 6403              XRL      A,#03H
+001ED9 6005              JZ       ?C0058?KB_PROCESS
+001EDB EF                MOV      A,R7
+001EDC 6405              XRL      A,#05H
+001EDE 7003              JNZ      ?C0057?KB_PROCESS
+001EE0         ?C0058?KB_PROCESS:
+  317: 		||(g_variable.key_combination_step == CAMBINATION_KEY_COMPLETE)
+  318: 		|| (g_variable.key_combination_step == CAMBINATION_KEY_RELEASE)
+  319: 		)
+  320: 			kb_motion();
+001EE0 0226AF            LJMP     kb_motion
+001EE3         ?C0057?KB_PROCESS:
+  321: 		else
+  322: 		{
+  323: 			if(g_variable.key_combination_step == CAMBINATION_KEY_PRESS)
+001EE3 904CF4            MOV      DPTR,#g_variable+035H
+001EE6 E0                MOVX     A,@DPTR
+001EE7 6401              XRL      A,#01H
+001EE9 700E              JNZ      ?C0060?KB_PROCESS
+  324: 			{
+  325: 				kb_send_combination_key(g_variable.key_combination_ctrl,0);
+001EEB A3                INC      DPTR
+001EEC E0                MOVX     A,@DPTR
+001EED FF                MOV      R7,A
+001EEE E4                CLR      A
+001EEF FD                MOV      R5,A
+001EF0 F157              ACALL    _kb_send_combination_key
+  326: 				g_variable.key_combination_step = CAMBINATION_KEY_HOLD;
+001EF2 904CF4            MOV      DPTR,#g_variable+035H
+001EF5 7402              MOV      A,#02H
+001EF7 F0                MOVX     @DPTR,A
+  327: 			}
+001EF8 22                RET      
+001EF9         ?C0060?KB_PROCESS:
+  328: 			else if(g_variable.key_combination_step == CAMBINATION_KEY_HOLD)
+001EF9 904CF4            MOV      DPTR,#g_variable+035H
+001EFC E0                MOVX     A,@DPTR
+001EFD 6402              XRL      A,#02H
+001EFF 700B              JNZ      ?C0062?KB_PROCESS
+  329: 			{	
+  330: 				g_variable.key_combination_step = CAMBINATION_KEY_COMPLETE;
+001F01 7403              MOV      A,#03H
+001F03 F0                MOVX     @DPTR,A
+  331: 				kb_send_combination_key(g_variable.key_combination_ctrl,g_variable.key_combination_keyvalue);
+001F04 A3                INC      DPTR
+001F05 E0                MOVX     A,@DPTR
+001F06 FF                MOV      R7,A
+001F07 A3                INC      DPTR
+001F08 E0                MOVX     A,@DPTR
+001F09 FD                MOV      R5,A
+001F0A 804B              SJMP     _kb_send_combination_key
+  332: 			}
+001F0C         ?C0062?KB_PROCESS:
+  333: 			else if(g_variable.key_combination_step == CAMBINATION_KEY_WAIT_RELEASE)
+001F0C 904CF4            MOV      DPTR,#g_variable+035H
+001F0F E0                MOVX     A,@DPTR
+001F10 6404              XRL      A,#04H
+001F12 7026              JNZ      ?C0064?KB_PROCESS
+  334: 			{
+  335: 				g_variable.key_combination_keyvalue = 0;
+001F14 904CF6            MOV      DPTR,#g_variable+037H
+001F17 F0                MOVX     @DPTR,A
+  336: 				kb_send_combination_key(g_variable.key_combination_ctrl,g_variable.key_combination_keyvalue);
+001F18 904CF5            MOV      DPTR,#g_variable+036H
+001F1B E0                MOVX     A,@DPTR
+001F1C FF                MOV      R7,A
+001F1D E4                CLR      A
+001F1E FD                MOV      R5,A
+001F1F F157              ACALL    _kb_send_combination_key
+  337: 				g_variable.key_combination_ctrl = 0;
+001F21 E4                CLR      A
+001F22 904CF5            MOV      DPTR,#g_variable+036H
+001F25 F0                MOVX     @DPTR,A
+  338: 				if(!g_variable.one_key_press_wait_release_timer)
+001F26 904CF8            MOV      DPTR,#g_variable+039H
+001F29 E0                MOVX     A,@DPTR
+001F2A 7007              JNZ      ?C0065?KB_PROCESS
+  339: 					g_variable.key_combination_step = CAMBINATION_KEY_NULL;
+001F2C 904CF4            MOV      DPTR,#g_variable+035H
+001F2F 7406              MOV      A,#06H
+001F31 F0                MOVX     @DPTR,A
+001F32 22                RET      
+001F33         ?C0065?KB_PROCESS:
+  340: 				else
+  341: 					g_variable.key_combination_step = CAMBINATION_KEY_RELEASE;
+001F33 904CF4            MOV      DPTR,#g_variable+035H
+001F36 7405              MOV      A,#05H
+001F38 F0                MOVX     @DPTR,A
+  342: 			}
+001F39 22                RET      
+001F3A         ?C0064?KB_PROCESS:
+  343: 			else if(g_variable.key_combination_step == CAMBINATION_KEY_NULL)
+001F3A 904CF4            MOV      DPTR,#g_variable+035H
+001F3D E0                MOVX     A,@DPTR
+001F3E 6406              XRL      A,#06H
+001F40 7014              JNZ      ?C0069?KB_PROCESS
+  344: 			{
+  345: 				g_variable.key_combination_keyvalue = 0;
+001F42 904CF6            MOV      DPTR,#g_variable+037H
+001F45 F0                MOVX     @DPTR,A
+  346: 				g_variable.key_combination_ctrl = 0;
+001F46 904CF5            MOV      DPTR,#g_variable+036H
+001F49 F0                MOVX     @DPTR,A
+  347: 				kb_send_combination_key(g_variable.key_combination_ctrl,g_variable.key_combination_keyvalue);
+001F4A A3                INC      DPTR
+001F4B E0                MOVX     A,@DPTR
+001F4C FD                MOV      R5,A
+001F4D E4                CLR      A
+001F4E FF                MOV      R7,A
+001F4F F157              ACALL    _kb_send_combination_key
+  348: 				g_variable.key_combination_step = CAMBINATION_KEY_FREE;
+001F51 E4                CLR      A
+001F52 904CF4            MOV      DPTR,#g_variable+035H
+001F55 F0                MOVX     @DPTR,A
+  349: 			}
+  350: 		}
+  351: 	}
+  352: }
+001F56         ?C0069?KB_PROCESS:
+001F56 22                RET      
+----- FUNCTION kb_need_keyscan (END) -------
+
+
+----- FUNCTION _kb_send_combination_key (BEGIN) -----
+ FILE: 'kb_process.c'
+  198: void kb_send_combination_key(byte ctrl_value,byte key_value)
+  199: {
+001F57 904EF8            MOV      DPTR,#ctrl_value
+001F5A EF                MOV      A,R7
+001F5B F0                MOVX     @DPTR,A
+001F5C A3                INC      DPTR
+001F5D ED                MOV      A,R5
+001F5E F0                MOVX     @DPTR,A
+  200: 	xmemclear(hidBuff,9);
+  201: 	hidBuff[0] = HID_REPORTID_1;
+001F5F 7B01              MOV      R3,#01H
+001F61 7A48              MOV      R2,#HIGH hidBuff
+001F63 7900              MOV      R1,#LOW hidBuff
+001F65 7D09              MOV      R5,#09H
+001F67 7C00              MOV      R4,#00H
+001F69 120DFA            LCALL    _xmemclear
+  202: 	hidBuff[1] |= ctrl_value;
+001F6C 904800            MOV      DPTR,#hidBuff
+001F6F 7401              MOV      A,#01H
+001F71 F0                MOVX     @DPTR,A
+  203: 	hidBuff[3] = key_value; 
+001F72 A3                INC      DPTR
+001F73 E0                MOVX     A,@DPTR
+001F74 FF                MOV      R7,A
+001F75 904EF8            MOV      DPTR,#ctrl_value
+001F78 E0                MOVX     A,@DPTR
+001F79 FE                MOV      R6,A
+001F7A EF                MOV      A,R7
+001F7B 4E                ORL      A,R6
+001F7C 904801            MOV      DPTR,#hidBuff+01H
+001F7F F0                MOVX     @DPTR,A
+  204: 	IPC_TxHidData(hidBuff, 9);
+001F80 904EF9            MOV      DPTR,#key_value
+001F83 E0                MOVX     A,@DPTR
+001F84 904803            MOV      DPTR,#hidBuff+03H
+001F87 F0                MOVX     @DPTR,A
+  205: }
+001F88 7B01              MOV      R3,#01H
+001F8A 7A48              MOV      R2,#HIGH hidBuff
+001F8C 7900              MOV      R1,#LOW hidBuff
+001F8E 7D09              MOV      R5,#09H
+001F90 020EDA            LJMP     _IPC_TxHidData
+----- FUNCTION _kb_send_combination_key (END) -------
+
+
+----- FUNCTION kb_cb_init (BEGIN) -----
+ FILE: 'sys.c'
+  807: static void kb_cb_init()
+  808: {
+  809: 	IPC_Initialize(&cb);
+  810: }
+001F93 7B01              MOV      R3,#01H
+001F95 7A4E              MOV      R2,#HIGH cb
+001F97 7956              MOV      R1,#LOW cb
+;----                  JMP      _IPC_Initialize
+----- FUNCTION kb_cb_init (END) -------
+
+
+----- FUNCTION _IPC_Initialize (BEGIN) -----
+;---- Variable 'cb' assigned to Register 'R1/R2/R3' ----
+001F99 7868              MOV      R0,#LOW ipcCb
+001F9B 7C4E              MOV      R4,#HIGH ipcCb
+001F9D 7D01              MOV      R5,#01H
+001F9F 7E00              MOV      R6,#00H
+001FA1 7F12              MOV      R7,#012H
+001FA3 020390            LJMP     ?C?COPY
+----- FUNCTION _IPC_Initialize (END) -------
+
+
+----- FUNCTION _GPIO_GetInputStatus (BEGIN) -----
+;---- Variable 'gpio_num' assigned to Register 'R7' ----
+001FA6 7B01              MOV      R3,#01H
+001FA8 7A81              MOV      R2,#081H
+001FAA 791C              MOV      R1,#01CH
+;----                  JMP      _gpioGetBit
+----- FUNCTION _GPIO_GetInputStatus (END) -------
+
+
+----- FUNCTION _gpioGetBit (BEGIN) -----
+;---- Variable 'gpio_num' assigned to Register 'R5' ----
+001FAC AD07              MOV      R5,AR7
+;---- Variable 'reg_base' assigned to Register 'R1/R2/R3' ----
+001FAE E4                CLR      A
+001FAF 904F08            MOV      DPTR,#queue
+001FB2 F0                MOVX     @DPTR,A
+;---- Variable 'group' assigned to Register 'R6' ----
+001FB3 FE                MOV      R6,A
+001FB4 EF                MOV      A,R7
+001FB5 5407              ANL      A,#07H
+001FB7 F0                MOVX     @DPTR,A
+001FB8 EF                MOV      A,R7
+001FB9 13                RRC      A
+001FBA 13                RRC      A
+001FBB 13                RRC      A
+001FBC 5403              ANL      A,#03H
+001FBE FE                MOV      R6,A
+001FBF F582              MOV      DPL,A
+001FC1 758300            MOV      DPH,#00H
+001FC4 1203CF            LCALL    ?C?CLDOPTR
+001FC7 FD                MOV      R5,A
+001FC8 33                RLC      A
+001FC9 95E0              SUBB     A,ACC
+001FCB FC                MOV      R4,A
+001FCC 904F08            MOV      DPTR,#queue
+001FCF E0                MOVX     A,@DPTR
+001FD0 FF                MOV      R7,A
+001FD1 7401              MOV      A,#01H
+001FD3 7E00              MOV      R6,#00H
+001FD5 A807              MOV      R0,AR7
+001FD7 08                INC      R0
+001FD8 8005              SJMP     ?C0035?GPIO
+001FDA         ?C0034?GPIO:
+001FDA C3                CLR      C
+001FDB 33                RLC      A
+001FDC CE                XCH      A,R6
+001FDD 33                RLC      A
+001FDE CE                XCH      A,R6
+001FDF         ?C0035?GPIO:
+001FDF D8F9              DJNZ     R0,?C0034?GPIO
+001FE1 FF                MOV      R7,A
+001FE2 EE                MOV      A,R6
+001FE3 5C                ANL      A,R4
+001FE4 FE                MOV      R6,A
+001FE5 EF                MOV      A,R7
+001FE6 5D                ANL      A,R5
+001FE7 4E                ORL      A,R6
+001FE8 24FF              ADD      A,#0FFH
+001FEA 22                RET      
+----- FUNCTION _gpioGetBit (END) -------
+
+
+----- FUNCTION main (BEGIN) -----
+ FILE: 'ram.c'
+    5: void main()
+    6: {
+    7: 	YC_System_Main();
+    8: }
+001FEB A13C              AJMP     YC_System_Main
+----- FUNCTION main (END) -------
+
+
+----- FUNCTION YC_g24_mode_discovery (BEGIN) -----
+ FILE: 'bluetooth.c'
+  141: byte YC_g24_mode_discovery()
+  142: {
+  143: 	if (g_variable.last_device_num == 0xfe ||g_variable.last_device_num == 0x00)
+  144: 	{
+001FED 904CC0            MOV      DPTR,#g_variable+01H
+001FF0 E0                MOVX     A,@DPTR
+001FF1 FF                MOV      R7,A
+001FF2 64FE              XRL      A,#0FEH
+001FF4 6003              JZ       ?C0029?BLUETOOTH
+001FF6 EF                MOV      A,R7
+001FF7 7008              JNZ      ?C0028?BLUETOOTH
+001FF9         ?C0029?BLUETOOTH:
+  145: 		IPC_TxControlCmd(IPC_CMD_STOP_24G);
+  146: 		return 1;
+001FF9 7F22              MOV      R7,#022H
+001FFB 12149D            LCALL    _IPC_TxControlCmd
+  147: 	}
+001FFE 7F01              MOV      R7,#01H
+002000 22                RET      
+  148: 	return 0;
+002001         ?C0028?BLUETOOTH:
+  149: }
+002001 7F00              MOV      R7,#00H
+  150: 
+002003 22                RET      
+----- FUNCTION YC_g24_mode_discovery (END) -------
+
+
+----- FUNCTION YC_start_reconnect (BEGIN) -----
+ FILE: 'bluetooth.c'
+  153: void YC_start_reconnect()
+  154: {
+  155: 	power_on_flag = 2;
+  156: 	IIC_Read(EEPROM_RECON_INFO_BASE ,sizeof(BD_KEY_RECORD)*3, (byte *)bd_key_record_list);
+002004 904DEB            MOV      DPTR,#power_on_flag
+002007 7402              MOV      A,#02H
+002009 F0                MOVX     @DPTR,A
+  157: 	Delay1ms(10);
+00200A 7B01              MOV      R3,#01H
+00200C 7A4D              MOV      R2,#HIGH bd_key_record_list
+00200E 79EE              MOV      R1,#LOW bd_key_record_list
+002010 7D5D              MOV      R5,#05DH
+002012 7C00              MOV      R4,#00H
+002014 7F60              MOV      R7,#060H
+002016 7E7F              MOV      R6,#07FH
+002018 11CA              ACALL    _IIC_Read
+  158: 	IIC_Read(EEPROM_RECON_INFO_BASE_6+2,4 , (byte *)m_24g_addr);
+00201A 7F0A              MOV      R7,#0AH
+00201C 121798            LCALL    _Delay1ms
+  159: 	Delay1ms(10);
+00201F 7B01              MOV      R3,#01H
+002021 7A4C              MOV      R2,#HIGH m_24g_addr
+002023 7900              MOV      R1,#LOW m_24g_addr
+002025 7D04              MOV      R5,#04H
+002027 7C00              MOV      R4,#00H
+002029 7F52              MOV      R7,#052H
+00202B 7E7F              MOV      R6,#07FH
+00202D 11CA              ACALL    _IIC_Read
+  160: 	IIC_Read(EEPROM_RECON_INFO_G24_FN_LOCK ,1 ,(byte *)&fn_lock_flag);
+00202F 7F0A              MOV      R7,#0AH
+002031 121798            LCALL    _Delay1ms
+  161: 	Delay1ms(10);
+002034 7B01              MOV      R3,#01H
+002036 7A4D              MOV      R2,#HIGH fn_lock_flag
+002038 79E7              MOV      R1,#LOW fn_lock_flag
+00203A 7D01              MOV      R5,#01H
+00203C 7C00              MOV      R4,#00H
+00203E 7F56              MOV      R7,#056H
+002040 7E7F              MOV      R6,#07FH
+002042 11CA              ACALL    _IIC_Read
+  162: 	IIC_Read(EEPROM_RECON_INFO_G24_SYTEM_MODE ,1 ,(byte *)&g_variable.system_mode);
+002044 7F0A              MOV      R7,#0AH
+002046 121798            LCALL    _Delay1ms
+  163: 	Delay1ms(10);
+002049 7B01              MOV      R3,#01H
+00204B 7A4C              MOV      R2,#HIGH g_variable+02H
+00204D 79C1              MOV      R1,#LOW g_variable+02H
+00204F 7D01              MOV      R5,#01H
+002051 7C00              MOV      R4,#00H
+002053 7F57              MOV      R7,#057H
+002055 7E7F              MOV      R6,#07FH
+002057 11CA              ACALL    _IIC_Read
+  164: 	
+002059 7F0A              MOV      R7,#0AH
+00205B 121798            LCALL    _Delay1ms
+  165: 	if (g_variable.current_device_num <= 3 && g_variable.current_device_num >= 1)
+00205E 904CC3            MOV      DPTR,#g_variable+04H
+002061 E0                MOVX     A,@DPTR
+002062 FF                MOV      R7,A
+002063 7E00              MOV      R6,#00H
+002065 D3                SETB     C
+002066 9403              SUBB     A,#03H
+002068 7480              MOV      A,#080H
+00206A 9480              SUBB     A,#080H
+00206C 5038              JNC      ?C0031?BLUETOOTH
+00206E C3                CLR      C
+00206F EF                MOV      A,R7
+002070 9401              SUBB     A,#01H
+002072 7480              MOV      A,#080H
+002074 9480              SUBB     A,#080H
+002076 402E              JC       ?C0031?BLUETOOTH
+  166: 	{
+  167: 		g_variable.system_mode = bd_key_record_list[g_variable.current_device_num - 1].system_mode;
+002078 E0                MOVX     A,@DPTR
+002079 75F01F            MOV      B,#01FH
+00207C A4                MUL      AB
+00207D 24EC              ADD      A,#LOW bd_key_record_list-02H
+00207F F582              MOV      DPL,A
+002081 E4                CLR      A
+002082 344D              ADDC     A,#HIGH bd_key_record_list-02H
+002084 F583              MOV      DPH,A
+002086 E0                MOVX     A,@DPTR
+002087 904CC1            MOV      DPTR,#g_variable+02H
+00208A F0                MOVX     @DPTR,A
+  168: 		fn_lock_flag = bd_key_record_list[g_variable.current_device_num - 1].fn_lock; 
+00208B 904CC3            MOV      DPTR,#g_variable+04H
+00208E E0                MOVX     A,@DPTR
+00208F 75F01F            MOV      B,#01FH
+002092 A4                MUL      AB
+002093 24ED              ADD      A,#LOW bd_key_record_list-01H
+002095 F582              MOV      DPL,A
+002097 E4                CLR      A
+002098 344D              ADDC     A,#HIGH bd_key_record_list-01H
+00209A F583              MOV      DPH,A
+00209C E0                MOVX     A,@DPTR
+00209D 904DE7            MOV      DPTR,#fn_lock_flag
+0020A0 F0                MOVX     @DPTR,A
+  169: 		YC_key_action_handle(g_variable.current_device_num);
+0020A1 1212C6            LCALL    _YC_key_action_handle
+  170: 	}
+0020A4 8005              SJMP     ?C0032?BLUETOOTH
+0020A6         ?C0031?BLUETOOTH:
+  171: 	else	
+  172: 	{	
+  173: 		YC_key_action_handle(KEY_START_24G);
+0020A6 7F08              MOV      R7,#08H
+0020A8 1212C6            LCALL    _YC_key_action_handle
+  174: 	}
+0020AB         ?C0032?BLUETOOTH:
+  175: 	if(fn_lock_flag > 1)
+0020AB 904DE7            MOV      DPTR,#fn_lock_flag
+0020AE E0                MOVX     A,@DPTR
+0020AF D3                SETB     C
+0020B0 9401              SUBB     A,#01H
+0020B2 7480              MOV      A,#080H
+0020B4 9480              SUBB     A,#080H
+0020B6 4002              JC       ?C0033?BLUETOOTH
+  176: 		fn_lock_flag = 0;
+0020B8 E4                CLR      A
+0020B9 F0                MOVX     @DPTR,A
+0020BA         ?C0033?BLUETOOTH:
+  177: 	if(g_variable.system_mode > OSMODE_IOS)
+0020BA 904CC1            MOV      DPTR,#g_variable+02H
+0020BD E0                MOVX     A,@DPTR
+0020BE D3                SETB     C
+0020BF 9402              SUBB     A,#02H
+0020C1 7480              MOV      A,#080H
+0020C3 9480              SUBB     A,#080H
+0020C5 4002              JC       ?C0035?BLUETOOTH
+  178: 	{
+  179: 		g_variable.system_mode = OSMODE_WINDOWS;
+0020C7 E4                CLR      A
+0020C8 F0                MOVX     @DPTR,A
+  180: 	}	
+  181: }
+0020C9         ?C0035?BLUETOOTH:
+0020C9 22                RET      
+----- FUNCTION YC_start_reconnect (END) -------
+
+
+----- FUNCTION _IIC_Read (BEGIN) -----
+0020CA 904ECF            MOV      DPTR,#len
+0020CD EC                MOV      A,R4
+0020CE F0                MOVX     @DPTR,A
+0020CF A3                INC      DPTR
+0020D0 ED                MOV      A,R5
+0020D1 F0                MOVX     @DPTR,A
+0020D2 A3                INC      DPTR
+0020D3 EB                MOV      A,R3
+0020D4 F0                MOVX     @DPTR,A
+0020D5 A3                INC      DPTR
+0020D6 EA                MOV      A,R2
+0020D7 F0                MOVX     @DPTR,A
+0020D8 A3                INC      DPTR
+0020D9 E9                MOV      A,R1
+0020DA F0                MOVX     @DPTR,A
+;---- Variable 'addr' assigned to Register 'R6/R7' ----
+;---- Variable 'mem_src' assigned to Register 'R6/R7' ----
+0020DB 908098            MOV      DPTR,#08098H
+0020DE 7404              MOV      A,#04H
+0020E0 F0                MOVX     @DPTR,A
+0020E1 A3                INC      DPTR
+0020E2 E4                CLR      A
+0020E3 F0                MOVX     @DPTR,A
+0020E4 900CAF            MOV      DPTR,#YC_IICDTbuf
+0020E7 74A0              MOV      A,#0A0H
+0020E9 F0                MOVX     @DPTR,A
+0020EA A3                INC      DPTR
+0020EB EE                MOV      A,R6
+0020EC F0                MOVX     @DPTR,A
+0020ED A3                INC      DPTR
+0020EE EF                MOV      A,R7
+0020EF F0                MOVX     @DPTR,A
+0020F0 900CB2            MOV      DPTR,#YC_IICDTbuf+03H
+0020F3 74A1              MOV      A,#0A1H
+0020F5 F0                MOVX     @DPTR,A
+0020F6 7A0C              MOV      R2,#HIGH YC_IICDTbuf
+0020F8 79AF              MOV      R1,#LOW YC_IICDTbuf
+0020FA 7E0C              MOV      R6,#HIGH YC_IICDTbuf
+0020FC 7FAF              MOV      R7,#LOW YC_IICDTbuf
+0020FE 74AF              MOV      A,#LOW YC_IICDTbuf
+002100 FC                MOV      R4,A
+002101 740C              MOV      A,#HIGH YC_IICDTbuf
+002103 FF                MOV      R7,A
+002104 EC                MOV      A,R4
+002105 FE                MOV      R6,A
+002106 EF                MOV      A,R7
+002107 90809A            MOV      DPTR,#0809AH
+00210A EE                MOV      A,R6
+00210B F0                MOVX     @DPTR,A
+00210C A3                INC      DPTR
+00210D EF                MOV      A,R7
+00210E F0                MOVX     @DPTR,A
+00210F 904ECF            MOV      DPTR,#len
+002112 E0                MOVX     A,@DPTR
+002113 FC                MOV      R4,A
+002114 A3                INC      DPTR
+002115 E0                MOVX     A,@DPTR
+002116 FA                MOV      R2,A
+002117 EC                MOV      A,R4
+002118 FF                MOV      R7,A
+002119 EA                MOV      A,R2
+00211A FE                MOV      R6,A
+00211B EF                MOV      A,R7
+00211C 90809E            MOV      DPTR,#0809EH
+00211F EE                MOV      A,R6
+002120 F0                MOVX     @DPTR,A
+002121 A3                INC      DPTR
+002122 EF                MOV      A,R7
+002123 F0                MOVX     @DPTR,A
+002124 7A0B              MOV      R2,#HIGH IIC_TempBuff
+002126 7983              MOV      R1,#LOW IIC_TempBuff
+002128 7E0B              MOV      R6,#HIGH IIC_TempBuff
+00212A 7F83              MOV      R7,#LOW IIC_TempBuff
+00212C 7483              MOV      A,#LOW IIC_TempBuff
+00212E FC                MOV      R4,A
+00212F 740B              MOV      A,#HIGH IIC_TempBuff
+002131 FF                MOV      R7,A
+002132 EC                MOV      A,R4
+002133 FE                MOV      R6,A
+002134 EF                MOV      A,R7
+002135 90809C            MOV      DPTR,#0809CH
+002138 EE                MOV      A,R6
+002139 F0                MOVX     @DPTR,A
+00213A A3                INC      DPTR
+00213B EF                MOV      A,R7
+00213C F0                MOVX     @DPTR,A
+00213D 908090            MOV      DPTR,#08090H
+002140 7402              MOV      A,#02H
+002142 F0                MOVX     @DPTR,A
+002143 90809C            MOV      DPTR,#0809CH
+002146 A3                INC      DPTR
+002147 E0                MOVX     A,@DPTR
+002148 20E707            JB       ACC.7,?C0004?IIC
+00214B 908090            MOV      DPTR,#08090H
+00214E E0                MOVX     A,@DPTR
+00214F 4401              ORL      A,#01H
+002151 F0                MOVX     @DPTR,A
+002152         ?C0004?IIC:
+002152 908006            MOV      DPTR,#08006H
+002155 E0                MOVX     A,@DPTR
+002156 4404              ORL      A,#04H
+002158 F0                MOVX     @DPTR,A
+002159 317A              ACALL    IIcWaitDone
+00215B 904ED1            MOV      DPTR,#pbuff
+00215E E0                MOVX     A,@DPTR
+00215F A3                INC      DPTR
+002160 E0                MOVX     A,@DPTR
+002161 FA                MOV      R2,A
+002162 A3                INC      DPTR
+002163 E0                MOVX     A,@DPTR
+002164 AE02              MOV      R6,AR2
+002166 FF                MOV      R7,A
+002167 7B01              MOV      R3,#01H
+002169 7A0B              MOV      R2,#HIGH IIC_TempBuff
+00216B 7983              MOV      R1,#LOW IIC_TempBuff
+00216D 904ECF            MOV      DPTR,#len
+002170 E0                MOVX     A,@DPTR
+002171 A3                INC      DPTR
+002172 E0                MOVX     A,@DPTR
+002173 904EC4            MOV      DPTR,#?_xmemcpy?BYTE+05H
+002176 F0                MOVX     @DPTR,A
+002177 020878            LJMP     _xmemcpy
+----- FUNCTION _IIC_Read (END) -------
+
+
+----- FUNCTION IIcWaitDone (BEGIN) -----
+00217A         ?C0001?IIC:
+00217A 90812C            MOV      DPTR,#0812CH
+00217D E0                MOVX     A,@DPTR
+00217E 30E5F9            JNB      ACC.5,?C0001?IIC
+002181 22                RET      
+----- FUNCTION IIcWaitDone (END) -------
+
+
+----- FUNCTION _IIC_write (BEGIN) -----
+002182 904EB2            MOV      DPTR,#addr
+002185 EE                MOV      A,R6
+002186 F0                MOVX     @DPTR,A
+002187 A3                INC      DPTR
+002188 EF                MOV      A,R7
+002189 F0                MOVX     @DPTR,A
+00218A 904EB6            MOV      DPTR,#pbuff
+00218D EB                MOV      A,R3
+00218E F0                MOVX     @DPTR,A
+00218F A3                INC      DPTR
+002190 EA                MOV      A,R2
+002191 F0                MOVX     @DPTR,A
+002192 A3                INC      DPTR
+002193 E9                MOV      A,R1
+002194 F0                MOVX     @DPTR,A
+002195 904EB4            MOV      DPTR,#len
+002198 EC                MOV      A,R4
+002199 F0                MOVX     @DPTR,A
+00219A A3                INC      DPTR
+00219B ED                MOV      A,R5
+00219C F0                MOVX     @DPTR,A
+00219D A3                INC      DPTR
+00219E E0                MOVX     A,@DPTR
+00219F F9                MOV      R1,A
+0021A0 A3                INC      DPTR
+0021A1 E0                MOVX     A,@DPTR
+0021A2 FA                MOV      R2,A
+0021A3 A3                INC      DPTR
+0021A4 E0                MOVX     A,@DPTR
+0021A5 904E9F            MOV      DPTR,#?_dmemcpy?BYTE+03H
+0021A8 C9                XCH      A,R1
+0021A9 F0                MOVX     @DPTR,A
+0021AA A3                INC      DPTR
+0021AB EA                MOV      A,R2
+0021AC F0                MOVX     @DPTR,A
+0021AD A3                INC      DPTR
+0021AE E9                MOV      A,R1
+0021AF F0                MOVX     @DPTR,A
+0021B0 A3                INC      DPTR
+0021B1 EC                MOV      A,R4
+0021B2 F0                MOVX     @DPTR,A
+0021B3 A3                INC      DPTR
+0021B4 ED                MOV      A,R5
+0021B5 F0                MOVX     @DPTR,A
+0021B6 7B01              MOV      R3,#01H
+0021B8 7A0B              MOV      R2,#HIGH IIC_TempBuff+03H
+0021BA 7986              MOV      R1,#LOW IIC_TempBuff+03H
+0021BC 9162              ACALL    _dmemcpy
+0021BE 900B83            MOV      DPTR,#IIC_TempBuff
+0021C1 74A0              MOV      A,#0A0H
+0021C3 F0                MOVX     @DPTR,A
+0021C4 904EB2            MOV      DPTR,#addr
+0021C7 E0                MOVX     A,@DPTR
+0021C8 FF                MOV      R7,A
+0021C9 A3                INC      DPTR
+0021CA E0                MOVX     A,@DPTR
+0021CB 900B84            MOV      DPTR,#IIC_TempBuff+01H
+0021CE CF                XCH      A,R7
+0021CF F0                MOVX     @DPTR,A
+0021D0 A3                INC      DPTR
+0021D1 EF                MOV      A,R7
+0021D2 F0                MOVX     @DPTR,A
+0021D3 904EB5            MOV      DPTR,#len+01H
+0021D6 E0                MOVX     A,@DPTR
+0021D7 2403              ADD      A,#03H
+0021D9 FD                MOV      R5,A
+0021DA 904EB4            MOV      DPTR,#len
+0021DD E0                MOVX     A,@DPTR
+0021DE 3400              ADDC     A,#00H
+0021E0 FC                MOV      R4,A
+0021E1 ED                MOV      A,R5
+0021E2 FA                MOV      R2,A
+0021E3 EC                MOV      A,R4
+0021E4 FF                MOV      R7,A
+0021E5 EA                MOV      A,R2
+0021E6 FE                MOV      R6,A
+0021E7 EF                MOV      A,R7
+0021E8 908098            MOV      DPTR,#08098H
+0021EB EE                MOV      A,R6
+0021EC F0                MOVX     @DPTR,A
+0021ED A3                INC      DPTR
+0021EE EF                MOV      A,R7
+0021EF F0                MOVX     @DPTR,A
+0021F0 7A0B              MOV      R2,#HIGH IIC_TempBuff
+0021F2 7983              MOV      R1,#LOW IIC_TempBuff
+0021F4 7E0B              MOV      R6,#HIGH IIC_TempBuff
+0021F6 7F83              MOV      R7,#LOW IIC_TempBuff
+0021F8 7483              MOV      A,#LOW IIC_TempBuff
+0021FA FC                MOV      R4,A
+0021FB 740B              MOV      A,#HIGH IIC_TempBuff
+0021FD FF                MOV      R7,A
+0021FE EC                MOV      A,R4
+0021FF FE                MOV      R6,A
+002200 EF                MOV      A,R7
+002201 A3                INC      DPTR
+002202 EE                MOV      A,R6
+002203 F0                MOVX     @DPTR,A
+002204 A3                INC      DPTR
+002205 EF                MOV      A,R7
+002206 F0                MOVX     @DPTR,A
+002207 90809E            MOV      DPTR,#0809EH
+00220A E4                CLR      A
+00220B F0                MOVX     @DPTR,A
+00220C A3                INC      DPTR
+00220D F0                MOVX     @DPTR,A
+00220E 908090            MOV      DPTR,#08090H
+002211 04                INC      A
+002212 F0                MOVX     @DPTR,A
+002213 908006            MOV      DPTR,#08006H
+002216 E0                MOVX     A,@DPTR
+002217 4404              ORL      A,#04H
+002219 F0                MOVX     @DPTR,A
+00221A 217A              AJMP     IIcWaitDone
+----- FUNCTION _IIC_write (END) -------
+
+
+----- FUNCTION YC_get_ble_ramdon_lap (BEGIN) -----
+ FILE: 'bluetooth.c'
+  185: void YC_get_ble_ramdon_lap()		
+  186: {
+  187: 	IIC_Read(EEPROM_RECON_INFO_RAMDON_LE_LAP1 ,2 ,(byte *)&g_variable.ble_ramdon_lap1);
+  188: 	g_variable.ble_ramdon_lap1++;
+00221C 7B01              MOV      R3,#01H
+00221E 7A4C              MOV      R2,#HIGH g_variable+033H
+002220 79F2              MOV      R1,#LOW g_variable+033H
+002222 7D02              MOV      R5,#02H
+002224 7C00              MOV      R4,#00H
+002226 7FBE              MOV      R7,#0BEH
+002228 7E7F              MOV      R6,#07FH
+00222A 11CA              ACALL    _IIC_Read
+  189: 	g_variable.ble_ramdon_lap2++;
+00222C 904CF2            MOV      DPTR,#g_variable+033H
+00222F E0                MOVX     A,@DPTR
+002230 04                INC      A
+002231 F0                MOVX     @DPTR,A
+  190: 	m_le_lap[1] = g_variable.ble_ramdon_lap1;
+002232 A3                INC      DPTR
+002233 E0                MOVX     A,@DPTR
+002234 04                INC      A
+002235 F0                MOVX     @DPTR,A
+  191: 	m_le_lap[2] = g_variable.ble_ramdon_lap2;
+002236 904CF2            MOV      DPTR,#g_variable+033H
+002239 E0                MOVX     A,@DPTR
+00223A 9044FA            MOV      DPTR,#m_le_lap+01H
+00223D F0                MOVX     @DPTR,A
+  192: 	m_le_lap[3] = le_lap_temp[0];
+00223E 904CF3            MOV      DPTR,#g_variable+034H
+002241 E0                MOVX     A,@DPTR
+002242 9044FB            MOV      DPTR,#m_le_lap+02H
+002245 F0                MOVX     @DPTR,A
+  193: 	m_le_lap[4] = le_lap_temp[1];
+002246 904DD0            MOV      DPTR,#le_lap_temp
+002249 E0                MOVX     A,@DPTR
+00224A 9044FC            MOV      DPTR,#m_le_lap+03H
+00224D F0                MOVX     @DPTR,A
+  194: 	m_le_lap[5] = le_lap_temp[2];
+00224E 904DD1            MOV      DPTR,#le_lap_temp+01H
+002251 E0                MOVX     A,@DPTR
+002252 9044FD            MOV      DPTR,#m_le_lap+04H
+002255 F0                MOVX     @DPTR,A
+  195: }
+002256 904DD2            MOV      DPTR,#le_lap_temp+02H
+002259 E0                MOVX     A,@DPTR
+00225A 9044FE            MOV      DPTR,#m_le_lap+05H
+00225D F0                MOVX     @DPTR,A
+  196: 
+00225E 22                RET      
+----- FUNCTION YC_get_ble_ramdon_lap (END) -------
+
+
+----- FUNCTION YC_wait_disconnect_timer500ms (BEGIN) -----
+ FILE: 'sys.c'
+  451: void YC_wait_disconnect_timer500ms()
+  452: {
+  453: //before discovery/adv,if current state is connected,wait disconnect done
+  454: 	if (action_timeout!=0)
+00225F 904DEC            MOV      DPTR,#action_timeout
+002262 E0                MOVX     A,@DPTR
+002263 6039              JZ       ?C0089?SYS
+  455: 	{
+  456: 		action_timeout--;
+002265 E0                MOVX     A,@DPTR
+002266 14                DEC      A
+002267 F0                MOVX     @DPTR,A
+  457: 		if(action_timeout == 0)
+002268 E0                MOVX     A,@DPTR
+002269 7033              JNZ      ?C0089?SYS
+  458: 		{
+  459: 			if(g_variable.key_action == KEY_DISCOVERY
+00226B 904CED            MOV      DPTR,#g_variable+02EH
+00226E E0                MOVX     A,@DPTR
+00226F 6405              XRL      A,#05H
+002271 702B              JNZ      ?C0089?SYS
+002273 9047F5            MOV      DPTR,#m_ui_state_map+01H
+002276 E0                MOVX     A,@DPTR
+002277 20E324            JB       ACC.3,?C0089?SYS
+  460: 			&& (m_ui_state_map & 0x0008) != 0x0008)
+  461: 
+  462: 			{
+  463: //				m_lpm_mode = 0;
+  464: 				ble_send_secutiry_request_timer = 0;
+00227A E4                CLR      A
+00227B 904DD4            MOV      DPTR,#ble_send_secutiry_request_timer
+00227E F0                MOVX     @DPTR,A
+  465: 				g_variable.pairing_timeout = BT_PAIRING_TIME_OUT_2MIN;
+00227F 904CE9            MOV      DPTR,#g_variable+02AH
+002282 74F0              MOV      A,#0F0H
+002284 F0                MOVX     @DPTR,A
+  466: 				g_variable.pairing_g24_timeout = 0;
+002285 E4                CLR      A
+002286 904CEE            MOV      DPTR,#g_variable+02FH
+002289 F0                MOVX     @DPTR,A
+  467: 				fast_connect_flag = 0;
+00228A 904E55            MOV      DPTR,#fast_connect_flag
+00228D F0                MOVX     @DPTR,A
+  468: 				ble_fast_connect_flag = 0;
+00228E 904DD3            MOV      DPTR,#ble_fast_connect_flag
+002291 F0                MOVX     @DPTR,A
+  469: 				YC_get_ble_ramdon_lap();
+002292 511C              ACALL    YC_get_ble_ramdon_lap
+  470: 				IPC_TxControlCmd(IPC_CMD_START_ADV);
+002294 7F0D              MOV      R7,#0DH
+002296 12149D            LCALL    _IPC_TxControlCmd
+  471: 				g_variable.key_action = KEY_NONE;
+002299 E4                CLR      A
+00229A 904CED            MOV      DPTR,#g_variable+02EH
+00229D F0                MOVX     @DPTR,A
+  472: 			}
+  473: 		}
+  474: 	}
+  475: 
+  476: }
+00229E         ?C0089?SYS:
+00229E 22                RET      
+----- FUNCTION YC_wait_disconnect_timer500ms (END) -------
+
+
+----- FUNCTION kb_cb_Timer500ms (BEGIN) -----
+ FILE: 'sys.c'
+  670: static void kb_cb_Timer500ms()
+  671: {
+  672: 	LED_timer500ms();	
+  673: 
+00229F 1210E9            LCALL    LED_timer500ms
+  674: 	g_variable.sleepTimer++;
+0022A2 904CE4            MOV      DPTR,#g_variable+025H
+0022A5 E0                MOVX     A,@DPTR
+0022A6 04                INC      A
+0022A7 F0                MOVX     @DPTR,A
+0022A8 7006              JNZ      ?C0172?SYS
+0022AA 904CE3            MOV      DPTR,#g_variable+024H
+0022AD E0                MOVX     A,@DPTR
+0022AE 04                INC      A
+0022AF F0                MOVX     @DPTR,A
+0022B0         ?C0172?SYS:
+  675: 
+  676: 	YC_adc_motion_check_timer500ms();
+0022B0 7102              ACALL    YC_adc_motion_check_timer500ms
+  677: 	YC_connect_timeout_500ms();
+0022B2 7134              ACALL    YC_connect_timeout_500ms
+  678: 	kb_button_press_timer500ms();
+0022B4 1219F0            LCALL    kb_button_press_timer500ms
+  679: 	YC_wait_disconnect_timer500ms();
+0022B7 515F              ACALL    YC_wait_disconnect_timer500ms
+;----                  JMP      YC_pairing_timerout_500ms
+  680: 	YC_pairing_timerout_500ms();
+  681: 	
+  682: /*	
+  683: 	if(g_variable.ble_currentSubState ==  CHANGE_TO_BLE_SUB_PINCODE)
+  684: 	{
+  685: 		g_variable.sleepTimer = 0;				//wait macOS enter pincode
+  686: 	}
+  687: */	
+  688: 	return;
+----- FUNCTION kb_cb_Timer500ms (END) -------
+
+
+----- FUNCTION YC_pairing_timerout_500ms (BEGIN) -----
+ FILE: 'sys.c'
+  479: void YC_pairing_timerout_500ms()
+  480: {
+  481: //pairing timer
+  482: 	if (g_variable.pairing_timeout != 0)
+0022B9 904CE9            MOV      DPTR,#g_variable+02AH
+0022BC E0                MOVX     A,@DPTR
+0022BD 6024              JZ       ?C0090?SYS
+  483: 	{
+  484: 		g_variable.sleepTimer = 0;
+0022BF E4                CLR      A
+0022C0 904CE3            MOV      DPTR,#g_variable+024H
+0022C3 F0                MOVX     @DPTR,A
+0022C4 A3                INC      DPTR
+0022C5 F0                MOVX     @DPTR,A
+  485: 		g_variable.pairing_timeout--;
+0022C6 904CE9            MOV      DPTR,#g_variable+02AH
+0022C9 E0                MOVX     A,@DPTR
+0022CA 14                DEC      A
+0022CB F0                MOVX     @DPTR,A
+  486: 		if (g_variable.pairing_timeout == 0)
+0022CC E0                MOVX     A,@DPTR
+0022CD 7014              JNZ      ?C0090?SYS
+  487: 		{
+  488: 			g_variable.current_device_num = g_variable.temp_device_num;
+0022CF 904CC4            MOV      DPTR,#g_variable+05H
+0022D2 E0                MOVX     A,@DPTR
+0022D3 904CC3            MOV      DPTR,#g_variable+04H
+0022D6 F0                MOVX     @DPTR,A
+  489: 			g_variable.last_device_num = g_variable.current_device_num;
+0022D7 904CC0            MOV      DPTR,#g_variable+01H
+0022DA F0                MOVX     @DPTR,A
+  490: 		
+  491: 			YC_key_action_handle(KEY_STOP_DISCOVERY);
+0022DB 7F0D              MOV      R7,#0DH
+0022DD 1212C6            LCALL    _YC_key_action_handle
+  492: 			System_long_sleep();
+0022E0 12178F            LCALL    System_long_sleep
+  493: 		}
+  494: 	}
+0022E3         ?C0090?SYS:
+  495: 
+  496: 	if (g_variable.pairing_g24_timeout != 0)
+0022E3 904CEE            MOV      DPTR,#g_variable+02FH
+0022E6 E0                MOVX     A,@DPTR
+0022E7 6018              JZ       ?C0094?SYS
+  497: 	{
+  498: 		g_variable.sleepTimer = 0;
+0022E9 E4                CLR      A
+0022EA 904CE3            MOV      DPTR,#g_variable+024H
+0022ED F0                MOVX     @DPTR,A
+0022EE A3                INC      DPTR
+0022EF F0                MOVX     @DPTR,A
+  499: 		g_variable.pairing_g24_timeout--;
+0022F0 904CEE            MOV      DPTR,#g_variable+02FH
+0022F3 E0                MOVX     A,@DPTR
+0022F4 14                DEC      A
+0022F5 F0                MOVX     @DPTR,A
+  500: 		if (g_variable.pairing_g24_timeout == 0)
+0022F6 E0                MOVX     A,@DPTR
+0022F7 7008              JNZ      ?C0094?SYS
+  501: 		{
+  502: //			IPC_TxControlCmd(IPC_CMD_STOP_24G);
+  503: 			Delay1ms(10);
+0022F9 7F0A              MOV      R7,#0AH
+0022FB 121798            LCALL    _Delay1ms
+  504: 			System_long_sleep();
+0022FE 12178F            LCALL    System_long_sleep
+  505: 		}
+  506: 	}
+  507: }
+002301         ?C0094?SYS:
+002301 22                RET      
+----- FUNCTION YC_pairing_timerout_500ms (END) -------
+
+
+----- FUNCTION YC_adc_motion_check_timer500ms (BEGIN) -----
+ FILE: 'adc.c'
+  100: void YC_adc_motion_check_timer500ms()
+  101: {
+  102: #ifdef  ADC_ENABLE
+  103: 	byte i = 0;
+;---- Variable 'i' assigned to Register 'R7' ----
+002302 E4                CLR      A
+002303 FF                MOV      R7,A
+  104: 
+  105: 	if(ksSelMapCurr[i] == 0 && g_variable.battery_motion_check_interval)
+002304 24BC              ADD      A,#LOW ksSelMapCurr
+002306 F582              MOV      DPL,A
+002308 E4                CLR      A
+002309 344D              ADDC     A,#HIGH ksSelMapCurr
+00230B F583              MOV      DPH,A
+00230D E0                MOVX     A,@DPTR
+00230E 7012              JNZ      ?C0024?ADC
+002310 904D06            MOV      DPTR,#g_variable+047H
+002313 E0                MOVX     A,@DPTR
+002314 600C              JZ       ?C0024?ADC
+  106: 	{
+  107: 		g_variable.battery_motion_check_interval--;
+002316 14                DEC      A
+002317 F0                MOVX     @DPTR,A
+  108: 		if (g_variable.battery_motion_check_interval == 0)
+002318 E0                MOVX     A,@DPTR
+002319 7005              JNZ      ?C0022?ADC
+  109: 			g_variable.battery_status = BAT_STATUS_NONE;
+00231B 904CD5            MOV      DPTR,#g_variable+016H
+00231E F0                MOVX     @DPTR,A
+00231F 22                RET      
+002320         ?C0022?ADC:
+  110: 		else
+  111: 			YC_adc_check_timer500ms();
+002320 7123              ACALL    YC_adc_check_timer500ms
+  112: 	}
+  113: 	
+  114: 
+  115: #endif	
+  116: }
+002322         ?C0024?ADC:
+002322 22                RET      
+----- FUNCTION YC_adc_motion_check_timer500ms (END) -------
+
+
+----- FUNCTION YC_adc_check_timer500ms (BEGIN) -----
+ FILE: 'adc.c'
+  118: void YC_adc_check_timer500ms()
+  119: {
+  120: #ifdef  ADC_ENABLE
+  121: 
+  122: 	// adc check timer	
+  123: 	if (g_variable.battery_check_interval)
+002323 904CD3            MOV      DPTR,#g_variable+014H
+002326 E0                MOVX     A,@DPTR
+002327 600A              JZ       ?C0027?ADC
+  124: 	{
+  125: 		g_variable.battery_check_interval--;
+002329 14                DEC      A
+00232A F0                MOVX     @DPTR,A
+  126: 		if (g_variable.battery_check_interval == 0)
+00232B E0                MOVX     A,@DPTR
+00232C 7005              JNZ      ?C0027?ADC
+  127: 		{
+  128: 			g_variable.battery_check_interval = BATTERY_CHECK_INTERVAL;
+00232E 7405              MOV      A,#05H
+002330 F0                MOVX     @DPTR,A
+  129: 			YC_adc_check();
+002331 91A6              ACALL    YC_adc_check
+  130: 		}
+  131: 	}
+  132: #endif	
+  133: }
+002333         ?C0027?ADC:
+002333 22                RET      
+----- FUNCTION YC_adc_check_timer500ms (END) -------
+
+
+----- FUNCTION YC_connect_timeout_500ms (BEGIN) -----
+ FILE: 'sys.c'
+  375: void YC_connect_timeout_500ms()
+  376: {
+  377: 
+  378: 	if(le_send_battery_level_delay_count)
+002334 904DDB            MOV      DPTR,#le_send_battery_level_delay_count
+002337 E0                MOVX     A,@DPTR
+002338 600F              JZ       ?C0067?SYS
+  379: 	{
+  380: 		le_send_battery_level_delay_count--;
+00233A E0                MOVX     A,@DPTR
+00233B 14                DEC      A
+00233C F0                MOVX     @DPTR,A
+  381: 		if(!le_send_battery_level_delay_count)
+00233D E0                MOVX     A,@DPTR
+00233E 7009              JNZ      ?C0067?SYS
+  382: 		{	
+  383: 			m_lpm_mode = 1;
+002340 904131            MOV      DPTR,#m_lpm_mode
+002343 04                INC      A
+002344 F0                MOVX     @DPTR,A
+  384: 			le_send_battery_level_flag = 1;
+002345 904DDA            MOV      DPTR,#le_send_battery_level_flag
+002348 F0                MOVX     @DPTR,A
+  385: 		}
+  386: 	}
+002349         ?C0067?SYS:
+  387: 	
+  388: //system long sleep timer
+  389: 	if (g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTED)
+002349 904CC7            MOV      DPTR,#g_variable+08H
+00234C E0                MOVX     A,@DPTR
+00234D FF                MOV      R7,A
+00234E 6404              XRL      A,#04H
+002350 7053              JNZ      ?C0069?SYS
+  390: 	{
+  391: 		if (g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTED)
+002352 EF                MOV      A,R7
+002353 6404              XRL      A,#04H
+002355 7034              JNZ      ?C0070?SYS
+  392: 		{
+  393: 			if(le_send_battery_level_flag || (g_variable.sleepTimer && !(g_variable.sleepTimer & 0x1f)))		// ble battery l
+>> evel updata each 16 second
+002357 904DDA            MOV      DPTR,#le_send_battery_level_flag
+00235A E0                MOVX     A,@DPTR
+00235B 7010              JNZ      ?C0072?SYS
+00235D 904CE3            MOV      DPTR,#g_variable+024H
+002360 E0                MOVX     A,@DPTR
+002361 FE                MOV      R6,A
+002362 A3                INC      DPTR
+002363 E0                MOVX     A,@DPTR
+002364 FF                MOV      R7,A
+002365 4E                ORL      A,R6
+002366 6023              JZ       ?C0070?SYS
+002368 EF                MOV      A,R7
+002369 541F              ANL      A,#01FH
+00236B 701E              JNZ      ?C0070?SYS
+00236D         ?C0072?SYS:
+  394: 			{
+  395: 				le_send_battery_level_flag = 0;
+00236D E4                CLR      A
+00236E 904DDA            MOV      DPTR,#le_send_battery_level_flag
+002371 F0                MOVX     @DPTR,A
+  396: 				multikey[0] = HID_REPORTID_BATTERY;	
+002372 904E4C            MOV      DPTR,#multikey
+002375 7404              MOV      A,#04H
+002377 F0                MOVX     @DPTR,A
+  397: 				multikey[1] = g_variable.battery_level_percentage;	
+002378 904CF9            MOV      DPTR,#g_variable+03AH
+00237B E0                MOVX     A,@DPTR
+00237C 904E4D            MOV      DPTR,#multikey+01H
+00237F F0                MOVX     @DPTR,A
+  398: 				IPC_TxHidData(multikey, 2);
+002380 7B01              MOV      R3,#01H
+002382 7A4E              MOV      R2,#HIGH multikey
+002384 794C              MOV      R1,#LOW multikey
+002386 7D02              MOV      R5,#02H
+002388 120EDA            LCALL    _IPC_TxHidData
+  399: 			}
+  400: 		}
+00238B         ?C0070?SYS:
+  401: 		if (g_variable.sleepTimer == STANDBY_TIMER_120MIN) 
+00238B 904CE3            MOV      DPTR,#g_variable+024H
+00238E E0                MOVX     A,@DPTR
+00238F 6438              XRL      A,#038H
+002391 7004              JNZ      ?C0171?SYS
+002393 A3                INC      DPTR
+002394 E0                MOVX     A,@DPTR
+002395 6440              XRL      A,#040H
+002397         ?C0171?SYS:
+002397 6002              JZ       $ + 4H
+002399 8132              AJMP     ?C0085?SYS
+  402: 		{
+  403: 			YC_disconnect_all_link();
+00239B 1219C1            LCALL    YC_disconnect_all_link
+  404: 			g_variable.lockLpm = 1;
+00239E 904CEC            MOV      DPTR,#g_variable+02DH
+0023A1 7401              MOV      A,#01H
+0023A3 F0                MOVX     @DPTR,A
+  405: 		}
+  406: 	}
+0023A4 22                RET      
+0023A5         ?C0069?SYS:
+  407: 	else if(g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED)
+0023A5 904CC5            MOV      DPTR,#g_variable+06H
+0023A8 E0                MOVX     A,@DPTR
+0023A9 6403              XRL      A,#03H
+0023AB 704D              JNZ      ?C0075?SYS
+  408: 	{
+  409: 		if((g_variable.sleepTimer == 10) && m_24g_led_flag)
+0023AD 904CE3            MOV      DPTR,#g_variable+024H
+0023B0 E0                MOVX     A,@DPTR
+0023B1 FE                MOV      R6,A
+0023B2 A3                INC      DPTR
+0023B3 E0                MOVX     A,@DPTR
+0023B4 FF                MOV      R7,A
+0023B5 640A              XRL      A,#0AH
+0023B7 4E                ORL      A,R6
+0023B8 7008              JNZ      ?C0076?SYS
+0023BA 904D46            MOV      DPTR,#m_24g_led_flag
+0023BD E0                MOVX     A,@DPTR
+0023BE 6002              JZ       ?C0076?SYS
+  410: 		{
+  411: 			m_24g_led_flag = 0;
+0023C0 E4                CLR      A
+0023C1 F0                MOVX     @DPTR,A
+  412: 		}	
+0023C2         ?C0076?SYS:
+  413: 	
+  414: #ifdef PC_SLEEP_STATUS_GET	
+  415: 		if((g_variable.sleepTimer & 0x1f) == 0x10)	// search dongle each 8s
+0023C2 EF                MOV      A,R7
+0023C3 541F              ANL      A,#01FH
+0023C5 6410              XRL      A,#010H
+0023C7 7020              JNZ      ?C0077?SYS
+  416: 		{
+  417: 			xmemclear(hidBuff,9);
+0023C9 7B01              MOV      R3,#01H
+0023CB 7A48              MOV      R2,#HIGH hidBuff
+0023CD 7900              MOV      R1,#LOW hidBuff
+0023CF 7D09              MOV      R5,#09H
+0023D1 FC                MOV      R4,A
+0023D2 120DFA            LCALL    _xmemclear
+  418: 
+  419: 			mult_key_status = 0;
+0023D5 E4                CLR      A
+0023D6 904E4B            MOV      DPTR,#mult_key_status
+0023D9 F0                MOVX     @DPTR,A
+  420: 			hidBuff[0] = HID_REPORTID_1;		// standard key send
+0023DA 904800            MOV      DPTR,#hidBuff
+0023DD 04                INC      A
+0023DE F0                MOVX     @DPTR,A
+  421: 			IPC_TxHidData(hidBuff, 9);
+0023DF FB                MOV      R3,A
+0023E0 7A48              MOV      R2,#HIGH hidBuff
+0023E2 7900              MOV      R1,#LOW hidBuff
+0023E4 7D09              MOV      R5,#09H
+0023E6 120EDA            LCALL    _IPC_TxHidData
+  422: 		}
+0023E9         ?C0077?SYS:
+  423: #endif	
+  424: 		if (g_variable.sleepTimer >= STANDBY_TIMER_10MIN)
+0023E9 C3                CLR      C
+0023EA 904CE4            MOV      DPTR,#g_variable+025H
+0023ED E0                MOVX     A,@DPTR
+0023EE 94B0              SUBB     A,#0B0H
+0023F0 904CE3            MOV      DPTR,#g_variable+024H
+0023F3 E0                MOVX     A,@DPTR
+0023F4 9404              SUBB     A,#04H
+0023F6 403A              JC       ?C0085?SYS
+  425: 		{
+  426: 			System_G24_long_lpm();
+0023F8 8039              SJMP     System_G24_long_lpm
+  427: 		}
+  428: 	}
+0023FA         ?C0075?SYS:
+  429: 	else if(g_variable.g24_currentState == CHANGE_TO_24G_PAIRING)
+0023FA 904CC5            MOV      DPTR,#g_variable+06H
+0023FD E0                MOVX     A,@DPTR
+0023FE 6401              XRL      A,#01H
+002400 7011              JNZ      ?C0080?SYS
+  430: 	{
+  431: 		if (g_variable.sleepTimer >= BT_PAIRING_TIME_OUT_1MIN)
+002402 C3                CLR      C
+002403 904CE4            MOV      DPTR,#g_variable+025H
+002406 E0                MOVX     A,@DPTR
+002407 9478              SUBB     A,#078H
+002409 904CE3            MOV      DPTR,#g_variable+024H
+00240C E0                MOVX     A,@DPTR
+00240D 9400              SUBB     A,#00H
+00240F 4021              JC       ?C0085?SYS
+  432: 		{
+  433: 			System_G24_long_lpm();
+002411 8020              SJMP     System_G24_long_lpm
+  434: 		}
+  435: 	}
+002413         ?C0080?SYS:
+  436: 	else
+  437: 	{
+  438: 		if (g_variable.sleepTimer >= RECONNECT_TIMER_10S)
+002413 C3                CLR      C
+002414 904CE4            MOV      DPTR,#g_variable+025H
+002417 E0                MOVX     A,@DPTR
+002418 9414              SUBB     A,#014H
+00241A 904CE3            MOV      DPTR,#g_variable+024H
+00241D E0                MOVX     A,@DPTR
+00241E 9400              SUBB     A,#00H
+002420 4010              JC       ?C0085?SYS
+  439: 		{
+  440: 			if(ble_reconnect_flag)
+002422 904DE5            MOV      DPTR,#ble_reconnect_flag
+002425 E0                MOVX     A,@DPTR
+002426 6007              JZ       ?C0084?SYS
+  441: 			{
+  442: 				ble_reconnect_flag = 0;
+002428 E4                CLR      A
+002429 F0                MOVX     @DPTR,A
+  443: 				IPC_TxControlCmd(IPC_CMD_STOP_ADV);
+00242A 7F0E              MOV      R7,#0EH
+00242C 12149D            LCALL    _IPC_TxControlCmd
+  444: 			}
+00242F         ?C0084?SYS:
+  445: 			System_long_sleep();
+00242F 12178F            LCALL    System_long_sleep
+  446: 		}
+  447: 	}
+  448: }
+002432         ?C0085?SYS:
+002432 22                RET      
+----- FUNCTION YC_connect_timeout_500ms (END) -------
+
+
+----- FUNCTION System_G24_long_lpm (BEGIN) -----
+ FILE: 'sys.c'
+   87: void System_G24_long_lpm()
+   88: {
+   89: 	LED_all_shutdown();
+   90: 	m_24g_pairing_sm = 0xff;
+002433 1217F0            LCALL    LED_all_shutdown
+   91: 	g_variable.g24_long_sleep_flag = 1;
+002436 904BEF            MOV      DPTR,#m_24g_pairing_sm
+002439 74FF              MOV      A,#0FFH
+00243B F0                MOVX     @DPTR,A
+   92: #ifdef PC_SLEEP_STATUS_GET	
+00243C 904CFC            MOV      DPTR,#g_variable+03DH
+00243F 7401              MOV      A,#01H
+002441 F0                MOVX     @DPTR,A
+   93: 	g_variable.sys_numlockled_on_timer = 0;
+002442 E4                CLR      A
+002443 904CE6            MOV      DPTR,#g_variable+027H
+002446 F0                MOVX     @DPTR,A
+   94: 	g_variable.sys_capslockled_on_timer = 0;
+002447 A3                INC      DPTR
+002448 F0                MOVX     @DPTR,A
+   95: 	g_variable.sys_scrolllockled_on_timer = 0;
+002449 A3                INC      DPTR
+00244A F0                MOVX     @DPTR,A
+   96: 	m_caps_num_lock = 0xf0;
+00244B 904CB7            MOV      DPTR,#m_caps_num_lock
+00244E 74F0              MOV      A,#0F0H
+002450 F0                MOVX     @DPTR,A
+   97: 	m_caps_num_lock_last = 0xf0; 
+002451 904DE0            MOV      DPTR,#m_caps_num_lock_last
+002454 F0                MOVX     @DPTR,A
+   98: #endif	
+   99: 	m_24g_enter_hibernate[0]	= 0xff;
+002455 904D40            MOV      DPTR,#m_24g_enter_hibernate
+002458 74FF              MOV      A,#0FFH
+00245A F0                MOVX     @DPTR,A
+  100: 	m_24g_enter_hibernate[1]	= 0xff;
+00245B A3                INC      DPTR
+00245C F0                MOVX     @DPTR,A
+  101: 	m_24g_enter_hibernate[2]	= 0xff;
+00245D A3                INC      DPTR
+00245E F0                MOVX     @DPTR,A
+  102: 	m_24g_enter_hibernate[3]	= 0xff;
+00245F A3                INC      DPTR
+002460 F0                MOVX     @DPTR,A
+  103: }
+002461 22                RET      
+----- FUNCTION System_G24_long_lpm (END) -------
+
+
+----- FUNCTION _dmemcpy (BEGIN) -----
+002462 904E9C            MOV      DPTR,#dest
+002465 EB                MOV      A,R3
+002466 F0                MOVX     @DPTR,A
+002467 A3                INC      DPTR
+002468 EA                MOV      A,R2
+002469 F0                MOVX     @DPTR,A
+00246A A3                INC      DPTR
+00246B E9                MOV      A,R1
+00246C F0                MOVX     @DPTR,A
+00246D         ?C0005?UTILITIES:
+00246D 904EA2            MOV      DPTR,#len
+002470 74FF              MOV      A,#0FFH
+002472 F5F0              MOV      B,A
+002474 120424            LCALL    ?C?ILDIX
+002477 45F0              ORL      A,B
+002479 602A              JZ       ?C0007?UTILITIES
+00247B 904E9F            MOV      DPTR,#src
+00247E E0                MOVX     A,@DPTR
+00247F FB                MOV      R3,A
+002480 A3                INC      DPTR
+002481 E4                CLR      A
+002482 75F001            MOV      B,#01H
+002485 120424            LCALL    ?C?ILDIX
+002488 A9F0              MOV      R1,B
+00248A FA                MOV      R2,A
+00248B 1203B6            LCALL    ?C?CLDPTR
+00248E FF                MOV      R7,A
+00248F 904E9C            MOV      DPTR,#dest
+002492 E0                MOVX     A,@DPTR
+002493 FB                MOV      R3,A
+002494 A3                INC      DPTR
+002495 E4                CLR      A
+002496 75F001            MOV      B,#01H
+002499 120424            LCALL    ?C?ILDIX
+00249C A9F0              MOV      R1,B
+00249E FA                MOV      R2,A
+00249F EF                MOV      A,R7
+0024A0 1203FC            LCALL    ?C?CSTPTR
+0024A3 80C8              SJMP     ?C0005?UTILITIES
+0024A5         ?C0007?UTILITIES:
+0024A5 22                RET      
+----- FUNCTION _dmemcpy (END) -------
+
+
+----- FUNCTION YC_adc_check (BEGIN) -----
+ FILE: 'adc.c'
+   43: void YC_adc_check() 
+   44: {
+   45: #ifdef  ADC_ENABLE
+   46: 	byte i;
+   47: 	ulong batValue = 0;
+0024A6 904ECB            MOV      DPTR,#batValue
+0024A9 120582            LCALL    ?C?LSTKXDATA
+0024AC 00                DB       00H
+0024AD 00                DB       00H
+0024AE 00                DB       00H
+0024AF 00                DB       00H
+   48: 
+   49: 	if(!m_adcCurrentValue)
+0024B0 904C95            MOV      DPTR,#m_adcCurrentValue
+0024B3 E0                MOVX     A,@DPTR
+0024B4 7002              JNZ      ?C0028?ADC
+0024B6 A3                INC      DPTR
+0024B7 E0                MOVX     A,@DPTR
+0024B8         ?C0028?ADC:
+0024B8 7002              JNZ      $ + 4H
+0024BA C170              AJMP     ?C0006?ADC
+   50: 		return;
+   51: 
+   52: 	g_variable.battery_value[g_variable.battery_value_index++] = m_adcCurrentValue;
+0024BC 904C95            MOV      DPTR,#m_adcCurrentValue
+0024BF E0                MOVX     A,@DPTR
+0024C0 FE                MOV      R6,A
+0024C1 A3                INC      DPTR
+0024C2 E0                MOVX     A,@DPTR
+0024C3 FF                MOV      R7,A
+0024C4 904CD4            MOV      DPTR,#g_variable+015H
+0024C7 E0                MOVX     A,@DPTR
+0024C8 FD                MOV      R5,A
+0024C9 04                INC      A
+0024CA F0                MOVX     @DPTR,A
+0024CB ED                MOV      A,R5
+0024CC 25E0              ADD      A,ACC
+0024CE 24D6              ADD      A,#LOW g_variable+017H
+0024D0 F582              MOV      DPL,A
+0024D2 E4                CLR      A
+0024D3 344C              ADDC     A,#HIGH g_variable+017H
+0024D5 F583              MOV      DPH,A
+0024D7 EE                MOV      A,R6
+0024D8 F0                MOVX     @DPTR,A
+0024D9 A3                INC      DPTR
+0024DA EF                MOV      A,R7
+0024DB F0                MOVX     @DPTR,A
+   53: 	if (g_variable.battery_value_index >= BAT_ARRAY_LEN)
+0024DC 904CD4            MOV      DPTR,#g_variable+015H
+0024DF E0                MOVX     A,@DPTR
+0024E0 C3                CLR      C
+0024E1 9404              SUBB     A,#04H
+0024E3 7480              MOV      A,#080H
+0024E5 9480              SUBB     A,#080H
+0024E7 4002              JC       ?C0007?ADC
+   54: 		g_variable.battery_value_index = 0;
+0024E9 E4                CLR      A
+0024EA F0                MOVX     @DPTR,A
+0024EB         ?C0007?ADC:
+   55: 	for (i = 0; i < BAT_ARRAY_LEN; i++)
+0024EB E4                CLR      A
+0024EC 904ECA            MOV      DPTR,#i
+0024EF F0                MOVX     @DPTR,A
+0024F0         ?C0008?ADC:
+0024F0 904ECA            MOV      DPTR,#i
+0024F3 E0                MOVX     A,@DPTR
+0024F4 C3                CLR      C
+0024F5 9404              SUBB     A,#04H
+0024F7 7480              MOV      A,#080H
+0024F9 9480              SUBB     A,#080H
+0024FB 503D              JNC      ?C0009?ADC
+   56: 	{
+   57: 		batValue += g_variable.battery_value[i];
+0024FD A3                INC      DPTR
+0024FE E0                MOVX     A,@DPTR
+0024FF F8                MOV      R0,A
+002500 A3                INC      DPTR
+002501 E0                MOVX     A,@DPTR
+002502 F9                MOV      R1,A
+002503 A3                INC      DPTR
+002504 E0                MOVX     A,@DPTR
+002505 FA                MOV      R2,A
+002506 A3                INC      DPTR
+002507 E0                MOVX     A,@DPTR
+002508 FB                MOV      R3,A
+002509 904ECA            MOV      DPTR,#i
+00250C E0                MOVX     A,@DPTR
+00250D 25E0              ADD      A,ACC
+00250F 24D6              ADD      A,#LOW g_variable+017H
+002511 F582              MOV      DPL,A
+002513 E4                CLR      A
+002514 344C              ADDC     A,#HIGH g_variable+017H
+002516 F583              MOV      DPH,A
+002518 E0                MOVX     A,@DPTR
+002519 FE                MOV      R6,A
+00251A A3                INC      DPTR
+00251B E0                MOVX     A,@DPTR
+00251C FF                MOV      R7,A
+00251D E4                CLR      A
+00251E FC                MOV      R4,A
+00251F FD                MOV      R5,A
+002520 EB                MOV      A,R3
+002521 2F                ADD      A,R7
+002522 FF                MOV      R7,A
+002523 EA                MOV      A,R2
+002524 3E                ADDC     A,R6
+002525 FE                MOV      R6,A
+002526 ED                MOV      A,R5
+002527 39                ADDC     A,R1
+002528 FD                MOV      R5,A
+002529 EC                MOV      A,R4
+00252A 38                ADDC     A,R0
+00252B FC                MOV      R4,A
+00252C 904ECB            MOV      DPTR,#batValue
+00252F 120576            LCALL    ?C?LSTXDATA
+   58: 	}
+002532 904ECA            MOV      DPTR,#i
+002535 E0                MOVX     A,@DPTR
+002536 04                INC      A
+002537 F0                MOVX     @DPTR,A
+002538 80B6              SJMP     ?C0008?ADC
+00253A         ?C0009?ADC:
+   59: 	batValue = batValue/BAT_ARRAY_LEN;
+00253A 904ECB            MOV      DPTR,#batValue
+00253D E0                MOVX     A,@DPTR
+00253E FC                MOV      R4,A
+00253F A3                INC      DPTR
+002540 E0                MOVX     A,@DPTR
+002541 FD                MOV      R5,A
+002542 A3                INC      DPTR
+002543 E0                MOVX     A,@DPTR
+002544 FE                MOV      R6,A
+002545 A3                INC      DPTR
+002546 E0                MOVX     A,@DPTR
+002547 FF                MOV      R7,A
+002548 E4                CLR      A
+002549 7B04              MOV      R3,#04H
+00254B FA                MOV      R2,A
+00254C F9                MOV      R1,A
+00254D F8                MOV      R0,A
+00254E 1204C5            LCALL    ?C?ULDIV
+002551 904ECB            MOV      DPTR,#batValue
+002554 120576            LCALL    ?C?LSTXDATA
+   60: 
+   61: 	if(batValue <= g_variable.battery_level_shutdown)
+002557 904CE0            MOV      DPTR,#g_variable+021H
+00255A E0                MOVX     A,@DPTR
+00255B FE                MOV      R6,A
+00255C A3                INC      DPTR
+00255D E0                MOVX     A,@DPTR
+00255E FF                MOV      R7,A
+00255F E4                CLR      A
+002560 FC                MOV      R4,A
+002561 FD                MOV      R5,A
+002562 904ECB            MOV      DPTR,#batValue
+002565 E0                MOVX     A,@DPTR
+002566 F8                MOV      R0,A
+002567 A3                INC      DPTR
+002568 E0                MOVX     A,@DPTR
+002569 F9                MOV      R1,A
+00256A A3                INC      DPTR
+00256B E0                MOVX     A,@DPTR
+00256C FA                MOV      R2,A
+00256D A3                INC      DPTR
+00256E E0                MOVX     A,@DPTR
+00256F FB                MOV      R3,A
+002570 D3                SETB     C
+002571 120565            LCALL    ?C?ULCMP
+002574 5007              JNC      ?C0011?ADC
+   62: 		g_variable.battery_level_percentage = 0;
+002576 E4                CLR      A
+002577 904CF9            MOV      DPTR,#g_variable+03AH
+00257A F0                MOVX     @DPTR,A
+00257B A1FF              AJMP     ?C0012?ADC
+00257D         ?C0011?ADC:
+   63: 	else	if(batValue >= g_variable.battery_level_full)
+00257D 904CFA            MOV      DPTR,#g_variable+03BH
+002580 E0                MOVX     A,@DPTR
+002581 FE                MOV      R6,A
+002582 A3                INC      DPTR
+002583 E0                MOVX     A,@DPTR
+002584 FF                MOV      R7,A
+002585 E4                CLR      A
+002586 FC                MOV      R4,A
+002587 FD                MOV      R5,A
+002588 904ECB            MOV      DPTR,#batValue
+00258B E0                MOVX     A,@DPTR
+00258C F8                MOV      R0,A
+00258D A3                INC      DPTR
+00258E E0                MOVX     A,@DPTR
+00258F F9                MOV      R1,A
+002590 A3                INC      DPTR
+002591 E0                MOVX     A,@DPTR
+002592 FA                MOV      R2,A
+002593 A3                INC      DPTR
+002594 E0                MOVX     A,@DPTR
+002595 FB                MOV      R3,A
+002596 C3                CLR      C
+002597 120565            LCALL    ?C?ULCMP
+00259A 4008              JC       ?C0013?ADC
+   64: 		g_variable.battery_level_percentage = 100;
+00259C 904CF9            MOV      DPTR,#g_variable+03AH
+00259F 7464              MOV      A,#064H
+0025A1 F0                MOVX     @DPTR,A
+0025A2 805B              SJMP     ?C0012?ADC
+0025A4         ?C0013?ADC:
+   65: 	else	
+   66: 		g_variable.battery_level_percentage = (byte)(((batValue - g_variable.battery_level_shutdown)*100)/(g_variable.b
+>> attery_level_full -g_variable.battery_level_shutdown) );
+0025A4 904CE0            MOV      DPTR,#g_variable+021H
+0025A7 E0                MOVX     A,@DPTR
+0025A8 FE                MOV      R6,A
+0025A9 A3                INC      DPTR
+0025AA E0                MOVX     A,@DPTR
+0025AB FF                MOV      R7,A
+0025AC FB                MOV      R3,A
+0025AD AA06              MOV      R2,AR6
+0025AF E4                CLR      A
+0025B0 904ECB            MOV      DPTR,#batValue
+0025B3 E0                MOVX     A,@DPTR
+0025B4 FC                MOV      R4,A
+0025B5 A3                INC      DPTR
+0025B6 E0                MOVX     A,@DPTR
+0025B7 FD                MOV      R5,A
+0025B8 A3                INC      DPTR
+0025B9 E0                MOVX     A,@DPTR
+0025BA FE                MOV      R6,A
+0025BB A3                INC      DPTR
+0025BC E0                MOVX     A,@DPTR
+0025BD C3                CLR      C
+0025BE 9B                SUBB     A,R3
+0025BF FF                MOV      R7,A
+0025C0 EE                MOV      A,R6
+0025C1 9A                SUBB     A,R2
+0025C2 FE                MOV      R6,A
+0025C3 ED                MOV      A,R5
+0025C4 9400              SUBB     A,#00H
+0025C6 FD                MOV      R5,A
+0025C7 EC                MOV      A,R4
+0025C8 9400              SUBB     A,#00H
+0025CA FC                MOV      R4,A
+0025CB E4                CLR      A
+0025CC 7B64              MOV      R3,#064H
+0025CE FA                MOV      R2,A
+0025CF F9                MOV      R1,A
+0025D0 F8                MOV      R0,A
+0025D1 12043A            LCALL    ?C?LMUL
+0025D4 C006              PUSH     AR6
+0025D6 C007              PUSH     AR7
+0025D8 904CE0            MOV      DPTR,#g_variable+021H
+0025DB E0                MOVX     A,@DPTR
+0025DC FE                MOV      R6,A
+0025DD A3                INC      DPTR
+0025DE E0                MOVX     A,@DPTR
+0025DF FF                MOV      R7,A
+0025E0 C3                CLR      C
+0025E1 904CFB            MOV      DPTR,#g_variable+03CH
+0025E4 E0                MOVX     A,@DPTR
+0025E5 9F                SUBB     A,R7
+0025E6 FF                MOV      R7,A
+0025E7 904CFA            MOV      DPTR,#g_variable+03BH
+0025EA E0                MOVX     A,@DPTR
+0025EB 9E                SUBB     A,R6
+0025EC FE                MOV      R6,A
+0025ED AB07              MOV      R3,AR7
+0025EF FA                MOV      R2,A
+0025F0 E4                CLR      A
+0025F1 F9                MOV      R1,A
+0025F2 F8                MOV      R0,A
+0025F3 D007              POP      AR7
+0025F5 D006              POP      AR6
+0025F7 1204C5            LCALL    ?C?ULDIV
+0025FA 904CF9            MOV      DPTR,#g_variable+03AH
+0025FD EF                MOV      A,R7
+0025FE F0                MOVX     @DPTR,A
+0025FF         ?C0012?ADC:
+   67: 	
+   68: 	if(g_variable.battery_value[0] < g_variable.battery_level_shutdown)
+0025FF 904CE0            MOV      DPTR,#g_variable+021H
+002602 E0                MOVX     A,@DPTR
+002603 FE                MOV      R6,A
+002604 A3                INC      DPTR
+002605 E0                MOVX     A,@DPTR
+002606 FF                MOV      R7,A
+002607 C3                CLR      C
+002608 904CD7            MOV      DPTR,#g_variable+018H
+00260B E0                MOVX     A,@DPTR
+00260C 9F                SUBB     A,R7
+00260D 904CD6            MOV      DPTR,#g_variable+017H
+002610 E0                MOVX     A,@DPTR
+002611 9E                SUBB     A,R6
+002612 5007              JNC      ?C0015?ADC
+   69: 	{
+   70: 		g_variable.battery_status = BAT_STATUS_SHUT_DOWN;
+002614 904CD5            MOV      DPTR,#g_variable+016H
+002617 7402              MOV      A,#02H
+002619 F0                MOVX     @DPTR,A
+   71: 	}
+00261A 22                RET      
+00261B         ?C0015?ADC:
+   72: 	else
+   73: 	{
+   74: 		if (batValue < g_variable.battery_level_low)
+00261B 904CDE            MOV      DPTR,#g_variable+01FH
+00261E E0                MOVX     A,@DPTR
+00261F FE                MOV      R6,A
+002620 A3                INC      DPTR
+002621 E0                MOVX     A,@DPTR
+002622 FF                MOV      R7,A
+002623 E4                CLR      A
+002624 FC                MOV      R4,A
+002625 FD                MOV      R5,A
+002626 904ECB            MOV      DPTR,#batValue
+002629 E0                MOVX     A,@DPTR
+00262A F8                MOV      R0,A
+00262B A3                INC      DPTR
+00262C E0                MOVX     A,@DPTR
+00262D F9                MOV      R1,A
+00262E A3                INC      DPTR
+00262F E0                MOVX     A,@DPTR
+002630 FA                MOV      R2,A
+002631 A3                INC      DPTR
+002632 E0                MOVX     A,@DPTR
+002633 FB                MOV      R3,A
+002634 C3                CLR      C
+002635 120565            LCALL    ?C?ULCMP
+002638 501C              JNC      ?C0017?ADC
+   75: 		{
+   76: 			g_variable.battery_status = BAT_STATUS_LOW;
+00263A 904CD5            MOV      DPTR,#g_variable+016H
+00263D 7401              MOV      A,#01H
+00263F F0                MOVX     @DPTR,A
+   77: 			if(!g_variable.g24_long_sleep_flag)
+002640 904CFC            MOV      DPTR,#g_variable+03DH
+002643 E0                MOVX     A,@DPTR
+002644 702A              JNZ      ?C0006?ADC
+   78: 			{
+   79: 			m_24g_enter_hibernate[0]	= 0x00;
+002646 904D40            MOV      DPTR,#m_24g_enter_hibernate
+002649 F0                MOVX     @DPTR,A
+   80: 			m_24g_enter_hibernate[1]	= 0x48;
+00264A A3                INC      DPTR
+00264B 7448              MOV      A,#048H
+00264D F0                MOVX     @DPTR,A
+   81: 			m_24g_enter_hibernate[2]	= 0x12;		// 100ms
+00264E A3                INC      DPTR
+00264F 7412              MOV      A,#012H
+002651 F0                MOVX     @DPTR,A
+   82: 			m_24g_enter_hibernate[3]	= 0x00;
+002652 E4                CLR      A
+002653 A3                INC      DPTR
+002654 F0                MOVX     @DPTR,A
+   83: 			}
+   84: 		}
+002655 22                RET      
+002656         ?C0017?ADC:
+   85: 		else
+   86: 		{
+   87: 			g_variable.battery_status = BAT_STATUS_NONE;
+002656 E4                CLR      A
+002657 904CD5            MOV      DPTR,#g_variable+016H
+00265A F0                MOVX     @DPTR,A
+   88: 			if(!g_variable.g24_long_sleep_flag)
+00265B 904CFC            MOV      DPTR,#g_variable+03DH
+00265E E0                MOVX     A,@DPTR
+00265F 700F              JNZ      ?C0006?ADC
+   89: 			{
+   90: 			m_24g_enter_hibernate[0]	= 0x00;
+002661 904D40            MOV      DPTR,#m_24g_enter_hibernate
+002664 F0                MOVX     @DPTR,A
+   91: 			m_24g_enter_hibernate[1]	= 0x48;
+002665 A3                INC      DPTR
+002666 7448              MOV      A,#048H
+002668 F0                MOVX     @DPTR,A
+   92: 			m_24g_enter_hibernate[2]   = 0x5d;		// 510ms
+002669 A3                INC      DPTR
+00266A 745D              MOV      A,#05DH
+00266C F0                MOVX     @DPTR,A
+   93: 			m_24g_enter_hibernate[3]	= 0x00;
+00266D E4                CLR      A
+00266E A3                INC      DPTR
+00266F F0                MOVX     @DPTR,A
+   94: 			}
+   95: 		}
+   96: 	}
+   97: #endif	
+   98: }
+002670         ?C0006?ADC:
+002670 22                RET      
+----- FUNCTION YC_adc_check (END) -------
+
+
+----- FUNCTION kb_24g_get_led_status (BEGIN) -----
+ FILE: 'kb_process.c'
+  268: void kb_24g_get_led_status()		//get RF Ack for get numlock/capslock status
+  269: {
+  270: 	if((m_24g_led_flag)&& (repeat_send_24g == 0))
+  271: 	{
+002671 904D46            MOV      DPTR,#m_24g_led_flag
+002674 E0                MOVX     A,@DPTR
+002675 6037              JZ       ?C0053?KB_PROCESS
+002677 904DDD            MOV      DPTR,#repeat_send_24g
+00267A E0                MOVX     A,@DPTR
+00267B 7031              JNZ      ?C0053?KB_PROCESS
+  272: 		if (g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED)
+  273: 		{
+00267D 904CC5            MOV      DPTR,#g_variable+06H
+002680 E0                MOVX     A,@DPTR
+002681 6403              XRL      A,#03H
+002683 7029              JNZ      ?C0053?KB_PROCESS
+  274: 			xmemclear(hidBuff,9);
+  275: 
+002685 7B01              MOV      R3,#01H
+002687 7A48              MOV      R2,#HIGH hidBuff
+002689 7900              MOV      R1,#LOW hidBuff
+00268B 7D09              MOV      R5,#09H
+00268D FC                MOV      R4,A
+00268E 120DFA            LCALL    _xmemclear
+  276: 			mult_key_status = 0;
+002691 E4                CLR      A
+002692 904E4B            MOV      DPTR,#mult_key_status
+002695 F0                MOVX     @DPTR,A
+  277: 			hidBuff[0] = HID_REPORTID_1;		// standard key send
+002696 904800            MOV      DPTR,#hidBuff
+002699 04                INC      A
+00269A F0                MOVX     @DPTR,A
+  278: 			hidBuff[2] = m_24g_led_flag;
+00269B 904D46            MOV      DPTR,#m_24g_led_flag
+00269E E0                MOVX     A,@DPTR
+00269F 904802            MOV      DPTR,#hidBuff+02H
+0026A2 F0                MOVX     @DPTR,A
+  279: 			IPC_TxHidData(hidBuff, 9);
+0026A3 7B01              MOV      R3,#01H
+0026A5 7A48              MOV      R2,#HIGH hidBuff
+0026A7 7900              MOV      R1,#LOW hidBuff
+0026A9 7D09              MOV      R5,#09H
+0026AB 120EDA            LCALL    _IPC_TxHidData
+  280: 		}	
+  281: 	}
+  282: }
+0026AE         ?C0053?KB_PROCESS:
+0026AE 22                RET      
+----- FUNCTION kb_24g_get_led_status (END) -------
+
+
+----- FUNCTION kb_motion (BEGIN) -----
+ FILE: 'kb_process.c'
+  286: static void kb_motion()
+  287: {
+  288: 	tKSEVENT *pEvt = NULL;
+  289: 	
+0026AF 904EE0            MOV      DPTR,#pEvt
+0026B2 E4                CLR      A
+0026B3 F0                MOVX     @DPTR,A
+0026B4 A3                INC      DPTR
+0026B5 F0                MOVX     @DPTR,A
+0026B6 A3                INC      DPTR
+0026B7 F0                MOVX     @DPTR,A
+  290: 	if (!IPC_IsTxBuffEmpty())
+0026B8 D1E3              ACALL    IPC_IsTxBuffEmpty
+0026BA 5026              JNC      ?C0055?KB_PROCESS
+  291: 		return;
+  292: 	pEvt = KS_GetCurrentEvt();
+0026BC 122ACB            LCALL    KS_GetCurrentEvt
+0026BF 904EE0            MOV      DPTR,#pEvt
+0026C2 EB                MOV      A,R3
+0026C3 F0                MOVX     @DPTR,A
+0026C4 A3                INC      DPTR
+0026C5 EA                MOV      A,R2
+0026C6 F0                MOVX     @DPTR,A
+0026C7 A3                INC      DPTR
+0026C8 E9                MOV      A,R1
+0026C9 F0                MOVX     @DPTR,A
+  293: 
+  294: 	if (pEvt == NULL)
+0026CA 4A                ORL      A,R2
+0026CB 7007              JNZ      ?C0056?KB_PROCESS
+  295: 	{
+  296: 		m_power_on_flag = 1;
+0026CD 904CB6            MOV      DPTR,#m_power_on_flag
+0026D0 04                INC      A
+0026D1 F0                MOVX     @DPTR,A
+  297: 		kb_24g_get_led_status();
+0026D2 809D              SJMP     kb_24g_get_led_status
+  298: 		return;
+  299: 	}
+0026D4         ?C0056?KB_PROCESS:
+  300: 	kb_motion_keyscan(pEvt);
+0026D4 904EE0            MOV      DPTR,#pEvt
+0026D7 E0                MOVX     A,@DPTR
+0026D8 FB                MOV      R3,A
+0026D9 A3                INC      DPTR
+0026DA E0                MOVX     A,@DPTR
+0026DB FA                MOV      R2,A
+0026DC A3                INC      DPTR
+0026DD E0                MOVX     A,@DPTR
+0026DE F9                MOV      R1,A
+0026DF 1208BB            LCALL    _kb_motion_keyscan
+  301: }
+0026E2         ?C0055?KB_PROCESS:
+0026E2 22                RET      
+----- FUNCTION kb_motion (END) -------
+
+
+----- FUNCTION IPC_IsTxBuffEmpty (BEGIN) -----
+0026E3 904B9C            MOV      DPTR,#ipcTxWritePtr
+0026E6 E0                MOVX     A,@DPTR
+0026E7 FE                MOV      R6,A
+0026E8 A3                INC      DPTR
+0026E9 E0                MOVX     A,@DPTR
+0026EA FF                MOV      R7,A
+0026EB 904B9A            MOV      DPTR,#ipcTxReadPtr
+0026EE E0                MOVX     A,@DPTR
+0026EF B50607            CJNE     A,AR6,?C0025?IPC
+0026F2 A3                INC      DPTR
+0026F3 E0                MOVX     A,@DPTR
+0026F4 B50702            CJNE     A,AR7,?C0025?IPC
+0026F7 D3                SETB     C
+0026F8 22                RET      
+0026F9         ?C0025?IPC:
+0026F9 C3                CLR      C
+0026FA 22                RET      
+----- FUNCTION IPC_IsTxBuffEmpty (END) -------
+
+
+----- FUNCTION _kb_device_select (BEGIN) -----
+ FILE: 'kb_process.c'
+  517: byte kb_device_select(tKSEVENT *pEvt)
+  518: {
+0026FB 904EE3            MOV      DPTR,#pEvt
+0026FE EB                MOV      A,R3
+0026FF F0                MOVX     @DPTR,A
+002700 A3                INC      DPTR
+002701 EA                MOV      A,R2
+002702 F0                MOVX     @DPTR,A
+002703 A3                INC      DPTR
+002704 E9                MOV      A,R1
+002705 F0                MOVX     @DPTR,A
+  519: 	byte temp = 0;
+  520: 	byte i=0;
+;---- Variable 'temp' assigned to Register 'R5' ----
+002706 E4                CLR      A
+002707 FD                MOV      R5,A
+  521: 	
+;---- Variable 'i' assigned to Register 'R4' ----
+002708 FC                MOV      R4,A
+  522: 	if (fn_flag == 1) 
+002709 904DE2            MOV      DPTR,#fn_flag
+00270C E0                MOVX     A,@DPTR
+00270D 6401              XRL      A,#01H
+00270F 6002              JZ       $ + 4H
+002711 E1AE              AJMP     ?C0115?KB_PROCESS
+  523: 	{
+  524: 		i = KS_BUFF_POLL_LEN-1;
+002713 7C05              MOV      R4,#05H
+002715         ?C0116?KB_PROCESS:
+  525: 
+  526: 		while (i--) 
+002715 AF04              MOV      R7,AR4
+002717 1C                DEC      R4
+002718 EF                MOV      A,R7
+002719 7003              JNZ      $ + 5H
+00271B 02285D            LJMP     ?C0126?KB_PROCESS
+  527: 		{
+  528: 			temp = pEvt->ksPool[i];
+00271E 904EE3            MOV      DPTR,#pEvt
+002721 E0                MOVX     A,@DPTR
+002722 FB                MOV      R3,A
+002723 A3                INC      DPTR
+002724 E0                MOVX     A,@DPTR
+002725 FA                MOV      R2,A
+002726 A3                INC      DPTR
+002727 E0                MOVX     A,@DPTR
+002728 2401              ADD      A,#01H
+00272A F9                MOV      R1,A
+00272B E4                CLR      A
+00272C 3A                ADDC     A,R2
+00272D FA                MOV      R2,A
+00272E EC                MOV      A,R4
+00272F 7E00              MOV      R6,#00H
+002731 29                ADD      A,R1
+002732 F9                MOV      R1,A
+002733 EE                MOV      A,R6
+002734 3A                ADDC     A,R2
+002735 FA                MOV      R2,A
+002736 1203B6            LCALL    ?C?CLDPTR
+002739 FD                MOV      R5,A
+  529: 
+  530: 			if (temp == HID_KEY_P) 
+00273A 6413              XRL      A,#013H
+00273C 7036              JNZ      ?C0118?KB_PROCESS
+  531: 			{
+  532: 						g_variable.delay_enter_lpm_timer = 10;
+00273E 904CEA            MOV      DPTR,#g_variable+02BH
+002741 740A              MOV      A,#0AH
+002743 F0                MOVX     @DPTR,A
+  533: 
+  534: 						g_variable.button_flag |= KEY_FLAG_FN_DEVICE_BUTTON;
+002744 904CCE            MOV      DPTR,#g_variable+0FH
+002747 E0                MOVX     A,@DPTR
+002748 4408              ORL      A,#08H
+00274A F0                MOVX     @DPTR,A
+  535: 						g_variable.button_flag &= ~KEY_FLAG_FN_24G_DEVICE_BUTTON;
+00274B 54EF              ANL      A,#0EFH
+00274D F0                MOVX     @DPTR,A
+  536: 						if((g_variable.current_device_num != (temp-(HID_KEY_P - 1))) ||(g_variable.g24_currentState == CHANGE_TO_24
+>> G_CONNECTED))
+00274E ED                MOV      A,R5
+00274F 24EE              ADD      A,#0EEH
+002751 FF                MOV      R7,A
+002752 904CC3            MOV      DPTR,#g_variable+04H
+002755 E0                MOVX     A,@DPTR
+002756 B50708            CJNE     A,AR7,?C0120?KB_PROCESS
+002759 904CC5            MOV      DPTR,#g_variable+06H
+00275C E0                MOVX     A,@DPTR
+00275D 6403              XRL      A,#03H
+00275F 7010              JNZ      ?C0119?KB_PROCESS
+002761         ?C0120?KB_PROCESS:
+  537: 						{
+  538: 							g_variable.current_device_num = temp-(HID_KEY_P - 1);
+002761 904CC3            MOV      DPTR,#g_variable+04H
+002764 EF                MOV      A,R7
+002765 F0                MOVX     @DPTR,A
+  539: 							g_variable.button_reconnect_flag = 1;		// long press = 3s enter discovery
+002766 904CCC            MOV      DPTR,#g_variable+0DH
+002769 7401              MOV      A,#01H
+00276B F0                MOVX     @DPTR,A
+  540: 							g_variable.powerOn_timer = 0;
+00276C E4                CLR      A
+00276D 904CE5            MOV      DPTR,#g_variable+026H
+002770 F0                MOVX     @DPTR,A
+  541: 						}
+002771         ?C0119?KB_PROCESS:
+  542: 				return 1;
+002771 7F01              MOV      R7,#01H
+002773 22                RET      
+  543: 			}
+002774         ?C0118?KB_PROCESS:
+  544: 			else
+  545: 			{
+  546: 				g_variable.button_flag &= ~(KEY_FLAG_FN_DEVICE_BUTTON |KEY_FLAG_FN_24G_DEVICE_BUTTON);
+002774 904CCE            MOV      DPTR,#g_variable+0FH
+002777 E0                MOVX     A,@DPTR
+002778 54E7              ANL      A,#0E7H
+00277A F0                MOVX     @DPTR,A
+  547: 			}
+  548: 
+  549: 			
+  550: 			if((temp == HID_KEY_Q) || (temp == HID_KEY_W) || (temp == HID_KEY_O)|| (temp == HID_KEY_E))
+00277B ED                MOV      A,R5
+00277C FF                MOV      R7,A
+00277D 6414              XRL      A,#014H
+00277F 600F              JZ       ?C0124?KB_PROCESS
+002781 EF                MOV      A,R7
+002782 641A              XRL      A,#01AH
+002784 600A              JZ       ?C0124?KB_PROCESS
+002786 EF                MOV      A,R7
+002787 6412              XRL      A,#012H
+002789 6005              JZ       ?C0124?KB_PROCESS
+00278B EF                MOV      A,R7
+00278C 6408              XRL      A,#08H
+00278E 7015              JNZ      ?C0123?KB_PROCESS
+002790         ?C0124?KB_PROCESS:
+  551: 			{
+  552: 				g_variable.delay_enter_lpm_timer = 10;
+002790 904CEA            MOV      DPTR,#g_variable+02BH
+002793 740A              MOV      A,#0AH
+002795 F0                MOVX     @DPTR,A
+  553: 				key_value_temp = temp;
+002796 904DE8            MOV      DPTR,#key_value_temp
+002799 ED                MOV      A,R5
+00279A F0                MOVX     @DPTR,A
+  554: 				g_variable.button_flag |= KEY_FLAG_FN_SYSTEM_MODE_BUTTON;
+00279B 904CCE            MOV      DPTR,#g_variable+0FH
+00279E E0                MOVX     A,@DPTR
+00279F 4420              ORL      A,#020H
+0027A1 F0                MOVX     @DPTR,A
+  555: 				return 1;
+0027A2 7F01              MOV      R7,#01H
+0027A4 22                RET      
+  556: 			}
+0027A5         ?C0123?KB_PROCESS:
+  557: 			else
+  558: 				g_variable.button_flag &= ~KEY_FLAG_FN_SYSTEM_MODE_BUTTON;
+0027A5 904CCE            MOV      DPTR,#g_variable+0FH
+0027A8 E0                MOVX     A,@DPTR
+0027A9 54DF              ANL      A,#0DFH
+0027AB F0                MOVX     @DPTR,A
+  559: 		}
+0027AC E115              AJMP     ?C0116?KB_PROCESS
+  560: 	}
+0027AE         ?C0115?KB_PROCESS:
+  561: 	else
+  562: 	{
+  563: //		i = KS_BUFF_POLL_LEN-1;
+  564: //		while (i--) 
+  565: //		{
+  566: //			temp = pEvt->ksPool[i];
+  567: 
+  568: 			if (pEvt->ksPool[0] == HID_KEY_PB)                                                                            
+>>            //24G pairing button
+0027AE 904EE3            MOV      DPTR,#pEvt
+0027B1 E0                MOVX     A,@DPTR
+0027B2 FB                MOV      R3,A
+0027B3 A3                INC      DPTR
+0027B4 E0                MOVX     A,@DPTR
+0027B5 FA                MOV      R2,A
+0027B6 A3                INC      DPTR
+0027B7 E0                MOVX     A,@DPTR
+0027B8 F9                MOV      R1,A
+0027B9 900001            MOV      DPTR,#01H
+0027BC 1203CF            LCALL    ?C?CLDOPTR
+0027BF FD                MOV      R5,A
+0027C0 7C00              MOV      R4,#00H
+0027C2 64EF              XRL      A,#0EFH
+0027C4 702C              JNZ      ?C0127?KB_PROCESS
+  569: 			{
+  570: 				g_variable.delay_enter_lpm_timer = 10;
+0027C6 904CEA            MOV      DPTR,#g_variable+02BH
+0027C9 740A              MOV      A,#0AH
+0027CB F0                MOVX     @DPTR,A
+  571: 				g_variable.button_flag &= ~KEY_FLAG_FN_DEVICE_BUTTON;
+0027CC 904CCE            MOV      DPTR,#g_variable+0FH
+0027CF E0                MOVX     A,@DPTR
+0027D0 54F7              ANL      A,#0F7H
+0027D2 F0                MOVX     @DPTR,A
+  572: 				g_variable.button_flag |= KEY_FLAG_FN_24G_DEVICE_BUTTON;
+0027D3 4410              ORL      A,#010H
+0027D5 F0                MOVX     @DPTR,A
+  573: 				if( (g_variable.current_device_num != 0) && (g_variable.current_device_num != 0xfe))
+0027D6 904CC3            MOV      DPTR,#g_variable+04H
+0027D9 E0                MOVX     A,@DPTR
+0027DA 6013              JZ       ?C0128?KB_PROCESS
+0027DC 64FE              XRL      A,#0FEH
+0027DE 600F              JZ       ?C0128?KB_PROCESS
+  574: 				{
+  575: 					g_variable.button_24G_rec_flag = 1;
+0027E0 904CCD            MOV      DPTR,#g_variable+0EH
+0027E3 7401              MOV      A,#01H
+0027E5 F0                MOVX     @DPTR,A
+  576: 					g_variable.current_device_num =0;
+0027E6 E4                CLR      A
+0027E7 904CC3            MOV      DPTR,#g_variable+04H
+0027EA F0                MOVX     @DPTR,A
+  577: 					g_variable.powerOn_timer = 0;
+0027EB 904CE5            MOV      DPTR,#g_variable+026H
+0027EE F0                MOVX     @DPTR,A
+  578: 
+  579: 				}
+0027EF         ?C0128?KB_PROCESS:
+  580: 				return 1;
+0027EF 7F01              MOV      R7,#01H
+0027F1 22                RET      
+  581: 			}
+0027F2         ?C0127?KB_PROCESS:
+  582: 		
+  583: 			else if (pEvt->ksPool[0] == HID_KEY_BLE_1 ||pEvt->ksPool[0] ==  HID_KEY_BLE_2)                 //ble 1 /2  pai
+>> ring button
+0027F2 ED                MOV      A,R5
+0027F3 64E9              XRL      A,#0E9H
+0027F5 4C                ORL      A,R4
+0027F6 6015              JZ       ?C0131?KB_PROCESS
+0027F8 904EE3            MOV      DPTR,#pEvt
+0027FB E0                MOVX     A,@DPTR
+0027FC FB                MOV      R3,A
+0027FD A3                INC      DPTR
+0027FE E0                MOVX     A,@DPTR
+0027FF FA                MOV      R2,A
+002800 A3                INC      DPTR
+002801 E0                MOVX     A,@DPTR
+002802 F9                MOV      R1,A
+002803 900001            MOV      DPTR,#01H
+002806 1203CF            LCALL    ?C?CLDOPTR
+002809 64EA              XRL      A,#0EAH
+00280B 7046              JNZ      ?C0129?KB_PROCESS
+00280D         ?C0131?KB_PROCESS:
+  584: 			{
+  585: 				g_variable.delay_enter_lpm_timer = 10;
+00280D 904CEA            MOV      DPTR,#g_variable+02BH
+002810 740A              MOV      A,#0AH
+002812 F0                MOVX     @DPTR,A
+  586: 				g_variable.button_flag |= KEY_FLAG_FN_DEVICE_BUTTON;
+002813 904CCE            MOV      DPTR,#g_variable+0FH
+002816 E0                MOVX     A,@DPTR
+002817 4408              ORL      A,#08H
+002819 F0                MOVX     @DPTR,A
+  587: 				g_variable.button_flag &= ~KEY_FLAG_FN_24G_DEVICE_BUTTON;
+00281A 54EF              ANL      A,#0EFH
+00281C F0                MOVX     @DPTR,A
+  588: 				if((g_variable.current_device_num != (pEvt->ksPool[0]-(HID_KEY_BLE_1 - 1))) ||(g_variable.g24_currentState ==
+>>  CHANGE_TO_24G_CONNECTED))
+00281D 904EE3            MOV      DPTR,#pEvt
+002820 E0                MOVX     A,@DPTR
+002821 FB                MOV      R3,A
+002822 A3                INC      DPTR
+002823 E0                MOVX     A,@DPTR
+002824 FA                MOV      R2,A
+002825 A3                INC      DPTR
+002826 E0                MOVX     A,@DPTR
+002827 F9                MOV      R1,A
+002828 900001            MOV      DPTR,#01H
+00282B 1203CF            LCALL    ?C?CLDOPTR
+00282E 2418              ADD      A,#018H
+002830 FF                MOV      R7,A
+002831 904CC3            MOV      DPTR,#g_variable+04H
+002834 E0                MOVX     A,@DPTR
+002835 B50708            CJNE     A,AR7,?C0133?KB_PROCESS
+002838 904CC5            MOV      DPTR,#g_variable+06H
+00283B E0                MOVX     A,@DPTR
+00283C 6403              XRL      A,#03H
+00283E 7010              JNZ      ?C0132?KB_PROCESS
+002840         ?C0133?KB_PROCESS:
+  589: 				{
+  590: 					g_variable.current_device_num = pEvt->ksPool[0]-(HID_KEY_BLE_1 - 1);
+002840 904CC3            MOV      DPTR,#g_variable+04H
+002843 EF                MOV      A,R7
+002844 F0                MOVX     @DPTR,A
+  591: 					g_variable.button_reconnect_flag = 1;		// long press = 3s enter discovery
+002845 904CCC            MOV      DPTR,#g_variable+0DH
+002848 7401              MOV      A,#01H
+00284A F0                MOVX     @DPTR,A
+  592: 					g_variable.powerOn_timer = 0;
+00284B E4                CLR      A
+00284C 904CE5            MOV      DPTR,#g_variable+026H
+00284F F0                MOVX     @DPTR,A
+  593: 				}
+002850         ?C0132?KB_PROCESS:
+  594: 				return 1;
+002850 7F01              MOV      R7,#01H
+002852 22                RET      
+  595: 			}
+002853         ?C0129?KB_PROCESS:
+  596: 
+  597: //		}
+  598: 		g_variable.button_flag &= ~(KEY_FLAG_FN_DEVICE_BUTTON |KEY_FLAG_FN_24G_DEVICE_BUTTON) ;
+002853 904CCE            MOV      DPTR,#g_variable+0FH
+002856 E0                MOVX     A,@DPTR
+002857 54E7              ANL      A,#0E7H
+002859 F0                MOVX     @DPTR,A
+  599: 		g_variable.button_flag &= ~KEY_FLAG_FN_SYSTEM_MODE_BUTTON;
+00285A 54DF              ANL      A,#0DFH
+00285C F0                MOVX     @DPTR,A
+  600: 	}
+00285D         ?C0126?KB_PROCESS:
+  601: 	return 0;
+00285D 7F00              MOV      R7,#00H
+  602: }
+00285F 22                RET      
+----- FUNCTION _kb_device_select (END) -------
+
+
+----- FUNCTION _kb_combination_key_press (BEGIN) -----
+ FILE: 'kb_process.c'
+  607: void kb_combination_key_press(byte press_state,byte special_key,byte standrad_key)
+  608: {
+;---- Variable 'press_state' assigned to Register 'R7' ----
+;---- Variable 'standrad_key' assigned to Register 'R3' ----
+;---- Variable 'special_key' assigned to Register 'R5' ----
+  609: 	g_variable.key_combination_ctrl = special_key;	
+  610: 	g_variable.key_combination_keyvalue = standrad_key;
+002860 904CF5            MOV      DPTR,#g_variable+036H
+002863 ED                MOV      A,R5
+002864 F0                MOVX     @DPTR,A
+  611: 
+002865 A3                INC      DPTR
+002866 EB                MOV      A,R3
+002867 F0                MOVX     @DPTR,A
+  612: 	if(press_state & 1)
+002868 EF                MOV      A,R7
+002869 30E013            JNB      ACC.0,?C0134?KB_PROCESS
+  613: 	{
+  614: 		if(g_variable.key_combination_step == CAMBINATION_KEY_COMPLETE) 
+00286C 904CF4            MOV      DPTR,#g_variable+035H
+00286F E0                MOVX     A,@DPTR
+002870 6403              XRL      A,#03H
+002872 7004              JNZ      ?C0135?KB_PROCESS
+  615: 			g_variable.key_combination_step = CAMBINATION_KEY_HOLD;
+002874 7402              MOV      A,#02H
+002876 F0                MOVX     @DPTR,A
+002877 22                RET      
+002878         ?C0135?KB_PROCESS:
+  616: 		else	
+  617: 			g_variable.key_combination_step = CAMBINATION_KEY_PRESS;
+002878 904CF4            MOV      DPTR,#g_variable+035H
+00287B 7401              MOV      A,#01H
+00287D F0                MOVX     @DPTR,A
+  618: 	}
+00287E 22                RET      
+00287F         ?C0134?KB_PROCESS:
+  619: 	else
+  620: 	{
+  621: 		g_variable.key_combination_step = CAMBINATION_KEY_WAIT_RELEASE;
+00287F 904CF4            MOV      DPTR,#g_variable+035H
+002882 7404              MOV      A,#04H
+002884 F0                MOVX     @DPTR,A
+  622: 	}
+  623: 
+  624: }
+002885 22                RET      
+----- FUNCTION _kb_combination_key_press (END) -------
+
+
+----- FUNCTION _key_fn_function (BEGIN) -----
+ FILE: 'kb_process.c'
+  627: byte key_fn_function(byte state ,byte key_value)
+  628: {
+;---- Variable 'key_value' assigned to Register 'R6' ----
+002886 AE05              MOV      R6,AR5
+;---- Variable 'state' assigned to Register 'R4' ----
+002888 AC07              MOV      R4,AR7
+  629: 	byte temp = 0;
+  630: 
+00288A E4                CLR      A
+00288B 904F02            MOV      DPTR,#temp
+00288E F0                MOVX     @DPTR,A
+  631: 	if(state & 1)
+00288F EC                MOV      A,R4
+002890 30E005            JNB      ACC.0,?C0139?KB_PROCESS
+  632: 		g_variable.one_key_press_wait_release_timer = 0;
+002893 E4                CLR      A
+002894 904CF8            MOV      DPTR,#g_variable+039H
+002897 F0                MOVX     @DPTR,A
+002898         ?C0139?KB_PROCESS:
+  633: 
+  634: 	temp = key_value;
+002898 904F02            MOV      DPTR,#temp
+00289B EE                MOV      A,R6
+00289C F0                MOVX     @DPTR,A
+  635: 	if(g_variable.system_mode != OSMODE_WINDOWS)
+00289D 904CC1            MOV      DPTR,#g_variable+02H
+0028A0 E0                MOVX     A,@DPTR
+0028A1 FF                MOV      R7,A
+0028A2 6038              JZ       ?C0140?KB_PROCESS
+  636: 	{
+  637: 		if(key_value == HID_KEY_RIGHT_ALT)
+0028A4 EE                MOV      A,R6
+0028A5 FB                MOV      R3,A
+0028A6 7A00              MOV      R2,#00H
+0028A8 64E6              XRL      A,#0E6H
+0028AA 7008              JNZ      ?C0141?KB_PROCESS
+  638: 			temp = HID_KEY_RIGHT_GUI;
+0028AC 904F02            MOV      DPTR,#temp
+0028AF 74E7              MOV      A,#0E7H
+0028B1 F0                MOVX     @DPTR,A
+0028B2 8028              SJMP     ?C0140?KB_PROCESS
+0028B4         ?C0141?KB_PROCESS:
+  639: 		else if(key_value == HID_KEY_RIGHT_CTL)
+0028B4 EB                MOV      A,R3
+0028B5 64E4              XRL      A,#0E4H
+0028B7 4A                ORL      A,R2
+0028B8 7008              JNZ      ?C0143?KB_PROCESS
+  640: 			temp = HID_KEY_RIGHT_ALT;	
+0028BA 904F02            MOV      DPTR,#temp
+0028BD 74E6              MOV      A,#0E6H
+0028BF F0                MOVX     @DPTR,A
+0028C0 801A              SJMP     ?C0140?KB_PROCESS
+0028C2         ?C0143?KB_PROCESS:
+  641: 		else if(key_value == HID_KEY_LEFT_GUI)
+0028C2 EB                MOV      A,R3
+0028C3 64E3              XRL      A,#0E3H
+0028C5 4A                ORL      A,R2
+0028C6 7008              JNZ      ?C0145?KB_PROCESS
+  642: 			temp = HID_KEY_LEFT_ALT;
+0028C8 904F02            MOV      DPTR,#temp
+0028CB 74E2              MOV      A,#0E2H
+0028CD F0                MOVX     @DPTR,A
+0028CE 800C              SJMP     ?C0140?KB_PROCESS
+0028D0         ?C0145?KB_PROCESS:
+  643: 		else if(key_value == HID_KEY_LEFT_ALT)
+0028D0 EB                MOV      A,R3
+0028D1 64E2              XRL      A,#0E2H
+0028D3 4A                ORL      A,R2
+0028D4 7006              JNZ      ?C0140?KB_PROCESS
+  644: 			temp = HID_KEY_LEFT_GUI;	
+0028D6 904F02            MOV      DPTR,#temp
+0028D9 74E3              MOV      A,#0E3H
+0028DB F0                MOVX     @DPTR,A
+  645: 	}
+0028DC         ?C0140?KB_PROCESS:
+  646: 	if(g_variable.system_mode == OSMODE_WINDOWS)
+0028DC EF                MOV      A,R7
+0028DD 7012              JNZ      ?C0148?KB_PROCESS
+  647: 	{
+  648: 		if(key_value == HID_MULTIKEY_OS_LOCK)
+0028DF EE                MOV      A,R6
+0028E0 64DA              XRL      A,#0DAH
+0028E2 700D              JNZ      ?C0148?KB_PROCESS
+  649: 		{
+  650: 			kb_combination_key_press(state,KS_SEL_LGUI,HID_KEY_L);
+0028E4 AF04              MOV      R7,AR4
+0028E6 7B0F              MOV      R3,#0FH
+0028E8 7D08              MOV      R5,#08H
+0028EA 1160              ACALL    _kb_combination_key_press
+  651: 			temp = HID_KEY_NULL;
+0028EC E4                CLR      A
+0028ED 904F02            MOV      DPTR,#temp
+0028F0 F0                MOVX     @DPTR,A
+  652: 		}
+  653: 	}
+0028F1         ?C0148?KB_PROCESS:
+  654: 	if(fn_flag == 1)			// Fn lock
+0028F1 904DE2            MOV      DPTR,#fn_flag
+0028F4 E0                MOVX     A,@DPTR
+0028F5 6401              XRL      A,#01H
+0028F7 6002              JZ       $ + 4H
+0028F9 21AB              AJMP     ?C0150?KB_PROCESS
+  655: 	{
+  656: 		if(key_value == HID_KEY_HOME)
+0028FB EE                MOV      A,R6
+0028FC FB                MOV      R3,A
+0028FD 7A00              MOV      R2,#00H
+0028FF 644A              XRL      A,#04AH
+002901 7008              JNZ      ?C0151?KB_PROCESS
+  657: 		{
+  658: 			temp = HID_KEY_PRINT_SCREEN;
+002903 904F02            MOV      DPTR,#temp
+002906 7446              MOV      A,#046H
+002908 F0                MOVX     @DPTR,A
+  659: 		}
+002909 21AB              AJMP     ?C0150?KB_PROCESS
+00290B         ?C0151?KB_PROCESS:
+  660: 		else if(key_value == HID_KEY_END)
+00290B EB                MOV      A,R3
+00290C 644D              XRL      A,#04DH
+00290E 4A                ORL      A,R2
+00290F 7008              JNZ      ?C0153?KB_PROCESS
+  661: 		{
+  662: 			temp = HID_KEY_PAUSE;
+002911 904F02            MOV      DPTR,#temp
+002914 7448              MOV      A,#048H
+002916 F0                MOVX     @DPTR,A
+  663: 		}
+002917 21AB              AJMP     ?C0150?KB_PROCESS
+002919         ?C0153?KB_PROCESS:
+  664: 		else if(key_value == HID_KEY_DOWN_ARROW)
+002919 EB                MOV      A,R3
+00291A 6451              XRL      A,#051H
+00291C 4A                ORL      A,R2
+00291D 7008              JNZ      ?C0155?KB_PROCESS
+  665: 		{
+  666: 			temp = HID_MULTIKEY_LIGHT_DOWN;
+00291F 904F02            MOV      DPTR,#temp
+002922 74D7              MOV      A,#0D7H
+002924 F0                MOVX     @DPTR,A
+  667: 		}
+002925 21AB              AJMP     ?C0150?KB_PROCESS
+002927         ?C0155?KB_PROCESS:
+  668: 		else if(key_value == HID_KEY_ENTER)
+002927 EB                MOV      A,R3
+002928 6428              XRL      A,#028H
+00292A 4A                ORL      A,R2
+00292B 7008              JNZ      ?C0157?KB_PROCESS
+  669: 		{
+  670: 			temp = HID_KEY_SCROLL_LOCK;
+00292D 904F02            MOV      DPTR,#temp
+002930 7447              MOV      A,#047H
+002932 F0                MOVX     @DPTR,A
+  671: 		}
+002933 8076              SJMP     ?C0150?KB_PROCESS
+002935         ?C0157?KB_PROCESS:
+  672: 		else if(key_value == HID_KEY_BACKSPACE)
+002935 EB                MOV      A,R3
+002936 642A              XRL      A,#02AH
+002938 4A                ORL      A,R2
+002939 7008              JNZ      ?C0159?KB_PROCESS
+  673: 		{
+  674: 			temp = HID_MULTIKEY_OS_LOCK;
+00293B 904F02            MOV      DPTR,#temp
+00293E 74DA              MOV      A,#0DAH
+002940 F0                MOVX     @DPTR,A
+  675: 		}
+002941 8068              SJMP     ?C0150?KB_PROCESS
+002943         ?C0159?KB_PROCESS:
+  676: 		else if(key_value == HID_KEY_ESC)
+002943 EB                MOV      A,R3
+002944 6429              XRL      A,#029H
+002946 4A                ORL      A,R2
+002947 7062              JNZ      ?C0150?KB_PROCESS
+  677: 		{
+  678: 			if(state & 1)
+002949 EC                MOV      A,R4
+00294A 30E059            JNB      ACC.0,?C0162?KB_PROCESS
+  679: 			{						
+  680: 				if(fn_lock_flag)
+00294D 904DE7            MOV      DPTR,#fn_lock_flag
+002950 E0                MOVX     A,@DPTR
+002951 6004              JZ       ?C0163?KB_PROCESS
+  681: 				{
+  682: 					fn_lock_flag = 0;
+002953 E4                CLR      A
+002954 F0                MOVX     @DPTR,A
+  683: 				}
+002955 8006              SJMP     ?C0164?KB_PROCESS
+002957         ?C0163?KB_PROCESS:
+  684: 				else
+  685: 					fn_lock_flag = 1;
+002957 904DE7            MOV      DPTR,#fn_lock_flag
+00295A 7401              MOV      A,#01H
+00295C F0                MOVX     @DPTR,A
+00295D         ?C0164?KB_PROCESS:
+  686: 					
+  687: 				if(g_variable.current_device_num == 0 || g_variable.current_device_num == 0xfe)
+00295D 904CC3            MOV      DPTR,#g_variable+04H
+002960 E0                MOVX     A,@DPTR
+002961 FB                MOV      R3,A
+002962 7A00              MOV      R2,#00H
+002964 6004              JZ       ?C0166?KB_PROCESS
+002966 64FE              XRL      A,#0FEH
+002968 7008              JNZ      ?C0165?KB_PROCESS
+00296A         ?C0166?KB_PROCESS:
+  688: 				{
+  689: 					g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_G24;
+00296A 904CBF            MOV      DPTR,#g_variable
+00296D 7402              MOV      A,#02H
+00296F F0                MOVX     @DPTR,A
+  690: 				}
+002970 8034              SJMP     ?C0162?KB_PROCESS
+002972         ?C0165?KB_PROCESS:
+  691: 				else	if (g_variable.current_device_num <= 3 && g_variable.current_device_num >= 1)
+002972 D3                SETB     C
+002973 EB                MOV      A,R3
+002974 9403              SUBB     A,#03H
+002976 EA                MOV      A,R2
+002977 6480              XRL      A,#080H
+002979 9480              SUBB     A,#080H
+00297B 5029              JNC      ?C0162?KB_PROCESS
+00297D C3                CLR      C
+00297E EB                MOV      A,R3
+00297F 9401              SUBB     A,#01H
+002981 EA                MOV      A,R2
+002982 6480              XRL      A,#080H
+002984 9480              SUBB     A,#080H
+002986 401E              JC       ?C0162?KB_PROCESS
+  692: 				{
+  693: 					bd_key_record_list[g_variable.current_device_num - 1].fn_lock = fn_lock_flag;
+002988 904DE7            MOV      DPTR,#fn_lock_flag
+00298B E0                MOVX     A,@DPTR
+00298C FF                MOV      R7,A
+00298D 904CC3            MOV      DPTR,#g_variable+04H
+002990 E0                MOVX     A,@DPTR
+002991 75F01F            MOV      B,#01FH
+002994 A4                MUL      AB
+002995 24ED              ADD      A,#LOW bd_key_record_list-01H
+002997 F582              MOV      DPL,A
+002999 E4                CLR      A
+00299A 344D              ADDC     A,#HIGH bd_key_record_list-01H
+00299C F583              MOV      DPH,A
+00299E EF                MOV      A,R7
+00299F F0                MOVX     @DPTR,A
+  694: 					g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_BT;
+0029A0 904CBF            MOV      DPTR,#g_variable
+0029A3 7403              MOV      A,#03H
+0029A5 F0                MOVX     @DPTR,A
+  695: 				}
+  696: 			}
+0029A6         ?C0162?KB_PROCESS:
+  697: 			temp = HID_KEY_NULL;
+0029A6 E4                CLR      A
+0029A7 904F02            MOV      DPTR,#temp
+0029AA F0                MOVX     @DPTR,A
+  698: 		}		
+  699: 	}
+0029AB         ?C0150?KB_PROCESS:
+  700: 	
+  701: 	if((!fast_connect_flag)  && ((!fn_flag && !fn_lock_flag) || (fn_flag == 1 && fn_lock_flag == 1)))
+0029AB 904E55            MOV      DPTR,#fast_connect_flag
+0029AE E0                MOVX     A,@DPTR
+0029AF 6002              JZ       $ + 4H
+0029B1 41C5              AJMP     ?C0169?KB_PROCESS
+0029B3 904DE2            MOV      DPTR,#fn_flag
+0029B6 E0                MOVX     A,@DPTR
+0029B7 7006              JNZ      ?C0171?KB_PROCESS
+0029B9 904DE7            MOV      DPTR,#fn_lock_flag
+0029BC E0                MOVX     A,@DPTR
+0029BD 6014              JZ       ?C0170?KB_PROCESS
+0029BF         ?C0171?KB_PROCESS:
+0029BF 904DE2            MOV      DPTR,#fn_flag
+0029C2 E0                MOVX     A,@DPTR
+0029C3 6401              XRL      A,#01H
+0029C5 6002              JZ       $ + 4H
+0029C7 41C5              AJMP     ?C0169?KB_PROCESS
+0029C9 904DE7            MOV      DPTR,#fn_lock_flag
+0029CC E0                MOVX     A,@DPTR
+0029CD 6401              XRL      A,#01H
+0029CF 6002              JZ       $ + 4H
+0029D1 41C5              AJMP     ?C0169?KB_PROCESS
+0029D3         ?C0170?KB_PROCESS:
+  702: 	{
+  703: 		switch (key_value)
+0029D3 EE                MOV      A,R6
+0029D4 24C6              ADD      A,#0C6H
+0029D6 B40C00            CJNE     A,#0CH,?C0258?KB_PROCESS
+0029D9         ?C0258?KB_PROCESS:
+0029D9 4002              JC       $ + 4H
+0029DB 41C5              AJMP     ?C0169?KB_PROCESS
+0029DD 9029EB            MOV      DPTR,#029EBH
+0029E0 75F003            MOV      B,#03H
+0029E3 A4                MUL      AB
+0029E4 C583              XCH      A,DPH
+0029E6 25F0              ADD      A,B
+0029E8 C583              XCH      A,DPH
+0029EA 73                JMP      @A+DPTR
+0029EB         ?C0259?KB_PROCESS:
+0029EB 022A0F            LJMP     ?C0173?KB_PROCESS
+0029EE 022A17            LJMP     ?C0174?KB_PROCESS
+0029F1 022A1F            LJMP     ?C0175?KB_PROCESS
+0029F4 022A27            LJMP     ?C0176?KB_PROCESS
+0029F7 022A72            LJMP     ?C0184?KB_PROCESS
+0029FA 022A8F            LJMP     ?C0187?KB_PROCESS
+0029FD 022A97            LJMP     ?C0188?KB_PROCESS
+002A00 022A9F            LJMP     ?C0189?KB_PROCESS
+002A03 022AA7            LJMP     ?C0190?KB_PROCESS
+002A06 022AAF            LJMP     ?C0191?KB_PROCESS
+002A09 022AB7            LJMP     ?C0192?KB_PROCESS
+002A0C 022ABF            LJMP     ?C0193?KB_PROCESS
+  704: 		{ 	
+  705: 			case HID_KEY_F1:
+002A0F         ?C0173?KB_PROCESS:
+  706: 				temp = HID_MULTIKEY_LIGHT_DOWN;	
+002A0F 904F02            MOV      DPTR,#temp
+002A12 74D7              MOV      A,#0D7H
+002A14 F0                MOVX     @DPTR,A
+  707: 				break;
+002A15 41C5              AJMP     ?C0169?KB_PROCESS
+  708: 			case HID_KEY_F2:
+002A17         ?C0174?KB_PROCESS:
+  709: 				temp = HID_MULTIKEY_LIGHT_UP;
+002A17 904F02            MOV      DPTR,#temp
+002A1A 74D8              MOV      A,#0D8H
+002A1C F0                MOVX     @DPTR,A
+  710: 				break;
+002A1D 41C5              AJMP     ?C0169?KB_PROCESS
+  711: 			case HID_KEY_F3:
+002A1F         ?C0175?KB_PROCESS:
+  712: 				temp = HID_MULTIKEY_AC_HOME;
+002A1F 904F02            MOV      DPTR,#temp
+002A22 74D6              MOV      A,#0D6H
+002A24 F0                MOVX     @DPTR,A
+  713: 				break;
+002A25 41C5              AJMP     ?C0169?KB_PROCESS
+  714: 			case HID_KEY_F4:
+002A27         ?C0176?KB_PROCESS:
+  715: 				if(g_variable.system_mode == OSMODE_WINDOWS)
+002A27 904CC1            MOV      DPTR,#g_variable+02H
+002A2A E0                MOVX     A,@DPTR
+002A2B FE                MOV      R6,A
+002A2C 7014              JNZ      ?C0177?KB_PROCESS
+  716: 				{
+  717: 					kb_combination_key_press(state,KS_SEL_LALT,HID_KEY_TAB);
+002A2E AF04              MOV      R7,AR4
+002A30 7B2B              MOV      R3,#02BH
+002A32 7D04              MOV      R5,#04H
+002A34 1160              ACALL    _kb_combination_key_press
+  718: 					if(state & 1)
+002A36 EC                MOV      A,R4
+002A37 30E031            JNB      ACC.0,?C0179?KB_PROCESS
+  719: 					{						
+  720: 						g_variable.one_key_press_wait_release_timer = 10;
+002A3A 904CF8            MOV      DPTR,#g_variable+039H
+002A3D 740A              MOV      A,#0AH
+002A3F F0                MOVX     @DPTR,A
+  721: 					}
+  722: 				}
+002A40 8029              SJMP     ?C0179?KB_PROCESS
+002A42         ?C0177?KB_PROCESS:
+  723: 				else if(g_variable.system_mode == OSMODE_MAC)
+002A42 EE                MOV      A,R6
+002A43 6401              XRL      A,#01H
+002A45 700A              JNZ      ?C0180?KB_PROCESS
+  724: 				{
+  725: 					kb_combination_key_press(state,KS_SEL_LCTRL,HID_KEY_UP_ARROW);
+002A47 AF04              MOV      R7,AR4
+002A49 7B52              MOV      R3,#052H
+002A4B 7D01              MOV      R5,#01H
+002A4D 1160              ACALL    _kb_combination_key_press
+  726: 				}
+002A4F 801A              SJMP     ?C0179?KB_PROCESS
+002A51         ?C0180?KB_PROCESS:
+  727: 				else if(g_variable.system_mode == OSMODE_IOS)
+002A51 904CC1            MOV      DPTR,#g_variable+02H
+002A54 E0                MOVX     A,@DPTR
+002A55 6402              XRL      A,#02H
+002A57 7012              JNZ      ?C0179?KB_PROCESS
+  728: 				{
+  729: 					kb_combination_key_press(state,KS_SEL_LGUI,HID_KEY_TAB);
+002A59 AF04              MOV      R7,AR4
+002A5B 7B2B              MOV      R3,#02BH
+002A5D 7D08              MOV      R5,#08H
+002A5F 1160              ACALL    _kb_combination_key_press
+  730: 					if(state & 1)
+002A61 EC                MOV      A,R4
+002A62 30E006            JNB      ACC.0,?C0179?KB_PROCESS
+  731: 					{						
+  732: 						g_variable.one_key_press_wait_release_timer = 10;
+002A65 904CF8            MOV      DPTR,#g_variable+039H
+002A68 740A              MOV      A,#0AH
+002A6A F0                MOVX     @DPTR,A
+  733: 					}
+  734: 				}
+002A6B         ?C0179?KB_PROCESS:
+  735: 				temp = HID_KEY_NULL;
+002A6B E4                CLR      A
+002A6C 904F02            MOV      DPTR,#temp
+002A6F F0                MOVX     @DPTR,A
+  736: 				break;
+002A70 8053              SJMP     ?C0169?KB_PROCESS
+  737: 			case HID_KEY_F5:
+002A72         ?C0184?KB_PROCESS:
+  738: 				if(g_variable.system_mode == OSMODE_WINDOWS)
+002A72 904CC1            MOV      DPTR,#g_variable+02H
+002A75 E0                MOVX     A,@DPTR
+002A76 7008              JNZ      ?C0185?KB_PROCESS
+  739: 				{
+  740: 					temp = HID_MULTIKEY_AC_BACK;
+002A78 904F02            MOV      DPTR,#temp
+002A7B 74D2              MOV      A,#0D2H
+002A7D F0                MOVX     @DPTR,A
+  741: 				}
+002A7E 8045              SJMP     ?C0169?KB_PROCESS
+002A80         ?C0185?KB_PROCESS:
+  742: 				else
+  743: 				{
+  744: 					kb_combination_key_press(state,KS_SEL_LGUI,HID_KEY_LEFT_ARROW);
+002A80 AF04              MOV      R7,AR4
+002A82 7B50              MOV      R3,#050H
+002A84 7D08              MOV      R5,#08H
+002A86 1160              ACALL    _kb_combination_key_press
+  745: 					temp = HID_KEY_NULL;
+002A88 E4                CLR      A
+002A89 904F02            MOV      DPTR,#temp
+002A8C F0                MOVX     @DPTR,A
+  746: 				}
+  747: 				break;
+002A8D 8036              SJMP     ?C0169?KB_PROCESS
+  748: 			case HID_KEY_F6:
+002A8F         ?C0187?KB_PROCESS:
+  749: 				temp = HID_MULTIKEY_AC_SEARCH;
+002A8F 904F02            MOV      DPTR,#temp
+002A92 74D5              MOV      A,#0D5H
+002A94 F0                MOVX     @DPTR,A
+  750: 				break;
+002A95 802E              SJMP     ?C0169?KB_PROCESS
+  751: 			case HID_KEY_F7:
+002A97         ?C0188?KB_PROCESS:
+  752: 				temp = HID_MULTIKEY_PRE_TRACK;
+002A97 904F02            MOV      DPTR,#temp
+002A9A 74F4              MOV      A,#0F4H
+002A9C F0                MOVX     @DPTR,A
+  753: 				break;	
+002A9D 8026              SJMP     ?C0169?KB_PROCESS
+  754: 			case HID_KEY_F8:
+002A9F         ?C0189?KB_PROCESS:
+  755: 				temp = HID_MULTIKEY_PALY;
+002A9F 904F02            MOV      DPTR,#temp
+002AA2 74F2              MOV      A,#0F2H
+002AA4 F0                MOVX     @DPTR,A
+  756: 				break;
+002AA5 801E              SJMP     ?C0169?KB_PROCESS
+  757: 			case HID_KEY_F9:
+002AA7         ?C0190?KB_PROCESS:
+  758: 				temp = HID_MULTIKEY_NEXT_TRACK;
+002AA7 904F02            MOV      DPTR,#temp
+002AAA 74F5              MOV      A,#0F5H
+002AAC F0                MOVX     @DPTR,A
+  759: 				break;
+002AAD 8016              SJMP     ?C0169?KB_PROCESS
+  760: 			case HID_KEY_F10:
+002AAF         ?C0191?KB_PROCESS:
+  761: 				temp = HID_MULTIKEY_MUTE;
+002AAF 904F02            MOV      DPTR,#temp
+002AB2 74F8              MOV      A,#0F8H
+002AB4 F0                MOVX     @DPTR,A
+  762: 				break;
+002AB5 800E              SJMP     ?C0169?KB_PROCESS
+  763: 			case HID_KEY_F11:
+002AB7         ?C0192?KB_PROCESS:
+  764: 				temp = HID_MULTIKEY_VOL_DOWN;
+002AB7 904F02            MOV      DPTR,#temp
+002ABA 74F6              MOV      A,#0F6H
+002ABC F0                MOVX     @DPTR,A
+  765: 				break;
+002ABD 8006              SJMP     ?C0169?KB_PROCESS
+  766: 			case HID_KEY_F12:
+002ABF         ?C0193?KB_PROCESS:
+  767: 				temp = HID_MULTIKEY_VOL_UP;
+002ABF 904F02            MOV      DPTR,#temp
+002AC2 74F7              MOV      A,#0F7H
+002AC4 F0                MOVX     @DPTR,A
+  768: 				break;
+  769: 			default :
+  770: 				break;
+  771: 		}
+  772: 	}
+002AC5         ?C0169?KB_PROCESS:
+  773: 
+  774: 	return temp;
+002AC5 904F02            MOV      DPTR,#temp
+002AC8 E0                MOVX     A,@DPTR
+002AC9 FF                MOV      R7,A
+  775: }
+002ACA 22                RET      
+----- FUNCTION _key_fn_function (END) -------
+
+
+----- FUNCTION KS_GetCurrentEvt (BEGIN) -----
+ FILE: 'keyscan.c'
+  292: tKSEVENT *KS_GetCurrentEvt()
+  293: {
+  294: 	//
+  295: 	byte i = 0;
+002ACB E4                CLR      A
+002ACC 904E88            MOV      DPTR,#i
+002ACF F0                MOVX     @DPTR,A
+  296: 	byte j = 0;
+002AD0 A3                INC      DPTR
+002AD1 F0                MOVX     @DPTR,A
+  297: 	byte k = 0;
+002AD2 A3                INC      DPTR
+002AD3 F0                MOVX     @DPTR,A
+  298: 	byte temp = 0;
+002AD4 A3                INC      DPTR
+002AD5 F0                MOVX     @DPTR,A
+  299: 	byte flag = 0;
+002AD6 A3                INC      DPTR
+002AD7 F0                MOVX     @DPTR,A
+  300: 	byte offset = 0;
+002AD8 A3                INC      DPTR
+002AD9 F0                MOVX     @DPTR,A
+  301: 	byte state = 0;
+002ADA A3                INC      DPTR
+002ADB F0                MOVX     @DPTR,A
+  302: 	byte keyCounttemp = 0;
+002ADC A3                INC      DPTR
+002ADD F0                MOVX     @DPTR,A
+  303: 	byte key_value_temp = 0;
+002ADE A3                INC      DPTR
+002ADF F0                MOVX     @DPTR,A
+  304: 	byte ghost = 0;
+002AE0 A3                INC      DPTR
+002AE1 F0                MOVX     @DPTR,A
+  305: 	byte rawCount = 0;
+002AE2 A3                INC      DPTR
+002AE3 F0                MOVX     @DPTR,A
+  306: 	
+  307: 	KS_ScanMatrix();
+002AE4 D1DE              ACALL    KS_ScanMatrix
+  308: 
+  309: 	if (compare_str(ksSelMapCurr,ksSelMapCheck,KB_KSCAN_COL_NUM) 
+002AE6 7A4D              MOV      R2,#HIGH ksSelMapCheck
+002AE8 79A8              MOV      R1,#LOW ksSelMapCheck
+002AEA 904EAE            MOV      DPTR,#?_compare_str?BYTE+03H
+002AED 7401              MOV      A,#01H
+002AEF F0                MOVX     @DPTR,A
+002AF0 A3                INC      DPTR
+002AF1 744D              MOV      A,#HIGH ksSelMapCheck
+002AF3 F0                MOVX     @DPTR,A
+002AF4 A3                INC      DPTR
+002AF5 74A8              MOV      A,#LOW ksSelMapCheck
+002AF7 F0                MOVX     @DPTR,A
+002AF8 A3                INC      DPTR
+002AF9 7414              MOV      A,#014H
+002AFB F0                MOVX     @DPTR,A
+002AFC 7B01              MOV      R3,#01H
+002AFE 7A4D              MOV      R2,#HIGH ksSelMapCurr
+002B00 79BC              MOV      R1,#LOW ksSelMapCurr
+002B02 B16B              ACALL    _compare_str
+002B04 EF                MOV      A,R7
+002B05 601C              JZ       ?C0059?KEYSCAN
+002B07 7B01              MOV      R3,#01H
+002B09 7A4D              MOV      R2,#HIGH ksSelMapCurr
+002B0B 79BC              MOV      R1,#LOW ksSelMapCurr
+002B0D 7D14              MOV      R5,#014H
+002B0F B13B              ACALL    _array_is_empty
+002B11 EF                MOV      A,R7
+002B12 700F              JNZ      ?C0059?KEYSCAN
+  310: 		&& !array_is_empty(ksSelMapCurr,KB_KSCAN_COL_NUM))
+  311: 	{
+  312: 		g_variable.button_flag |= 0x02;
+002B14 904CCE            MOV      DPTR,#g_variable+0FH
+002B17 E0                MOVX     A,@DPTR
+002B18 4402              ORL      A,#02H
+002B1A F0                MOVX     @DPTR,A
+  313: 		g_variable.battery_motion_check_interval = BATTERY_MOTION_CHECK_INTERVAL;
+002B1B 904D06            MOV      DPTR,#g_variable+047H
+002B1E 7414              MOV      A,#014H
+002B20 F0                MOVX     @DPTR,A
+  314: 	}
+002B21 800C              SJMP     ?C0060?KEYSCAN
+002B23         ?C0059?KEYSCAN:
+  315: 	else
+  316: 	{	
+  317: 		g_variable.button_flag &= 0xFD;
+002B23 904CCE            MOV      DPTR,#g_variable+0FH
+002B26 E0                MOVX     A,@DPTR
+002B27 54FD              ANL      A,#0FDH
+002B29 F0                MOVX     @DPTR,A
+  318: 		g_variable.button_timer[1] = 0;
+002B2A E4                CLR      A
+002B2B 904CD0            MOV      DPTR,#g_variable+011H
+002B2E F0                MOVX     @DPTR,A
+  319: 	}
+002B2F         ?C0060?KEYSCAN:
+  320: 
+  321: 	for (i=0; col[i]!=0; i++) 
+002B2F E4                CLR      A
+002B30 904E88            MOV      DPTR,#i
+002B33 F0                MOVX     @DPTR,A
+002B34         ?C0061?KEYSCAN:
+002B34 904E88            MOV      DPTR,#i
+002B37 E0                MOVX     A,@DPTR
+002B38 FF                MOV      R7,A
+002B39 900681            MOV      DPTR,#col
+002B3C 93                MOVC     A,@A+DPTR
+002B3D 7002              JNZ      $ + 4H
+002B3F 8109              AJMP     ?C0062?KEYSCAN
+  322: 	{
+  323: 		temp = ksSelMapCurr[i];
+002B41 74BC              MOV      A,#LOW ksSelMapCurr
+002B43 2F                ADD      A,R7
+002B44 F582              MOV      DPL,A
+002B46 E4                CLR      A
+002B47 344D              ADDC     A,#HIGH ksSelMapCurr
+002B49 F583              MOV      DPH,A
+002B4B E0                MOVX     A,@DPTR
+002B4C 904E8B            MOV      DPTR,#temp
+002B4F F0                MOVX     @DPTR,A
+  324: 		rawCount = bit_count(temp);
+002B50 E0                MOVX     A,@DPTR
+002B51 FF                MOV      R7,A
+002B52 B12D              ACALL    _bit_count
+002B54 904E92            MOV      DPTR,#rawCount
+002B57 EF                MOV      A,R7
+002B58 F0                MOVX     @DPTR,A
+  325: 		if(rawCount >= 2)		// col[i] has more than two key press
+002B59 C3                CLR      C
+002B5A 9402              SUBB     A,#02H
+002B5C 7480              MOV      A,#080H
+002B5E 9480              SUBB     A,#080H
+002B60 5002              JNC      $ + 4H
+002B62 61F2              AJMP     ?C0064?KEYSCAN
+  326: 		{
+  327: 			for(j=0 ; j<8 ;j++)
+002B64 E4                CLR      A
+002B65 904E89            MOV      DPTR,#j
+002B68 F0                MOVX     @DPTR,A
+002B69         ?C0065?KEYSCAN:
+002B69 904E89            MOV      DPTR,#j
+002B6C E0                MOVX     A,@DPTR
+002B6D FF                MOV      R7,A
+002B6E C3                CLR      C
+002B6F 9408              SUBB     A,#08H
+002B71 7480              MOV      A,#080H
+002B73 9480              SUBB     A,#080H
+002B75 507B              JNC      ?C0064?KEYSCAN
+  328: 			{
+  329: 				if(temp & (1<<j))	// Ci_Rj press
+002B77 7E00              MOV      R6,#00H
+002B79 7401              MOV      A,#01H
+002B7B A807              MOV      R0,AR7
+002B7D 08                INC      R0
+002B7E 8005              SJMP     ?C0103?KEYSCAN
+002B80         ?C0102?KEYSCAN:
+002B80 C3                CLR      C
+002B81 33                RLC      A
+002B82 CE                XCH      A,R6
+002B83 33                RLC      A
+002B84 CE                XCH      A,R6
+002B85         ?C0103?KEYSCAN:
+002B85 D8F9              DJNZ     R0,?C0102?KEYSCAN
+002B87 FF                MOV      R7,A
+002B88 904E8B            MOV      DPTR,#temp
+002B8B E0                MOVX     A,@DPTR
+002B8C FD                MOV      R5,A
+002B8D E4                CLR      A
+002B8E EF                MOV      A,R7
+002B8F 5D                ANL      A,R5
+002B90 6058              JZ       ?C0067?KEYSCAN
+  330: 				{
+  331: 					for(k=0 ; col[k]!=0; k++)
+002B92 E4                CLR      A
+002B93 904E8A            MOV      DPTR,#k
+002B96 F0                MOVX     @DPTR,A
+002B97         ?C0069?KEYSCAN:
+002B97 904E8A            MOV      DPTR,#k
+002B9A E0                MOVX     A,@DPTR
+002B9B FF                MOV      R7,A
+002B9C 900681            MOV      DPTR,#col
+002B9F 93                MOVC     A,@A+DPTR
+002BA0 6048              JZ       ?C0067?KEYSCAN
+  332: 					{
+  333: 						if(k!= i)
+002BA2 904E88            MOV      DPTR,#i
+002BA5 E0                MOVX     A,@DPTR
+002BA6 FE                MOV      R6,A
+002BA7 EF                MOV      A,R7
+002BA8 6E                XRL      A,R6
+002BA9 6037              JZ       ?C0071?KEYSCAN
+  334: 						{
+  335: 							if(ksSelMapCurr[k] & (1<<j))	// R line has another key press
+002BAB 904E8A            MOV      DPTR,#k
+002BAE E0                MOVX     A,@DPTR
+002BAF 24BC              ADD      A,#LOW ksSelMapCurr
+002BB1 F582              MOV      DPL,A
+002BB3 E4                CLR      A
+002BB4 344D              ADDC     A,#HIGH ksSelMapCurr
+002BB6 F583              MOV      DPH,A
+002BB8 E0                MOVX     A,@DPTR
+002BB9 FD                MOV      R5,A
+002BBA 7C00              MOV      R4,#00H
+002BBC 904E89            MOV      DPTR,#j
+002BBF E0                MOVX     A,@DPTR
+002BC0 FF                MOV      R7,A
+002BC1 7E00              MOV      R6,#00H
+002BC3 7401              MOV      A,#01H
+002BC5 A807              MOV      R0,AR7
+002BC7 08                INC      R0
+002BC8 8005              SJMP     ?C0105?KEYSCAN
+002BCA         ?C0104?KEYSCAN:
+002BCA C3                CLR      C
+002BCB 33                RLC      A
+002BCC CE                XCH      A,R6
+002BCD 33                RLC      A
+002BCE CE                XCH      A,R6
+002BCF         ?C0105?KEYSCAN:
+002BCF D8F9              DJNZ     R0,?C0104?KEYSCAN
+002BD1 FF                MOV      R7,A
+002BD2 EE                MOV      A,R6
+002BD3 5C                ANL      A,R4
+002BD4 FE                MOV      R6,A
+002BD5 EF                MOV      A,R7
+002BD6 5D                ANL      A,R5
+002BD7 4E                ORL      A,R6
+002BD8 6008              JZ       ?C0071?KEYSCAN
+  336: 							{
+  337: 								ghost = 1;
+002BDA 904E91            MOV      DPTR,#ghost
+002BDD 7401              MOV      A,#01H
+002BDF F0                MOVX     @DPTR,A
+  338: 								break;
+002BE0 8008              SJMP     ?C0067?KEYSCAN
+  339: 							}	
+  340: 						}
+  341: 					}
+002BE2         ?C0071?KEYSCAN:
+002BE2 904E8A            MOV      DPTR,#k
+002BE5 E0                MOVX     A,@DPTR
+002BE6 04                INC      A
+002BE7 F0                MOVX     @DPTR,A
+002BE8 80AD              SJMP     ?C0069?KEYSCAN
+  342: 				}
+  343: 			}
+002BEA         ?C0067?KEYSCAN:
+002BEA 904E89            MOV      DPTR,#j
+002BED E0                MOVX     A,@DPTR
+002BEE 04                INC      A
+002BEF F0                MOVX     @DPTR,A
+002BF0 6169              AJMP     ?C0065?KEYSCAN
+  344: 		}
+002BF2         ?C0064?KEYSCAN:
+  345: 		
+  346: 		if (temp!=0)
+002BF2 904E8B            MOV      DPTR,#temp
+002BF5 E0                MOVX     A,@DPTR
+002BF6 FF                MOV      R7,A
+002BF7 6008              JZ       ?C0063?KEYSCAN
+  347: 		{
+  348: 			keyCounttemp += bit_count(temp);
+002BF9 B12D              ACALL    _bit_count
+002BFB 904E8F            MOV      DPTR,#keyCounttemp
+002BFE E0                MOVX     A,@DPTR
+002BFF 2F                ADD      A,R7
+002C00 F0                MOVX     @DPTR,A
+  349: 		}
+  350: 	}
+002C01         ?C0063?KEYSCAN:
+002C01 904E88            MOV      DPTR,#i
+002C04 E0                MOVX     A,@DPTR
+002C05 04                INC      A
+002C06 F0                MOVX     @DPTR,A
+002C07 6134              AJMP     ?C0061?KEYSCAN
+002C09         ?C0062?KEYSCAN:
+  351: 	keyCount = keyCounttemp;
+002C09 904E8F            MOV      DPTR,#keyCounttemp
+002C0C E0                MOVX     A,@DPTR
+002C0D 904DE4            MOV      DPTR,#keyCount
+002C10 F0                MOVX     @DPTR,A
+  352: 	
+  353: 	for (i=0; col[i]!=0; i++)
+002C11 E4                CLR      A
+002C12 904E88            MOV      DPTR,#i
+002C15 F0                MOVX     @DPTR,A
+002C16         ?C0075?KEYSCAN:
+002C16 904E88            MOV      DPTR,#i
+002C19 E0                MOVX     A,@DPTR
+002C1A FB                MOV      R3,A
+002C1B 900681            MOV      DPTR,#col
+002C1E 93                MOVC     A,@A+DPTR
+002C1F 7002              JNZ      $ + 4H
+002C21 81FE              AJMP     ?C0076?KEYSCAN
+  354: 	{
+  355: 		temp = ksSelMapCurr[i] ^ ksSelMapOld[i];
+002C23 904E88            MOV      DPTR,#i
+002C26 E0                MOVX     A,@DPTR
+002C27 FE                MOV      R6,A
+002C28 2493              ADD      A,#LOW ksSelMapOld
+002C2A F582              MOV      DPL,A
+002C2C E4                CLR      A
+002C2D 344D              ADDC     A,#HIGH ksSelMapOld
+002C2F F583              MOV      DPH,A
+002C31 E0                MOVX     A,@DPTR
+002C32 FD                MOV      R5,A
+002C33 74BC              MOV      A,#LOW ksSelMapCurr
+002C35 2E                ADD      A,R6
+002C36 F582              MOV      DPL,A
+002C38 E4                CLR      A
+002C39 344D              ADDC     A,#HIGH ksSelMapCurr
+002C3B F583              MOV      DPH,A
+002C3D E0                MOVX     A,@DPTR
+002C3E 6D                XRL      A,R5
+002C3F 904E8B            MOV      DPTR,#temp
+002C42 F0                MOVX     @DPTR,A
+  356: 		state = ksSelMapCurr[i];
+002C43 74BC              MOV      A,#LOW ksSelMapCurr
+002C45 2B                ADD      A,R3
+002C46 F582              MOV      DPL,A
+002C48 E4                CLR      A
+002C49 344D              ADDC     A,#HIGH ksSelMapCurr
+002C4B F583              MOV      DPH,A
+002C4D E0                MOVX     A,@DPTR
+002C4E 904E8E            MOV      DPTR,#state
+002C51 F0                MOVX     @DPTR,A
+  357: 		if (temp == 0) 
+002C52 904E8B            MOV      DPTR,#temp
+002C55 E0                MOVX     A,@DPTR
+002C56 7002              JNZ      $ + 4H
+002C58 81F6              AJMP     ?C0077?KEYSCAN
+  358: 		{
+  359: 			continue;
+  360: 		}
+  361: 		else 
+  362: 		{
+  363: 
+  364: 			if (ghost) 
+002C5A 904E91            MOV      DPTR,#ghost
+002C5D E0                MOVX     A,@DPTR
+002C5E 6007              JZ       ?C0080?KEYSCAN
+  365: 				return NULL;
+002C60 7B00              MOV      R3,#00H
+002C62 7A00              MOV      R2,#00H
+002C64 7900              MOV      R1,#00H
+002C66 22                RET      
+002C67         ?C0080?KEYSCAN:
+  366: 			ksSelMapOld[i] = ksSelMapCurr[i];
+002C67 904E88            MOV      DPTR,#i
+002C6A E0                MOVX     A,@DPTR
+002C6B FF                MOV      R7,A
+002C6C 24BC              ADD      A,#LOW ksSelMapCurr
+002C6E F582              MOV      DPL,A
+002C70 E4                CLR      A
+002C71 344D              ADDC     A,#HIGH ksSelMapCurr
+002C73 F583              MOV      DPH,A
+002C75 E0                MOVX     A,@DPTR
+002C76 FE                MOV      R6,A
+002C77 7493              MOV      A,#LOW ksSelMapOld
+002C79 2F                ADD      A,R7
+002C7A F582              MOV      DPL,A
+002C7C E4                CLR      A
+002C7D 344D              ADDC     A,#HIGH ksSelMapOld
+002C7F F583              MOV      DPH,A
+002C81 EE                MOV      A,R6
+002C82 F0                MOVX     @DPTR,A
+  367: 			for (j = 0 ; j<8 ; j++) 
+002C83 E4                CLR      A
+002C84 904E89            MOV      DPTR,#j
+002C87 F0                MOVX     @DPTR,A
+002C88         ?C0082?KEYSCAN:
+002C88 904E89            MOV      DPTR,#j
+002C8B E0                MOVX     A,@DPTR
+002C8C FF                MOV      R7,A
+002C8D C3                CLR      C
+002C8E 9408              SUBB     A,#08H
+002C90 7480              MOV      A,#080H
+002C92 9480              SUBB     A,#080H
+002C94 505A              JNC      ?C0083?KEYSCAN
+  368: 			{
+  369: 				if (temp&1)
+002C96 904E8B            MOV      DPTR,#temp
+002C99 E0                MOVX     A,@DPTR
+002C9A 30E03B            JNB      ACC.0,?C0085?KEYSCAN
+  370: 				{
+  371: 					offset = i<<3 |j;
+002C9D 904E88            MOV      DPTR,#i
+002CA0 E0                MOVX     A,@DPTR
+002CA1 FE                MOV      R6,A
+002CA2 33                RLC      A
+002CA3 33                RLC      A
+002CA4 33                RLC      A
+002CA5 54F8              ANL      A,#0F8H
+002CA7 FE                MOV      R6,A
+002CA8 EF                MOV      A,R7
+002CA9 4E                ORL      A,R6
+002CAA 904E8D            MOV      DPTR,#offset
+002CAD F0                MOVX     @DPTR,A
+  372: 					key_value_temp = key_fn_function(state,ksMap[offset]);
+002CAE A3                INC      DPTR
+002CAF E0                MOVX     A,@DPTR
+002CB0 FF                MOV      R7,A
+002CB1 904E8D            MOV      DPTR,#offset
+002CB4 E0                MOVX     A,@DPTR
+002CB5 900696            MOV      DPTR,#ksMap
+002CB8 93                MOVC     A,@A+DPTR
+002CB9 FD                MOV      R5,A
+002CBA 1186              ACALL    _key_fn_function
+002CBC 904E90            MOV      DPTR,#key_value_temp
+002CBF EF                MOV      A,R7
+002CC0 F0                MOVX     @DPTR,A
+  373: 					if (state & 1)
+002CC1 904E8E            MOV      DPTR,#state
+002CC4 E0                MOVX     A,@DPTR
+002CC5 30E009            JNB      ACC.0,?C0086?KEYSCAN
+  374: 					{
+  375: 						keyIn(key_value_temp);
+002CC8 904E90            MOV      DPTR,#key_value_temp
+002CCB E0                MOVX     A,@DPTR
+002CCC FF                MOV      R7,A
+002CCD B1B5              ACALL    _keyIn
+  376: 					}
+002CCF 8007              SJMP     ?C0085?KEYSCAN
+002CD1         ?C0086?KEYSCAN:
+  377: 					else
+  378: 					{
+  379: 						keyOut(key_value_temp);
+002CD1 904E90            MOV      DPTR,#key_value_temp
+002CD4 E0                MOVX     A,@DPTR
+002CD5 FF                MOV      R7,A
+002CD6 D11D              ACALL    _keyOut
+  380: 					}
+  381: 				}
+002CD8         ?C0085?KEYSCAN:
+  382: 				temp = temp >>1;
+002CD8 904E8B            MOV      DPTR,#temp
+002CDB E0                MOVX     A,@DPTR
+002CDC FF                MOV      R7,A
+002CDD C3                CLR      C
+002CDE 13                RRC      A
+002CDF F0                MOVX     @DPTR,A
+  383: 				state = state>>1;
+002CE0 904E8E            MOV      DPTR,#state
+002CE3 E0                MOVX     A,@DPTR
+002CE4 FF                MOV      R7,A
+002CE5 C3                CLR      C
+002CE6 13                RRC      A
+002CE7 F0                MOVX     @DPTR,A
+  384: 			}
+002CE8 904E89            MOV      DPTR,#j
+002CEB E0                MOVX     A,@DPTR
+002CEC 04                INC      A
+002CED F0                MOVX     @DPTR,A
+002CEE 8098              SJMP     ?C0082?KEYSCAN
+002CF0         ?C0083?KEYSCAN:
+  385: 			flag = 1;
+002CF0 904E8C            MOV      DPTR,#flag
+002CF3 7401              MOV      A,#01H
+002CF5 F0                MOVX     @DPTR,A
+  386: 		}
+  387: 	}
+002CF6         ?C0077?KEYSCAN:
+002CF6 904E88            MOV      DPTR,#i
+002CF9 E0                MOVX     A,@DPTR
+002CFA 04                INC      A
+002CFB F0                MOVX     @DPTR,A
+002CFC 8116              AJMP     ?C0075?KEYSCAN
+002CFE         ?C0076?KEYSCAN:
+  388: 	
+  389: 	if((mult_key_status == KEY_RELEASE) && (standard_key_release_flag == 1))
+002CFE 904E4B            MOV      DPTR,#mult_key_status
+002D01 E0                MOVX     A,@DPTR
+002D02 6403              XRL      A,#03H
+002D04 700B              JNZ      ?C0088?KEYSCAN
+002D06 904DDF            MOV      DPTR,#standard_key_release_flag
+002D09 E0                MOVX     A,@DPTR
+002D0A 6401              XRL      A,#01H
+002D0C 7003              JNZ      ?C0088?KEYSCAN
+  390: 	{
+  391: 		standard_key_release_flag = 2;		//media key and standard key  release the same time
+002D0E 7402              MOV      A,#02H
+002D10 F0                MOVX     @DPTR,A
+  392: 	}
+002D11         ?C0088?KEYSCAN:
+  393: 
+  394: 	
+  395: 	if (flag || standard_key_release_flag == 2) 
+002D11 904E8C            MOV      DPTR,#flag
+002D14 E0                MOVX     A,@DPTR
+002D15 7008              JNZ      ?C0090?KEYSCAN
+002D17 904DDF            MOV      DPTR,#standard_key_release_flag
+002D1A E0                MOVX     A,@DPTR
+002D1B 6402              XRL      A,#02H
+002D1D 7007              JNZ      ?C0089?KEYSCAN
+002D1F         ?C0090?KEYSCAN:
+  396: 	{
+  397: 		return &ksEvtPool;
+002D1F 7B01              MOV      R3,#01H
+002D21 7A4E              MOV      R2,#HIGH ksEvtPool
+002D23 79A4              MOV      R1,#LOW ksEvtPool
+002D25 22                RET      
+  398: 	}
+002D26         ?C0089?KEYSCAN:
+  399: 	else
+  400: 	{
+  401: 		return NULL;
+002D26 7B00              MOV      R3,#00H
+002D28 7A00              MOV      R2,#00H
+002D2A 7900              MOV      R1,#00H
+  402: 	}
+  403: 	
+  404: 
+  405: }
+002D2C 22                RET      
+----- FUNCTION KS_GetCurrentEvt (END) -------
+
+
+----- FUNCTION _bit_count (BEGIN) -----
+ FILE: 'keyscan.c'
+   24: static byte bit_count(byte v)
+   25: {
+;---- Variable 'v' assigned to Register 'R7' ----
+   26: 	unsigned char c;
+   27: 	for (c = 0; v; c++) {
+;---- Variable 'c' assigned to Register 'R6' ----
+002D2D E4                CLR      A
+002D2E FE                MOV      R6,A
+002D2F         ?C0001?KEYSCAN:
+002D2F EF                MOV      A,R7
+002D30 6006              JZ       ?C0002?KEYSCAN
+   28:     	v &= v - 1;
+002D32 14                DEC      A
+002D33 5F                ANL      A,R7
+002D34 FF                MOV      R7,A
+   29:     }
+002D35 0E                INC      R6
+002D36 80F7              SJMP     ?C0001?KEYSCAN
+002D38         ?C0002?KEYSCAN:
+   30:     return c;
+002D38 AF06              MOV      R7,AR6
+   31: }
+002D3A 22                RET      
+----- FUNCTION _bit_count (END) -------
+
+
+----- FUNCTION _array_is_empty (BEGIN) -----
+ FILE: 'keyscan.c'
+  280: byte array_is_empty(byte * str1,byte len)
+  281: {
+002D3B 904EE9            MOV      DPTR,#str1
+002D3E EB                MOV      A,R3
+002D3F F0                MOVX     @DPTR,A
+002D40 A3                INC      DPTR
+002D41 EA                MOV      A,R2
+002D42 F0                MOVX     @DPTR,A
+002D43 A3                INC      DPTR
+002D44 E9                MOV      A,R1
+002D45 F0                MOVX     @DPTR,A
+;---- Variable 'len' assigned to Register 'R5' ----
+  282: 	byte i;
+  283: 	for (i=0;i < len;i++)
+;---- Variable 'i' assigned to Register 'R7' ----
+002D46 E4                CLR      A
+002D47 FF                MOV      R7,A
+002D48         ?C0054?KEYSCAN:
+002D48 EF                MOV      A,R7
+002D49 C3                CLR      C
+002D4A 9D                SUBB     A,R5
+002D4B 501B              JNC      ?C0055?KEYSCAN
+  284: 	{
+  285: 		if (str1[i] != 0)
+002D4D 904EE9            MOV      DPTR,#str1
+002D50 E0                MOVX     A,@DPTR
+002D51 FB                MOV      R3,A
+002D52 A3                INC      DPTR
+002D53 E0                MOVX     A,@DPTR
+002D54 FA                MOV      R2,A
+002D55 A3                INC      DPTR
+002D56 E0                MOVX     A,@DPTR
+002D57 F9                MOV      R1,A
+002D58 8F82              MOV      DPL,R7
+002D5A 758300            MOV      DPH,#00H
+002D5D 1203CF            LCALL    ?C?CLDOPTR
+002D60 6003              JZ       ?C0056?KEYSCAN
+  286: 			return 0x00;
+002D62 7F00              MOV      R7,#00H
+002D64 22                RET      
+  287: 	}
+002D65         ?C0056?KEYSCAN:
+002D65 0F                INC      R7
+002D66 80E0              SJMP     ?C0054?KEYSCAN
+002D68         ?C0055?KEYSCAN:
+  288: 	return 0x01;
+002D68 7F01              MOV      R7,#01H
+  289: }
+002D6A 22                RET      
+----- FUNCTION _array_is_empty (END) -------
+
+
+----- FUNCTION _compare_str (BEGIN) -----
+002D6B 904EAB            MOV      DPTR,#str1
+002D6E EB                MOV      A,R3
+002D6F F0                MOVX     @DPTR,A
+002D70 A3                INC      DPTR
+002D71 EA                MOV      A,R2
+002D72 F0                MOVX     @DPTR,A
+002D73 A3                INC      DPTR
+002D74 E9                MOV      A,R1
+002D75 F0                MOVX     @DPTR,A
+;---- Variable 'i' assigned to Register 'R7' ----
+002D76 E4                CLR      A
+002D77 FF                MOV      R7,A
+002D78         ?C0021?UTILITIES:
+002D78 904EB1            MOV      DPTR,#len
+002D7B E0                MOVX     A,@DPTR
+002D7C FE                MOV      R6,A
+002D7D EF                MOV      A,R7
+002D7E C3                CLR      C
+002D7F 9E                SUBB     A,R6
+002D80 5030              JNC      ?C0022?UTILITIES
+002D82 904EAE            MOV      DPTR,#str2
+002D85 E0                MOVX     A,@DPTR
+002D86 FB                MOV      R3,A
+002D87 A3                INC      DPTR
+002D88 E0                MOVX     A,@DPTR
+002D89 FA                MOV      R2,A
+002D8A A3                INC      DPTR
+002D8B E0                MOVX     A,@DPTR
+002D8C F9                MOV      R1,A
+002D8D 8F82              MOV      DPL,R7
+002D8F 758300            MOV      DPH,#00H
+002D92 1203CF            LCALL    ?C?CLDOPTR
+002D95 FE                MOV      R6,A
+002D96 904EAB            MOV      DPTR,#str1
+002D99 E0                MOVX     A,@DPTR
+002D9A FB                MOV      R3,A
+002D9B A3                INC      DPTR
+002D9C E0                MOVX     A,@DPTR
+002D9D FA                MOV      R2,A
+002D9E A3                INC      DPTR
+002D9F E0                MOVX     A,@DPTR
+002DA0 F9                MOV      R1,A
+002DA1 8F82              MOV      DPL,R7
+002DA3 758300            MOV      DPH,#00H
+002DA6 1203CF            LCALL    ?C?CLDOPTR
+002DA9 6E                XRL      A,R6
+002DAA 6003              JZ       ?C0023?UTILITIES
+002DAC 7F00              MOV      R7,#00H
+002DAE 22                RET      
+002DAF         ?C0023?UTILITIES:
+002DAF 0F                INC      R7
+002DB0 80C6              SJMP     ?C0021?UTILITIES
+002DB2         ?C0022?UTILITIES:
+002DB2 7F01              MOV      R7,#01H
+002DB4 22                RET      
+----- FUNCTION _compare_str (END) -------
+
+
+----- FUNCTION _keyIn (BEGIN) -----
+ FILE: 'keyscan.c'
+   35: static void keyIn(byte key)
+   36: {
+;---- Variable 'key' assigned to Register 'R7' ----
+   37: 	byte i = 0;
+   38: 
+;---- Variable 'i' assigned to Register 'R6' ----
+002DB5 E4                CLR      A
+002DB6 FE                MOV      R6,A
+   39: 	if(key >= HID_KEY_LEFT_CTL && key <= HID_KEY_RIGHT_GUI)
+002DB7 EF                MOV      A,R7
+002DB8 FD                MOV      R5,A
+002DB9 7C00              MOV      R4,#00H
+002DBB C3                CLR      C
+002DBC 94E0              SUBB     A,#0E0H
+002DBE 7480              MOV      A,#080H
+002DC0 9480              SUBB     A,#080H
+002DC2 4023              JC       ?C0005?KEYSCAN
+002DC4 D3                SETB     C
+002DC5 ED                MOV      A,R5
+002DC6 94E7              SUBB     A,#0E7H
+002DC8 7480              MOV      A,#080H
+002DCA 9480              SUBB     A,#080H
+002DCC 5019              JNC      ?C0005?KEYSCAN
+   40: 	{
+   41: 		ksEvtPool.standardSel  |=  0x01 << (key & 0x07);
+002DCE 904EA4            MOV      DPTR,#ksEvtPool
+002DD1 E0                MOVX     A,@DPTR
+002DD2 FE                MOV      R6,A
+002DD3 EF                MOV      A,R7
+002DD4 5407              ANL      A,#07H
+002DD6 FF                MOV      R7,A
+002DD7 F8                MOV      R0,A
+002DD8 7401              MOV      A,#01H
+002DDA 08                INC      R0
+002DDB 8002              SJMP     ?C0093?KEYSCAN
+002DDD         ?C0092?KEYSCAN:
+002DDD C3                CLR      C
+002DDE 33                RLC      A
+002DDF         ?C0093?KEYSCAN:
+002DDF D8FC              DJNZ     R0,?C0092?KEYSCAN
+002DE1 4E                ORL      A,R6
+002DE2 904EA4            MOV      DPTR,#ksEvtPool
+002DE5 F0                MOVX     @DPTR,A
+002DE6 22                RET      
+   42: 		return;
+   43: 	}
+002DE7         ?C0005?KEYSCAN:
+   44: /*
+   45: 
+   46: 	if (key == HID_KEY_RIGHT_GUI)
+   47: 	{
+   48: 		ksEvtPool.standardSel |= KS_SEL_RGUI;
+   49: 		return;
+   50: 	}
+   51: 	else if (key ==HID_KEY_RIGHT_ALT) 
+   52: 	{
+   53: 		ksEvtPool.standardSel |= KS_SEL_RALT;
+   54: 		return;
+   55: 	}
+   56: 	else if (key ==HID_KEY_RIGHT_SHIFT) 
+   57: 	{
+   58: 		ksEvtPool.standardSel |= KS_SEL_RSHIFT;
+   59: 		return;
+   60: 	}
+   61: 	else if (key ==HID_KEY_RIGHT_CTL) 
+   62: 	{
+   63: 		ksEvtPool.standardSel |= KS_SEL_RCTRL;
+   64: 		return;
+   65: 	}
+   66: 	else if (key ==HID_KEY_LEFT_GUI) 
+   67: 	{
+   68: 		ksEvtPool.standardSel |= KS_SEL_LGUI;
+   69: 		return;
+   70: 	}
+   71: 	else if (key ==HID_KEY_LEFT_ALT) 
+   72: 	{
+   73: 		ksEvtPool.standardSel |= KS_SEL_LALT;
+   74: 		return;
+   75: 	}
+   76: 	else if (key ==HID_KEY_LEFT_SHIFT)
+   77: 	{
+   78: 		ksEvtPool.standardSel |= KS_SEL_LSHIFT;
+   79: 		return;
+   80: 	}
+   81: 	else if (key ==HID_KEY_LEFT_CTL) 
+   82: 	{
+   83: 		ksEvtPool.standardSel |= KS_SEL_LCTRL;
+   84: 		return;
+   85: 	}
+   86: */	
+   87: 	//special key
+   88: 
+   89: 	for (i=0 ; i<KS_BUFF_POLL_LEN ; i++) 
+002DE7 E4                CLR      A
+002DE8 FE                MOV      R6,A
+002DE9         ?C0007?KEYSCAN:
+002DE9 EE                MOV      A,R6
+002DEA C3                CLR      C
+002DEB 9406              SUBB     A,#06H
+002DED 7480              MOV      A,#080H
+002DEF 9480              SUBB     A,#080H
+002DF1 5029              JNC      ?C0006?KEYSCAN
+   90: 	{
+   91: 		if (ksEvtPool.ksPool[i] == key)
+002DF3 74A5              MOV      A,#LOW ksEvtPool+01H
+002DF5 2E                ADD      A,R6
+002DF6 F582              MOV      DPL,A
+002DF8 E4                CLR      A
+002DF9 344E              ADDC     A,#HIGH ksEvtPool+01H
+002DFB F583              MOV      DPH,A
+002DFD E0                MOVX     A,@DPTR
+002DFE FD                MOV      R5,A
+002DFF 6F                XRL      A,R7
+002E00 601A              JZ       ?C0006?KEYSCAN
+   92: 			break;
+   93: 		if (ksEvtPool.ksPool[i] == 0) 
+002E02 ED                MOV      A,R5
+002E03 7014              JNZ      ?C0009?KEYSCAN
+   94: 		{
+   95: 			if(mult_key_value != key)
+002E05 904DED            MOV      DPTR,#mult_key_value
+002E08 E0                MOVX     A,@DPTR
+002E09 6F                XRL      A,R7
+002E0A 6010              JZ       ?C0006?KEYSCAN
+   96: 				ksEvtPool.ksPool[i] = key;
+002E0C 74A5              MOV      A,#LOW ksEvtPool+01H
+002E0E 2E                ADD      A,R6
+002E0F F582              MOV      DPL,A
+002E11 E4                CLR      A
+002E12 344E              ADDC     A,#HIGH ksEvtPool+01H
+002E14 F583              MOV      DPH,A
+002E16 EF                MOV      A,R7
+002E17 F0                MOVX     @DPTR,A
+   97: 			break;
+002E18 22                RET      
+   98: 		}
+   99: 	}
+002E19         ?C0009?KEYSCAN:
+002E19 0E                INC      R6
+002E1A 80CD              SJMP     ?C0007?KEYSCAN
+  100: }
+002E1C         ?C0006?KEYSCAN:
+002E1C 22                RET      
+----- FUNCTION _keyIn (END) -------
+
+
+----- FUNCTION _keyOut (BEGIN) -----
+ FILE: 'keyscan.c'
+  102: static void keyOut(byte key)
+  103: {
+;---- Variable 'key' assigned to Register 'R7' ----
+  104: 	byte i = 0 ;
+  105: 	byte found = 0;
+;---- Variable 'i' assigned to Register 'R6' ----
+002E1D E4                CLR      A
+002E1E FE                MOV      R6,A
+  106: 
+;---- Variable 'found' assigned to Register 'R5' ----
+002E1F FD                MOV      R5,A
+  107: 	if ((key &0xF0) == 0xf0 || (key &0xD0) == 0xD0)
+002E20 EF                MOV      A,R7
+002E21 54F0              ANL      A,#0F0H
+002E23 64F0              XRL      A,#0F0H
+002E25 6007              JZ       ?C0014?KEYSCAN
+002E27 EF                MOV      A,R7
+002E28 54D0              ANL      A,#0D0H
+002E2A 64D0              XRL      A,#0D0H
+002E2C 700D              JNZ      ?C0013?KEYSCAN
+002E2E         ?C0014?KEYSCAN:
+  108: 	{
+  109: 		if(mult_key_status == KEY_WAIT_RELEASE)
+002E2E 904E4B            MOV      DPTR,#mult_key_status
+002E31 E0                MOVX     A,@DPTR
+002E32 6402              XRL      A,#02H
+002E34 700B              JNZ      ?C0016?KEYSCAN
+  110: 		{
+  111: 			mult_key_status = KEY_RELEASE;
+002E36 7403              MOV      A,#03H
+002E38 F0                MOVX     @DPTR,A
+  112: 		}
+  113: 	}
+002E39 8006              SJMP     ?C0016?KEYSCAN
+002E3B         ?C0013?KEYSCAN:
+  114: 	else
+  115: 		standard_key_release_flag = 1;
+002E3B 904DDF            MOV      DPTR,#standard_key_release_flag
+002E3E 7401              MOV      A,#01H
+002E40 F0                MOVX     @DPTR,A
+002E41         ?C0016?KEYSCAN:
+  116: 
+  117: 	if(key >= HID_KEY_LEFT_CTL && key <= HID_KEY_RIGHT_GUI)
+002E41 EF                MOV      A,R7
+002E42 FB                MOV      R3,A
+002E43 7A00              MOV      R2,#00H
+002E45 C3                CLR      C
+002E46 94E0              SUBB     A,#0E0H
+002E48 7480              MOV      A,#080H
+002E4A 9480              SUBB     A,#080H
+002E4C 4024              JC       ?C0017?KEYSCAN
+002E4E D3                SETB     C
+002E4F EB                MOV      A,R3
+002E50 94E7              SUBB     A,#0E7H
+002E52 7480              MOV      A,#080H
+002E54 9480              SUBB     A,#080H
+002E56 501A              JNC      ?C0017?KEYSCAN
+  118: 	{
+  119: 		ksEvtPool.standardSel  &= ~(0x01 << (key & 0x07));
+002E58 904EA4            MOV      DPTR,#ksEvtPool
+002E5B E0                MOVX     A,@DPTR
+002E5C FE                MOV      R6,A
+002E5D EF                MOV      A,R7
+002E5E 5407              ANL      A,#07H
+002E60 FF                MOV      R7,A
+002E61 F8                MOV      R0,A
+002E62 7401              MOV      A,#01H
+002E64 08                INC      R0
+002E65 8002              SJMP     ?C0095?KEYSCAN
+002E67         ?C0094?KEYSCAN:
+002E67 C3                CLR      C
+002E68 33                RLC      A
+002E69         ?C0095?KEYSCAN:
+002E69 D8FC              DJNZ     R0,?C0094?KEYSCAN
+002E6B F4                CPL      A
+002E6C 5E                ANL      A,R6
+002E6D 904EA4            MOV      DPTR,#ksEvtPool
+002E70 F0                MOVX     @DPTR,A
+002E71 22                RET      
+  120: 		return;
+  121: 	}
+002E72         ?C0017?KEYSCAN:
+  122: 	
+  123: 
+  124: /*
+  125: 	if (key == HID_KEY_RIGHT_GUI ) 
+  126: 	{
+  127: 		ksEvtPool.standardSel &= ~KS_SEL_RGUI;
+  128: 		return;
+  129: 	}
+  130: 	else if (key ==HID_KEY_RIGHT_ALT ) 
+  131: 	{
+  132: 		ksEvtPool.standardSel &= ~KS_SEL_RALT;
+  133: 		return;
+  134: 	}
+  135: 	else if (key ==HID_KEY_RIGHT_SHIFT) 
+  136: 	{
+  137: 		ksEvtPool.standardSel &= ~KS_SEL_RSHIFT;
+  138: 		return;
+  139: 	}
+  140: 	else if (key ==HID_KEY_RIGHT_CTL) 
+  141: 	{
+  142: 		ksEvtPool.standardSel &= ~KS_SEL_RCTRL;
+  143: 		return;
+  144: 	}
+  145: 	else if (key ==HID_KEY_LEFT_GUI)
+  146: 	{
+  147: 		ksEvtPool.standardSel &= ~KS_SEL_LGUI;
+  148: 		return;
+  149: 	}
+  150: 	else if (key ==HID_KEY_LEFT_ALT)
+  151: 	{
+  152: 		ksEvtPool.standardSel &= ~KS_SEL_LALT;
+  153: 		return;
+  154: 	}
+  155: 	else if (key ==HID_KEY_LEFT_SHIFT) 
+  156: 	{
+  157: 		ksEvtPool.standardSel &= ~KS_SEL_LSHIFT;
+  158: 		return;
+  159: 	}
+  160: 	else if (key ==HID_KEY_LEFT_CTL) 
+  161: 	{
+  162: 		ksEvtPool.standardSel &= ~ KS_SEL_LCTRL;
+  163: 		return;
+  164: 	}
+  165: */	
+  166: 	for (i=0 ; i<KS_BUFF_POLL_LEN ; i++) 
+002E72 E4                CLR      A
+002E73 FE                MOV      R6,A
+002E74         ?C0019?KEYSCAN:
+002E74 EE                MOV      A,R6
+002E75 C3                CLR      C
+002E76 9406              SUBB     A,#06H
+002E78 7480              MOV      A,#080H
+002E7A 9480              SUBB     A,#080H
+002E7C 505F              JNC      ?C0018?KEYSCAN
+  167: 	{
+  168: 		if (found == 0) 
+002E7E ED                MOV      A,R5
+002E7F 7023              JNZ      ?C0022?KEYSCAN
+  169: 		{
+  170: 			if (ksEvtPool.ksPool[i] == key) {
+002E81 74A5              MOV      A,#LOW ksEvtPool+01H
+002E83 2E                ADD      A,R6
+002E84 F582              MOV      DPL,A
+002E86 E4                CLR      A
+002E87 344E              ADDC     A,#HIGH ksEvtPool+01H
+002E89 F583              MOV      DPH,A
+002E8B E0                MOVX     A,@DPTR
+002E8C 6F                XRL      A,R7
+002E8D 704B              JNZ      ?C0021?KEYSCAN
+  171: 				if (i == KS_BUFF_POLL_LEN-1) {
+002E8F EE                MOV      A,R6
+002E90 6405              XRL      A,#05H
+002E92 700C              JNZ      ?C0024?KEYSCAN
+  172: 					ksEvtPool.ksPool[i] = 0;
+002E94 74A5              MOV      A,#LOW ksEvtPool+01H
+002E96 2E                ADD      A,R6
+002E97 F582              MOV      DPL,A
+002E99 E4                CLR      A
+002E9A 344E              ADDC     A,#HIGH ksEvtPool+01H
+002E9C F583              MOV      DPH,A
+002E9E E4                CLR      A
+002E9F F0                MOVX     @DPTR,A
+  173: 				}
+002EA0         ?C0024?KEYSCAN:
+  174: 				found = 1;
+002EA0 7D01              MOV      R5,#01H
+  175: 			}
+  176: 		}
+002EA2 8036              SJMP     ?C0021?KEYSCAN
+002EA4         ?C0022?KEYSCAN:
+  177: 		else 
+  178: 		{
+  179: 			ksEvtPool.ksPool[i-1] = ksEvtPool.ksPool[i];
+002EA4 74A5              MOV      A,#LOW ksEvtPool+01H
+002EA6 2E                ADD      A,R6
+002EA7 F582              MOV      DPL,A
+002EA9 E4                CLR      A
+002EAA 344E              ADDC     A,#HIGH ksEvtPool+01H
+002EAC F583              MOV      DPH,A
+002EAE E0                MOVX     A,@DPTR
+002EAF FC                MOV      R4,A
+002EB0 74A4              MOV      A,#LOW ksEvtPool
+002EB2 2E                ADD      A,R6
+002EB3 F582              MOV      DPL,A
+002EB5 E4                CLR      A
+002EB6 344E              ADDC     A,#HIGH ksEvtPool
+002EB8 F583              MOV      DPH,A
+002EBA EC                MOV      A,R4
+002EBB F0                MOVX     @DPTR,A
+  180: 			if (ksEvtPool.ksPool[i] == 0)
+002EBC 74A5              MOV      A,#LOW ksEvtPool+01H
+002EBE 2E                ADD      A,R6
+002EBF F582              MOV      DPL,A
+002EC1 E4                CLR      A
+002EC2 344E              ADDC     A,#HIGH ksEvtPool+01H
+002EC4 F583              MOV      DPH,A
+002EC6 E0                MOVX     A,@DPTR
+002EC7 6014              JZ       ?C0018?KEYSCAN
+  181: 				break;
+  182: 			if (i == KS_BUFF_POLL_LEN-1) {
+002EC9 EE                MOV      A,R6
+002ECA 6405              XRL      A,#05H
+002ECC 700C              JNZ      ?C0021?KEYSCAN
+  183: 				ksEvtPool.ksPool[i] = 0;
+002ECE 74A5              MOV      A,#LOW ksEvtPool+01H
+002ED0 2E                ADD      A,R6
+002ED1 F582              MOV      DPL,A
+002ED3 E4                CLR      A
+002ED4 344E              ADDC     A,#HIGH ksEvtPool+01H
+002ED6 F583              MOV      DPH,A
+002ED8 E4                CLR      A
+002ED9 F0                MOVX     @DPTR,A
+  184: 			}
+  185: 		}
+  186: 	}
+002EDA         ?C0021?KEYSCAN:
+002EDA 0E                INC      R6
+002EDB 8097              SJMP     ?C0019?KEYSCAN
+  187: }
+002EDD         ?C0018?KEYSCAN:
+002EDD 22                RET      
+----- FUNCTION _keyOut (END) -------
+
+
+----- FUNCTION KS_ScanMatrix (BEGIN) -----
+ FILE: 'keyscan.c'
+  253: void KS_ScanMatrix()
+  254: {
+  255: 	byte i = 0;
+  256: 	byte j = 0;
+;---- Variable 'i' assigned to Register 'R7' ----
+002EDE E4                CLR      A
+002EDF FF                MOV      R7,A
+  257: 	byte tgroup = 0;
+002EE0 904EE6            MOV      DPTR,#j
+002EE3 F0                MOVX     @DPTR,A
+  258: 	byte tgpionum = 0;
+;---- Variable 'tgroup' assigned to Register 'R6' ----
+002EE4 FE                MOV      R6,A
+  259: 	byte temp = 0;
+;---- Variable 'tgpionum' assigned to Register 'R5' ----
+002EE5 FD                MOV      R5,A
+  260: 	byte check = 0;
+002EE6 A3                INC      DPTR
+002EE7 F0                MOVX     @DPTR,A
+  261: 	for (i=0; col[i]!=0; i++) {
+002EE8 A3                INC      DPTR
+002EE9 F0                MOVX     @DPTR,A
+  262: 		tgroup = col[i]  >> 3;
+002EEA         ?C0043?KEYSCAN:
+002EEA EF                MOV      A,R7
+002EEB 900681            MOV      DPTR,#col
+002EEE 93                MOVC     A,@A+DPTR
+002EEF 607B              JZ       ?C0044?KEYSCAN
+  263: 		tgpionum = 1 << (col[i] & 7);
+002EF1 EF                MOV      A,R7
+002EF2 93                MOVC     A,@A+DPTR
+002EF3 FD                MOV      R5,A
+002EF4 13                RRC      A
+002EF5 13                RRC      A
+002EF6 13                RRC      A
+002EF7 541F              ANL      A,#01FH
+002EF9 FE                MOV      R6,A
+  264: 		GET_RAW_KEY_SEL(ksSelMapCurr[i], tgroup, tgpionum);
+002EFA ED                MOV      A,R5
+002EFB 5407              ANL      A,#07H
+002EFD FD                MOV      R5,A
+002EFE F8                MOV      R0,A
+002EFF 7401              MOV      A,#01H
+002F01 08                INC      R0
+002F02 8002              SJMP     ?C0099?KEYSCAN
+002F04         ?C0098?KEYSCAN:
+002F04 C3                CLR      C
+002F05 33                RLC      A
+002F06         ?C0099?KEYSCAN:
+002F06 D8FC              DJNZ     R0,?C0098?KEYSCAN
+002F08 FD                MOV      R5,A
+  265: 	}
+002F09 EE                MOV      A,R6
+002F0A 2478              ADD      A,#078H
+002F0C FB                MOV      R3,A
+002F0D E4                CLR      A
+002F0E 3480              ADDC     A,#080H
+002F10 8B82              MOV      DPL,R3
+002F12 F583              MOV      DPH,A
+002F14 E0                MOVX     A,@DPTR
+002F15 FC                MOV      R4,A
+002F16 ED                MOV      A,R5
+002F17 F4                CPL      A
+002F18 FB                MOV      R3,A
+002F19 EC                MOV      A,R4
+002F1A 5B                ANL      A,R3
+002F1B F0                MOVX     @DPTR,A
+002F1C EE                MOV      A,R6
+002F1D 2470              ADD      A,#070H
+002F1F F582              MOV      DPL,A
+002F21 E4                CLR      A
+002F22 3480              ADDC     A,#080H
+002F24 F583              MOV      DPH,A
+002F26 E0                MOVX     A,@DPTR
+002F27 4D                ORL      A,R5
+002F28 F0                MOVX     @DPTR,A
+002F29 EE                MOV      A,R6
+002F2A 2474              ADD      A,#074H
+002F2C F582              MOV      DPL,A
+002F2E E4                CLR      A
+002F2F 3480              ADDC     A,#080H
+002F31 F583              MOV      DPH,A
+002F33 E0                MOVX     A,@DPTR
+002F34 5B                ANL      A,R3
+002F35 F0                MOVX     @DPTR,A
+002F36 90811C            MOV      DPTR,#0811CH
+002F39 E0                MOVX     A,@DPTR
+002F3A F4                CPL      A
+002F3B FC                MOV      R4,A
+002F3C 74BC              MOV      A,#LOW ksSelMapCurr
+002F3E 2F                ADD      A,R7
+002F3F F582              MOV      DPL,A
+002F41 E4                CLR      A
+002F42 344D              ADDC     A,#HIGH ksSelMapCurr
+002F44 F583              MOV      DPH,A
+002F46 EC                MOV      A,R4
+002F47 F0                MOVX     @DPTR,A
+002F48 EE                MOV      A,R6
+002F49 2478              ADD      A,#078H
+002F4B FB                MOV      R3,A
+002F4C E4                CLR      A
+002F4D 3480              ADDC     A,#080H
+002F4F 8B82              MOV      DPL,R3
+002F51 F583              MOV      DPH,A
+002F53 E0                MOVX     A,@DPTR
+002F54 4D                ORL      A,R5
+002F55 F0                MOVX     @DPTR,A
+002F56 EE                MOV      A,R6
+002F57 2470              ADD      A,#070H
+002F59 FB                MOV      R3,A
+002F5A E4                CLR      A
+002F5B 3480              ADDC     A,#080H
+002F5D 8B82              MOV      DPL,R3
+002F5F F583              MOV      DPH,A
+002F61 E0                MOVX     A,@DPTR
+002F62 FC                MOV      R4,A
+002F63 ED                MOV      A,R5
+002F64 F4                CPL      A
+002F65 FB                MOV      R3,A
+002F66 EC                MOV      A,R4
+002F67 5B                ANL      A,R3
+002F68 F0                MOVX     @DPTR,A
+  266: 
+002F69 0F                INC      R7
+002F6A C1EA              AJMP     ?C0043?KEYSCAN
+002F6C         ?C0044?KEYSCAN:
+  267: 	for (i=0; col[i]!=0; i++) {
+002F6C E4                CLR      A
+002F6D FF                MOV      R7,A
+002F6E         ?C0046?KEYSCAN:
+002F6E EF                MOV      A,R7
+002F6F 900681            MOV      DPTR,#col
+002F72 93                MOVC     A,@A+DPTR
+002F73 607B              JZ       ?C0047?KEYSCAN
+  268: 		tgroup = col[i]  >> 3;
+002F75 EF                MOV      A,R7
+002F76 93                MOVC     A,@A+DPTR
+002F77 FD                MOV      R5,A
+002F78 13                RRC      A
+002F79 13                RRC      A
+002F7A 13                RRC      A
+002F7B 541F              ANL      A,#01FH
+002F7D FE                MOV      R6,A
+  269: 		tgpionum = 1 << (col[i] & 7);
+002F7E ED                MOV      A,R5
+002F7F 5407              ANL      A,#07H
+002F81 FD                MOV      R5,A
+002F82 F8                MOV      R0,A
+002F83 7401              MOV      A,#01H
+002F85 08                INC      R0
+002F86 8002              SJMP     ?C0101?KEYSCAN
+002F88         ?C0100?KEYSCAN:
+002F88 C3                CLR      C
+002F89 33                RLC      A
+002F8A         ?C0101?KEYSCAN:
+002F8A D8FC              DJNZ     R0,?C0100?KEYSCAN
+002F8C FD                MOV      R5,A
+  270: 		GET_RAW_KEY_SEL(ksSelMapCheck[i], tgroup, tgpionum);
+002F8D EE                MOV      A,R6
+002F8E 2478              ADD      A,#078H
+002F90 FB                MOV      R3,A
+002F91 E4                CLR      A
+002F92 3480              ADDC     A,#080H
+002F94 8B82              MOV      DPL,R3
+002F96 F583              MOV      DPH,A
+002F98 E0                MOVX     A,@DPTR
+002F99 FC                MOV      R4,A
+002F9A ED                MOV      A,R5
+002F9B F4                CPL      A
+002F9C FB                MOV      R3,A
+002F9D EC                MOV      A,R4
+002F9E 5B                ANL      A,R3
+002F9F F0                MOVX     @DPTR,A
+002FA0 EE                MOV      A,R6
+002FA1 2470              ADD      A,#070H
+002FA3 F582              MOV      DPL,A
+002FA5 E4                CLR      A
+002FA6 3480              ADDC     A,#080H
+002FA8 F583              MOV      DPH,A
+002FAA E0                MOVX     A,@DPTR
+002FAB 4D                ORL      A,R5
+002FAC F0                MOVX     @DPTR,A
+002FAD EE                MOV      A,R6
+002FAE 2474              ADD      A,#074H
+002FB0 F582              MOV      DPL,A
+002FB2 E4                CLR      A
+002FB3 3480              ADDC     A,#080H
+002FB5 F583              MOV      DPH,A
+002FB7 E0                MOVX     A,@DPTR
+002FB8 5B                ANL      A,R3
+002FB9 F0                MOVX     @DPTR,A
+002FBA 90811C            MOV      DPTR,#0811CH
+002FBD E0                MOVX     A,@DPTR
+002FBE F4                CPL      A
+002FBF FC                MOV      R4,A
+002FC0 74A8              MOV      A,#LOW ksSelMapCheck
+002FC2 2F                ADD      A,R7
+002FC3 F582              MOV      DPL,A
+002FC5 E4                CLR      A
+002FC6 344D              ADDC     A,#HIGH ksSelMapCheck
+002FC8 F583              MOV      DPH,A
+002FCA EC                MOV      A,R4
+002FCB F0                MOVX     @DPTR,A
+002FCC EE                MOV      A,R6
+002FCD 2478              ADD      A,#078H
+002FCF FB                MOV      R3,A
+002FD0 E4                CLR      A
+002FD1 3480              ADDC     A,#080H
+002FD3 8B82              MOV      DPL,R3
+002FD5 F583              MOV      DPH,A
+002FD7 E0                MOVX     A,@DPTR
+002FD8 4D                ORL      A,R5
+002FD9 F0                MOVX     @DPTR,A
+002FDA EE                MOV      A,R6
+002FDB 2470              ADD      A,#070H
+002FDD FB                MOV      R3,A
+002FDE E4                CLR      A
+002FDF 3480              ADDC     A,#080H
+002FE1 8B82              MOV      DPL,R3
+002FE3 F583              MOV      DPH,A
+002FE5 E0                MOVX     A,@DPTR
+002FE6 FC                MOV      R4,A
+002FE7 ED                MOV      A,R5
+002FE8 F4                CPL      A
+002FE9 FB                MOV      R3,A
+002FEA EC                MOV      A,R4
+002FEB 5B                ANL      A,R3
+002FEC F0                MOVX     @DPTR,A
+  271: 	}
+002FED 0F                INC      R7
+002FEE E16E              AJMP     ?C0046?KEYSCAN
+002FF0         ?C0047?KEYSCAN:
+  272: 
+  273: 	for (i=0; col[i]!=0; i++) {
+002FF0 E4                CLR      A
+002FF1 FF                MOV      R7,A
+002FF2         ?C0049?KEYSCAN:
+002FF2 EF                MOV      A,R7
+002FF3 900681            MOV      DPTR,#col
+002FF6 93                MOVC     A,@A+DPTR
+002FF7 6040              JZ       ?C0053?KEYSCAN
+  274: 		if (ksSelMapCheck[i]!=ksSelMapCurr[i]) {
+002FF9 74BC              MOV      A,#LOW ksSelMapCurr
+002FFB 2F                ADD      A,R7
+002FFC F582              MOV      DPL,A
+002FFE E4                CLR      A
+002FFF 344D              ADDC     A,#HIGH ksSelMapCurr
+003001 F583              MOV      DPH,A
+003003 E0                MOVX     A,@DPTR
+003004 FE                MOV      R6,A
+003005 74A8              MOV      A,#LOW ksSelMapCheck
+003007 2F                ADD      A,R7
+003008 F582              MOV      DPL,A
+00300A E4                CLR      A
+00300B 344D              ADDC     A,#HIGH ksSelMapCheck
+00300D F583              MOV      DPH,A
+00300F E0                MOVX     A,@DPTR
+003010 6E                XRL      A,R6
+003011 6023              JZ       ?C0051?KEYSCAN
+  275: 			ksSelMapCurr[i] &= ksSelMapCheck[i];
+003013 74BC              MOV      A,#LOW ksSelMapCurr
+003015 2F                ADD      A,R7
+003016 F582              MOV      DPL,A
+003018 E4                CLR      A
+003019 344D              ADDC     A,#HIGH ksSelMapCurr
+00301B F583              MOV      DPH,A
+00301D C083              PUSH     DPH
+00301F C082              PUSH     DPL
+003021 E0                MOVX     A,@DPTR
+003022 FE                MOV      R6,A
+003023 74A8              MOV      A,#LOW ksSelMapCheck
+003025 2F                ADD      A,R7
+003026 F582              MOV      DPL,A
+003028 E4                CLR      A
+003029 344D              ADDC     A,#HIGH ksSelMapCheck
+00302B F583              MOV      DPH,A
+00302D E0                MOVX     A,@DPTR
+00302E FD                MOV      R5,A
+00302F EE                MOV      A,R6
+003030 5D                ANL      A,R5
+003031 D082              POP      DPL
+003033 D083              POP      DPH
+003035 F0                MOVX     @DPTR,A
+  276: 		}
+  277: 	}
+003036         ?C0051?KEYSCAN:
+003036 0F                INC      R7
+003037 80B9              SJMP     ?C0049?KEYSCAN
+  278: }
+003039         ?C0053?KEYSCAN:
+003039 22                RET      
+----- FUNCTION KS_ScanMatrix (END) -------
+
+
+----- FUNCTION System_IIC_clk_setup (BEGIN) -----
+ FILE: 'sys.c'
+   43: static void System_IIC_clk_setup()		// 400KHz
+   44: {
+   45: 	REG_IICD_SCL_LOW  =  0x0d;
+   46:    	REG_IICD_SCL_HIGH  =  0x0e;
+00303A 908091            MOV      DPTR,#08091H
+00303D 740D              MOV      A,#0DH
+00303F F0                MOVX     @DPTR,A
+   47:    	REG_IICD_START_SETUP  = 0x0e;
+003040 A3                INC      DPTR
+003041 04                INC      A
+003042 F0                MOVX     @DPTR,A
+   48:    	REG_IICD_START_HOLD  = 0x0e;
+003043 A3                INC      DPTR
+003044 F0                MOVX     @DPTR,A
+   49:   	REG_IICD_STOP_SETUP  = 0x0e;
+003045 A3                INC      DPTR
+003046 F0                MOVX     @DPTR,A
+   50:    	REG_IICD_DATA_SETUP  = 0x0d;
+003047 A3                INC      DPTR
+003048 F0                MOVX     @DPTR,A
+   51: }
+003049 A3                INC      DPTR
+00304A 14                DEC      A
+00304B F0                MOVX     @DPTR,A
+   52: 
+00304C 22                RET      
+----- FUNCTION System_IIC_clk_setup (END) -------
+
+
+----- FUNCTION System_Software_init (BEGIN) -----
+ FILE: 'sys.c'
+   61: void System_Software_init()
+   62: {
+   63: 	System_clear_mem();
+   64: 	YC_adc_init();
+00304D 120E26            LCALL    System_clear_mem
+   65: 	g_variable.release_data =1;
+003050 1182              ACALL    YC_adc_init
+   66: 	g_variable.powerOn_timer = KB_POWERON_LED_ON_TIMER;
+003052 904CEB            MOV      DPTR,#g_variable+02CH
+003055 7401              MOV      A,#01H
+003057 F0                MOVX     @DPTR,A
+   67: //	g_variable.powerOn_first_flag = 1;
+003058 904CE5            MOV      DPTR,#g_variable+026H
+00305B 740A              MOV      A,#0AH
+00305D F0                MOVX     @DPTR,A
+   68: 	g_variable.recon_count = 0;
+00305E E4                CLR      A
+00305F 904CF0            MOV      DPTR,#g_variable+031H
+003062 F0                MOVX     @DPTR,A
+   69: 	g_variable.test_buff = 0xff;
+003063 904D05            MOV      DPTR,#g_variable+046H
+003066 74FF              MOV      A,#0FFH
+003068 F0                MOVX     @DPTR,A
+   70: 	le_lap_temp[0] = m_le_lap[3];
+003069 9044FC            MOV      DPTR,#m_le_lap+03H
+00306C E0                MOVX     A,@DPTR
+00306D 904DD0            MOV      DPTR,#le_lap_temp
+003070 F0                MOVX     @DPTR,A
+   71: 	le_lap_temp[1] = m_le_lap[4];
+003071 9044FD            MOV      DPTR,#m_le_lap+04H
+003074 E0                MOVX     A,@DPTR
+003075 904DD1            MOV      DPTR,#le_lap_temp+01H
+003078 F0                MOVX     @DPTR,A
+   72: 	le_lap_temp[2] = m_le_lap[5];
+003079 9044FE            MOV      DPTR,#m_le_lap+05H
+00307C E0                MOVX     A,@DPTR
+00307D 904DD2            MOV      DPTR,#le_lap_temp+02H
+003080 F0                MOVX     @DPTR,A
+   73: }
+003081 22                RET      
+----- FUNCTION System_Software_init (END) -------
+
+
+----- FUNCTION YC_adc_init (BEGIN) -----
+ FILE: 'adc.c'
+    3: void YC_adc_init()
+    4: {
+    5: #ifdef  ADC_ENABLE
+    6: 	byte i;
+    7: 	
+    8: 	g_variable.battery_check_interval = BATTERY_CHECK_INTERVAL;
+003082 904CD3            MOV      DPTR,#g_variable+014H
+003085 7405              MOV      A,#05H
+003087 F0                MOVX     @DPTR,A
+    9: 	g_variable.battery_value_index = 0;
+003088 E4                CLR      A
+003089 A3                INC      DPTR
+00308A F0                MOVX     @DPTR,A
+   10: 	g_variable.battery_motion_check_interval = BATTERY_MOTION_CHECK_INTERVAL;
+00308B 904D06            MOV      DPTR,#g_variable+047H
+00308E 7414              MOV      A,#014H
+003090 F0                MOVX     @DPTR,A
+   11: 	
+   12: #ifdef ADC_TYPE_HVIN 	
+   13: 	for (i = 0; i < BAT_ARRAY_LEN; i++)
+   14: 	{
+   15: 		g_variable.battery_value[i] = INIT_BATTERY_VALUE;
+   16: 	}
+   17: 	g_variable.battery_level_full = (m_adc3vValue - m_adc0vBase)*LOW_BATTER_COEFFICIENT_3V7+m_adc0vBase;
+   18: 	g_variable.battery_level_low = (m_adc3vValue - m_adc0vBase)*LOW_BATTER_COEFFICIENT_3V2+m_adc0vBase;
+   19: 	g_variable.battery_level_shutdown = (m_adc3vValue - m_adc0vBase)*LOW_BATTER_COEFFICIENT_3V0+m_adc0vBase;
+   20: #endif
+   21: #ifdef ADC_TYPE_VINLPM
+   22: 		for (i = 0; i < BAT_ARRAY_LEN; i++)
+   23: 		{
+   24: 			g_variable.battery_value[i] = INIT_BATTERY_VALUE_VINLPM;
+   25: 		}
+   26: 		g_variable.battery_level_full = m_adc3vValue;
+   27: 		g_variable.battery_level_low = (m_adc3vValue - m_adc0vBase)*LOW_BATTER_COEFFICIENT_2V2+m_adc0vBase;
+   28: 		g_variable.battery_level_shutdown = (m_adc3vValue - m_adc0vBase)*LOW_BATTER_COEFFICIENT_2V0+m_adc0vBase;
+   29: #endif
+   30: #ifdef ADC_TYPE_GPIO
+   31: 	m_adc_channel = ADC_CHANNEL;
+003091 904C90            MOV      DPTR,#m_adc_channel
+003094 7433              MOV      A,#033H
+003096 F0                MOVX     @DPTR,A
+   32: 	for (i = 0; i < BAT_ARRAY_LEN; i++)
+;---- Variable 'i' assigned to Register 'R7' ----
+003097 E4                CLR      A
+003098 FF                MOV      R7,A
+003099         ?C0001?ADC:
+003099 EF                MOV      A,R7
+00309A C3                CLR      C
+00309B 9404              SUBB     A,#04H
+00309D 7480              MOV      A,#080H
+00309F 9480              SUBB     A,#080H
+0030A1 5014              JNC      ?C0002?ADC
+   33: 	{
+   34: 		g_variable.battery_value[i] = INIT_BATTERY_VALUE_GPIO;
+0030A3 EF                MOV      A,R7
+0030A4 25E0              ADD      A,ACC
+0030A6 24D6              ADD      A,#LOW g_variable+017H
+0030A8 F582              MOV      DPL,A
+0030AA E4                CLR      A
+0030AB 344C              ADDC     A,#HIGH g_variable+017H
+0030AD F583              MOV      DPH,A
+0030AF 7462              MOV      A,#062H
+0030B1 F0                MOVX     @DPTR,A
+0030B2 A3                INC      DPTR
+0030B3 F0                MOVX     @DPTR,A
+   35: 	}
+0030B4 0F                INC      R7
+0030B5 80E2              SJMP     ?C0001?ADC
+0030B7         ?C0002?ADC:
+   36: 	g_variable.battery_level_full = (m_adc3vValue - m_adc0vBase)*LOW_BATTER_COEFFICIENT_1V5+m_adc0vBase;
+0030B7 904C91            MOV      DPTR,#m_adc0vBase
+0030BA E0                MOVX     A,@DPTR
+0030BB FE                MOV      R6,A
+0030BC A3                INC      DPTR
+0030BD E0                MOVX     A,@DPTR
+0030BE FF                MOV      R7,A
+0030BF C3                CLR      C
+0030C0 904C94            MOV      DPTR,#m_adc3vValue+01H
+0030C3 E0                MOVX     A,@DPTR
+0030C4 9F                SUBB     A,R7
+0030C5 FD                MOV      R5,A
+0030C6 904C93            MOV      DPTR,#m_adc3vValue
+0030C9 E0                MOVX     A,@DPTR
+0030CA 9E                SUBB     A,R6
+0030CB FC                MOV      R4,A
+0030CC E4                CLR      A
+0030CD 120206            LCALL    ?C?FCASTI
+0030D0 7BAE              MOV      R3,#0AEH
+0030D2 7A47              MOV      R2,#047H
+0030D4 7961              MOV      R1,#061H
+0030D6 783F              MOV      R0,#03FH
+0030D8 1200FB            LCALL    ?C?FPMUL
+0030DB C004              PUSH     AR4
+0030DD C005              PUSH     AR5
+0030DF C006              PUSH     AR6
+0030E1 C007              PUSH     AR7
+0030E3 904C91            MOV      DPTR,#m_adc0vBase
+0030E6 E0                MOVX     A,@DPTR
+0030E7 FC                MOV      R4,A
+0030E8 A3                INC      DPTR
+0030E9 E0                MOVX     A,@DPTR
+0030EA FD                MOV      R5,A
+0030EB E4                CLR      A
+0030EC 120206            LCALL    ?C?FCASTI
+0030EF D003              POP      AR3
+0030F1 D002              POP      AR2
+0030F3 D001              POP      AR1
+0030F5 D000              POP      AR0
+0030F7 12000A            LCALL    ?C?FPADD
+0030FA 12023F            LCALL    ?C?CASTF
+0030FD 904CFA            MOV      DPTR,#g_variable+03BH
+003100 EE                MOV      A,R6
+003101 F0                MOVX     @DPTR,A
+003102 A3                INC      DPTR
+003103 EF                MOV      A,R7
+003104 F0                MOVX     @DPTR,A
+   37: 	g_variable.battery_level_low = (m_adc3vValue - m_adc0vBase)*LOW_BATTER_COEFFICIENT_1V1+m_adc0vBase;
+003105 904C91            MOV      DPTR,#m_adc0vBase
+003108 E0                MOVX     A,@DPTR
+003109 FE                MOV      R6,A
+00310A A3                INC      DPTR
+00310B E0                MOVX     A,@DPTR
+00310C FF                MOV      R7,A
+00310D C3                CLR      C
+00310E 904C94            MOV      DPTR,#m_adc3vValue+01H
+003111 E0                MOVX     A,@DPTR
+003112 9F                SUBB     A,R7
+003113 FD                MOV      R5,A
+003114 904C93            MOV      DPTR,#m_adc3vValue
+003117 E0                MOVX     A,@DPTR
+003118 9E                SUBB     A,R6
+003119 FC                MOV      R4,A
+00311A E4                CLR      A
+00311B 120206            LCALL    ?C?FCASTI
+00311E 7433              MOV      A,#033H
+003120 FB                MOV      R3,A
+003121 FA                MOV      R2,A
+003122 F9                MOV      R1,A
+003123 783F              MOV      R0,#03FH
+003125 1200FB            LCALL    ?C?FPMUL
+003128 C004              PUSH     AR4
+00312A C005              PUSH     AR5
+00312C C006              PUSH     AR6
+00312E C007              PUSH     AR7
+003130 904C91            MOV      DPTR,#m_adc0vBase
+003133 E0                MOVX     A,@DPTR
+003134 FC                MOV      R4,A
+003135 A3                INC      DPTR
+003136 E0                MOVX     A,@DPTR
+003137 FD                MOV      R5,A
+003138 E4                CLR      A
+003139 120206            LCALL    ?C?FCASTI
+00313C D003              POP      AR3
+00313E D002              POP      AR2
+003140 D001              POP      AR1
+003142 D000              POP      AR0
+003144 12000A            LCALL    ?C?FPADD
+003147 12023F            LCALL    ?C?CASTF
+00314A 904CDE            MOV      DPTR,#g_variable+01FH
+00314D EE                MOV      A,R6
+00314E F0                MOVX     @DPTR,A
+00314F A3                INC      DPTR
+003150 EF                MOV      A,R7
+003151 F0                MOVX     @DPTR,A
+   38: 	g_variable.battery_level_shutdown = (m_adc3vValue - m_adc0vBase)*LOW_BATTER_COEFFICIENT_0V9+m_adc0vBase;
+003152 904C91            MOV      DPTR,#m_adc0vBase
+003155 E0                MOVX     A,@DPTR
+003156 FE                MOV      R6,A
+003157 A3                INC      DPTR
+003158 E0                MOVX     A,@DPTR
+003159 FF                MOV      R7,A
+00315A C3                CLR      C
+00315B 904C94            MOV      DPTR,#m_adc3vValue+01H
+00315E E0                MOVX     A,@DPTR
+00315F 9F                SUBB     A,R7
+003160 FD                MOV      R5,A
+003161 904C93            MOV      DPTR,#m_adc3vValue
+003164 E0                MOVX     A,@DPTR
+003165 9E                SUBB     A,R6
+003166 FC                MOV      R4,A
+003167 E4                CLR      A
+003168 120206            LCALL    ?C?FCASTI
+00316B 7B85              MOV      R3,#085H
+00316D 7AEB              MOV      R2,#0EBH
+00316F 7911              MOV      R1,#011H
+003171 783F              MOV      R0,#03FH
+003173 1200FB            LCALL    ?C?FPMUL
+003176 C004              PUSH     AR4
+003178 C005              PUSH     AR5
+00317A C006              PUSH     AR6
+00317C C007              PUSH     AR7
+00317E 904C91            MOV      DPTR,#m_adc0vBase
+003181 E0                MOVX     A,@DPTR
+003182 FC                MOV      R4,A
+003183 A3                INC      DPTR
+003184 E0                MOVX     A,@DPTR
+003185 FD                MOV      R5,A
+003186 E4                CLR      A
+003187 120206            LCALL    ?C?FCASTI
+00318A D003              POP      AR3
+00318C D002              POP      AR2
+00318E D001              POP      AR1
+003190 D000              POP      AR0
+003192 12000A            LCALL    ?C?FPADD
+003195 12023F            LCALL    ?C?CASTF
+003198 904CE0            MOV      DPTR,#g_variable+021H
+00319B EE                MOV      A,R6
+00319C F0                MOVX     @DPTR,A
+00319D A3                INC      DPTR
+00319E EF                MOV      A,R7
+00319F F0                MOVX     @DPTR,A
+   39: #endif	
+   40: #endif
+   41: }
+0031A0 22                RET      
+----- FUNCTION YC_adc_init (END) -------
+
+
+----- FUNCTION _kb_cb_Hid (BEGIN) -----
+ FILE: 'sys.c'
+  115: static void kb_cb_Hid(byte *p,byte len) {
+  116: 	//p[0] is hid type,always is 1(kb) now
+0031A1 904EFA            MOV      DPTR,#len
+0031A4 ED                MOV      A,R5
+0031A5 F0                MOVX     @DPTR,A
+;---- Variable 'p' assigned to Register 'R1/R2/R3' ----
+  117: 	byte temp = p[1];
+0031A6 900001            MOV      DPTR,#01H
+0031A9 1203CF            LCALL    ?C?CLDOPTR
+0031AC 904EFB            MOV      DPTR,#temp
+0031AF F0                MOVX     @DPTR,A
+  118: 
+  119: 	if (len<2) {
+  120: 		return;
+  121: 	}
+  122: }
+0031B0 22                RET      
+----- FUNCTION _kb_cb_Hid (END) -------
+
+
+----- FUNCTION kb_cb_Timer100ms (BEGIN) -----
+ FILE: 'sys.c'
+  692: static void kb_cb_Timer100ms()
+  693: {
+  694: 
+  695: 	if (g_variable.delay_enter_lpm_timer) 
+0031B1 904CEA            MOV      DPTR,#g_variable+02BH
+0031B4 E0                MOVX     A,@DPTR
+0031B5 6002              JZ       ?C0131?SYS
+  696: 	{
+  697: 		g_variable.delay_enter_lpm_timer --;
+0031B7 14                DEC      A
+0031B8 F0                MOVX     @DPTR,A
+  698: 	}
+0031B9         ?C0131?SYS:
+  699: 
+  700: 	if(g_variable.recon_delay)
+0031B9 904CEF            MOV      DPTR,#g_variable+030H
+0031BC E0                MOVX     A,@DPTR
+0031BD 6002              JZ       ?C0132?SYS
+  701: 		g_variable.recon_delay--;
+0031BF 14                DEC      A
+0031C0 F0                MOVX     @DPTR,A
+0031C1         ?C0132?SYS:
+  702: 
+  703: 	if(g_variable.one_key_press_wait_release_timer)
+0031C1 904CF8            MOV      DPTR,#g_variable+039H
+0031C4 E0                MOVX     A,@DPTR
+0031C5 600B              JZ       ?C0133?SYS
+  704: 	{
+  705: 		g_variable.one_key_press_wait_release_timer--;
+0031C7 14                DEC      A
+0031C8 F0                MOVX     @DPTR,A
+  706: 		if(!g_variable.one_key_press_wait_release_timer)
+0031C9 E0                MOVX     A,@DPTR
+0031CA 7006              JNZ      ?C0133?SYS
+  707: 			g_variable.key_combination_step = CAMBINATION_KEY_NULL;
+0031CC 904CF4            MOV      DPTR,#g_variable+035H
+0031CF 7406              MOV      A,#06H
+0031D1 F0                MOVX     @DPTR,A
+  708: 	}
+0031D2         ?C0133?SYS:
+  709: 	
+  710: 	if (g_variable.powerOn_timer != 0)
+0031D2 904CE5            MOV      DPTR,#g_variable+026H
+0031D5 E0                MOVX     A,@DPTR
+0031D6 6020              JZ       ?C0135?SYS
+  711: 	{	
+  712: 		if(g_variable.pairing_g24_timeout)
+0031D8 904CEE            MOV      DPTR,#g_variable+02FH
+0031DB E0                MOVX     A,@DPTR
+0031DC 6006              JZ       ?C0136?SYS
+  713: 		{
+  714: 			g_variable.powerOn_timer = 0;
+0031DE E4                CLR      A
+0031DF 904CE5            MOV      DPTR,#g_variable+026H
+0031E2 F0                MOVX     @DPTR,A
+0031E3 22                RET      
+  715: 			return;
+  716: 		}
+0031E4         ?C0136?SYS:
+  717: 			
+  718: 		g_variable.powerOn_timer--;
+0031E4 904CE5            MOV      DPTR,#g_variable+026H
+0031E7 E0                MOVX     A,@DPTR
+0031E8 14                DEC      A
+0031E9 F0                MOVX     @DPTR,A
+  719: 		LED_device_poweron();
+0031EA 1217B0            LCALL    LED_device_poweron
+  720: 		if (!g_variable.powerOn_timer)
+0031ED 904CE5            MOV      DPTR,#g_variable+026H
+0031F0 E0                MOVX     A,@DPTR
+0031F1 704A              JNZ      ?C0139?SYS
+  721: 		{
+  722: 			LED_device_poweroff();
+0031F3 1217C8            LCALL    LED_device_poweroff
+  723: 		}
+  724: 	}
+0031F6 8045              SJMP     ?C0139?SYS
+0031F8         ?C0135?SYS:
+  725: 	else	if ((g_variable.pairing_timeout == 0) && (g_variable.pairing_g24_timeout == 0))  //  pairing
+0031F8 904CE9            MOV      DPTR,#g_variable+02AH
+0031FB E0                MOVX     A,@DPTR
+0031FC 703F              JNZ      ?C0139?SYS
+0031FE 904CEE            MOV      DPTR,#g_variable+02FH
+003201 E0                MOVX     A,@DPTR
+003202 7039              JNZ      ?C0139?SYS
+  726: 	{
+  727: 		if(g_variable.battery_low_led_flash_interval)
+003204 904CE2            MOV      DPTR,#g_variable+023H
+003207 E0                MOVX     A,@DPTR
+003208 6033              JZ       ?C0139?SYS
+  728: 		{
+  729: 			g_variable.battery_low_led_flash_interval--;
+00320A 14                DEC      A
+00320B F0                MOVX     @DPTR,A
+  730: 			if(g_variable.battery_low_led_flash_interval < 4)
+00320C E0                MOVX     A,@DPTR
+00320D FF                MOV      R7,A
+00320E C3                CLR      C
+00320F 9404              SUBB     A,#04H
+003211 7480              MOV      A,#080H
+003213 9480              SUBB     A,#080H
+003215 5016              JNC      ?C0142?SYS
+  731: 			{
+  732: 				if(g_variable.battery_low_led_flash_interval & 0x02)
+003217 EF                MOV      A,R7
+003218 30E109            JNB      ACC.1,?C0143?SYS
+  733: 				{
+  734: 					GPIO_Setout(LOWPOWER_LED_GPIO, LED_ON);
+00321B D201              SETB     ?_GPIO_Setout?BIT
+00321D 7F14              MOV      R7,#014H
+00321F 1211B2            LCALL    _GPIO_Setout
+  735: 				}
+003222 8010              SJMP     ?C0145?SYS
+003224         ?C0143?SYS:
+  736: 				else
+  737: 				{
+  738: 					GPIO_Setout(LOWPOWER_LED_GPIO, LED_OFF);	
+003224 C201              CLR      ?_GPIO_Setout?BIT
+003226 7F14              MOV      R7,#014H
+003228 1211B2            LCALL    _GPIO_Setout
+  739: 				}	
+  740: 			}
+00322B 8007              SJMP     ?C0145?SYS
+00322D         ?C0142?SYS:
+  741: 			else
+  742: 				GPIO_Setout(LOWPOWER_LED_GPIO, LED_OFF);
+00322D C201              CLR      ?_GPIO_Setout?BIT
+00322F 7F14              MOV      R7,#014H
+003231 1211B2            LCALL    _GPIO_Setout
+003234         ?C0145?SYS:
+  743: 			if(!g_variable.battery_low_led_flash_interval)
+003234 904CE2            MOV      DPTR,#g_variable+023H
+003237 E0                MOVX     A,@DPTR
+003238 7003              JNZ      ?C0139?SYS
+  744: 				g_variable.battery_low_led_flash_interval = LOW_BATTERY_FLASH_INTERVAL;
+00323A 740A              MOV      A,#0AH
+00323C F0                MOVX     @DPTR,A
+  745: 		}
+  746: 	}
+00323D         ?C0139?SYS:
+  747: 	
+  748: // The dongle must receive data within 200ms, otherwise it will be forced to lift
+  749: 	if(!long_press_flag)
+00323D 904DDC            MOV      DPTR,#long_press_flag
+003240 E0                MOVX     A,@DPTR
+003241 7036              JNZ      ?C0147?SYS
+  750: 	{
+  751: 		if (repeat_send_24g == 1)
+003243 904DDD            MOV      DPTR,#repeat_send_24g
+003246 E0                MOVX     A,@DPTR
+003247 6401              XRL      A,#01H
+003249 702E              JNZ      ?C0147?SYS
+  752: 		{
+  753: 			g_variable.sleepTimer = 0;	
+00324B 904CE3            MOV      DPTR,#g_variable+024H
+00324E F0                MOVX     @DPTR,A
+00324F A3                INC      DPTR
+003250 F0                MOVX     @DPTR,A
+  754: 			repeat_send_24g = 0;
+003251 904DDD            MOV      DPTR,#repeat_send_24g
+003254 F0                MOVX     @DPTR,A
+  755: 
+  756: 			 if (multikey[0] != 0)
+003255 904E4C            MOV      DPTR,#multikey
+003258 E0                MOVX     A,@DPTR
+003259 600D              JZ       ?C0149?SYS
+  757: 			{
+  758: 				IPC_TxHidData(multikey, 3);
+00325B 7B01              MOV      R3,#01H
+00325D 7A4E              MOV      R2,#HIGH multikey
+00325F 794C              MOV      R1,#LOW multikey
+003261 7D03              MOV      R5,#03H
+003263 120EDA            LCALL    _IPC_TxHidData
+  759: 			}
+003266 8011              SJMP     ?C0147?SYS
+003268         ?C0149?SYS:
+  760: 			else if (hidBuff[0] != 0)
+003268 904800            MOV      DPTR,#hidBuff
+00326B E0                MOVX     A,@DPTR
+00326C 600B              JZ       ?C0147?SYS
+  761: 			{
+  762: 
+  763: 				IPC_TxHidData(hidBuff,9);
+00326E 7B01              MOV      R3,#01H
+003270 7A48              MOV      R2,#HIGH hidBuff
+003272 7900              MOV      R1,#LOW hidBuff
+003274 7D09              MOV      R5,#09H
+003276 120EDA            LCALL    _IPC_TxHidData
+  764: 			}
+  765: 		}
+  766: 	}
+003279         ?C0147?SYS:
+  767: 
+  768: 
+  769: // ble delay send secutiry request
+  770: 	if(ble_send_secutiry_request_timer)
+003279 904DD4            MOV      DPTR,#ble_send_secutiry_request_timer
+00327C E0                MOVX     A,@DPTR
+00327D 6011              JZ       ?C0152?SYS
+  771: 	{
+  772: 		ble_send_secutiry_request_timer--;
+00327F E0                MOVX     A,@DPTR
+003280 14                DEC      A
+003281 F0                MOVX     @DPTR,A
+  773: 		if(!ble_send_secutiry_request_timer)
+003282 E0                MOVX     A,@DPTR
+003283 700B              JNZ      ?C0152?SYS
+  774: 		{
+  775: 			if(!m_le_send_security_request_flag)
+003285 904D3D            MOV      DPTR,#m_le_send_security_request_flag
+003288 E0                MOVX     A,@DPTR
+003289 7005              JNZ      ?C0152?SYS
+  776: 			{
+  777: 				IPC_TxControlCmd(IPC_CMD_LE_SMP_SECURITY_REQUEST);
+00328B 7F1B              MOV      R7,#01BH
+00328D 12149D            LCALL    _IPC_TxControlCmd
+  778: 			}
+  779: 		}
+  780: 	}
+003290         ?C0152?SYS:
+  781: 
+  782: 	if (delayChgInvTimer != 0){
+003290 904DE6            MOV      DPTR,#delayChgInvTimer
+003293 E0                MOVX     A,@DPTR
+003294 6014              JZ       ?C0137?SYS
+  783: 		delayChgInvTimer--;
+003296 E0                MOVX     A,@DPTR
+003297 14                DEC      A
+003298 F0                MOVX     @DPTR,A
+  784: 		if (delayChgInvTimer == 0)
+003299 E0                MOVX     A,@DPTR
+00329A 700E              JNZ      ?C0137?SYS
+  785: 		{
+  786: 
+  787: 			if (g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTED)
+00329C 904CC7            MOV      DPTR,#g_variable+08H
+00329F E0                MOVX     A,@DPTR
+0032A0 6404              XRL      A,#04H
+0032A2 7006              JNZ      ?C0137?SYS
+  788: 			{
+  789: 				kscurrmult = 0x0c;
+0032A4 904213            MOV      DPTR,#kscurrmult
+0032A7 740C              MOV      A,#0CH
+0032A9 F0                MOVX     @DPTR,A
+  790: 			}
+  791: 		}
+  792: 	}
+  793: }
+0032AA         ?C0137?SYS:
+0032AA 22                RET      
+----- FUNCTION kb_cb_Timer100ms (END) -------
+
+
+----- FUNCTION _ipcRx (BEGIN) -----
+0032AB 904EFC            MOV      DPTR,#dest
+0032AE EE                MOV      A,R6
+0032AF F0                MOVX     @DPTR,A
+0032B0 A3                INC      DPTR
+0032B1 EF                MOV      A,R7
+0032B2 F0                MOVX     @DPTR,A
+;---- Variable 'len' assigned to Register 'R1' ----
+0032B3 A905              MOV      R1,AR5
+0032B5 904B9E            MOV      DPTR,#ipcRxReadPtr
+0032B8 E0                MOVX     A,@DPTR
+0032B9 FE                MOV      R6,A
+0032BA A3                INC      DPTR
+0032BB E0                MOVX     A,@DPTR
+0032BC FF                MOV      R7,A
+;---- Variable 'src' assigned to Register 'R6/R7' ----
+0032BD         ?C0004?IPC:
+0032BD AD01              MOV      R5,AR1
+0032BF 19                DEC      R1
+0032C0 ED                MOV      A,R5
+0032C1 602F              JZ       ?C0005?IPC
+0032C3 0F                INC      R7
+0032C4 EF                MOV      A,R7
+0032C5 AC06              MOV      R4,AR6
+0032C7 7001              JNZ      ?C0046?IPC
+0032C9 0E                INC      R6
+0032CA         ?C0046?IPC:
+0032CA 14                DEC      A
+0032CB F582              MOV      DPL,A
+0032CD 8C83              MOV      DPH,R4
+0032CF E0                MOVX     A,@DPTR
+0032D0 FD                MOV      R5,A
+0032D1 904EFC            MOV      DPTR,#dest
+0032D4 E4                CLR      A
+0032D5 75F001            MOV      B,#01H
+0032D8 120424            LCALL    ?C?ILDIX
+0032DB 85F082            MOV      DPL,B
+0032DE F583              MOV      DPH,A
+0032E0 ED                MOV      A,R5
+0032E1 F0                MOVX     @DPTR,A
+0032E2 AD07              MOV      R5,AR7
+0032E4 AC06              MOV      R4,AR6
+0032E6 BC4BD4            CJNE     R4,#04BH,?C0004?IPC
+0032E9 BD9AD1            CJNE     R5,#09AH,?C0004?IPC
+0032EC 7E4B              MOV      R6,#04BH
+0032EE 7F36              MOV      R7,#036H
+0032F0 80CB              SJMP     ?C0004?IPC
+0032F2         ?C0005?IPC:
+0032F2 904B9E            MOV      DPTR,#ipcRxReadPtr
+0032F5 EE                MOV      A,R6
+0032F6 F0                MOVX     @DPTR,A
+0032F7 A3                INC      DPTR
+0032F8 EF                MOV      A,R7
+0032F9 F0                MOVX     @DPTR,A
+0032FA 22                RET      
+----- FUNCTION _ipcRx (END) -------
+
+
+----- FUNCTION IPC_DealSingleStep (BEGIN) -----
+0032FB 7A0C              MOV      R2,#HIGH ipcReadBuff
+0032FD 794B              MOV      R1,#LOW ipcReadBuff
+0032FF 904EEC            MOV      DPTR,#pbuff
+003302 7401              MOV      A,#01H
+003304 F0                MOVX     @DPTR,A
+003305 A3                INC      DPTR
+003306 740C              MOV      A,#HIGH ipcReadBuff
+003308 F0                MOVX     @DPTR,A
+003309 A3                INC      DPTR
+00330A 744B              MOV      A,#LOW ipcReadBuff
+00330C F0                MOVX     @DPTR,A
+00330D 904BA0            MOV      DPTR,#ipcRxWritePtr
+003310 E0                MOVX     A,@DPTR
+003311 FE                MOV      R6,A
+003312 A3                INC      DPTR
+003313 E0                MOVX     A,@DPTR
+003314 FF                MOV      R7,A
+003315 904B9E            MOV      DPTR,#ipcRxReadPtr
+003318 E0                MOVX     A,@DPTR
+003319 6E                XRL      A,R6
+00331A 7003              JNZ      ?C0048?IPC
+00331C A3                INC      DPTR
+00331D E0                MOVX     A,@DPTR
+00331E 6F                XRL      A,R7
+00331F         ?C0048?IPC:
+00331F 7002              JNZ      $ + 4H
+003321 81AA              AJMP     ?C0039?IPC
+003323         ?C0027?IPC:
+003323 7E0C              MOV      R6,#HIGH ipcReadBuff
+003325 7F4B              MOV      R7,#LOW ipcReadBuff
+003327 7D03              MOV      R5,#03H
+003329 51AB              ACALL    _ipcRx
+00332B 904EEC            MOV      DPTR,#pbuff
+00332E E0                MOVX     A,@DPTR
+00332F FB                MOV      R3,A
+003330 A3                INC      DPTR
+003331 E0                MOVX     A,@DPTR
+003332 FA                MOV      R2,A
+003333 A3                INC      DPTR
+003334 E0                MOVX     A,@DPTR
+003335 F9                MOV      R1,A
+003336 1203B6            LCALL    ?C?CLDPTR
+003339 B4022B            CJNE     A,#02H,?C0029?IPC
+00333C 904EED            MOV      DPTR,#pbuff+01H
+00333F E4                CLR      A
+003340 75F002            MOV      B,#02H
+003343 12040E            LCALL    ?C?IILDX
+003346 904EEC            MOV      DPTR,#pbuff
+003349 E0                MOVX     A,@DPTR
+00334A FB                MOV      R3,A
+00334B A3                INC      DPTR
+00334C E0                MOVX     A,@DPTR
+00334D FA                MOV      R2,A
+00334E A3                INC      DPTR
+00334F E0                MOVX     A,@DPTR
+003350 F9                MOV      R1,A
+003351 1203B6            LCALL    ?C?CLDPTR
+003354 FF                MOV      R7,A
+003355 904E68            MOV      DPTR,#ipcCb
+003358 E0                MOVX     A,@DPTR
+003359 A3                INC      DPTR
+00335A E0                MOVX     A,@DPTR
+00335B FA                MOV      R2,A
+00335C A3                INC      DPTR
+00335D E0                MOVX     A,@DPTR
+00335E F582              MOV      DPL,A
+003360 8A83              MOV      DPH,R2
+003362 1205DD            LCALL    ?C?ICALL2
+003365 81AA              AJMP     ?C0039?IPC
+003367         ?C0029?IPC:
+003367 904EEC            MOV      DPTR,#pbuff
+00336A E0                MOVX     A,@DPTR
+00336B FB                MOV      R3,A
+00336C A3                INC      DPTR
+00336D E0                MOVX     A,@DPTR
+00336E FA                MOV      R2,A
+00336F A3                INC      DPTR
+003370 E0                MOVX     A,@DPTR
+003371 F9                MOV      R1,A
+003372 1203B6            LCALL    ?C?CLDPTR
+003375 6404              XRL      A,#04H
+003377 7059              JNZ      ?C0031?IPC
+003379 904EED            MOV      DPTR,#pbuff+01H
+00337C 75F001            MOV      B,#01H
+00337F 12040E            LCALL    ?C?IILDX
+003382 7E0C              MOV      R6,#HIGH ipcReadBuff+03H
+003384 7F4E              MOV      R7,#LOW ipcReadBuff+03H
+003386 904EEC            MOV      DPTR,#pbuff
+003389 E0                MOVX     A,@DPTR
+00338A FB                MOV      R3,A
+00338B A3                INC      DPTR
+00338C E0                MOVX     A,@DPTR
+00338D FA                MOV      R2,A
+00338E A3                INC      DPTR
+00338F E0                MOVX     A,@DPTR
+003390 F9                MOV      R1,A
+003391 1203B6            LCALL    ?C?CLDPTR
+003394 14                DEC      A
+003395 FD                MOV      R5,A
+003396 51AB              ACALL    _ipcRx
+003398 904EEC            MOV      DPTR,#pbuff
+00339B E0                MOVX     A,@DPTR
+00339C FB                MOV      R3,A
+00339D A3                INC      DPTR
+00339E E0                MOVX     A,@DPTR
+00339F FA                MOV      R2,A
+0033A0 A3                INC      DPTR
+0033A1 E0                MOVX     A,@DPTR
+0033A2 2401              ADD      A,#01H
+0033A4 F9                MOV      R1,A
+0033A5 E4                CLR      A
+0033A6 3A                ADDC     A,R2
+0033A7 FA                MOV      R2,A
+0033A8 C002              PUSH     AR2
+0033AA C001              PUSH     AR1
+0033AC 904EEC            MOV      DPTR,#pbuff
+0033AF E0                MOVX     A,@DPTR
+0033B0 A3                INC      DPTR
+0033B1 E0                MOVX     A,@DPTR
+0033B2 FA                MOV      R2,A
+0033B3 A3                INC      DPTR
+0033B4 E0                MOVX     A,@DPTR
+0033B5 F9                MOV      R1,A
+0033B6 1203B6            LCALL    ?C?CLDPTR
+0033B9 FD                MOV      R5,A
+0033BA 7C00              MOV      R4,#00H
+0033BC 904E6B            MOV      DPTR,#ipcCb+03H
+0033BF E0                MOVX     A,@DPTR
+0033C0 A3                INC      DPTR
+0033C1 E0                MOVX     A,@DPTR
+0033C2 FA                MOV      R2,A
+0033C3 A3                INC      DPTR
+0033C4 E0                MOVX     A,@DPTR
+0033C5 F582              MOV      DPL,A
+0033C7 8A83              MOV      DPH,R2
+0033C9 D001              POP      AR1
+0033CB D002              POP      AR2
+0033CD 1205DD            LCALL    ?C?ICALL2
+0033D0 81AA              AJMP     ?C0039?IPC
+0033D2         ?C0031?IPC:
+0033D2 904EEC            MOV      DPTR,#pbuff
+0033D5 E0                MOVX     A,@DPTR
+0033D6 FB                MOV      R3,A
+0033D7 A3                INC      DPTR
+0033D8 E0                MOVX     A,@DPTR
+0033D9 FA                MOV      R2,A
+0033DA A3                INC      DPTR
+0033DB E0                MOVX     A,@DPTR
+0033DC F9                MOV      R1,A
+0033DD 1203B6            LCALL    ?C?CLDPTR
+0033E0 6405              XRL      A,#05H
+0033E2 7059              JNZ      ?C0033?IPC
+0033E4 904EED            MOV      DPTR,#pbuff+01H
+0033E7 75F001            MOV      B,#01H
+0033EA 12040E            LCALL    ?C?IILDX
+0033ED 7E0C              MOV      R6,#HIGH ipcReadBuff+03H
+0033EF 7F4E              MOV      R7,#LOW ipcReadBuff+03H
+0033F1 904EEC            MOV      DPTR,#pbuff
+0033F4 E0                MOVX     A,@DPTR
+0033F5 FB                MOV      R3,A
+0033F6 A3                INC      DPTR
+0033F7 E0                MOVX     A,@DPTR
+0033F8 FA                MOV      R2,A
+0033F9 A3                INC      DPTR
+0033FA E0                MOVX     A,@DPTR
+0033FB F9                MOV      R1,A
+0033FC 1203B6            LCALL    ?C?CLDPTR
+0033FF 14                DEC      A
+003400 FD                MOV      R5,A
+003401 51AB              ACALL    _ipcRx
+003403 904EEC            MOV      DPTR,#pbuff
+003406 E0                MOVX     A,@DPTR
+003407 FB                MOV      R3,A
+003408 A3                INC      DPTR
+003409 E0                MOVX     A,@DPTR
+00340A FA                MOV      R2,A
+00340B A3                INC      DPTR
+00340C E0                MOVX     A,@DPTR
+00340D 2401              ADD      A,#01H
+00340F F9                MOV      R1,A
+003410 E4                CLR      A
+003411 3A                ADDC     A,R2
+003412 FA                MOV      R2,A
+003413 C002              PUSH     AR2
+003415 C001              PUSH     AR1
+003417 904EEC            MOV      DPTR,#pbuff
+00341A E0                MOVX     A,@DPTR
+00341B A3                INC      DPTR
+00341C E0                MOVX     A,@DPTR
+00341D FA                MOV      R2,A
+00341E A3                INC      DPTR
+00341F E0                MOVX     A,@DPTR
+003420 F9                MOV      R1,A
+003421 1203B6            LCALL    ?C?CLDPTR
+003424 FD                MOV      R5,A
+003425 7C00              MOV      R4,#00H
+003427 904E74            MOV      DPTR,#ipcCb+0CH
+00342A E0                MOVX     A,@DPTR
+00342B A3                INC      DPTR
+00342C E0                MOVX     A,@DPTR
+00342D FA                MOV      R2,A
+00342E A3                INC      DPTR
+00342F E0                MOVX     A,@DPTR
+003430 F582              MOV      DPL,A
+003432 8A83              MOV      DPH,R2
+003434 D001              POP      AR1
+003436 D002              POP      AR2
+003438 1205DD            LCALL    ?C?ICALL2
+00343B 806D              SJMP     ?C0039?IPC
+00343D         ?C0033?IPC:
+00343D 904EEC            MOV      DPTR,#pbuff
+003440 E0                MOVX     A,@DPTR
+003441 FB                MOV      R3,A
+003442 A3                INC      DPTR
+003443 E0                MOVX     A,@DPTR
+003444 FA                MOV      R2,A
+003445 A3                INC      DPTR
+003446 E0                MOVX     A,@DPTR
+003447 F9                MOV      R1,A
+003448 1203B6            LCALL    ?C?CLDPTR
+00344B 6403              XRL      A,#03H
+00344D 7059              JNZ      ?C0037?IPC
+00344F 904EED            MOV      DPTR,#pbuff+01H
+003452 75F001            MOV      B,#01H
+003455 12040E            LCALL    ?C?IILDX
+003458 7E0C              MOV      R6,#HIGH ipcReadBuff+03H
+00345A 7F4E              MOV      R7,#LOW ipcReadBuff+03H
+00345C 904EEC            MOV      DPTR,#pbuff
+00345F E0                MOVX     A,@DPTR
+003460 FB                MOV      R3,A
+003461 A3                INC      DPTR
+003462 E0                MOVX     A,@DPTR
+003463 FA                MOV      R2,A
+003464 A3                INC      DPTR
+003465 E0                MOVX     A,@DPTR
+003466 F9                MOV      R1,A
+003467 1203B6            LCALL    ?C?CLDPTR
+00346A 14                DEC      A
+00346B FD                MOV      R5,A
+00346C 51AB              ACALL    _ipcRx
+00346E 904EEC            MOV      DPTR,#pbuff
+003471 E0                MOVX     A,@DPTR
+003472 FB                MOV      R3,A
+003473 A3                INC      DPTR
+003474 E0                MOVX     A,@DPTR
+003475 FA                MOV      R2,A
+003476 A3                INC      DPTR
+003477 E0                MOVX     A,@DPTR
+003478 2401              ADD      A,#01H
+00347A F9                MOV      R1,A
+00347B E4                CLR      A
+00347C 3A                ADDC     A,R2
+00347D FA                MOV      R2,A
+00347E C002              PUSH     AR2
+003480 C001              PUSH     AR1
+003482 904EEC            MOV      DPTR,#pbuff
+003485 E0                MOVX     A,@DPTR
+003486 A3                INC      DPTR
+003487 E0                MOVX     A,@DPTR
+003488 FA                MOV      R2,A
+003489 A3                INC      DPTR
+00348A E0                MOVX     A,@DPTR
+00348B F9                MOV      R1,A
+00348C 1203B6            LCALL    ?C?CLDPTR
+00348F FD                MOV      R5,A
+003490 7C00              MOV      R4,#00H
+003492 904E77            MOV      DPTR,#ipcCb+0FH
+003495 E0                MOVX     A,@DPTR
+003496 A3                INC      DPTR
+003497 E0                MOVX     A,@DPTR
+003498 FA                MOV      R2,A
+003499 A3                INC      DPTR
+00349A E0                MOVX     A,@DPTR
+00349B F582              MOV      DPL,A
+00349D 8A83              MOV      DPH,R2
+00349F D001              POP      AR1
+0034A1 D002              POP      AR2
+0034A3 1205DD            LCALL    ?C?ICALL2
+0034A6 8002              SJMP     ?C0039?IPC
+0034A8         ?C0037?IPC:
+0034A8 80FE              SJMP     ?C0037?IPC
+0034AA         IPC_TIMER:
+0034AA         ?C0039?IPC:
+0034AA 904BA5            MOV      DPTR,#bttimer
+0034AD E0                MOVX     A,@DPTR
+0034AE FE                MOV      R6,A
+0034AF A3                INC      DPTR
+0034B0 E0                MOVX     A,@DPTR
+0034B1 FF                MOV      R7,A
+0034B2 904C5E            MOV      DPTR,#c51timer
+0034B5 E0                MOVX     A,@DPTR
+0034B6 6E                XRL      A,R6
+0034B7 7003              JNZ      ?C0049?IPC
+0034B9 A3                INC      DPTR
+0034BA E0                MOVX     A,@DPTR
+0034BB 6F                XRL      A,R7
+0034BC         ?C0049?IPC:
+0034BC 6022              JZ       ?C0043?IPC
+0034BE 904E6E            MOV      DPTR,#ipcCb+06H
+0034C1 E0                MOVX     A,@DPTR
+0034C2 FB                MOV      R3,A
+0034C3 A3                INC      DPTR
+0034C4 E0                MOVX     A,@DPTR
+0034C5 FA                MOV      R2,A
+0034C6 A3                INC      DPTR
+0034C7 E0                MOVX     A,@DPTR
+0034C8 F9                MOV      R1,A
+0034C9 4A                ORL      A,R2
+0034CA 6037              JZ       ?C0042?IPC
+0034CC         ?C0041?IPC:
+0034CC 1205D9            LCALL    ?C?ICALL
+0034CF 904BA5            MOV      DPTR,#bttimer
+0034D2 E0                MOVX     A,@DPTR
+0034D3 FF                MOV      R7,A
+0034D4 A3                INC      DPTR
+0034D5 E0                MOVX     A,@DPTR
+0034D6 904C5E            MOV      DPTR,#c51timer
+0034D9 CF                XCH      A,R7
+0034DA F0                MOVX     @DPTR,A
+0034DB A3                INC      DPTR
+0034DC EF                MOV      A,R7
+0034DD F0                MOVX     @DPTR,A
+0034DE 80CA              SJMP     ?C0039?IPC
+0034E0         ?C0043?IPC:
+0034E0 904C8D            MOV      DPTR,#btstimer
+0034E3 E0                MOVX     A,@DPTR
+0034E4 FF                MOV      R7,A
+0034E5 A3                INC      DPTR
+0034E6 E0                MOVX     A,@DPTR
+0034E7 6F                XRL      A,R7
+0034E8 6019              JZ       ?C0042?IPC
+0034EA 904E71            MOV      DPTR,#ipcCb+09H
+0034ED E0                MOVX     A,@DPTR
+0034EE FB                MOV      R3,A
+0034EF A3                INC      DPTR
+0034F0 E0                MOVX     A,@DPTR
+0034F1 FA                MOV      R2,A
+0034F2 A3                INC      DPTR
+0034F3 E0                MOVX     A,@DPTR
+0034F4 F9                MOV      R1,A
+0034F5 4A                ORL      A,R2
+0034F6 600B              JZ       ?C0042?IPC
+0034F8         ?C0045?IPC:
+0034F8 1205D9            LCALL    ?C?ICALL
+0034FB 904C8D            MOV      DPTR,#btstimer
+0034FE E0                MOVX     A,@DPTR
+0034FF A3                INC      DPTR
+003500 F0                MOVX     @DPTR,A
+003501 80DD              SJMP     ?C0043?IPC
+003503         ?C0042?IPC:
+003503 22                RET      
+----- FUNCTION IPC_DealSingleStep (END) -------
+
+
+----- FUNCTION _IPC_TxBREDRHidData (BEGIN) -----
+;---- Variable 'len' assigned to Register 'R5' ----
+;---- Variable 'dt' assigned to Register 'R1/R2/R3' ----
+003504 900BE7            MOV      DPTR,#ipcSendBuff
+003507 7403              MOV      A,#03H
+003509 F0                MOVX     @DPTR,A
+00350A ED                MOV      A,R5
+00350B 6003              JZ       ?C0017?IPC
+00350D         ?C0016?IPC:
+00350D 120FC2            LCALL    _IPC_TxData
+003510         ?C0017?IPC:
+003510 22                RET      
+----- FUNCTION _IPC_TxBREDRHidData (END) -------
+
+
+----- FUNCTION _IPC_Tx24GData (BEGIN) -----
+;---- Variable 'len' assigned to Register 'R5' ----
+;---- Variable 'dt' assigned to Register 'R1/R2/R3' ----
+003511 900BE7            MOV      DPTR,#ipcSendBuff
+003514 7406              MOV      A,#06H
+003516 F0                MOVX     @DPTR,A
+003517 020FC2            LJMP     _IPC_TxData
+----- FUNCTION _IPC_Tx24GData (END) -------
+
+
+----- FUNCTION _IPC_TxSppData (BEGIN) -----
+;---- Variable 'len' assigned to Register 'R5' ----
+;---- Variable 'dt' assigned to Register 'R1/R2/R3' ----
+00351A 900BE7            MOV      DPTR,#ipcSendBuff
+00351D 7404              MOV      A,#04H
+00351F F0                MOVX     @DPTR,A
+003520 020FC2            LJMP     _IPC_TxData
+----- FUNCTION _IPC_TxSppData (END) -------
+
+
+----- FUNCTION _IPC_TxBleData (BEGIN) -----
+;---- Variable 'len' assigned to Register 'R5' ----
+;---- Variable 'dt' assigned to Register 'R1/R2/R3' ----
+003523 900BE7            MOV      DPTR,#ipcSendBuff
+003526 7405              MOV      A,#05H
+003528 F0                MOVX     @DPTR,A
+003529 020FC2            LJMP     _IPC_TxData
+----- FUNCTION _IPC_TxBleData (END) -------
+
+
+----- FUNCTION IPC_GetBBDIsconnectReason (BEGIN) -----
+00352C 900446            MOV      DPTR,#bbDisReason
+00352F E0                MOVX     A,@DPTR
+003530 FF                MOV      R7,A
+003531 22                RET      
+----- FUNCTION IPC_GetBBDIsconnectReason (END) -------
+
+
+----- FUNCTION IPC_AbandonLpm (BEGIN) -----
+003532 900B7F            MOV      DPTR,#lpm_flag
+003535 7401              MOV      A,#01H
+003537 F0                MOVX     @DPTR,A
+003538 E4                CLR      A
+003539 900B7E            MOV      DPTR,#current_task
+00353C F0                MOVX     @DPTR,A
+00353D 22                RET      
+----- FUNCTION IPC_AbandonLpm (END) -------
+
+
+----- FUNCTION YC_Ice_break (BEGIN) -----
+00353E 908280            MOV      DPTR,#08280H
+003541 7401              MOV      A,#01H
+003543 F0                MOVX     @DPTR,A
+003544 22                RET      
+----- FUNCTION YC_Ice_break (END) -------
+
+
+----- FUNCTION _xmemclear_ff (BEGIN) -----
+003545 904EF2            MOV      DPTR,#dest
+003548 EB                MOV      A,R3
+003549 F0                MOVX     @DPTR,A
+00354A A3                INC      DPTR
+00354B EA                MOV      A,R2
+00354C F0                MOVX     @DPTR,A
+00354D A3                INC      DPTR
+00354E E9                MOV      A,R1
+00354F F0                MOVX     @DPTR,A
+;---- Variable 'len' assigned to Register 'R4/R5' ----
+003550         ?C0011?UTILITIES:
+003550 ED                MOV      A,R5
+003551 1D                DEC      R5
+003552 AE04              MOV      R6,AR4
+003554 7001              JNZ      ?C0027?UTILITIES
+003556 1C                DEC      R4
+003557         ?C0027?UTILITIES:
+003557 4E                ORL      A,R6
+003558 6017              JZ       ?C0013?UTILITIES
+00355A 904EF2            MOV      DPTR,#dest
+00355D E0                MOVX     A,@DPTR
+00355E FB                MOV      R3,A
+00355F A3                INC      DPTR
+003560 E4                CLR      A
+003561 75F001            MOV      B,#01H
+003564 120424            LCALL    ?C?ILDIX
+003567 A9F0              MOV      R1,B
+003569 FA                MOV      R2,A
+00356A 74FF              MOV      A,#0FFH
+00356C 1203FC            LCALL    ?C?CSTPTR
+00356F 80DF              SJMP     ?C0011?UTILITIES
+003571         ?C0013?UTILITIES:
+003571 22                RET      
+----- FUNCTION _xmemclear_ff (END) -------
+
+
+----- FUNCTION _GPIO_ClearWakeup (BEGIN) -----
+;---- Variable 'gpio_num' assigned to Register 'R7' ----
+003572 EF                MOV      A,R7
+003573 F4                CPL      A
+003574 603A              JZ       ?C0023?GPIO
+003576         ?C0022?GPIO:
+003576 EF                MOV      A,R7
+003577 5407              ANL      A,#07H
+003579 FE                MOV      R6,A
+;---- Variable 'queue' assigned to Register 'R6' ----
+00357A EF                MOV      A,R7
+00357B 13                RRC      A
+00357C 13                RRC      A
+00357D 13                RRC      A
+00357E 5403              ANL      A,#03H
+003580 FF                MOV      R7,A
+;---- Variable 'group' assigned to Register 'R7' ----
+003581 24A3              ADD      A,#LOW YC_GPIOWakeupL
+003583 F582              MOV      DPL,A
+003585 E4                CLR      A
+003586 3400              ADDC     A,#HIGH YC_GPIOWakeupL
+003588 F583              MOV      DPH,A
+00358A C083              PUSH     DPH
+00358C C082              PUSH     DPL
+00358E E0                MOVX     A,@DPTR
+00358F FD                MOV      R5,A
+003590 7401              MOV      A,#01H
+003592 A806              MOV      R0,AR6
+003594 08                INC      R0
+003595 8002              SJMP     ?C0043?GPIO
+003597         ?C0042?GPIO:
+003597 C3                CLR      C
+003598 33                RLC      A
+003599         ?C0043?GPIO:
+003599 D8FC              DJNZ     R0,?C0042?GPIO
+00359B F4                CPL      A
+00359C FC                MOV      R4,A
+00359D 5D                ANL      A,R5
+00359E D082              POP      DPL
+0035A0 D083              POP      DPH
+0035A2 F0                MOVX     @DPTR,A
+0035A3 74A7              MOV      A,#LOW YC_GPIOWakeupH
+0035A5 2F                ADD      A,R7
+0035A6 F582              MOV      DPL,A
+0035A8 E4                CLR      A
+0035A9 3400              ADDC     A,#HIGH YC_GPIOWakeupH
+0035AB F583              MOV      DPH,A
+0035AD E0                MOVX     A,@DPTR
+0035AE 5C                ANL      A,R4
+0035AF F0                MOVX     @DPTR,A
+0035B0         ?C0023?GPIO:
+0035B0 22                RET      
+----- FUNCTION _GPIO_ClearWakeup (END) -------
+
+
+----- FUNCTION _GPIO_FlipOutBit (BEGIN) -----
+0035B1 904F0A            MOV      DPTR,#gpio_num
+0035B4 EF                MOV      A,R7
+0035B5 F0                MOVX     @DPTR,A
+0035B6 7B01              MOV      R3,#01H
+0035B8 7A80              MOV      R2,#080H
+0035BA 7974              MOV      R1,#074H
+0035BC 121FAC            LCALL    _gpioGetBit
+0035BF 9209              MOV      st,C
+0035C1 904F0A            MOV      DPTR,#gpio_num
+0035C4 E0                MOVX     A,@DPTR
+0035C5 FF                MOV      R7,A
+0035C6 A209              MOV      C,st
+0035C8 B3                CPL      C
+0035C9 9201              MOV      ?_GPIO_Setout?BIT,C
+0035CB 0211B2            LJMP     _GPIO_Setout
+----- FUNCTION _GPIO_FlipOutBit (END) -------
+
+
+----- FUNCTION GPIO_fillpd (BEGIN) -----
+;---- Variable 'i' assigned to Register 'R7' ----
+0035CE E4                CLR      A
+0035CF FF                MOV      R7,A
+0035D0         ?C0026?GPIO:
+0035D0 EF                MOV      A,R7
+0035D1 FD                MOV      R5,A
+0035D2 7C00              MOV      R4,#00H
+0035D4 2478              ADD      A,#078H
+0035D6 FB                MOV      R3,A
+0035D7 EC                MOV      A,R4
+0035D8 3480              ADDC     A,#080H
+0035DA 8B82              MOV      DPL,R3
+0035DC F583              MOV      DPH,A
+0035DE E0                MOVX     A,@DPTR
+0035DF FE                MOV      R6,A
+0035E0 ED                MOV      A,R5
+0035E1 2470              ADD      A,#070H
+0035E3 FD                MOV      R5,A
+0035E4 EC                MOV      A,R4
+0035E5 3480              ADDC     A,#080H
+0035E7 8D82              MOV      DPL,R5
+0035E9 F583              MOV      DPH,A
+0035EB E0                MOVX     A,@DPTR
+0035EC 4E                ORL      A,R6
+0035ED F4                CPL      A
+0035EE FE                MOV      R6,A
+0035EF EF                MOV      A,R7
+0035F0 247C              ADD      A,#07CH
+0035F2 FD                MOV      R5,A
+0035F3 EC                MOV      A,R4
+0035F4 3480              ADDC     A,#080H
+0035F6 8D82              MOV      DPL,R5
+0035F8 F583              MOV      DPH,A
+0035FA EE                MOV      A,R6
+0035FB F0                MOVX     @DPTR,A
+0035FC 0F                INC      R7
+0035FD EF                MOV      A,R7
+0035FE B404CF            CJNE     A,#04H,?C0026?GPIO
+003601 22                RET      
+----- FUNCTION GPIO_fillpd (END) -------
+
+
Index: c51/output/FW.HTM
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/FW.HTM	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/FW.HTM	(working copy)
@@ -0,0 +1,1274 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
+<html>
+<head>
+<title>LX51 Static Call Analysis</title>
+<meta http-equiv="Content-Type" content="text/html; charset=windows-1252">
+<style type="text/css">
+<!--
+p            { font-family: Verdana; font-size: 8pt; margin-top: 2; margin-bottom: 2 }
+.LI2         { margin-top: 2; margin-bottom: 2 }
+.Release     { background-color: #CCCCCC; font-weight: bold; padding: 6 }
+.ToolT       { font-size: 8pt; color: #808080 }
+.TinyT       { font-size: 8pt; text-align: Center }
+ul           { font-family: Verdana; font-size: 8pt; list-style-type: square;  margin-top: 2; margin-bottom: 2 }
+ol           { font-family: Verdana; font-size: 8pt }
+h1           { font-family: Verdana; font-size: 14pt; color: #000080; font-weight: bold; text-align: Center; margin-right: 3 }
+h2           { font-family: Verdana; font-size: 8pt; color: #000080; font-weight: bold; margin-top: 12; margin-bottom: 3; background-color: #CCCCCC; padding: 6 }
+h3           { font-family: Verdana; font-size: 8pt; font-weight: bold; margin-top: 12; margin-bottom: 3; background-color: #CCCCCC; padding: 6 }
+pre          { font-family: Courier New; font-size: 8pt; background-color: #CCFFCC; margin-left: 24; margin-right: 24 }
+li           { margin-top: 3; margin-bottom: 0 }
+-->
+</style>
+</head>
+<body>
+<h1>Static Call Analysis for<br>OUTPUT\FW (BLUETOOTH)</h1>
+
+<p class="TinyT">
+Created from: <b>LX51 LINKER/LOCATER V4.66.97.0</b><br>
+Creation time: <b>07/11/2022  10:06:55</b><p>
+
+<hr>
+
+
+<h2><a name="S2"></a>?PR?_YC_LOAD_RECORD_LIST?BLUETOOTH (C:000737H - C:0007FDH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S163">?PR?_XMEMCPY?UTILITIES</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a></li>
+<li><a href="#S163">?PR?_XMEMCPY?UTILITIES</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+</ul>
+
+<h2><a name="S13"></a>?PR?YC_START_RECONNECT?BLUETOOTH (C:002004H - C:0020C9H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=10 Bytes (<a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S171">?PR?_DELAY1MS?UTILITIES</a></li>
+<li><a href="#S205">?PR?_IIC_READ?IIC</a></li>
+<li><a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+</ul>
+
+<h2><a name="S99"></a>?PR?SYSTEM_HARDWARE_RESET?SYS (C:001D33H - C:001D3BH)</h2>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+</ul>
+
+<h2><a name="S103"></a>?PR?_KB_CB_HID?SYS (C:0031A1H - C:0031B0H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S213">?C?LIB_CODE</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+</ul>
+
+<h2><a name="S105"></a>?PR?_KB_CB_EVENT?SYS (C:0014C8H - C:00178EH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=14 Bytes (<a href="#S97">?PR?SYSTEM_HARDWARE_INIT?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+<li><a href="#S171">?PR?_DELAY1MS?UTILITIES</a></li>
+<li><a href="#S180">?PR?_GPIO_SETOUT?GPIO</a></li>
+<li><a href="#S205">?PR?_IIC_READ?IIC</a></li>
+<li><a href="#S209">?PR?_IIC_WRITEBLOCK?IIC</a></li>
+<li><a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a></li>
+<li><a href="#S169">?PR?_XMEMCLEAR_FF?UTILITIES</a></li>
+<li><a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a></li>
+<li><a href="#S2">?PR?_YC_LOAD_RECORD_LIST?BLUETOOTH</a></li>
+<li><a href="#S4">?PR?_YC_STORE_RECORD_LIST?BLUETOOTH</a></li>
+<li><a href="#S81">?PR?KS_INITIALIZE?KEYSCAN</a></li>
+<li><a href="#S93">?PR?LED_DEVICE_POWEROFF?LED</a></li>
+<li><a href="#S92">?PR?LED_DEVICE_POWERON?LED</a></li>
+<li><a href="#S97">?PR?SYSTEM_HARDWARE_INIT?SYS</a></li>
+<li><a href="#S99">?PR?SYSTEM_HARDWARE_RESET?SYS</a></li>
+<li><a href="#S96">?PR?SYSTEM_IIC_CLK_SETUP?SYS</a></li>
+<li><a href="#S100">?PR?SYSTEM_LONG_SLEEP?SYS</a></li>
+<li><a href="#S98">?PR?SYSTEM_SOFTWARE_INIT?SYS</a></li>
+<li><a href="#S10">?PR?YC_CLEAR_RECONNECT_FLAG?BLUETOOTH</a></li>
+<li><a href="#S13">?PR?YC_START_RECONNECT?BLUETOOTH</a></li>
+<li><a href="#S15">?PR?YC_UPDATE_EEPROM_DATA?BLUETOOTH</a></li>
+</ul>
+
+<h2><a name="S110"></a>?PR?YC_PAIRING_TIMEROUT_500MS?SYS (C:0022B9H - C:002301H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=10 Bytes (<a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S171">?PR?_DELAY1MS?UTILITIES</a></li>
+<li><a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a></li>
+<li><a href="#S100">?PR?SYSTEM_LONG_SLEEP?SYS</a></li>
+</ul>
+
+<h2><a name="S112"></a>?PR?KB_CB_TIMER500MS?SYS (C:00229FH - C:0022B8H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=16 Bytes (<a href="#S108">?PR?YC_CONNECT_TIMEOUT_500MS?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S111">?PR?KB_BUTTON_PRESS_TIMER500MS?SYS</a></li>
+<li><a href="#S107">?PR?LED_TIMER500MS?SYS</a></li>
+<li><a href="#S121">?PR?YC_ADC_MOTION_CHECK_TIMER500MS?ADC</a></li>
+<li><a href="#S108">?PR?YC_CONNECT_TIMEOUT_500MS?SYS</a></li>
+<li><a href="#S109">?PR?YC_WAIT_DISCONNECT_TIMER500MS?SYS</a></li>
+</ul>
+
+<h2><a name="S113"></a>?PR?KB_CB_TIMER100MS?SYS (C:0031B1H - C:0032AAH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=14 Bytes (<a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S180">?PR?_GPIO_SETOUT?GPIO</a></li>
+<li><a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a></li>
+<li><a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a></li>
+<li><a href="#S93">?PR?LED_DEVICE_POWEROFF?LED</a></li>
+<li><a href="#S92">?PR?LED_DEVICE_POWERON?LED</a></li>
+</ul>
+
+<h2><a name="S115"></a>?PR?YC_SYSTEM_MAIN?SYS (C:001D3CH - C:001D8AH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=18 Bytes (<a href="#S64">?PR?KB_NEED_KEYSCAN?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S141">?PR?IPC_ABANDONLPM?IPC</a></li>
+<li><a href="#S143">?PR?IPC_DEALSINGLESTEP?IPC</a></li>
+<li><a href="#S140">?PR?IPC_WAITLPM?IPC</a></li>
+<li><a href="#S114">?PR?KB_CB_INIT?SYS</a></li>
+<li><a href="#S64">?PR?KB_NEED_KEYSCAN?KB_PROCESS</a></li>
+<li><a href="#S82">?PR?KS_UNISTALL?KEYSCAN</a></li>
+<li><a href="#S91">?PR?LED_ALL_SHUTDOWN?LED</a></li>
+<li><a href="#S94">?PR?LED_HANDLE?LED</a></li>
+<li><a href="#S101">?PR?SYSTEM_G24_LONG_LPM?SYS</a></li>
+<li><a href="#S15">?PR?YC_UPDATE_EEPROM_DATA?BLUETOOTH</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S123">?PR?MAIN?RAM</a></li>
+</ul>
+
+<h2><a name="S123"></a>?PR?MAIN?RAM (C:001FEBH - C:001FECH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=18 Bytes (<a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a></li>
+</ul>
+
+<h2><a name="S134"></a>?PR?_IPC_TXBREDRHIDDATA?IPC (C:003504H - C:003510H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=6 Bytes (<a href="#S132">?PR?_IPC_TXDATA?IPC</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S132">?PR?_IPC_TXDATA?IPC</a></li>
+</ul>
+
+<h2><a name="S136"></a>?PR?_IPC_TXSPPDATA?IPC (C:00351AH - C:003522H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S132">?PR?_IPC_TXDATA?IPC</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S132">?PR?_IPC_TXDATA?IPC</a></li>
+</ul>
+
+<h2><a name="S139"></a>?PR?_IPC_INITIALIZE?IPC (C:001F99H - C:001FA5H)</h2>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+</ul>
+
+<h2><a name="S4"></a>?PR?_YC_STORE_RECORD_LIST?BLUETOOTH (C:0007FEH - C:000877H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S163">?PR?_XMEMCPY?UTILITIES</a>) Top=2 Bytes (<a href="#S105">?PR?_KB_CB_EVENT?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S163">?PR?_XMEMCPY?UTILITIES</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+</ul>
+
+<h2><a name="S6"></a>?PR?YC_CHECK_IS_CONNECTED?BLUETOOTH (C:0010D3H - C:0010E8H)</h2>
+<p><br><b>Maximum Stack:</b> Top=4 Bytes (<a href="#S107">?PR?LED_TIMER500MS?SYS</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S94">?PR?LED_HANDLE?LED</a></li>
+<li><a href="#S107">?PR?LED_TIMER500MS?SYS</a></li>
+</ul>
+
+<h2><a name="S7"></a>?PR?YC_CHECK_NEED_RECONNECTED?BLUETOOTH (C:001922H - C:0019ADH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=10 Bytes (<a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a>) Top=8 Bytes (<a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S9"></a>?PR?YC_CANCEL_RECONNECT?BLUETOOTH (C:0019AEH - C:0019C0H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a>) Top=12 Bytes (<a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S10"></a>?PR?YC_CLEAR_RECONNECT_FLAG?BLUETOOTH (C:0017E0H - C:0017E9H)</h2>
+<p><br><b>Maximum Stack:</b> Top=12 Bytes (<a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+<li><a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S11"></a>?PR?YC_DISCONNECT_ALL_LINK?BLUETOOTH (C:0019C1H - C:0019EFH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a>) Top=12 Bytes (<a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a></li>
+<li><a href="#S111">?PR?KB_BUTTON_PRESS_TIMER500MS?SYS</a></li>
+<li><a href="#S108">?PR?YC_CONNECT_TIMEOUT_500MS?SYS</a></li>
+</ul>
+
+<h2><a name="S12"></a>?PR?YC_G24_MODE_DISCOVERY?BLUETOOTH (C:001FEDH - C:002003H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a>) Top=12 Bytes (<a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S14"></a>?PR?YC_GET_BLE_RAMDON_LAP?BLUETOOTH (C:00221CH - C:00225EH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S205">?PR?_IIC_READ?IIC</a>) Top=12 Bytes (<a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S205">?PR?_IIC_READ?IIC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a></li>
+<li><a href="#S109">?PR?YC_WAIT_DISCONNECT_TIMER500MS?SYS</a></li>
+</ul>
+
+<h2><a name="S15"></a>?PR?YC_UPDATE_EEPROM_DATA?BLUETOOTH (C:001BEAH - C:001C83H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=8 Bytes (<a href="#S209">?PR?_IIC_WRITEBLOCK?IIC</a>) Top=4 Bytes (<a href="#S111">?PR?KB_BUTTON_PRESS_TIMER500MS?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S171">?PR?_DELAY1MS?UTILITIES</a></li>
+<li><a href="#S180">?PR?_GPIO_SETOUT?GPIO</a></li>
+<li><a href="#S209">?PR?_IIC_WRITEBLOCK?IIC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+<li><a href="#S111">?PR?KB_BUTTON_PRESS_TIMER500MS?SYS</a></li>
+<li><a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a></li>
+</ul>
+
+<h2><a name="S53"></a>?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS (C:0012C6H - C:00149CH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=8 Bytes (<a href="#S209">?PR?_IIC_WRITEBLOCK?IIC</a>) Top=10 Bytes (<a href="#S7">?PR?YC_CHECK_NEED_RECONNECTED?BLUETOOTH</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S171">?PR?_DELAY1MS?UTILITIES</a></li>
+<li><a href="#S180">?PR?_GPIO_SETOUT?GPIO</a></li>
+<li><a href="#S205">?PR?_IIC_READ?IIC</a></li>
+<li><a href="#S209">?PR?_IIC_WRITEBLOCK?IIC</a></li>
+<li><a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a></li>
+<li><a href="#S169">?PR?_XMEMCLEAR_FF?UTILITIES</a></li>
+<li><a href="#S9">?PR?YC_CANCEL_RECONNECT?BLUETOOTH</a></li>
+<li><a href="#S10">?PR?YC_CLEAR_RECONNECT_FLAG?BLUETOOTH</a></li>
+<li><a href="#S11">?PR?YC_DISCONNECT_ALL_LINK?BLUETOOTH</a></li>
+<li><a href="#S12">?PR?YC_G24_MODE_DISCOVERY?BLUETOOTH</a></li>
+<li><a href="#S14">?PR?YC_GET_BLE_RAMDON_LAP?BLUETOOTH</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+<li><a href="#S111">?PR?KB_BUTTON_PRESS_TIMER500MS?SYS</a></li>
+<li><a href="#S7">?PR?YC_CHECK_NEED_RECONNECTED?BLUETOOTH</a></li>
+<li><a href="#S110">?PR?YC_PAIRING_TIMEROUT_500MS?SYS</a></li>
+<li><a href="#S13">?PR?YC_START_RECONNECT?BLUETOOTH</a></li>
+</ul>
+
+<h2><a name="S55"></a>?PR?_IPC_TXHIDDATA?KB_PROCESS (C:000EDAH - C:000FC1H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=12 Bytes (<a href="#S7">?PR?YC_CHECK_NEED_RECONNECTED?BLUETOOTH</a>) Top=6 Bytes (<a href="#S65">?PR?_KB_MOTION_KEYSCAN?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+<li><a href="#S135">?PR?_IPC_TX24GDATA?IPC</a></li>
+<li><a href="#S137">?PR?_IPC_TXBLEDATA?IPC</a></li>
+<li><a href="#S7">?PR?YC_CHECK_NEED_RECONNECTED?BLUETOOTH</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S65">?PR?_KB_MOTION_KEYSCAN?KB_PROCESS</a></li>
+<li><a href="#S59">?PR?_KB_SEND_COMBINATION_KEY?KB_PROCESS</a></li>
+<li><a href="#S61">?PR?KB_24G_GET_LED_STATUS?KB_PROCESS</a></li>
+<li><a href="#S113">?PR?KB_CB_TIMER100MS?SYS</a></li>
+<li><a href="#S108">?PR?YC_CONNECT_TIMEOUT_500MS?SYS</a></li>
+</ul>
+
+<h2><a name="S57"></a>?PR?_KB_SET_MULTIKEY?KB_PROCESS (C:000DDFH - C:000DF9H)</h2>
+<p><br><b>Maximum Stack:</b> Top=8 Bytes (<a href="#S72">?PR?_KB_MULTIKEY_SETUP?KB_PROCESS</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S72">?PR?_KB_MULTIKEY_SETUP?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S58"></a>?PR?_KB_SET_SYSTEMKEY?KB_PROCESS (C:000EBFH - C:000ED9H)</h2>
+<p><br><b>Maximum Stack:</b> Top=8 Bytes (<a href="#S72">?PR?_KB_MULTIKEY_SETUP?KB_PROCESS</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S72">?PR?_KB_MULTIKEY_SETUP?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S59"></a>?PR?_KB_SEND_COMBINATION_KEY?KB_PROCESS (C:001F57H - C:001F92H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=12 Bytes (<a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a>) Top=4 Bytes (<a href="#S64">?PR?KB_NEED_KEYSCAN?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a></li>
+<li><a href="#S167">?PR?_XMEMCLEAR?UTILITIES</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S64">?PR?KB_NEED_KEYSCAN?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S61"></a>?PR?KB_24G_GET_LED_STATUS?KB_PROCESS (C:002671H - C:0026AEH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=14 Bytes (<a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a>) Top=2 Bytes (<a href="#S62">?PR?KB_MOTION?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a></li>
+<li><a href="#S167">?PR?_XMEMCLEAR?UTILITIES</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S62">?PR?KB_MOTION?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S62"></a>?PR?KB_MOTION?KB_PROCESS (C:0026AFH - C:0026E2H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=16 Bytes (<a href="#S65">?PR?_KB_MOTION_KEYSCAN?KB_PROCESS</a>) Top=2 Bytes (<a href="#S64">?PR?KB_NEED_KEYSCAN?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S65">?PR?_KB_MOTION_KEYSCAN?KB_PROCESS</a></li>
+<li><a href="#S142">?PR?IPC_ISTXBUFFEMPTY?IPC</a></li>
+<li><a href="#S61">?PR?KB_24G_GET_LED_STATUS?KB_PROCESS</a></li>
+<li><a href="#S88">?PR?KS_GETCURRENTEVT?KEYSCAN</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S64">?PR?KB_NEED_KEYSCAN?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S64"></a>?PR?KB_NEED_KEYSCAN?KB_PROCESS (C:001ED0H - C:001F56H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=16 Bytes (<a href="#S62">?PR?KB_MOTION?KB_PROCESS</a>) Top=2 Bytes (<a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S59">?PR?_KB_SEND_COMBINATION_KEY?KB_PROCESS</a></li>
+<li><a href="#S62">?PR?KB_MOTION?KB_PROCESS</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a></li>
+</ul>
+
+<h2><a name="S65"></a>?PR?_KB_MOTION_KEYSCAN?KB_PROCESS (C:0008BBH - C:000BDCH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=14 Bytes (<a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a>) Top=4 Bytes (<a href="#S62">?PR?KB_MOTION?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+<li><a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a></li>
+<li><a href="#S67">?PR?_KB_DEVICE_SELECT?KB_PROCESS</a></li>
+<li><a href="#S72">?PR?_KB_MULTIKEY_SETUP?KB_PROCESS</a></li>
+<li><a href="#S167">?PR?_XMEMCLEAR?UTILITIES</a></li>
+<li><a href="#S163">?PR?_XMEMCPY?UTILITIES</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S62">?PR?KB_MOTION?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S67"></a>?PR?_KB_DEVICE_SELECT?KB_PROCESS (C:0026FBH - C:00285FH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S213">?C?LIB_CODE</a>) Top=6 Bytes (<a href="#S65">?PR?_KB_MOTION_KEYSCAN?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S65">?PR?_KB_MOTION_KEYSCAN?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S69"></a>?PR?_KB_COMBINATION_KEY_PRESS?KB_PROCESS (C:002860H - C:002885H)</h2>
+<p><br><b>Maximum Stack:</b> Top=8 Bytes (<a href="#S70">?PR?_KEY_FN_FUNCTION?KB_PROCESS</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S70">?PR?_KEY_FN_FUNCTION?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S70"></a>?PR?_KEY_FN_FUNCTION?KB_PROCESS (C:002886H - C:002ACAH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S69">?PR?_KB_COMBINATION_KEY_PRESS?KB_PROCESS</a>) Top=6 Bytes (<a href="#S88">?PR?KS_GETCURRENTEVT?KEYSCAN</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S69">?PR?_KB_COMBINATION_KEY_PRESS?KB_PROCESS</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S88">?PR?KS_GETCURRENTEVT?KEYSCAN</a></li>
+</ul>
+
+<h2><a name="S72"></a>?PR?_KB_MULTIKEY_SETUP?KB_PROCESS (C:000BDDH - C:000DDEH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S213">?C?LIB_CODE</a>) Top=6 Bytes (<a href="#S65">?PR?_KB_MOTION_KEYSCAN?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+<li><a href="#S57">?PR?_KB_SET_MULTIKEY?KB_PROCESS</a></li>
+<li><a href="#S58">?PR?_KB_SET_SYSTEMKEY?KB_PROCESS</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S65">?PR?_KB_MOTION_KEYSCAN?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S74"></a>?PR?_BIT_COUNT?KEYSCAN (C:002D2DH - C:002D3AH)</h2>
+<p><br><b>Maximum Stack:</b> Top=6 Bytes (<a href="#S88">?PR?KS_GETCURRENTEVT?KEYSCAN</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S88">?PR?KS_GETCURRENTEVT?KEYSCAN</a></li>
+</ul>
+
+<h2><a name="S75"></a>?PR?_KEYIN?KEYSCAN (C:002DB5H - C:002E1CH)</h2>
+<p><br><b>Maximum Stack:</b> Top=6 Bytes (<a href="#S88">?PR?KS_GETCURRENTEVT?KEYSCAN</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S88">?PR?KS_GETCURRENTEVT?KEYSCAN</a></li>
+</ul>
+
+<h2><a name="S76"></a>?PR?_KEYOUT?KEYSCAN (C:002E1DH - C:002EDDH)</h2>
+<p><br><b>Maximum Stack:</b> Top=6 Bytes (<a href="#S88">?PR?KS_GETCURRENTEVT?KEYSCAN</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S88">?PR?KS_GETCURRENTEVT?KEYSCAN</a></li>
+</ul>
+
+<h2><a name="S77"></a>?PR?KSRAWINITIALIZE?KEYSCAN (C:001901H - C:001921H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=8 Bytes (<a href="#S188">?PR?_GPIO_SETINPUT?GPIO</a>) Top=6 Bytes (<a href="#S81">?PR?KS_INITIALIZE?KEYSCAN</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S188">?PR?_GPIO_SETINPUT?GPIO</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S81">?PR?KS_INITIALIZE?KEYSCAN</a></li>
+</ul>
+
+<h2><a name="S79"></a>?PR?KSCOLINITIALIZE?KEYSCAN (C:0018D6H - C:0018F3H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=8 Bytes (<a href="#S188">?PR?_GPIO_SETINPUT?GPIO</a>) Top=4 Bytes (<a href="#S81">?PR?KS_INITIALIZE?KEYSCAN</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S188">?PR?_GPIO_SETINPUT?GPIO</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S81">?PR?KS_INITIALIZE?KEYSCAN</a></li>
+</ul>
+
+<h2><a name="S81"></a>?PR?KS_INITIALIZE?KEYSCAN (C:0018F4H - C:001900H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=10 Bytes (<a href="#S77">?PR?KSRAWINITIALIZE?KEYSCAN</a>) Top=4 Bytes (<a href="#S97">?PR?SYSTEM_HARDWARE_INIT?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S79">?PR?KSCOLINITIALIZE?KEYSCAN</a></li>
+<li><a href="#S77">?PR?KSRAWINITIALIZE?KEYSCAN</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+<li><a href="#S97">?PR?SYSTEM_HARDWARE_INIT?SYS</a></li>
+</ul>
+
+<h2><a name="S82"></a>?PR?KS_UNISTALL?KEYSCAN (C:001D8BH - C:001E22H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S195">?PR?_GPIO_SETWAKEUPBYCURRENTSTATE?GPIO</a>) Top=2 Bytes (<a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S195">?PR?_GPIO_SETWAKEUPBYCURRENTSTATE?GPIO</a></li>
+<li><a href="#S201">?PR?GPIO_FILLPD?GPIO</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a></li>
+</ul>
+
+<h2><a name="S84"></a>?PR?KS_SCANMATRIX?KEYSCAN (C:002EDEH - C:003039H)</h2>
+<p><br><b>Maximum Stack:</b> Top=6 Bytes (<a href="#S88">?PR?KS_GETCURRENTEVT?KEYSCAN</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S88">?PR?KS_GETCURRENTEVT?KEYSCAN</a></li>
+</ul>
+
+<h2><a name="S86"></a>?PR?_ARRAY_IS_EMPTY?KEYSCAN (C:002D3BH - C:002D6AH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S213">?C?LIB_CODE</a>) Top=6 Bytes (<a href="#S88">?PR?KS_GETCURRENTEVT?KEYSCAN</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S88">?PR?KS_GETCURRENTEVT?KEYSCAN</a></li>
+</ul>
+
+<h2><a name="S88"></a>?PR?KS_GETCURRENTEVT?KEYSCAN (C:002ACBH - C:002D2CH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S84">?PR?KS_SCANMATRIX?KEYSCAN</a>) Top=4 Bytes (<a href="#S62">?PR?KB_MOTION?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S86">?PR?_ARRAY_IS_EMPTY?KEYSCAN</a></li>
+<li><a href="#S74">?PR?_BIT_COUNT?KEYSCAN</a></li>
+<li><a href="#S172">?PR?_COMPARE_STR?UTILITIES</a></li>
+<li><a href="#S70">?PR?_KEY_FN_FUNCTION?KB_PROCESS</a></li>
+<li><a href="#S75">?PR?_KEYIN?KEYSCAN</a></li>
+<li><a href="#S76">?PR?_KEYOUT?KEYSCAN</a></li>
+<li><a href="#S84">?PR?KS_SCANMATRIX?KEYSCAN</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S62">?PR?KB_MOTION?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S91"></a>?PR?LED_ALL_SHUTDOWN?LED (C:0017F0H - C:001807H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=8 Bytes (<a href="#S190">?PR?_GPIO_SETOUTPUT?GPIO</a>) Top=4 Bytes (<a href="#S101">?PR?SYSTEM_G24_LONG_LPM?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S190">?PR?_GPIO_SETOUTPUT?GPIO</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S111">?PR?KB_BUTTON_PRESS_TIMER500MS?SYS</a></li>
+<li><a href="#S101">?PR?SYSTEM_G24_LONG_LPM?SYS</a></li>
+<li><a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a></li>
+</ul>
+
+<h2><a name="S92"></a>?PR?LED_DEVICE_POWERON?LED (C:0017B0H - C:0017C7H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=6 Bytes (<a href="#S180">?PR?_GPIO_SETOUT?GPIO</a>) Top=2 Bytes (<a href="#S105">?PR?_KB_CB_EVENT?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S180">?PR?_GPIO_SETOUT?GPIO</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+<li><a href="#S113">?PR?KB_CB_TIMER100MS?SYS</a></li>
+</ul>
+
+<h2><a name="S93"></a>?PR?LED_DEVICE_POWEROFF?LED (C:0017C8H - C:0017DFH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=6 Bytes (<a href="#S180">?PR?_GPIO_SETOUT?GPIO</a>) Top=2 Bytes (<a href="#S105">?PR?_KB_CB_EVENT?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S180">?PR?_GPIO_SETOUT?GPIO</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+<li><a href="#S113">?PR?KB_CB_TIMER100MS?SYS</a></li>
+</ul>
+
+<h2><a name="S94"></a>?PR?LED_HANDLE?LED (C:0011C4H - C:0012C5H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=6 Bytes (<a href="#S180">?PR?_GPIO_SETOUT?GPIO</a>) Top=2 Bytes (<a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S180">?PR?_GPIO_SETOUT?GPIO</a></li>
+<li><a href="#S100">?PR?SYSTEM_LONG_SLEEP?SYS</a></li>
+<li><a href="#S6">?PR?YC_CHECK_IS_CONNECTED?BLUETOOTH</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a></li>
+</ul>
+
+<h2><a name="S95"></a>?PR?SYSTEM_CLEAR_MEM?SYS (C:000E26H - C:000EBEH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S167">?PR?_XMEMCLEAR?UTILITIES</a>) Top=4 Bytes (<a href="#S98">?PR?SYSTEM_SOFTWARE_INIT?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S167">?PR?_XMEMCLEAR?UTILITIES</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S98">?PR?SYSTEM_SOFTWARE_INIT?SYS</a></li>
+</ul>
+
+<h2><a name="S96"></a>?PR?SYSTEM_IIC_CLK_SETUP?SYS (C:00303AH - C:00304CH)</h2>
+<p><br><b>Maximum Stack:</b> Top=4 Bytes (<a href="#S97">?PR?SYSTEM_HARDWARE_INIT?SYS</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+<li><a href="#S97">?PR?SYSTEM_HARDWARE_INIT?SYS</a></li>
+</ul>
+
+<h2><a name="S97"></a>?PR?SYSTEM_HARDWARE_INIT?SYS (C:0017EAH - C:0017EFH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=12 Bytes (<a href="#S81">?PR?KS_INITIALIZE?KEYSCAN</a>) Top=2 Bytes (<a href="#S105">?PR?_KB_CB_EVENT?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S81">?PR?KS_INITIALIZE?KEYSCAN</a></li>
+<li><a href="#S96">?PR?SYSTEM_IIC_CLK_SETUP?SYS</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+</ul>
+
+<h2><a name="S98"></a>?PR?SYSTEM_SOFTWARE_INIT?SYS (C:00304DH - C:003081H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=8 Bytes (<a href="#S118">?PR?YC_ADC_INIT?ADC</a>) Top=2 Bytes (<a href="#S105">?PR?_KB_CB_EVENT?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S95">?PR?SYSTEM_CLEAR_MEM?SYS</a></li>
+<li><a href="#S118">?PR?YC_ADC_INIT?ADC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+</ul>
+
+<h2><a name="S100"></a>?PR?SYSTEM_LONG_SLEEP?SYS (C:00178FH - C:001797H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a>) Top=4 Bytes (<a href="#S108">?PR?YC_CONNECT_TIMEOUT_500MS?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+<li><a href="#S111">?PR?KB_BUTTON_PRESS_TIMER500MS?SYS</a></li>
+<li><a href="#S94">?PR?LED_HANDLE?LED</a></li>
+<li><a href="#S108">?PR?YC_CONNECT_TIMEOUT_500MS?SYS</a></li>
+<li><a href="#S110">?PR?YC_PAIRING_TIMEROUT_500MS?SYS</a></li>
+</ul>
+
+<h2><a name="S101"></a>?PR?SYSTEM_G24_LONG_LPM?SYS (C:002433H - C:002461H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=10 Bytes (<a href="#S91">?PR?LED_ALL_SHUTDOWN?LED</a>) Top=2 Bytes (<a href="#S108">?PR?YC_CONNECT_TIMEOUT_500MS?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S91">?PR?LED_ALL_SHUTDOWN?LED</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S108">?PR?YC_CONNECT_TIMEOUT_500MS?SYS</a></li>
+<li><a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a></li>
+</ul>
+
+<h2><a name="S102"></a>?PR?SYSTEM_RESET_CONNECT?SYS (C:001D33H - C:001D32H)</h2>
+<p><br><b>Maximum Stack:</b> Top=4 Bytes (<a href="#S111">?PR?KB_BUTTON_PRESS_TIMER500MS?SYS</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S111">?PR?KB_BUTTON_PRESS_TIMER500MS?SYS</a></li>
+</ul>
+
+<h2><a name="S107"></a>?PR?LED_TIMER500MS?SYS (C:0010E9H - C:0011B1H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=6 Bytes (<a href="#S198">?PR?_GPIO_FLIPOUTBIT?GPIO</a>) Top=2 Bytes (<a href="#S112">?PR?KB_CB_TIMER500MS?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S198">?PR?_GPIO_FLIPOUTBIT?GPIO</a></li>
+<li><a href="#S180">?PR?_GPIO_SETOUT?GPIO</a></li>
+<li><a href="#S6">?PR?YC_CHECK_IS_CONNECTED?BLUETOOTH</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S112">?PR?KB_CB_TIMER500MS?SYS</a></li>
+</ul>
+
+<h2><a name="S108"></a>?PR?YC_CONNECT_TIMEOUT_500MS?SYS (C:002334H - C:002432H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=14 Bytes (<a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a>) Top=2 Bytes (<a href="#S112">?PR?KB_CB_TIMER500MS?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a></li>
+<li><a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a></li>
+<li><a href="#S167">?PR?_XMEMCLEAR?UTILITIES</a></li>
+<li><a href="#S101">?PR?SYSTEM_G24_LONG_LPM?SYS</a></li>
+<li><a href="#S100">?PR?SYSTEM_LONG_SLEEP?SYS</a></li>
+<li><a href="#S11">?PR?YC_DISCONNECT_ALL_LINK?BLUETOOTH</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S112">?PR?KB_CB_TIMER500MS?SYS</a></li>
+</ul>
+
+<h2><a name="S109"></a>?PR?YC_WAIT_DISCONNECT_TIMER500MS?SYS (C:00225FH - C:00229EH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=6 Bytes (<a href="#S14">?PR?YC_GET_BLE_RAMDON_LAP?BLUETOOTH</a>) Top=2 Bytes (<a href="#S112">?PR?KB_CB_TIMER500MS?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a></li>
+<li><a href="#S14">?PR?YC_GET_BLE_RAMDON_LAP?BLUETOOTH</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S112">?PR?KB_CB_TIMER500MS?SYS</a></li>
+</ul>
+
+<h2><a name="S111"></a>?PR?KB_BUTTON_PRESS_TIMER500MS?SYS (C:0019F0H - C:001BE9H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=10 Bytes (<a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a>) Top=2 Bytes (<a href="#S112">?PR?KB_CB_TIMER500MS?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S171">?PR?_DELAY1MS?UTILITIES</a></li>
+<li><a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a></li>
+<li><a href="#S91">?PR?LED_ALL_SHUTDOWN?LED</a></li>
+<li><a href="#S100">?PR?SYSTEM_LONG_SLEEP?SYS</a></li>
+<li><a href="#S102">?PR?SYSTEM_RESET_CONNECT?SYS</a></li>
+<li><a href="#S11">?PR?YC_DISCONNECT_ALL_LINK?BLUETOOTH</a></li>
+<li><a href="#S15">?PR?YC_UPDATE_EEPROM_DATA?BLUETOOTH</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S112">?PR?KB_CB_TIMER500MS?SYS</a></li>
+</ul>
+
+<h2><a name="S114"></a>?PR?KB_CB_INIT?SYS (C:001F93H - C:001F98H)</h2>
+<p><br><b>Maximum Stack:</b> Top=2 Bytes (<a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a></li>
+</ul>
+
+<h2><a name="S118"></a>?PR?YC_ADC_INIT?ADC (C:003082H - C:0031A0H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=6 Bytes (<a href="#S213">?C?LIB_CODE</a>) Top=4 Bytes (<a href="#S98">?PR?SYSTEM_SOFTWARE_INIT?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S98">?PR?SYSTEM_SOFTWARE_INIT?SYS</a></li>
+</ul>
+
+<h2><a name="S119"></a>?PR?YC_ADC_CHECK?ADC (C:0024A6H - C:002670H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S213">?C?LIB_CODE</a>) Top=6 Bytes (<a href="#S122">?PR?YC_ADC_CHECK_TIMER500MS?ADC</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S122">?PR?YC_ADC_CHECK_TIMER500MS?ADC</a></li>
+</ul>
+
+<h2><a name="S121"></a>?PR?YC_ADC_MOTION_CHECK_TIMER500MS?ADC (C:002302H - C:002322H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=6 Bytes (<a href="#S122">?PR?YC_ADC_CHECK_TIMER500MS?ADC</a>) Top=2 Bytes (<a href="#S112">?PR?KB_CB_TIMER500MS?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S122">?PR?YC_ADC_CHECK_TIMER500MS?ADC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S112">?PR?KB_CB_TIMER500MS?SYS</a></li>
+</ul>
+
+<h2><a name="S122"></a>?PR?YC_ADC_CHECK_TIMER500MS?ADC (C:002323H - C:002333H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S119">?PR?YC_ADC_CHECK?ADC</a>) Top=4 Bytes (<a href="#S121">?PR?YC_ADC_MOTION_CHECK_TIMER500MS?ADC</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S119">?PR?YC_ADC_CHECK?ADC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S121">?PR?YC_ADC_MOTION_CHECK_TIMER500MS?ADC</a></li>
+</ul>
+
+<h2><a name="S124"></a>?PR?_BUFSIZE?IPC (C:001079H - C:0010D2H)</h2>
+<p><br><b>Maximum Stack:</b> Top=16 Bytes (<a href="#S128">?PR?_IPCTX?IPC</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S128">?PR?_IPCTX?IPC</a></li>
+</ul>
+
+<h2><a name="S126"></a>?PR?_IPCRX?IPC (C:0032ABH - C:0032FAH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S213">?C?LIB_CODE</a>) Top=4 Bytes (<a href="#S143">?PR?IPC_DEALSINGLESTEP?IPC</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S143">?PR?IPC_DEALSINGLESTEP?IPC</a></li>
+</ul>
+
+<h2><a name="S128"></a>?PR?_IPCTX?IPC (C:000FE5H - C:001078H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S124">?PR?_BUFSIZE?IPC</a>) Top=14 Bytes (<a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+<li><a href="#S124">?PR?_BUFSIZE?IPC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a></li>
+</ul>
+
+<h2><a name="S130"></a>?PR?_IPC_TXCONTROLCMD?IPC (C:00149DH - C:0014C7H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S213">?C?LIB_CODE</a>) Top=14 Bytes (<a href="#S11">?PR?YC_DISCONNECT_ALL_LINK?BLUETOOTH</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+<li><a href="#S128">?PR?_IPCTX?IPC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+<li><a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a></li>
+<li><a href="#S2">?PR?_YC_LOAD_RECORD_LIST?BLUETOOTH</a></li>
+<li><a href="#S113">?PR?KB_CB_TIMER100MS?SYS</a></li>
+<li><a href="#S100">?PR?SYSTEM_LONG_SLEEP?SYS</a></li>
+<li><a href="#S9">?PR?YC_CANCEL_RECONNECT?BLUETOOTH</a></li>
+<li><a href="#S108">?PR?YC_CONNECT_TIMEOUT_500MS?SYS</a></li>
+<li><a href="#S11">?PR?YC_DISCONNECT_ALL_LINK?BLUETOOTH</a></li>
+<li><a href="#S12">?PR?YC_G24_MODE_DISCOVERY?BLUETOOTH</a></li>
+<li><a href="#S109">?PR?YC_WAIT_DISCONNECT_TIMER500MS?SYS</a></li>
+</ul>
+
+<h2><a name="S132"></a>?PR?_IPC_TXDATA?IPC (C:000FC2H - C:000FE4H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S163">?PR?_XMEMCPY?UTILITIES</a>) Top=8 Bytes (<a href="#S137">?PR?_IPC_TXBLEDATA?IPC</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S163">?PR?_XMEMCPY?UTILITIES</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S135">?PR?_IPC_TX24GDATA?IPC</a></li>
+<li><a href="#S137">?PR?_IPC_TXBLEDATA?IPC</a></li>
+<li><a href="#S134">?PR?_IPC_TXBREDRHIDDATA?IPC</a></li>
+<li><a href="#S136">?PR?_IPC_TXSPPDATA?IPC</a></li>
+</ul>
+
+<h2><a name="S135"></a>?PR?_IPC_TX24GDATA?IPC (C:003511H - C:003519H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S132">?PR?_IPC_TXDATA?IPC</a>) Top=8 Bytes (<a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S132">?PR?_IPC_TXDATA?IPC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S137"></a>?PR?_IPC_TXBLEDATA?IPC (C:003523H - C:00352BH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S132">?PR?_IPC_TXDATA?IPC</a>) Top=8 Bytes (<a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S132">?PR?_IPC_TXDATA?IPC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S140"></a>?PR?IPC_WAITLPM?IPC (C:001EC2H - C:001ECFH)</h2>
+<p><br><b>Maximum Stack:</b> Top=2 Bytes (<a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S171">?PR?_DELAY1MS?UTILITIES</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a></li>
+</ul>
+
+<h2><a name="S141"></a>?PR?IPC_ABANDONLPM?IPC (C:003532H - C:00353DH)</h2>
+<p><br><b>Maximum Stack:</b> Top=2 Bytes (<a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a></li>
+</ul>
+
+<h2><a name="S142"></a>?PR?IPC_ISTXBUFFEMPTY?IPC (C:0026E3H - C:0026FAH)</h2>
+<p><br><b>Maximum Stack:</b> Top=4 Bytes (<a href="#S62">?PR?KB_MOTION?KB_PROCESS</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S62">?PR?KB_MOTION?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S143"></a>?PR?IPC_DEALSINGLESTEP?IPC (C:0032FBH - C:003503H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S126">?PR?_IPCRX?IPC</a>) Top=2 Bytes (<a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+<li><a href="#S126">?PR?_IPCRX?IPC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S115">?PR?YC_SYSTEM_MAIN?SYS</a></li>
+</ul>
+
+<h2><a name="S163"></a>?PR?_XMEMCPY?UTILITIES (C:000878H - C:0008BAH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S213">?C?LIB_CODE</a>) Top=14 Bytes (<a href="#S205">?PR?_IIC_READ?IIC</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S205">?PR?_IIC_READ?IIC</a></li>
+<li><a href="#S132">?PR?_IPC_TXDATA?IPC</a></li>
+<li><a href="#S65">?PR?_KB_MOTION_KEYSCAN?KB_PROCESS</a></li>
+<li><a href="#S2">?PR?_YC_LOAD_RECORD_LIST?BLUETOOTH</a></li>
+<li><a href="#S4">?PR?_YC_STORE_RECORD_LIST?BLUETOOTH</a></li>
+</ul>
+
+<h2><a name="S165"></a>?PR?_DMEMCPY?UTILITIES (C:002462H - C:0024A5H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S213">?C?LIB_CODE</a>) Top=16 Bytes (<a href="#S207">?PR?_IIC_WRITE?IIC</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S207">?PR?_IIC_WRITE?IIC</a></li>
+</ul>
+
+<h2><a name="S167"></a>?PR?_XMEMCLEAR?UTILITIES (C:000DFAH - C:000E25H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S213">?C?LIB_CODE</a>) Top=6 Bytes (<a href="#S95">?PR?SYSTEM_CLEAR_MEM?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S65">?PR?_KB_MOTION_KEYSCAN?KB_PROCESS</a></li>
+<li><a href="#S59">?PR?_KB_SEND_COMBINATION_KEY?KB_PROCESS</a></li>
+<li><a href="#S61">?PR?KB_24G_GET_LED_STATUS?KB_PROCESS</a></li>
+<li><a href="#S95">?PR?SYSTEM_CLEAR_MEM?SYS</a></li>
+<li><a href="#S108">?PR?YC_CONNECT_TIMEOUT_500MS?SYS</a></li>
+</ul>
+
+<h2><a name="S169"></a>?PR?_XMEMCLEAR_FF?UTILITIES (C:003545H - C:003571H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S213">?C?LIB_CODE</a>) Top=12 Bytes (<a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+<li><a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a></li>
+</ul>
+
+<h2><a name="S171"></a>?PR?_DELAY1MS?UTILITIES (C:001798H - C:0017AFH)</h2>
+<p><br><b>Maximum Stack:</b> Top=14 Bytes (<a href="#S209">?PR?_IIC_WRITEBLOCK?IIC</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S209">?PR?_IIC_WRITEBLOCK?IIC</a></li>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+<li><a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a></li>
+<li><a href="#S140">?PR?IPC_WAITLPM?IPC</a></li>
+<li><a href="#S111">?PR?KB_BUTTON_PRESS_TIMER500MS?SYS</a></li>
+<li><a href="#S110">?PR?YC_PAIRING_TIMEROUT_500MS?SYS</a></li>
+<li><a href="#S13">?PR?YC_START_RECONNECT?BLUETOOTH</a></li>
+<li><a href="#S15">?PR?YC_UPDATE_EEPROM_DATA?BLUETOOTH</a></li>
+</ul>
+
+<h2><a name="S172"></a>?PR?_COMPARE_STR?UTILITIES (C:002D6BH - C:002DB4H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S213">?C?LIB_CODE</a>) Top=6 Bytes (<a href="#S88">?PR?KS_GETCURRENTEVT?KEYSCAN</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S88">?PR?KS_GETCURRENTEVT?KEYSCAN</a></li>
+</ul>
+
+<h2><a name="S174"></a>?PR?_GPIOSETBIT?GPIO (C:001875H - C:0018D5H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S213">?C?LIB_CODE</a>) Top=14 Bytes (<a href="#S180">?PR?_GPIO_SETOUT?GPIO</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S186">?PR?_GPIO_SETOE?GPIO</a></li>
+<li><a href="#S180">?PR?_GPIO_SETOUT?GPIO</a></li>
+<li><a href="#S184">?PR?_GPIO_SETPD?GPIO</a></li>
+<li><a href="#S182">?PR?_GPIO_SETPU?GPIO</a></li>
+</ul>
+
+<h2><a name="S177"></a>?PR?_GPIOGETBIT?GPIO (C:001FACH - C:001FEAH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S213">?C?LIB_CODE</a>) Top=6 Bytes (<a href="#S198">?PR?_GPIO_FLIPOUTBIT?GPIO</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S198">?PR?_GPIO_FLIPOUTBIT?GPIO</a></li>
+</ul>
+
+<h2><a name="S179"></a>?PR?_GPIO_GETINPUTSTATUS?GPIO (C:001FA6H - C:001FABH)</h2>
+<p><br><b>Maximum Stack:</b> Top=6 Bytes (<a href="#S195">?PR?_GPIO_SETWAKEUPBYCURRENTSTATE?GPIO</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S195">?PR?_GPIO_SETWAKEUPBYCURRENTSTATE?GPIO</a></li>
+</ul>
+
+<h2><a name="S180"></a>?PR?_GPIO_SETOUT?GPIO (C:0011B2H - C:0011C3H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S174">?PR?_GPIOSETBIT?GPIO</a>) Top=12 Bytes (<a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S174">?PR?_GPIOSETBIT?GPIO</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S198">?PR?_GPIO_FLIPOUTBIT?GPIO</a></li>
+<li><a href="#S190">?PR?_GPIO_SETOUTPUT?GPIO</a></li>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+<li><a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a></li>
+<li><a href="#S113">?PR?KB_CB_TIMER100MS?SYS</a></li>
+<li><a href="#S93">?PR?LED_DEVICE_POWEROFF?LED</a></li>
+<li><a href="#S92">?PR?LED_DEVICE_POWERON?LED</a></li>
+<li><a href="#S94">?PR?LED_HANDLE?LED</a></li>
+<li><a href="#S107">?PR?LED_TIMER500MS?SYS</a></li>
+<li><a href="#S15">?PR?YC_UPDATE_EEPROM_DATA?BLUETOOTH</a></li>
+</ul>
+
+<h2><a name="S182"></a>?PR?_GPIO_SETPU?GPIO (C:001824H - C:001834H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S174">?PR?_GPIOSETBIT?GPIO</a>) Top=10 Bytes (<a href="#S188">?PR?_GPIO_SETINPUT?GPIO</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S174">?PR?_GPIOSETBIT?GPIO</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S188">?PR?_GPIO_SETINPUT?GPIO</a></li>
+<li><a href="#S190">?PR?_GPIO_SETOUTPUT?GPIO</a></li>
+</ul>
+
+<h2><a name="S184"></a>?PR?_GPIO_SETPD?GPIO (C:001864H - C:001874H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S174">?PR?_GPIOSETBIT?GPIO</a>) Top=10 Bytes (<a href="#S188">?PR?_GPIO_SETINPUT?GPIO</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S174">?PR?_GPIOSETBIT?GPIO</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S188">?PR?_GPIO_SETINPUT?GPIO</a></li>
+</ul>
+
+<h2><a name="S186"></a>?PR?_GPIO_SETOE?GPIO (C:001835H - C:001845H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S174">?PR?_GPIOSETBIT?GPIO</a>) Top=10 Bytes (<a href="#S188">?PR?_GPIO_SETINPUT?GPIO</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S174">?PR?_GPIOSETBIT?GPIO</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S188">?PR?_GPIO_SETINPUT?GPIO</a></li>
+<li><a href="#S190">?PR?_GPIO_SETOUTPUT?GPIO</a></li>
+</ul>
+
+<h2><a name="S188"></a>?PR?_GPIO_SETINPUT?GPIO (C:001846H - C:001863H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=6 Bytes (<a href="#S184">?PR?_GPIO_SETPD?GPIO</a>) Top=8 Bytes (<a href="#S77">?PR?KSRAWINITIALIZE?KEYSCAN</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S186">?PR?_GPIO_SETOE?GPIO</a></li>
+<li><a href="#S184">?PR?_GPIO_SETPD?GPIO</a></li>
+<li><a href="#S182">?PR?_GPIO_SETPU?GPIO</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S79">?PR?KSCOLINITIALIZE?KEYSCAN</a></li>
+<li><a href="#S77">?PR?KSRAWINITIALIZE?KEYSCAN</a></li>
+</ul>
+
+<h2><a name="S190"></a>?PR?_GPIO_SETOUTPUT?GPIO (C:001808H - C:001823H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=6 Bytes (<a href="#S186">?PR?_GPIO_SETOE?GPIO</a>) Top=6 Bytes (<a href="#S91">?PR?LED_ALL_SHUTDOWN?LED</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S186">?PR?_GPIO_SETOE?GPIO</a></li>
+<li><a href="#S180">?PR?_GPIO_SETOUT?GPIO</a></li>
+<li><a href="#S182">?PR?_GPIO_SETPU?GPIO</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S91">?PR?LED_ALL_SHUTDOWN?LED</a></li>
+</ul>
+
+<h2><a name="S195"></a>?PR?_GPIO_SETWAKEUPBYCURRENTSTATE?GPIO (C:001E23H - C:001E35H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S179">?PR?_GPIO_GETINPUTSTATUS?GPIO</a>) Top=4 Bytes (<a href="#S82">?PR?KS_UNISTALL?KEYSCAN</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S179">?PR?_GPIO_GETINPUTSTATUS?GPIO</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S82">?PR?KS_UNISTALL?KEYSCAN</a></li>
+</ul>
+
+<h2><a name="S198"></a>?PR?_GPIO_FLIPOUTBIT?GPIO (C:0035B1H - C:0035CDH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S177">?PR?_GPIOGETBIT?GPIO</a>) Top=4 Bytes (<a href="#S107">?PR?LED_TIMER500MS?SYS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S180">?PR?_GPIO_SETOUT?GPIO</a></li>
+<li><a href="#S177">?PR?_GPIOGETBIT?GPIO</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S107">?PR?LED_TIMER500MS?SYS</a></li>
+</ul>
+
+<h2><a name="S201"></a>?PR?GPIO_FILLPD?GPIO (C:0035CEH - C:003601H)</h2>
+<p><br><b>Maximum Stack:</b> Top=4 Bytes (<a href="#S82">?PR?KS_UNISTALL?KEYSCAN</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S82">?PR?KS_UNISTALL?KEYSCAN</a></li>
+</ul>
+
+<h2><a name="S204"></a>?PR?IICWAITDONE?IIC (C:00217AH - C:002181H)</h2>
+<p><br><b>Maximum Stack:</b> Top=16 Bytes (<a href="#S205">?PR?_IIC_READ?IIC</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S205">?PR?_IIC_READ?IIC</a></li>
+<li><a href="#S207">?PR?_IIC_WRITE?IIC</a></li>
+</ul>
+
+<h2><a name="S205"></a>?PR?_IIC_READ?IIC (C:0020CAH - C:002179H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=2 Bytes (<a href="#S204">?PR?IICWAITDONE?IIC</a>) Top=14 Bytes (<a href="#S14">?PR?YC_GET_BLE_RAMDON_LAP?BLUETOOTH</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S163">?PR?_XMEMCPY?UTILITIES</a></li>
+<li><a href="#S204">?PR?IICWAITDONE?IIC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+<li><a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a></li>
+<li><a href="#S14">?PR?YC_GET_BLE_RAMDON_LAP?BLUETOOTH</a></li>
+<li><a href="#S13">?PR?YC_START_RECONNECT?BLUETOOTH</a></li>
+</ul>
+
+<h2><a name="S207"></a>?PR?_IIC_WRITE?IIC (C:002182H - C:00221BH)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=4 Bytes (<a href="#S165">?PR?_DMEMCPY?UTILITIES</a>) Top=14 Bytes (<a href="#S209">?PR?_IIC_WRITEBLOCK?IIC</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S165">?PR?_DMEMCPY?UTILITIES</a></li>
+<li><a href="#S204">?PR?IICWAITDONE?IIC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S209">?PR?_IIC_WRITEBLOCK?IIC</a></li>
+</ul>
+
+<h2><a name="S209"></a>?PR?_IIC_WRITEBLOCK?IIC (C:001C84H - C:001D32H)</h2>
+<p><br><b>Maximum Stack:</b> Bottom=6 Bytes (<a href="#S207">?PR?_IIC_WRITE?IIC</a>) Top=12 Bytes (<a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a>)<p>
+<p><br><b>Calls to:</b></p>
+<ul>
+<li><a href="#S213">?C?LIB_CODE</a></li>
+<li><a href="#S171">?PR?_DELAY1MS?UTILITIES</a></li>
+<li><a href="#S207">?PR?_IIC_WRITE?IIC</a></li>
+</ul>
+
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+<li><a href="#S53">?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS</a></li>
+<li><a href="#S15">?PR?YC_UPDATE_EEPROM_DATA?BLUETOOTH</a></li>
+</ul>
+
+<h2><a name="S213"></a>?C?LIB_CODE (C:000003H - C:0005DEH)</h2>
+<p><br><b>Maximum Stack:</b> Top=18 Bytes (<a href="#S165">?PR?_DMEMCPY?UTILITIES</a>)<p>
+<p><br><b>Called from:</b></p>
+<ul>
+<li><a href="#S86">?PR?_ARRAY_IS_EMPTY?KEYSCAN</a></li>
+<li><a href="#S172">?PR?_COMPARE_STR?UTILITIES</a></li>
+<li><a href="#S165">?PR?_DMEMCPY?UTILITIES</a></li>
+<li><a href="#S177">?PR?_GPIOGETBIT?GPIO</a></li>
+<li><a href="#S174">?PR?_GPIOSETBIT?GPIO</a></li>
+<li><a href="#S209">?PR?_IIC_WRITEBLOCK?IIC</a></li>
+<li><a href="#S139">?PR?_IPC_INITIALIZE?IPC</a></li>
+<li><a href="#S130">?PR?_IPC_TXCONTROLCMD?IPC</a></li>
+<li><a href="#S55">?PR?_IPC_TXHIDDATA?KB_PROCESS</a></li>
+<li><a href="#S126">?PR?_IPCRX?IPC</a></li>
+<li><a href="#S128">?PR?_IPCTX?IPC</a></li>
+<li><a href="#S105">?PR?_KB_CB_EVENT?SYS</a></li>
+<li><a href="#S103">?PR?_KB_CB_HID?SYS</a></li>
+<li><a href="#S67">?PR?_KB_DEVICE_SELECT?KB_PROCESS</a></li>
+<li><a href="#S65">?PR?_KB_MOTION_KEYSCAN?KB_PROCESS</a></li>
+<li><a href="#S72">?PR?_KB_MULTIKEY_SETUP?KB_PROCESS</a></li>
+<li><a href="#S167">?PR?_XMEMCLEAR?UTILITIES</a></li>
+<li><a href="#S169">?PR?_XMEMCLEAR_FF?UTILITIES</a></li>
+<li><a href="#S163">?PR?_XMEMCPY?UTILITIES</a></li>
+<li><a href="#S143">?PR?IPC_DEALSINGLESTEP?IPC</a></li>
+<li><a href="#S119">?PR?YC_ADC_CHECK?ADC</a></li>
+<li><a href="#S118">?PR?YC_ADC_INIT?ADC</a></li>
+</ul>
+
+</body>
+</html>
Index: c51/output/FW.MAP
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/FW.MAP	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/FW.MAP	(working copy)
@@ -0,0 +1,3537 @@
+LX51 LINKER/LOCATER V4.66.97.0                                                          07/11/2022  10:06:55  PAGE 1
+
+
+LX51 LINKER/LOCATER V4.66.97.0, INVOKED BY:
+C:\KEIL_V5\C51\BIN\LX51.EXE OUTPUT/BLUETOOTH.OBJ, OUTPUT/GLOBAL_VARIABLE.OBJ, OUTPUT/KB_PROCESS.OBJ, OUTPUT/KEYSCAN.OBJ,
+>>  OUTPUT/LED.OBJ, OUTPUT/SYS.OBJ, OUTPUT/ADC.OBJ, OUTPUT/RAM.OBJ, OUTPUT/..\PATCH\IPC.OBJ, OUTPUT/..\PATCH\UTILITIES.O
+>> BJ, OUTPUT/..\PATCH\GPIO.OBJ, OUTPUT/..\PATCH\IIC.OBJ TO OUTPUT\FW CLASSES (XDATA (X:0X4DD0-X:0X4F40), CODE (C:0-C:0X
+>> FFFF), DATA (D:0X10-0X7F), IDATA (I:0X80-0XCF)) SEGMENTS (?STACK (D:0XD0)) NOOVERLAY PAGELENGTH (60000) CODE
+
+
+CPU MODE:     8051 MODE
+MEMORY MODEL: LARGE WITH FLOATING POINT ARITHMETIC
+
+
+INPUT MODULES INCLUDED:
+  OUTPUT/BLUETOOTH.OBJ (BLUETOOTH)
+         COMMENT TYPE 0: C51 V9.60.0.0
+  OUTPUT/GLOBAL_VARIABLE.OBJ (GLOBAL_VARIABLE)
+         COMMENT TYPE 0: C51 V9.60.0.0
+  OUTPUT/KB_PROCESS.OBJ (KB_PROCESS)
+         COMMENT TYPE 0: C51 V9.60.0.0
+  OUTPUT/KEYSCAN.OBJ (KEYSCAN)
+         COMMENT TYPE 0: C51 V9.60.0.0
+  OUTPUT/LED.OBJ (LED)
+         COMMENT TYPE 0: C51 V9.60.0.0
+  OUTPUT/SYS.OBJ (SYS)
+         COMMENT TYPE 0: C51 V9.60.0.0
+  OUTPUT/ADC.OBJ (ADC)
+         COMMENT TYPE 0: C51 V9.60.0.0
+  OUTPUT/RAM.OBJ (RAM)
+         COMMENT TYPE 0: C51 V9.60.0.0
+  OUTPUT/..\PATCH\IPC.OBJ (IPC)
+         COMMENT TYPE 0: C51 V9.00
+  OUTPUT/..\PATCH\UTILITIES.OBJ (UTILITIES)
+         COMMENT TYPE 0: C51 V9.00
+  OUTPUT/..\PATCH\GPIO.OBJ (GPIO)
+         COMMENT TYPE 0: C51 V9.00
+  OUTPUT/..\PATCH\IIC.OBJ (IIC)
+         COMMENT TYPE 0: C51 V9.00
+  C:\KEIL_V5\C51\LIB\C51FPL.LIB (?C?FPADD)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51FPL.LIB (?C?FPMUL)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51FPL.LIB (?C?FCAST)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51FPL.LIB (?C?CASTF)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51FPL.LIB (?C?FPGETOPN)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51L.LIB (?C_STARTUP)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51L.LIB (?C?COPY)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51L.LIB (?C?CLDPTR)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51L.LIB (?C?CLDOPTR)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51L.LIB (?C?CSTPTR)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51L.LIB (?C?IILDX)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51L.LIB (?C?ILDIX)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51L.LIB (?C?LMUL)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51L.LIB (?C?ULDIV)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51L.LIB (?C?LNEG)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51L.LIB (?C?ULCMP)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51L.LIB (?C?LSTXDATA)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51L.LIB (?C?LSTKXDATA)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51L.LIB (?C?CCASE)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51L.LIB (?C?ICALL)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+  C:\KEIL_V5\C51\LIB\C51L.LIB (?C_INIT)
+         COMMENT TYPE 1: A51 / ASM51 Assembler
+
+
+ACTIVE MEMORY CLASSES OF MODULE:  OUTPUT\FW (BLUETOOTH)
+
+BASE        START       END         USED      MEMORY CLASS
+==========================================================
+X:000000H   X:004DD0H   X:004F40H   000383H   XDATA
+C:000000H   C:000000H   C:00FFFFH   00354CH   CODE
+I:000000H   I:000010H   I:00007FH   000008H   DATA
+I:000000H   I:000080H   I:0000CFH   000001H   IDATA
+C:000000H   C:000000H   C:00FFFFH   0000B6H   CONST
+I:000020H.0 I:000020H.0 I:00002FH.7 000001H.2 BIT
+
+
+MEMORY MAP OF MODULE:  OUTPUT\FW (BLUETOOTH)
+
+
+START     STOP      LENGTH    ALIGN  RELOC    MEMORY CLASS   SEGMENT NAME
+=========================================================================
+
+* * * * * * * * * * *   D A T A   M E M O R Y   * * * * * * * * * * * * *
+000000H   000007H   000008H   ---    AT..     DATA           "REG BANK 0"
+000008H.0 00001FH.7 000018H.0 ---    ---      **GAP**
+000020H.0 000020H.0 000000H.1 BIT    UNIT     BIT            ?BI?_GPIOSETBIT?GPIO
+000020H.1 000020H.1 000000H.1 BIT    UNIT     BIT            ?BI?_GPIO_SETOUT?GPIO
+000020H.2 000020H.2 000000H.1 BIT    UNIT     BIT            ?BI?_GPIO_SETPU?GPIO
+000020H.3 000020H.3 000000H.1 BIT    UNIT     BIT            ?BI?_GPIO_SETPD?GPIO
+000020H.4 000020H.4 000000H.1 BIT    UNIT     BIT            ?BI?_GPIO_SETOE?GPIO
+000020H.5 000020H.5 000000H.1 BIT    UNIT     BIT            ?BI?_GPIO_SETINPUT?GPIO
+000020H.6 000020H.6 000000H.1 BIT    UNIT     BIT            ?BI?_GPIO_SETOUTPUT?GPIO
+000020H.7 000020H.7 000000H.1 BIT    UNIT     BIT            ?BI?_GPIO_SETWAKEUP?GPIO
+000021H.0 000021H.0 000000H.1 BIT    UNIT     BIT            ?BI?_GPIO_SETWAKEUPBYCURRENTSTATE?GPIO
+000021H.1 000021H.1 000000H.1 BIT    UNIT     BIT            ?BI?_GPIO_FLIPOUTBIT?GPIO
+000021H.2 0000CFH   0000AEH.6 ---    ---      **GAP**
+0000D0H   0000D0H   000001H   BYTE   UNIT     IDATA          ?STACK
+
+* * * * * * * * * * *   C O D E   M E M O R Y   * * * * * * * * * * * * *
+000000H   000002H   000003H   ---    OFFS..   CODE           ?CO??C_STARTUP?0
+000003H   0005DEH   0005DCH   BYTE   UNIT     CODE           ?C?LIB_CODE
+0005DFH   00066AH   00008CH   BYTE   UNIT     CODE           ?C_C51STARTUP
+00066BH   000680H   000016H   BYTE   UNIT     CODE           ?C_INITSEG
+000681H   000733H   0000B3H   BYTE   UNIT     CONST          ?CO?GLOBAL_VARIABLE
+000734H   000736H   000003H   BYTE   UNIT     CONST          ?CO?IPC
+000737H   0007FDH   0000C7H   BYTE   UNIT     CODE           ?PR?_YC_LOAD_RECORD_LIST?BLUETOOTH
+0007FEH   000877H   00007AH   BYTE   UNIT     CODE           ?PR?_YC_STORE_RECORD_LIST?BLUETOOTH
+000878H   0008BAH   000043H   BYTE   UNIT     CODE           ?PR?_XMEMCPY?UTILITIES
+0008BBH   000BDCH   000322H   BYTE   UNIT     CODE           ?PR?_KB_MOTION_KEYSCAN?KB_PROCESS
+000BDDH   000DDEH   000202H   BYTE   UNIT     CODE           ?PR?_KB_MULTIKEY_SETUP?KB_PROCESS
+000DDFH   000DF9H   00001BH   BYTE   UNIT     CODE           ?PR?_KB_SET_MULTIKEY?KB_PROCESS
+000DFAH   000E25H   00002CH   BYTE   UNIT     CODE           ?PR?_XMEMCLEAR?UTILITIES
+000E26H   000EBEH   000099H   BYTE   UNIT     CODE           ?PR?SYSTEM_CLEAR_MEM?SYS
+000EBFH   000ED9H   00001BH   BYTE   UNIT     CODE           ?PR?_KB_SET_SYSTEMKEY?KB_PROCESS
+000EDAH   000FC1H   0000E8H   BYTE   UNIT     CODE           ?PR?_IPC_TXHIDDATA?KB_PROCESS
+000FC2H   000FE4H   000023H   BYTE   UNIT     CODE           ?PR?_IPC_TXDATA?IPC
+000FE5H   001078H   000094H   BYTE   UNIT     CODE           ?PR?_IPCTX?IPC
+001079H   0010D2H   00005AH   BYTE   UNIT     CODE           ?PR?_BUFSIZE?IPC
+0010D3H   0010E8H   000016H   BYTE   UNIT     CODE           ?PR?YC_CHECK_IS_CONNECTED?BLUETOOTH
+0010E9H   0011B1H   0000C9H   BYTE   UNIT     CODE           ?PR?LED_TIMER500MS?SYS
+0011B2H   0011C3H   000012H   BYTE   UNIT     CODE           ?PR?_GPIO_SETOUT?GPIO
+0011C4H   0012C5H   000102H   BYTE   UNIT     CODE           ?PR?LED_HANDLE?LED
+0012C6H   00149CH   0001D7H   BYTE   UNIT     CODE           ?PR?_YC_KEY_ACTION_HANDLE?KB_PROCESS
+00149DH   0014C7H   00002BH   BYTE   UNIT     CODE           ?PR?_IPC_TXCONTROLCMD?IPC
+0014C8H   00178EH   0002C7H   BYTE   UNIT     CODE           ?PR?_KB_CB_EVENT?SYS
+00178FH   001797H   000009H   BYTE   UNIT     CODE           ?PR?SYSTEM_LONG_SLEEP?SYS
+001798H   0017AFH   000018H   BYTE   UNIT     CODE           ?PR?_DELAY1MS?UTILITIES
+0017B0H   0017C7H   000018H   BYTE   UNIT     CODE           ?PR?LED_DEVICE_POWERON?LED
+0017C8H   0017DFH   000018H   BYTE   UNIT     CODE           ?PR?LED_DEVICE_POWEROFF?LED
+0017E0H   0017E9H   00000AH   BYTE   UNIT     CODE           ?PR?YC_CLEAR_RECONNECT_FLAG?BLUETOOTH
+0017EAH   0017EFH   000006H   BYTE   UNIT     CODE           ?PR?SYSTEM_HARDWARE_INIT?SYS
+0017F0H   001807H   000018H   BYTE   UNIT     CODE           ?PR?LED_ALL_SHUTDOWN?LED
+001808H   001823H   00001CH   BYTE   UNIT     CODE           ?PR?_GPIO_SETOUTPUT?GPIO
+001824H   001834H   000011H   BYTE   UNIT     CODE           ?PR?_GPIO_SETPU?GPIO
+001835H   001845H   000011H   BYTE   UNIT     CODE           ?PR?_GPIO_SETOE?GPIO
+001846H   001863H   00001EH   BYTE   UNIT     CODE           ?PR?_GPIO_SETINPUT?GPIO
+001864H   001874H   000011H   BYTE   UNIT     CODE           ?PR?_GPIO_SETPD?GPIO
+001875H   0018D5H   000061H   BYTE   UNIT     CODE           ?PR?_GPIOSETBIT?GPIO
+0018D6H   0018F3H   00001EH   BYTE   UNIT     CODE           ?PR?KSCOLINITIALIZE?KEYSCAN
+0018F4H   001900H   00000DH   BYTE   UNIT     CODE           ?PR?KS_INITIALIZE?KEYSCAN
+001901H   001921H   000021H   BYTE   UNIT     CODE           ?PR?KSRAWINITIALIZE?KEYSCAN
+001922H   0019ADH   00008CH   BYTE   UNIT     CODE           ?PR?YC_CHECK_NEED_RECONNECTED?BLUETOOTH
+0019AEH   0019C0H   000013H   BYTE   UNIT     CODE           ?PR?YC_CANCEL_RECONNECT?BLUETOOTH
+0019C1H   0019EFH   00002FH   BYTE   UNIT     CODE           ?PR?YC_DISCONNECT_ALL_LINK?BLUETOOTH
+0019F0H   001BE9H   0001FAH   BYTE   UNIT     CODE           ?PR?KB_BUTTON_PRESS_TIMER500MS?SYS
+001BEAH   001C83H   00009AH   BYTE   UNIT     CODE           ?PR?YC_UPDATE_EEPROM_DATA?BLUETOOTH
+001C84H   001D32H   0000AFH   BYTE   UNIT     CODE           ?PR?_IIC_WRITEBLOCK?IIC
+001D33H   ---       000000H   BYTE   UNIT     CODE           ?PR?SYSTEM_RESET_CONNECT?SYS
+001D33H   001D3BH   000009H   BYTE   UNIT     CODE           ?PR?SYSTEM_HARDWARE_RESET?SYS
+001D3CH   001D8AH   00004FH   BYTE   UNIT     CODE           ?PR?YC_SYSTEM_MAIN?SYS
+001D8BH   001E22H   000098H   BYTE   UNIT     CODE           ?PR?KS_UNISTALL?KEYSCAN
+001E23H   001E35H   000013H   BYTE   UNIT     CODE           ?PR?_GPIO_SETWAKEUPBYCURRENTSTATE?GPIO
+001E36H   001EC1H   00008CH   BYTE   UNIT     CODE           ?PR?_GPIO_SETWAKEUP?GPIO
+001EC2H   001ECFH   00000EH   BYTE   UNIT     CODE           ?PR?IPC_WAITLPM?IPC
+001ED0H   001F56H   000087H   BYTE   UNIT     CODE           ?PR?KB_NEED_KEYSCAN?KB_PROCESS
+001F57H   001F92H   00003CH   BYTE   UNIT     CODE           ?PR?_KB_SEND_COMBINATION_KEY?KB_PROCESS
+001F93H   001F98H   000006H   BYTE   UNIT     CODE           ?PR?KB_CB_INIT?SYS
+001F99H   001FA5H   00000DH   BYTE   UNIT     CODE           ?PR?_IPC_INITIALIZE?IPC
+001FA6H   001FABH   000006H   BYTE   UNIT     CODE           ?PR?_GPIO_GETINPUTSTATUS?GPIO
+001FACH   001FEAH   00003FH   BYTE   UNIT     CODE           ?PR?_GPIOGETBIT?GPIO
+001FEBH   001FECH   000002H   BYTE   UNIT     CODE           ?PR?MAIN?RAM
+001FEDH   002003H   000017H   BYTE   UNIT     CODE           ?PR?YC_G24_MODE_DISCOVERY?BLUETOOTH
+002004H   0020C9H   0000C6H   BYTE   UNIT     CODE           ?PR?YC_START_RECONNECT?BLUETOOTH
+0020CAH   002179H   0000B0H   BYTE   UNIT     CODE           ?PR?_IIC_READ?IIC
+00217AH   002181H   000008H   BYTE   UNIT     CODE           ?PR?IICWAITDONE?IIC
+002182H   00221BH   00009AH   BYTE   UNIT     CODE           ?PR?_IIC_WRITE?IIC
+00221CH   00225EH   000043H   BYTE   UNIT     CODE           ?PR?YC_GET_BLE_RAMDON_LAP?BLUETOOTH
+00225FH   00229EH   000040H   BYTE   UNIT     CODE           ?PR?YC_WAIT_DISCONNECT_TIMER500MS?SYS
+00229FH   0022B8H   00001AH   BYTE   UNIT     CODE           ?PR?KB_CB_TIMER500MS?SYS
+0022B9H   002301H   000049H   BYTE   UNIT     CODE           ?PR?YC_PAIRING_TIMEROUT_500MS?SYS
+002302H   002322H   000021H   BYTE   UNIT     CODE           ?PR?YC_ADC_MOTION_CHECK_TIMER500MS?ADC
+002323H   002333H   000011H   BYTE   UNIT     CODE           ?PR?YC_ADC_CHECK_TIMER500MS?ADC
+002334H   002432H   0000FFH   BYTE   UNIT     CODE           ?PR?YC_CONNECT_TIMEOUT_500MS?SYS
+002433H   002461H   00002FH   BYTE   UNIT     CODE           ?PR?SYSTEM_G24_LONG_LPM?SYS
+002462H   0024A5H   000044H   BYTE   UNIT     CODE           ?PR?_DMEMCPY?UTILITIES
+0024A6H   002670H   0001CBH   BYTE   UNIT     CODE           ?PR?YC_ADC_CHECK?ADC
+002671H   0026AEH   00003EH   BYTE   UNIT     CODE           ?PR?KB_24G_GET_LED_STATUS?KB_PROCESS
+0026AFH   0026E2H   000034H   BYTE   UNIT     CODE           ?PR?KB_MOTION?KB_PROCESS
+0026E3H   0026FAH   000018H   BYTE   UNIT     CODE           ?PR?IPC_ISTXBUFFEMPTY?IPC
+0026FBH   00285FH   000165H   BYTE   UNIT     CODE           ?PR?_KB_DEVICE_SELECT?KB_PROCESS
+002860H   002885H   000026H   BYTE   UNIT     CODE           ?PR?_KB_COMBINATION_KEY_PRESS?KB_PROCESS
+002886H   002ACAH   000245H   BYTE   UNIT     CODE           ?PR?_KEY_FN_FUNCTION?KB_PROCESS
+002ACBH   002D2CH   000262H   BYTE   UNIT     CODE           ?PR?KS_GETCURRENTEVT?KEYSCAN
+002D2DH   002D3AH   00000EH   BYTE   UNIT     CODE           ?PR?_BIT_COUNT?KEYSCAN
+002D3BH   002D6AH   000030H   BYTE   UNIT     CODE           ?PR?_ARRAY_IS_EMPTY?KEYSCAN
+002D6BH   002DB4H   00004AH   BYTE   UNIT     CODE           ?PR?_COMPARE_STR?UTILITIES
+002DB5H   002E1CH   000068H   BYTE   UNIT     CODE           ?PR?_KEYIN?KEYSCAN
+002E1DH   002EDDH   0000C1H   BYTE   UNIT     CODE           ?PR?_KEYOUT?KEYSCAN
+002EDEH   003039H   00015CH   BYTE   UNIT     CODE           ?PR?KS_SCANMATRIX?KEYSCAN
+00303AH   00304CH   000013H   BYTE   UNIT     CODE           ?PR?SYSTEM_IIC_CLK_SETUP?SYS
+00304DH   003081H   000035H   BYTE   UNIT     CODE           ?PR?SYSTEM_SOFTWARE_INIT?SYS
+003082H   0031A0H   00011FH   BYTE   UNIT     CODE           ?PR?YC_ADC_INIT?ADC
+0031A1H   0031B0H   000010H   BYTE   UNIT     CODE           ?PR?_KB_CB_HID?SYS
+0031B1H   0032AAH   0000FAH   BYTE   UNIT     CODE           ?PR?KB_CB_TIMER100MS?SYS
+0032ABH   0032FAH   000050H   BYTE   UNIT     CODE           ?PR?_IPCRX?IPC
+0032FBH   003503H   000209H   BYTE   UNIT     CODE           ?PR?IPC_DEALSINGLESTEP?IPC
+003504H   003510H   00000DH   BYTE   UNIT     CODE           ?PR?_IPC_TXBREDRHIDDATA?IPC
+003511H   003519H   000009H   BYTE   UNIT     CODE           ?PR?_IPC_TX24GDATA?IPC
+00351AH   003522H   000009H   BYTE   UNIT     CODE           ?PR?_IPC_TXSPPDATA?IPC
+003523H   00352BH   000009H   BYTE   UNIT     CODE           ?PR?_IPC_TXBLEDATA?IPC
+00352CH   003531H   000006H   BYTE   UNIT     CODE           ?PR?IPC_GETBBDISCONNECTREASON?IPC
+003532H   00353DH   00000CH   BYTE   UNIT     CODE           ?PR?IPC_ABANDONLPM?IPC
+00353EH   003544H   000007H   BYTE   UNIT     CODE           ?PR?YC_ICE_BREAK?UTILITIES
+003545H   003571H   00002DH   BYTE   UNIT     CODE           ?PR?_XMEMCLEAR_FF?UTILITIES
+003572H   0035B0H   00003FH   BYTE   UNIT     CODE           ?PR?_GPIO_CLEARWAKEUP?GPIO
+0035B1H   0035CDH   00001DH   BYTE   UNIT     CODE           ?PR?_GPIO_FLIPOUTBIT?GPIO
+0035CEH   003601H   000034H   BYTE   UNIT     CODE           ?PR?GPIO_FILLPD?GPIO
+
+* * * * * * * * * * *  X D A T A   M E M O R Y  * * * * * * * * * * * * *
+000040H   000045H   000006H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?29
+000046H   0000A2H   00005DH   ---    ---      **GAP**
+0000A3H   0000A6H   000004H   BYTE   OFFS..   XDATA          ?XD?GPIO?1
+0000A7H   0000AAH   000004H   BYTE   OFFS..   XDATA          ?XD?GPIO?0
+0000ABH   0003CFH   000325H   ---    ---      **GAP**
+0003D0H   0003D5H   000006H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?2
+0003D6H   000445H   000070H   ---    ---      **GAP**
+000446H   000446H   000001H   BYTE   OFFS..   XDATA          ?XD?IPC?9
+000447H   00054EH   000108H   ---    ---      **GAP**
+00054FH   00054FH   000001H   BYTE   OFFS..   XDATA          ?XD?IPC?1
+000550H   00055FH   000010H   BYTE   OFFS..   XDATA          ?XD?IPC?11
+000560H   000B7DH   00061EH   ---    ---      **GAP**
+000B7EH   000B7EH   000001H   BYTE   OFFS..   XDATA          ?XD?IPC?0
+000B7FH   000B7FH   000001H   BYTE   OFFS..   XDATA          ?XD?IPC?5
+000B80H   000B80H   000001H   ---    ---      **GAP**
+000B81H   000B81H   000001H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?8
+000B82H   000B82H   000001H   ---    ---      **GAP**
+000B83H   000BE6H   000064H   BYTE   OFFS..   XDATA          ?XD?IIC?1
+000BE7H   000C4AH   000064H   BYTE   OFFS..   XDATA          ?XD?IPC?6
+000C4BH   000CAEH   000064H   BYTE   OFFS..   XDATA          ?XD?IPC?3
+000CAFH   000CB2H   000004H   BYTE   OFFS..   XDATA          ?XD?IIC?0
+000CB3H   004130H   00347EH   ---    ---      **GAP**
+004131H   004131H   000001H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?10
+004132H   004212H   0000E1H   ---    ---      **GAP**
+004213H   004213H   000001H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?32
+004214H   00425DH   00004AH   ---    ---      **GAP**
+00425EH   00425EH   000001H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?13
+00425FH   004261H   000003H   ---    ---      **GAP**
+004262H   004271H   000010H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?24
+004272H   004273H   000002H   ---    ---      **GAP**
+004274H   004279H   000006H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?28
+00427AH   00447AH   000201H   ---    ---      **GAP**
+00447BH   00448AH   000010H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?25
+00448BH   00448BH   000001H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?9
+00448CH   0044F8H   00006DH   ---    ---      **GAP**
+0044F9H   0044FEH   000006H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?21
+0044FFH   0047F3H   0002F5H   ---    ---      **GAP**
+0047F4H   0047F5H   000002H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?27
+0047F6H   0047FFH   00000AH   ---    ---      **GAP**
+004800H   004809H   00000AH   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?20
+00480AH   004B99H   000390H   ---    ---      **GAP**
+004B9AH   004B9BH   000002H   BYTE   OFFS..   XDATA          ?XD?IPC?4
+004B9CH   004B9DH   000002H   BYTE   OFFS..   XDATA          ?XD?IPC?8
+004B9EH   004B9FH   000002H   BYTE   OFFS..   XDATA          ?XD?IPC?2
+004BA0H   004BA1H   000002H   BYTE   OFFS..   XDATA          ?XD?IPC?7
+004BA2H   004BA4H   000003H   ---    ---      **GAP**
+004BA5H   004BA6H   000002H   BYTE   OFFS..   XDATA          ?XD?IPC?14
+004BA7H   004BEAH   000044H   ---    ---      **GAP**
+004BEBH   004BEEH   000004H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?0
+004BEFH   004BEFH   000001H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?12
+004BF0H   004BFFH   000010H   ---    ---      **GAP**
+004C00H   004C03H   000004H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?5
+004C04H   004C5DH   00005AH   ---    ---      **GAP**
+004C5EH   004C5FH   000002H   BYTE   OFFS..   XDATA          ?XD?IPC?12
+004C60H   004C8CH   00002DH   ---    ---      **GAP**
+004C8DH   004C8DH   000001H   BYTE   OFFS..   XDATA          ?XD?IPC?13
+004C8EH   004C8EH   000001H   BYTE   OFFS..   XDATA          ?XD?IPC?10
+004C8FH   004C8FH   000001H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?26
+004C90H   004C90H   000001H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?15
+004C91H   004C92H   000002H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?7
+004C93H   004C94H   000002H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?11
+004C95H   004C96H   000002H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?31
+004C97H   004CB5H   00001FH   ---    ---      **GAP**
+004CB6H   004CB6H   000001H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?18
+004CB7H   004CB7H   000001H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?16
+004CB8H   004CBEH   000007H   ---    ---      **GAP**
+004CBFH   004D06H   000048H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?3
+004D07H   004D37H   000031H   ---    ---      **GAP**
+004D38H   004D38H   000001H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?30
+004D39H   004D3CH   000004H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?34
+004D3DH   004D3DH   000001H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?33
+004D3EH   004D3FH   000002H   ---    ---      **GAP**
+004D40H   004D43H   000004H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?17
+004D44H   004D45H   000002H   ---    ---      **GAP**
+004D46H   004D46H   000001H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?14
+004D47H   004D50H   00000AH   ---    ---      **GAP**
+004D51H   004D51H   000001H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?19
+004D52H   004D7CH   00002BH   ---    ---      **GAP**
+004D7DH   004D7DH   000001H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?6
+004D7EH   004D92H   000015H   ---    ---      **GAP**
+004D93H   004DA6H   000014H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?23
+004DA7H   004DA7H   000001H   ---    ---      **GAP**
+004DA8H   004DBBH   000014H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?1
+004DBCH   004DCFH   000014H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?22
+004DD0H   004E55H   000086H   BYTE   UNIT     XDATA          ?XD?GLOBAL_VARIABLE
+004E56H   004E67H   000012H   BYTE   UNIT     XDATA          ?XD?SYS
+004E68H   004E79H   000012H   BYTE   UNIT     XDATA          ?XD?IPC
+004E7AH   004E87H   00000EH   BYTE   UNIT     XDATA          ?XD?_IPC_TXHIDDATA?KB_PROCESS
+004E88H   004E92H   00000BH   BYTE   UNIT     XDATA          ?XD?KS_GETCURRENTEVT?KEYSCAN
+004E93H   004E9BH   000009H   BYTE   UNIT     XDATA          ?XD?_IIC_WRITEBLOCK?IIC
+004E9CH   004EA3H   000008H   BYTE   UNIT     XDATA          ?XD?_DMEMCPY?UTILITIES
+004EA4H   004EAAH   000007H   BYTE   UNIT     XDATA          ?XD?KEYSCAN
+004EABH   004EB1H   000007H   BYTE   UNIT     XDATA          ?XD?_COMPARE_STR?UTILITIES
+004EB2H   004EB8H   000007H   BYTE   UNIT     XDATA          ?XD?_IIC_WRITE?IIC
+004EB9H   004EBEH   000006H   BYTE   UNIT     XDATA          ?XD?_IPCTX?IPC
+004EBFH   004EC4H   000006H   BYTE   UNIT     XDATA          ?XD?_XMEMCPY?UTILITIES
+004EC5H   004EC9H   000005H   BYTE   UNIT     XDATA          ?XD?_KB_MOTION_KEYSCAN?KB_PROCESS
+004ECAH   004ECEH   000005H   BYTE   UNIT     XDATA          ?XD?YC_ADC_CHECK?ADC
+004ECFH   004ED3H   000005H   BYTE   UNIT     XDATA          ?XD?_IIC_READ?IIC
+004ED4H   004ED7H   000004H   BYTE   UNIT     XDATA          ?XD?_KB_MULTIKEY_SETUP?KB_PROCESS
+004ED8H   004EDBH   000004H   BYTE   UNIT     XDATA          ?XD?_BUFSIZE?IPC
+004EDCH   004EDFH   000004H   BYTE   UNIT     XDATA          ?XD?_IPC_TXCONTROLCMD?IPC
+004EE0H   004EE2H   000003H   BYTE   UNIT     XDATA          ?XD?KB_MOTION?KB_PROCESS
+004EE3H   004EE5H   000003H   BYTE   UNIT     XDATA          ?XD?_KB_DEVICE_SELECT?KB_PROCESS
+004EE6H   004EE8H   000003H   BYTE   UNIT     XDATA          ?XD?KS_SCANMATRIX?KEYSCAN
+004EE9H   004EEBH   000003H   BYTE   UNIT     XDATA          ?XD?_ARRAY_IS_EMPTY?KEYSCAN
+004EECH   004EEEH   000003H   BYTE   UNIT     XDATA          ?XD?IPC_DEALSINGLESTEP?IPC
+004EEFH   004EF1H   000003H   BYTE   UNIT     XDATA          ?XD?_XMEMCLEAR?UTILITIES
+004EF2H   004EF4H   000003H   BYTE   UNIT     XDATA          ?XD?_XMEMCLEAR_FF?UTILITIES
+004EF5H   004EF7H   000003H   BYTE   UNIT     XDATA          ?XD?_GPIOSETBIT?GPIO
+004EF8H   004EF9H   000002H   BYTE   UNIT     XDATA          ?XD?_KB_SEND_COMBINATION_KEY?KB_PROCESS
+004EFAH   004EFBH   000002H   BYTE   UNIT     XDATA          ?XD?_KB_CB_HID?SYS
+004EFCH   004EFDH   000002H   BYTE   UNIT     XDATA          ?XD?_IPCRX?IPC
+004EFEH   004EFEH   000001H   BYTE   UNIT     XDATA          ?XD?_YC_LOAD_RECORD_LIST?BLUETOOTH
+004EFFH   004EFFH   000001H   BYTE   UNIT     XDATA          ?XD?_YC_STORE_RECORD_LIST?BLUETOOTH
+004F00H   004F00H   000001H   BYTE   UNIT     XDATA          ?XD?YC_CHECK_NEED_RECONNECTED?BLUETOOTH
+004F01H   004F01H   000001H   BYTE   UNIT     XDATA          ?XD?_YC_KEY_ACTION_HANDLE?KB_PROCESS
+004F02H   004F02H   000001H   BYTE   UNIT     XDATA          ?XD?_KEY_FN_FUNCTION?KB_PROCESS
+004F03H   004F03H   000001H   BYTE   UNIT     XDATA          ?XD?KSRAWINITIALIZE?KEYSCAN
+004F04H   004F04H   000001H   BYTE   UNIT     XDATA          ?XD?KSCOLINITIALIZE?KEYSCAN
+004F05H   004F05H   000001H   BYTE   UNIT     XDATA          ?XD?KS_UNISTALL?KEYSCAN
+004F06H   004F06H   000001H   BYTE   UNIT     XDATA          ?XD?_KB_CB_EVENT?SYS
+004F07H   004F07H   000001H   BYTE   UNIT     XDATA          ?XD?_IPC_TXDATA?IPC
+004F08H   004F08H   000001H   BYTE   UNIT     XDATA          ?XD?_GPIOGETBIT?GPIO
+004F09H   004F09H   000001H   BYTE   UNIT     XDATA          ?XD?_GPIO_SETWAKEUPBYCURRENTSTATE?GPIO
+004F0AH   004F0AH   000001H   BYTE   UNIT     XDATA          ?XD?_GPIO_FLIPOUTBIT?GPIO
+004F0BH   00800FH   003105H   ---    ---      **GAP**
+008010H   008010H   000001H   BYTE   OFFS..   XDATA          ?XD?GLOBAL_VARIABLE?4
+
+
+
+PUBLIC SYMBOLS OF MODULE:  OUTPUT\FW (BLUETOOTH)
+
+
+      VALUE       CLASS    TYPE      PUBLIC SYMBOL NAME
+      =================================================
+      02004EABH   XDATA    BYTE      ?_compare_str?BYTE
+      02004E9CH   XDATA    BYTE      ?_dmemcpy?BYTE
+      00000020H.5 BIT      BIT       ?_GPIO_SetInput?BIT
+      00000020H.4 BIT      BIT       ?_GPIO_Setoe?BIT
+      00000020H.1 BIT      BIT       ?_GPIO_Setout?BIT
+      00000020H.6 BIT      BIT       ?_GPIO_SetOutput?BIT
+      00000020H.3 BIT      BIT       ?_GPIO_SetPd?BIT
+      00000020H.2 BIT      BIT       ?_GPIO_SetPu?BIT
+      00000020H.7 BIT      BIT       ?_GPIO_SetWakeup?BIT
+      02004EBFH   XDATA    BYTE      ?_xmemcpy?BYTE
+      0100023FH   CODE     ---       ?C?CASTF
+      010005B3H   CODE     ---       ?C?CCASE
+      010003CFH   CODE     ---       ?C?CLDOPTR
+      010003B6H   CODE     ---       ?C?CLDPTR
+      00000000H   NUMBER   ---       ?C?CODESEG
+      01000390H   CODE     ---       ?C?COPY
+      010003FCH   CODE     ---       ?C?CSTPTR
+      0100020BH   CODE     ---       ?C?FCASTC
+      01000206H   CODE     ---       ?C?FCASTI
+      01000201H   CODE     ---       ?C?FCASTL
+      0100000AH   CODE     ---       ?C?FPADD
+      01000276H   CODE     ---       ?C?FPGETOPN2
+      010000FBH   CODE     ---       ?C?FPMUL
+      010002ABH   CODE     ---       ?C?FPNANRESULT
+      010002B5H   CODE     ---       ?C?FPOVERFLOW
+      0100028DH   CODE     ---       ?C?FPRESULT
+      010002A1H   CODE     ---       ?C?FPRESULT2
+      01000006H   CODE     ---       ?C?FPSUB
+      010002B2H   CODE     ---       ?C?FPUNDERFLOW
+      010005D9H   CODE     ---       ?C?ICALL
+      010005DDH   CODE     ---       ?C?ICALL2
+      0100040EH   CODE     ---       ?C?IILDX
+      01000424H   CODE     ---       ?C?ILDIX
+      0100043AH   CODE     ---       ?C?LMUL
+      01000557H   CODE     ---       ?C?LNEG
+      01000582H   CODE     ---       ?C?LSTKXDATA
+      01000576H   CODE     ---       ?C?LSTXDATA
+      01000565H   CODE     ---       ?C?ULCMP
+      010004C5H   CODE     ---       ?C?ULDIV
+      00000000H   NUMBER   ---       ?C?XDATASEG
+      01000626H   CODE     ---       ?C_START
+      01000000H   CODE     ---       ?C_STARTUP
+      01002D3BH   CODE     ---       _array_is_empty
+      01002D6BH   CODE     ---       _compare_str
+      01001798H   CODE     ---       _Delay1ms
+      01002462H   CODE     ---       _dmemcpy
+      01003572H   CODE     ---       _GPIO_ClearWakeup
+      010035B1H   CODE     ---       _GPIO_FlipOutBit
+      01001FA6H   CODE     ---       _GPIO_GetInputStatus
+      01001846H   CODE     ---       _GPIO_SetInput
+      01001835H   CODE     ---       _GPIO_Setoe
+      010011B2H   CODE     ---       _GPIO_Setout
+      01001808H   CODE     ---       _GPIO_SetOutput
+      01001864H   CODE     ---       _GPIO_SetPd
+      01001824H   CODE     ---       _GPIO_SetPu
+      01001E36H   CODE     ---       _GPIO_SetWakeup
+      01001E23H   CODE     ---       _GPIO_SetWakeupByCurrentState
+      010020CAH   CODE     ---       _IIC_Read
+      01002182H   CODE     ---       _IIC_write
+      01001C84H   CODE     ---       _IIC_WriteBlock
+      01001F99H   CODE     ---       _IPC_Initialize
+      01003511H   CODE     ---       _IPC_Tx24GData
+      01003523H   CODE     ---       _IPC_TxBleData
+      01003504H   CODE     ---       _IPC_TxBREDRHidData
+      0100149DH   CODE     ---       _IPC_TxControlCmd
+      01000FC2H   CODE     ---       _IPC_TxData
+      01000EDAH   CODE     ---       _IPC_TxHidData
+      0100351AH   CODE     ---       _IPC_TxSppData
+      01002860H   CODE     ---       _kb_combination_key_press
+      010026FBH   CODE     ---       _kb_device_select
+      010008BBH   CODE     ---       _kb_motion_keyscan
+      01000BDDH   CODE     ---       _kb_multikey_setup
+      01001F57H   CODE     ---       _kb_send_combination_key
+      01000DDFH   CODE     ---       _kb_set_multikey
+      01000EBFH   CODE     ---       _kb_set_systemkey
+      01002886H   CODE     ---       _key_fn_function
+      01000DFAH   CODE     ---       _xmemclear
+      01003545H   CODE     ---       _xmemclear_ff
+      01000878H   CODE     ---       _xmemcpy
+      010012C6H   CODE     ---       _YC_key_action_handle
+      01000737H   CODE     ---       _YC_load_record_list
+      010007FEH   CODE     ---       _YC_store_record_list
+      02004DECH   XDATA    BYTE      action_timeout
+      02004DEEH   XDATA    ---       bd_key_record_list
+      02004DD3H   XDATA    BYTE      ble_fast_connect_flag
+      02004DE5H   XDATA    BYTE      ble_reconnect_flag
+      02004DD4H   XDATA    BYTE      ble_send_secutiry_request_timer
+      02004C8DH   XDATA    BYTE      btstimer
+      02004BA5H   XDATA    WORD      bttimer
+      02004C8EH   XDATA    BYTE      c51stimer
+      02004C5EH   XDATA    WORD      c51timer
+      01000681H   CONST    ---       col
+      02000B7EH   XDATA    BYTE      current_task
+      02004DE6H   XDATA    BYTE      delayChgInvTimer
+      02004E55H   XDATA    BYTE      fast_connect_flag
+      02004DE2H   XDATA    BYTE      fn_flag
+      02004DEAH   XDATA    BYTE      fn_flag_last
+      02004DE7H   XDATA    BYTE      fn_lock_flag
+      02004DD8H   XDATA    BYTE      fn_tx_flag
+      02004CBFH   XDATA    ---       g_variable
+      02004DD5H   XDATA    BYTE      get_24g_led_send
+      010035CEH   CODE     ---       GPIO_fillpd
+      02004800H   XDATA    ---       hidBuff
+      02004DE1H   XDATA    BYTE      iOS_rec_pinCode
+      01003532H   CODE     ---       IPC_AbandonLpm
+      010032FBH   CODE     ---       IPC_DealSingleStep
+      0100352CH   CODE     ---       IPC_GetBBDIsconnectReason
+      010026E3H   CODE     ---       IPC_IsTxBuffEmpty
+      01001EC2H   CODE     ---       IPC_WaitLpm
+      02000550H   XDATA    ---       ipcPin
+      0200054FH   XDATA    BYTE      ipcPinlen
+      02000C4BH   XDATA    ---       ipcReadBuff
+      02000BE7H   XDATA    ---       ipcSendBuff
+      01002671H   CODE     ---       kb_24g_get_led_status
+      010019F0H   CODE     ---       kb_button_press_timer500ms
+      01001ED0H   CODE     ---       kb_need_keyscan
+      02004DE8H   XDATA    BYTE      key_value_temp
+      02004DE4H   XDATA    BYTE      keyCount
+      01002ACBH   CODE     ---       KS_GetCurrentEvt
+      010018F4H   CODE     ---       KS_Initialize
+      01002EDEH   CODE     ---       KS_ScanMatrix
+      01001D8BH   CODE     ---       KS_Unistall
+      02004213H   XDATA    BYTE      kscurrmult
+      02004EA4H   XDATA    ---       ksEvtPool
+      01000696H   CONST    ---       ksMap
+      02004DA8H   XDATA    ---       ksSelMapCheck
+      02004DBCH   XDATA    ---       ksSelMapCurr
+      02004D93H   XDATA    ---       ksSelMapOld
+      02004DD0H   XDATA    ---       le_lap_temp
+      02004D39H   XDATA    DWORD     le_pin_code
+      02004DD7H   XDATA    BYTE      le_pin_code_len
+      02004DDBH   XDATA    BYTE      le_send_battery_level_delay_count
+      02004DDAH   XDATA    BYTE      le_send_battery_level_flag
+      010017F0H   CODE     ---       LED_all_shutdown
+      010017C8H   CODE     ---       LED_device_poweroff
+      010017B0H   CODE     ---       LED_device_poweron
+      010011C4H   CODE     ---       LED_handle
+      010010E9H   CODE     ---       LED_timer500ms
+      02004DDCH   XDATA    BYTE      long_press_flag
+      02000B7FH   XDATA    BYTE      lpm_flag
+      02004C00H   XDATA    ---       m_24g_addr
+      02004D40H   XDATA    ---       m_24g_enter_hibernate
+      02004D46H   XDATA    BYTE      m_24g_led_flag
+      02004BEFH   XDATA    BYTE      m_24g_pairing_sm
+      02004BEBH   XDATA    ---       m_24g_paring_addr
+      02004C91H   XDATA    WORD      m_adc0vBase
+      02004C93H   XDATA    WORD      m_adc3vValue
+      02004C90H   XDATA    BYTE      m_adc_channel
+      02004C8FH   XDATA    BYTE      m_adc_config_flag
+      02004C95H   XDATA    WORD      m_adcCurrentValue
+      02004CB7H   XDATA    BYTE      m_caps_num_lock
+      02004DE0H   XDATA    BYTE      m_caps_num_lock_last
+      02004D51H   XDATA    BYTE      m_customize_timer
+      020044F9H   XDATA    ---       m_le_lap
+      0200447BH   XDATA    ---       m_le_ltk
+      02004D3DH   XDATA    BYTE      m_le_send_security_request_flag
+      0200425EH   XDATA    BYTE      m_link_key_exists
+      02004262H   XDATA    ---       m_linkkey
+      02004131H   XDATA    BYTE      m_lpm_mode
+      0200448BH   XDATA    BYTE      m_ltk_exists
+      02004D7DH   XDATA    BYTE      m_pc_sleep_flag
+      02004CB6H   XDATA    BYTE      m_power_on_flag
+      02004274H   XDATA    ---       m_reconn_addr
+      02004D38H   XDATA    BYTE      m_reconnect_continue
+      02000040H   XDATA    ---       m_remote_addr
+      020003D0H   XDATA    ---       m_remote_le_addr
+      02008010H   XDATA    BYTE      m_reset_reg
+      020047F4H   XDATA    WORD      m_ui_state_map
+      02000B81H   XDATA    BYTE      m_wakup_from_power_flag
+      01001FEBH   CODE     ---       main
+      02004E4BH   XDATA    BYTE      mult_key_status
+      02004DEDH   XDATA    BYTE      mult_key_value
+      02004E4CH   XDATA    ---       multikey
+      02004DDEH   XDATA    BYTE      pinCode_flag
+      02004DEBH   XDATA    BYTE      power_on_flag
+      02004DE3H   XDATA    BYTE      press_long_time_flag
+      02004DD6H   XDATA    BYTE      recon_index
+      02004DDDH   XDATA    BYTE      repeat_send_24g
+      02004DDFH   XDATA    BYTE      standard_key_release_flag
+      02004DD9H   XDATA    BYTE      switch_role_timer
+      01002433H   CODE     ---       System_G24_long_lpm
+      02004DE9H   XDATA    BYTE      system_key_press
+      0100178FH   CODE     ---       System_long_sleep
+      01001D33H   CODE     ---       System_Reset_Connect
+      0100304DH   CODE     ---       System_Software_init
+      010024A6H   CODE     ---       YC_adc_check
+      01002323H   CODE     ---       YC_adc_check_timer500ms
+      01003082H   CODE     ---       YC_adc_init
+      01002302H   CODE     ---       YC_adc_motion_check_timer500ms
+      010019AEH   CODE     ---       YC_cancel_reconnect
+      010010D3H   CODE     ---       YC_check_is_connected
+      01001922H   CODE     ---       YC_check_need_reconnected
+      010017E0H   CODE     ---       YC_clear_reconnect_flag
+      01002334H   CODE     ---       YC_connect_timeout_500ms
+      010019C1H   CODE     ---       YC_disconnect_all_link
+      01001FEDH   CODE     ---       YC_g24_mode_discovery
+      0100221CH   CODE     ---       YC_get_ble_ramdon_lap
+      020000A7H   XDATA    ---       YC_GPIOWakeupH
+      020000A3H   XDATA    ---       YC_GPIOWakeupL
+      0100353EH   CODE     ---       YC_Ice_break
+      010022B9H   CODE     ---       YC_pairing_timerout_500ms
+      01002004H   CODE     ---       YC_start_reconnect
+      01001D3CH   CODE     ---       YC_System_Main
+      01001BEAH   CODE     ---       YC_update_eeprom_data
+      0100225FH   CODE     ---       YC_wait_disconnect_timer500ms
+
+
+
+SYMBOL TABLE OF MODULE:  OUTPUT\FW (BLUETOOTH)
+
+      VALUE       REP       CLASS    TYPE      SYMBOL NAME
+      ====================================================
+      ---         MODULE    ---      ---       BLUETOOTH
+      01001BEAH   PUBLIC    CODE     ---       YC_update_eeprom_data
+      0100221CH   PUBLIC    CODE     ---       YC_get_ble_ramdon_lap
+      01002004H   PUBLIC    CODE     ---       YC_start_reconnect
+      01001FEDH   PUBLIC    CODE     ---       YC_g24_mode_discovery
+      010019C1H   PUBLIC    CODE     ---       YC_disconnect_all_link
+      010017E0H   PUBLIC    CODE     ---       YC_clear_reconnect_flag
+      010019AEH   PUBLIC    CODE     ---       YC_cancel_reconnect
+      01001922H   PUBLIC    CODE     ---       YC_check_need_reconnected
+      010010D3H   PUBLIC    CODE     ---       YC_check_is_connected
+      010007FEH   PUBLIC    CODE     ---       _YC_store_record_list
+      01000737H   PUBLIC    CODE     ---       _YC_load_record_list
+
+      01000737H   BLOCK     CODE     ---       LVL=0
+      01000737H   LINE      ---      ---       #4
+      0100073CH   LINE      ---      ---       #5
+      0100073CH   LINE      ---      ---       #6
+      01000744H   LINE      ---      ---       #8
+      01000746H   LINE      ---      ---       #9
+      0100074BH   LINE      ---      ---       #10
+      0100074FH   LINE      ---      ---       #11
+      01000766H   LINE      ---      ---       #12
+      01000766H   LINE      ---      ---       #13
+      01000782H   LINE      ---      ---       #14
+      010007A1H   LINE      ---      ---       #15
+      010007C0H   LINE      ---      ---       #16
+      010007C5H   LINE      ---      ---       #17
+      010007CBH   LINE      ---      ---       #18
+      010007D0H   LINE      ---      ---       #19
+      010007D5H   LINE      ---      ---       #20
+      010007D6H   LINE      ---      ---       #22
+      010007D6H   LINE      ---      ---       #23
+      010007DCH   LINE      ---      ---       #25
+      010007E2H   LINE      ---      ---       #26
+      010007E4H   LINE      ---      ---       #27
+      010007E6H   LINE      ---      ---       #28
+      010007E8H   LINE      ---      ---       #29
+      010007EAH   LINE      ---      ---       #30
+      010007ECH   LINE      ---      ---       #31
+      010007F2H   LINE      ---      ---       #32
+      010007F7H   LINE      ---      ---       #33
+      010007FDH   LINE      ---      ---       #36
+      010007FDH   LINE      ---      ---       #37
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010007FEH   BLOCK     CODE     ---       LVL=0
+      010007FEH   LINE      ---      ---       #41
+      01000803H   LINE      ---      ---       #42
+      01000803H   LINE      ---      ---       #43
+      01000808H   LINE      ---      ---       #44
+      01000808H   LINE      ---      ---       #45
+      0100081AH   LINE      ---      ---       #46
+      01000837H   LINE      ---      ---       #47
+      01000857H   LINE      ---      ---       #48
+      01000877H   LINE      ---      ---       #49
+      01000877H   LINE      ---      ---       #50
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010010D3H   BLOCK     CODE     ---       LVL=0
+      010010D3H   LINE      ---      ---       #53
+      010010D3H   LINE      ---      ---       #54
+      010010D3H   LINE      ---      ---       #55
+      010010E3H   LINE      ---      ---       #57
+      010010E3H   LINE      ---      ---       #58
+      010010E6H   LINE      ---      ---       #59
+      010010E6H   LINE      ---      ---       #60
+      010010E8H   LINE      ---      ---       #61
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001922H   BLOCK     CODE     ---       LVL=0
+      01001922H   LINE      ---      ---       #63
+      01001922H   LINE      ---      ---       #64
+      01001922H   BLOCK     CODE     NEAR LAB  LVL=1
+      01001922H   LINE      ---      ---       #65
+      01001927H   LINE      ---      ---       #66
+      0100192FH   LINE      ---      ---       #67
+      01001935H   LINE      ---      ---       #68
+      0100193CH   LINE      ---      ---       #69
+      01001942H   LINE      ---      ---       #71
+      01001948H   LINE      ---      ---       #72
+      0100194EH   LINE      ---      ---       #74
+      0100195CH   LINE      ---      ---       #77
+      0100195CH   LINE      ---      ---       #78
+      01001962H   LINE      ---      ---       #79
+      01001962H   LINE      ---      ---       #80
+      01001965H   LINE      ---      ---       #81
+      01001971H   LINE      ---      ---       #83
+      01001971H   LINE      ---      ---       #84
+      0100198BH   LINE      ---      ---       #85
+      0100198BH   LINE      ---      ---       #86
+      0100198FH   LINE      ---      ---       #87
+      01001991H   LINE      ---      ---       #89
+      01001991H   LINE      ---      ---       #90
+      01001996H   LINE      ---      ---       #91
+      0100199CH   LINE      ---      ---       #92
+      0100199CH   LINE      ---      ---       #93
+      0100199CH   LINE      ---      ---       #94
+      0100199CH   LINE      ---      ---       #95
+      0100199EH   LINE      ---      ---       #97
+      0100199EH   LINE      ---      ---       #98
+      010019A3H   LINE      ---      ---       #99
+      010019A8H   LINE      ---      ---       #100
+      010019A8H   LINE      ---      ---       #101
+      010019ADH   LINE      ---      ---       #102
+      02004F00H   SYMBOL    XDATA    VOID      return_val
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      010019AEH   BLOCK     CODE     ---       LVL=0
+      010019AEH   LINE      ---      ---       #105
+      010019AEH   LINE      ---      ---       #106
+      010019AEH   LINE      ---      ---       #107
+      010019B6H   LINE      ---      ---       #108
+      010019B6H   LINE      ---      ---       #110
+      010019BBH   LINE      ---      ---       #111
+      010019BEH   LINE      ---      ---       #112
+      010019BEH   LINE      ---      ---       #113
+      010019C0H   LINE      ---      ---       #114
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010017E0H   BLOCK     CODE     ---       LVL=0
+      010017E0H   LINE      ---      ---       #117
+      010017E0H   LINE      ---      ---       #118
+      010017E0H   LINE      ---      ---       #119
+      010017E5H   LINE      ---      ---       #120
+      010017E9H   LINE      ---      ---       #121
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010019C1H   BLOCK     CODE     ---       LVL=0
+      010019C1H   LINE      ---      ---       #124
+      010019C1H   LINE      ---      ---       #125
+      010019C1H   LINE      ---      ---       #126
+      010019CFH   LINE      ---      ---       #128
+      010019CFH   LINE      ---      ---       #129
+      010019D4H   LINE      ---      ---       #130
+      010019D7H   LINE      ---      ---       #131
+      010019D7H   LINE      ---      ---       #132
+      010019E5H   LINE      ---      ---       #134
+      010019E5H   LINE      ---      ---       #135
+      010019EAH   LINE      ---      ---       #136
+      010019EDH   LINE      ---      ---       #137
+      010019EDH   LINE      ---      ---       #138
+      010019EFH   LINE      ---      ---       #139
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001FEDH   BLOCK     CODE     ---       LVL=0
+      01001FEDH   LINE      ---      ---       #141
+      01001FEDH   LINE      ---      ---       #142
+      01001FEDH   LINE      ---      ---       #143
+      01001FF9H   LINE      ---      ---       #144
+      01001FF9H   LINE      ---      ---       #145
+      01001FFEH   LINE      ---      ---       #146
+      01002001H   LINE      ---      ---       #147
+      01002001H   LINE      ---      ---       #148
+      01002003H   LINE      ---      ---       #149
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01002004H   BLOCK     CODE     ---       LVL=0
+      01002004H   LINE      ---      ---       #153
+      01002004H   LINE      ---      ---       #154
+      01002004H   LINE      ---      ---       #155
+      0100200AH   LINE      ---      ---       #156
+      0100201AH   LINE      ---      ---       #157
+      0100201FH   LINE      ---      ---       #158
+      0100202FH   LINE      ---      ---       #159
+      01002034H   LINE      ---      ---       #160
+      01002044H   LINE      ---      ---       #161
+      01002049H   LINE      ---      ---       #162
+      01002059H   LINE      ---      ---       #163
+      0100205EH   LINE      ---      ---       #165
+      01002078H   LINE      ---      ---       #166
+      01002078H   LINE      ---      ---       #167
+      0100208BH   LINE      ---      ---       #168
+      010020A1H   LINE      ---      ---       #169
+      010020A4H   LINE      ---      ---       #170
+      010020A6H   LINE      ---      ---       #172
+      010020A6H   LINE      ---      ---       #173
+      010020ABH   LINE      ---      ---       #174
+      010020ABH   LINE      ---      ---       #175
+      010020B8H   LINE      ---      ---       #176
+      010020BAH   LINE      ---      ---       #177
+      010020C7H   LINE      ---      ---       #178
+      010020C7H   LINE      ---      ---       #179
+      010020C9H   LINE      ---      ---       #180
+      010020C9H   LINE      ---      ---       #181
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      0100221CH   BLOCK     CODE     ---       LVL=0
+      0100221CH   LINE      ---      ---       #185
+      0100221CH   LINE      ---      ---       #186
+      0100221CH   LINE      ---      ---       #187
+      0100222CH   LINE      ---      ---       #188
+      01002232H   LINE      ---      ---       #189
+      01002236H   LINE      ---      ---       #190
+      0100223EH   LINE      ---      ---       #191
+      01002246H   LINE      ---      ---       #192
+      0100224EH   LINE      ---      ---       #193
+      01002256H   LINE      ---      ---       #194
+      0100225EH   LINE      ---      ---       #195
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001BEAH   BLOCK     CODE     ---       LVL=0
+      01001BEAH   LINE      ---      ---       #199
+      01001BEAH   LINE      ---      ---       #200
+      01001BEAH   LINE      ---      ---       #201
+      01001BF2H   LINE      ---      ---       #202
+      01001BF2H   LINE      ---      ---       #203
+      01001BF6H   LINE      ---      ---       #204
+      01001BFBH   LINE      ---      ---       #205
+      01001C02H   LINE      ---      ---       #206
+      01001C0AH   LINE      ---      ---       #207
+      01001C0AH   LINE      ---      ---       #208
+      01001C19H   LINE      ---      ---       #209
+      01001C29H   LINE      ---      ---       #210
+      01001C39H   LINE      ---      ---       #211
+      01001C3BH   LINE      ---      ---       #212
+      01001C43H   LINE      ---      ---       #213
+      01001C52H   LINE      ---      ---       #215
+      01001C62H   LINE      ---      ---       #216
+      01001C72H   LINE      ---      ---       #218
+      01001C79H   LINE      ---      ---       #219
+      01001C7EH   LINE      ---      ---       #220
+      01001C83H   LINE      ---      ---       #221
+      01001C83H   LINE      ---      ---       #222
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      ---         MODULE    ---      ---       GLOBAL_VARIABLE
+      02004E55H   PUBLIC    XDATA    BYTE      fast_connect_flag
+      02004E4CH   PUBLIC    XDATA    ---       multikey
+      02004E4BH   PUBLIC    XDATA    BYTE      mult_key_status
+      02004D39H   PUBLIC    XDATA    DWORD     le_pin_code
+      02004D3DH   PUBLIC    XDATA    BYTE      m_le_send_security_request_flag
+      02004DEEH   PUBLIC    XDATA    ---       bd_key_record_list
+      02004DEDH   PUBLIC    XDATA    BYTE      mult_key_value
+      02004DECH   PUBLIC    XDATA    BYTE      action_timeout
+      02004DEBH   PUBLIC    XDATA    BYTE      power_on_flag
+      02004DEAH   PUBLIC    XDATA    BYTE      fn_flag_last
+      02004DE9H   PUBLIC    XDATA    BYTE      system_key_press
+      02004DE8H   PUBLIC    XDATA    BYTE      key_value_temp
+      02004213H   PUBLIC    XDATA    BYTE      kscurrmult
+      02004C95H   PUBLIC    XDATA    WORD      m_adcCurrentValue
+      02004D38H   PUBLIC    XDATA    BYTE      m_reconnect_continue
+      02004DE7H   PUBLIC    XDATA    BYTE      fn_lock_flag
+      02000040H   PUBLIC    XDATA    ---       m_remote_addr
+      02004DE6H   PUBLIC    XDATA    BYTE      delayChgInvTimer
+      02004DE5H   PUBLIC    XDATA    BYTE      ble_reconnect_flag
+      02004DE4H   PUBLIC    XDATA    BYTE      keyCount
+      02004274H   PUBLIC    XDATA    ---       m_reconn_addr
+      02004DE3H   PUBLIC    XDATA    BYTE      press_long_time_flag
+      02004DE2H   PUBLIC    XDATA    BYTE      fn_flag
+      020047F4H   PUBLIC    XDATA    WORD      m_ui_state_map
+      02004DE1H   PUBLIC    XDATA    BYTE      iOS_rec_pinCode
+      02004C8FH   PUBLIC    XDATA    BYTE      m_adc_config_flag
+      02004DE0H   PUBLIC    XDATA    BYTE      m_caps_num_lock_last
+      0200447BH   PUBLIC    XDATA    ---       m_le_ltk
+      02004262H   PUBLIC    XDATA    ---       m_linkkey
+      02004D93H   PUBLIC    XDATA    ---       ksSelMapOld
+      02004DDFH   PUBLIC    XDATA    BYTE      standard_key_release_flag
+      02004DBCH   PUBLIC    XDATA    ---       ksSelMapCurr
+      02004DDEH   PUBLIC    XDATA    BYTE      pinCode_flag
+      02004DDDH   PUBLIC    XDATA    BYTE      repeat_send_24g
+      02004DDCH   PUBLIC    XDATA    BYTE      long_press_flag
+      020044F9H   PUBLIC    XDATA    ---       m_le_lap
+      02004800H   PUBLIC    XDATA    ---       hidBuff
+      02004D51H   PUBLIC    XDATA    BYTE      m_customize_timer
+      02004DDBH   PUBLIC    XDATA    BYTE      le_send_battery_level_delay_count
+      02004CB6H   PUBLIC    XDATA    BYTE      m_power_on_flag
+      02004DDAH   PUBLIC    XDATA    BYTE      le_send_battery_level_flag
+      02004D40H   PUBLIC    XDATA    ---       m_24g_enter_hibernate
+      02004CB7H   PUBLIC    XDATA    BYTE      m_caps_num_lock
+      02004C90H   PUBLIC    XDATA    BYTE      m_adc_channel
+      02004DD9H   PUBLIC    XDATA    BYTE      switch_role_timer
+      02004D46H   PUBLIC    XDATA    BYTE      m_24g_led_flag
+      0200425EH   PUBLIC    XDATA    BYTE      m_link_key_exists
+      02004BEFH   PUBLIC    XDATA    BYTE      m_24g_pairing_sm
+      02004C93H   PUBLIC    XDATA    WORD      m_adc3vValue
+      02004131H   PUBLIC    XDATA    BYTE      m_lpm_mode
+      02004DD8H   PUBLIC    XDATA    BYTE      fn_tx_flag
+      0200448BH   PUBLIC    XDATA    BYTE      m_ltk_exists
+      02000B81H   PUBLIC    XDATA    BYTE      m_wakup_from_power_flag
+      02004C91H   PUBLIC    XDATA    WORD      m_adc0vBase
+      02004D7DH   PUBLIC    XDATA    BYTE      m_pc_sleep_flag
+      02004DD7H   PUBLIC    XDATA    BYTE      le_pin_code_len
+      02004C00H   PUBLIC    XDATA    ---       m_24g_addr
+      02004DD6H   PUBLIC    XDATA    BYTE      recon_index
+      02004DD5H   PUBLIC    XDATA    BYTE      get_24g_led_send
+      02004DD4H   PUBLIC    XDATA    BYTE      ble_send_secutiry_request_timer
+      02008010H   PUBLIC    XDATA    BYTE      m_reset_reg
+      02004CBFH   PUBLIC    XDATA    ---       g_variable
+      02004DD3H   PUBLIC    XDATA    BYTE      ble_fast_connect_flag
+      020003D0H   PUBLIC    XDATA    ---       m_remote_le_addr
+      02004DD0H   PUBLIC    XDATA    ---       le_lap_temp
+      02004DA8H   PUBLIC    XDATA    ---       ksSelMapCheck
+      02004BEBH   PUBLIC    XDATA    ---       m_24g_paring_addr
+      01000696H   PUBLIC    CONST    ---       ksMap
+      01000681H   PUBLIC    CONST    ---       col
+
+      ---         MODULE    ---      ---       KB_PROCESS
+      01000BDDH   PUBLIC    CODE     ---       _kb_multikey_setup
+      01002886H   PUBLIC    CODE     ---       _key_fn_function
+      01002860H   PUBLIC    CODE     ---       _kb_combination_key_press
+      010026FBH   PUBLIC    CODE     ---       _kb_device_select
+      010008BBH   PUBLIC    CODE     ---       _kb_motion_keyscan
+      01001ED0H   PUBLIC    CODE     ---       kb_need_keyscan
+      01002671H   PUBLIC    CODE     ---       kb_24g_get_led_status
+      01001F57H   PUBLIC    CODE     ---       _kb_send_combination_key
+      01000EBFH   PUBLIC    CODE     ---       _kb_set_systemkey
+      01000DDFH   PUBLIC    CODE     ---       _kb_set_multikey
+      01000EDAH   PUBLIC    CODE     ---       _IPC_TxHidData
+      010012C6H   PUBLIC    CODE     ---       _YC_key_action_handle
+
+      010012C6H   BLOCK     CODE     ---       LVL=0
+      010012C6H   LINE      ---      ---       #3
+      010012CBH   LINE      ---      ---       #4
+      010012CBH   LINE      ---      ---       #5
+      01001308H   LINE      ---      ---       #6
+      01001308H   LINE      ---      ---       #7
+      01001308H   LINE      ---      ---       #8
+      01001308H   LINE      ---      ---       #9
+      01001308H   LINE      ---      ---       #10
+      01001316H   LINE      ---      ---       #12
+      01001316H   LINE      ---      ---       #13
+      0100131AH   LINE      ---      ---       #14
+      01001322H   LINE      ---      ---       #15
+      01001323H   LINE      ---      ---       #17
+      01001323H   LINE      ---      ---       #18
+      0100132CH   LINE      ---      ---       #19
+      01001332H   LINE      ---      ---       #20
+      01001336H   LINE      ---      ---       #21
+      0100133AH   LINE      ---      ---       #22
+      0100133EH   LINE      ---      ---       #23
+      01001342H   LINE      ---      ---       #24
+      01001347H   LINE      ---      ---       #25
+      01001347H   LINE      ---      ---       #26
+      01001348H   LINE      ---      ---       #27
+      01001348H   LINE      ---      ---       #28
+      0100134CH   LINE      ---      ---       #29
+      0100134CH   LINE      ---      ---       #30
+      0100134CH   LINE      ---      ---       #31
+      01001351H   LINE      ---      ---       #32
+      01001363H   LINE      ---      ---       #33
+      01001363H   LINE      ---      ---       #34
+      0100136BH   LINE      ---      ---       #35
+      01001371H   LINE      ---      ---       #36
+      01001372H   LINE      ---      ---       #38
+      01001372H   LINE      ---      ---       #39
+      01001374H   LINE      ---      ---       #40
+      01001379H   LINE      ---      ---       #41
+      0100137DH   LINE      ---      ---       #42
+      01001381H   LINE      ---      ---       #44
+      01001384H   LINE      ---      ---       #45
+      01001388H   LINE      ---      ---       #46
+      0100138DH   LINE      ---      ---       #47
+      0100138DH   LINE      ---      ---       #48
+      0100138EH   LINE      ---      ---       #49
+      0100138EH   LINE      ---      ---       #50
+      01001391H   LINE      ---      ---       #51
+      01001396H   LINE      ---      ---       #52
+      01001397H   LINE      ---      ---       #53
+      01001397H   LINE      ---      ---       #54
+      010013A4H   LINE      ---      ---       #55
+      010013AAH   LINE      ---      ---       #56
+      010013ACH   LINE      ---      ---       #57
+      010013B0H   LINE      ---      ---       #58
+      010013B6H   LINE      ---      ---       #59
+      010013C7H   LINE      ---      ---       #60
+      010013D8H   LINE      ---      ---       #61
+      010013DEH   LINE      ---      ---       #62
+      010013E3H   LINE      ---      ---       #63
+      010013E4H   LINE      ---      ---       #64
+      010013E4H   LINE      ---      ---       #65
+      010013E4H   LINE      ---      ---       #66
+      010013E9H   LINE      ---      ---       #67
+      010013EFH   LINE      ---      ---       #68
+      010013EFH   LINE      ---      ---       #69
+      010013F7H   LINE      ---      ---       #70
+      010013F8H   LINE      ---      ---       #72
+      010013F8H   LINE      ---      ---       #73
+      01001409H   LINE      ---      ---       #74
+      0100140DH   LINE      ---      ---       #75
+      01001412H   LINE      ---      ---       #76
+      01001428H   LINE      ---      ---       #77
+      01001428H   LINE      ---      ---       #78
+      0100142EH   LINE      ---      ---       #79
+      01001430H   LINE      ---      ---       #80
+      01001432H   LINE      ---      ---       #81
+      01001434H   LINE      ---      ---       #82
+      0100143AH   LINE      ---      ---       #83
+      0100143AH   LINE      ---      ---       #85
+      0100143EH   LINE      ---      ---       #87
+      01001444H   LINE      ---      ---       #88
+      01001447H   LINE      ---      ---       #89
+      0100144BH   LINE      ---      ---       #90
+      0100144BH   LINE      ---      ---       #91
+      0100144CH   LINE      ---      ---       #92
+      0100144CH   LINE      ---      ---       #93
+      01001451H   LINE      ---      ---       #94
+      0100145DH   LINE      ---      ---       #95
+      0100145DH   LINE      ---      ---       #96
+      01001465H   LINE      ---      ---       #97
+      01001466H   LINE      ---      ---       #99
+      01001466H   LINE      ---      ---       #100
+      0100146EH   LINE      ---      ---       #101
+      0100146EH   LINE      ---      ---       #102
+      01001473H   LINE      ---      ---       #103
+      01001477H   LINE      ---      ---       #104
+      0100147DH   LINE      ---      ---       #105
+      01001480H   LINE      ---      ---       #106
+      01001486H   LINE      ---      ---       #107
+      0100148CH   LINE      ---      ---       #108
+      01001491H   LINE      ---      ---       #109
+      01001491H   LINE      ---      ---       #110
+      01001496H   LINE      ---      ---       #111
+      01001496H   LINE      ---      ---       #112
+      01001497H   LINE      ---      ---       #113
+      01001497H   LINE      ---      ---       #114
+      0100149CH   LINE      ---      ---       #115
+      0100149CH   LINE      ---      ---       #116
+      0100149CH   LINE      ---      ---       #117
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01000EDAH   BLOCK     CODE     ---       LVL=0
+      01000EDAH   LINE      ---      ---       #121
+      01000EE8H   LINE      ---      ---       #122
+      01000EE8H   BLOCK     CODE     NEAR LAB  LVL=1
+      01000EE8H   LINE      ---      ---       #124
+      01000EEAH   LINE      ---      ---       #126
+      01000EF4H   LINE      ---      ---       #127
+      01000EF4H   LINE      ---      ---       #128
+      01000F14H   LINE      ---      ---       #129
+      01000F17H   LINE      ---      ---       #131
+      01000F1FH   LINE      ---      ---       #133
+      01000F27H   LINE      ---      ---       #136
+      01000F3BH   LINE      ---      ---       #138
+      01000F3BH   LINE      ---      ---       #139
+      01000F43H   LINE      ---      ---       #140
+      01000F46H   LINE      ---      ---       #141
+      01000F54H   LINE      ---      ---       #143
+      01000F54H   LINE      ---      ---       #144
+      01000F5CH   LINE      ---      ---       #145
+      01000F5CH   LINE      ---      ---       #146
+      01000F64H   LINE      ---      ---       #147
+      01000F64H   LINE      ---      ---       #148
+      01000F67H   LINE      ---      ---       #149
+      01000F79H   LINE      ---      ---       #150
+      01000F7FH   LINE      ---      ---       #152
+      01000F85H   LINE      ---      ---       #153
+      01000F87H   LINE      ---      ---       #154
+      01000F8FH   LINE      ---      ---       #155
+      01000F8FH   LINE      ---      ---       #156
+      01000F92H   LINE      ---      ---       #157
+      01000F9AH   LINE      ---      ---       #158
+      01000F9AH   LINE      ---      ---       #159
+      01000F9EH   LINE      ---      ---       #160
+      01000FA0H   LINE      ---      ---       #162
+      01000FA0H   LINE      ---      ---       #163
+      01000FA6H   LINE      ---      ---       #164
+      01000FA6H   LINE      ---      ---       #165
+      01000FA8H   LINE      ---      ---       #166
+      01000FB0H   LINE      ---      ---       #167
+      01000FB0H   LINE      ---      ---       #168
+      01000FB3H   LINE      ---      ---       #169
+      01000FB3H   LINE      ---      ---       #170
+      01000FC1H   LINE      ---      ---       #171
+      01000FC1H   LINE      ---      ---       #172
+      02004E7EH   SYMBOL    XDATA    VOID      tx_hid_buff
+      00000007H   SYMBOL    DATA     VOID      i
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01000DDFH   BLOCK     CODE     ---       LVL=0
+      01000DDFH   LINE      ---      ---       #175
+      01000DE3H   LINE      ---      ---       #176
+      01000DE3H   LINE      ---      ---       #177
+      01000DEBH   LINE      ---      ---       #178
+      01000DEBH   LINE      ---      ---       #179
+      01000DEEH   LINE      ---      ---       #180
+      01000DF3H   LINE      ---      ---       #181
+      01000DF6H   LINE      ---      ---       #182
+      01000DF9H   LINE      ---      ---       #183
+      01000DF9H   LINE      ---      ---       #184
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01000EBFH   BLOCK     CODE     ---       LVL=0
+      01000EBFH   LINE      ---      ---       #186
+      01000EBFH   LINE      ---      ---       #187
+      01000EBFH   LINE      ---      ---       #188
+      01000EC7H   LINE      ---      ---       #189
+      01000EC7H   LINE      ---      ---       #190
+      01000ECAH   LINE      ---      ---       #191
+      01000ED0H   LINE      ---      ---       #192
+      01000ED6H   LINE      ---      ---       #193
+      01000ED9H   LINE      ---      ---       #194
+      01000ED9H   LINE      ---      ---       #195
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001F57H   BLOCK     CODE     ---       LVL=0
+      01001F57H   LINE      ---      ---       #198
+      01001F5FH   LINE      ---      ---       #199
+      01001F5FH   LINE      ---      ---       #200
+      01001F6CH   LINE      ---      ---       #201
+      01001F72H   LINE      ---      ---       #202
+      01001F80H   LINE      ---      ---       #203
+      01001F88H   LINE      ---      ---       #204
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01002671H   BLOCK     CODE     ---       LVL=0
+      01002671H   LINE      ---      ---       #268
+      01002671H   LINE      ---      ---       #269
+      01002671H   LINE      ---      ---       #270
+      0100267DH   LINE      ---      ---       #271
+      0100267DH   LINE      ---      ---       #272
+      01002685H   LINE      ---      ---       #273
+      01002685H   LINE      ---      ---       #274
+      01002691H   LINE      ---      ---       #276
+      01002696H   LINE      ---      ---       #277
+      0100269BH   LINE      ---      ---       #278
+      010026A3H   LINE      ---      ---       #279
+      010026AEH   LINE      ---      ---       #280
+      010026AEH   LINE      ---      ---       #281
+      010026AEH   LINE      ---      ---       #282
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010026AFH   BLOCK     CODE     ---       LVL=0
+      010026AFH   LINE      ---      ---       #286
+      010026AFH   LINE      ---      ---       #287
+      010026AFH   BLOCK     CODE     NEAR LAB  LVL=1
+      010026AFH   LINE      ---      ---       #288
+      010026B8H   LINE      ---      ---       #290
+      010026BCH   LINE      ---      ---       #292
+      010026CAH   LINE      ---      ---       #294
+      010026CDH   LINE      ---      ---       #295
+      010026CDH   LINE      ---      ---       #296
+      010026D2H   LINE      ---      ---       #297
+      010026D4H   LINE      ---      ---       #299
+      010026D4H   LINE      ---      ---       #300
+      010026E2H   LINE      ---      ---       #301
+      02004EE0H   SYMBOL    XDATA    VOID      pEvt
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01001ED0H   BLOCK     CODE     ---       LVL=0
+      01001ED0H   LINE      ---      ---       #305
+      01001ED0H   LINE      ---      ---       #306
+      01001ED0H   LINE      ---      ---       #315
+      01001ED0H   LINE      ---      ---       #316
+      01001EE0H   LINE      ---      ---       #320
+      01001EE3H   LINE      ---      ---       #322
+      01001EE3H   LINE      ---      ---       #323
+      01001EEBH   LINE      ---      ---       #324
+      01001EEBH   LINE      ---      ---       #325
+      01001EF2H   LINE      ---      ---       #326
+      01001EF8H   LINE      ---      ---       #327
+      01001EF9H   LINE      ---      ---       #328
+      01001F01H   LINE      ---      ---       #329
+      01001F01H   LINE      ---      ---       #330
+      01001F04H   LINE      ---      ---       #331
+      01001F0CH   LINE      ---      ---       #332
+      01001F0CH   LINE      ---      ---       #333
+      01001F14H   LINE      ---      ---       #334
+      01001F14H   LINE      ---      ---       #335
+      01001F18H   LINE      ---      ---       #336
+      01001F21H   LINE      ---      ---       #337
+      01001F26H   LINE      ---      ---       #338
+      01001F2CH   LINE      ---      ---       #339
+      01001F33H   LINE      ---      ---       #341
+      01001F39H   LINE      ---      ---       #342
+      01001F3AH   LINE      ---      ---       #343
+      01001F42H   LINE      ---      ---       #344
+      01001F42H   LINE      ---      ---       #345
+      01001F46H   LINE      ---      ---       #346
+      01001F4AH   LINE      ---      ---       #347
+      01001F51H   LINE      ---      ---       #348
+      01001F56H   LINE      ---      ---       #349
+      01001F56H   LINE      ---      ---       #350
+      01001F56H   LINE      ---      ---       #351
+      01001F56H   LINE      ---      ---       #352
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010008BBH   BLOCK     CODE     ---       LVL=0
+      010008BBH   LINE      ---      ---       #356
+      010008C6H   LINE      ---      ---       #357
+      010008C6H   BLOCK     CODE     NEAR LAB  LVL=1
+      010008C6H   LINE      ---      ---       #358
+      010008C9H   LINE      ---      ---       #359
+      010008CBH   LINE      ---      ---       #361
+      010008CFH   LINE      ---      ---       #362
+      010008E1H   LINE      ---      ---       #363
+      010008E1H   LINE      ---      ---       #364
+      01000900H   LINE      ---      ---       #365
+      01000900H   LINE      ---      ---       #366
+      01000905H   LINE      ---      ---       #367
+      01000905H   LINE      ---      ---       #368
+      0100090DH   LINE      ---      ---       #371
+      01000920H   LINE      ---      ---       #373
+      0100092EH   LINE      ---      ---       #377
+      01000934H   LINE      ---      ---       #378
+      01000934H   LINE      ---      ---       #379
+      01000936H   LINE      ---      ---       #380
+      0100093CH   LINE      ---      ---       #381
+      0100093CH   LINE      ---      ---       #384
+      01000944H   LINE      ---      ---       #385
+      01000944H   LINE      ---      ---       #386
+      0100094AH   LINE      ---      ---       #387
+      0100094AH   LINE      ---      ---       #388
+      01000950H   LINE      ---      ---       #389
+      01000957H   LINE      ---      ---       #390
+      0100095FH   LINE      ---      ---       #391
+      0100095FH   LINE      ---      ---       #392
+      01000963H   LINE      ---      ---       #393
+      01000967H   LINE      ---      ---       #394
+      0100096BH   LINE      ---      ---       #395
+      0100096EH   LINE      ---      ---       #396
+      01000970H   LINE      ---      ---       #398
+      01000970H   LINE      ---      ---       #399
+      01000975H   LINE      ---      ---       #400
+      01000979H   LINE      ---      ---       #401
+      0100097DH   LINE      ---      ---       #402
+      01000980H   LINE      ---      ---       #403
+      01000980H   LINE      ---      ---       #404
+      0100098CH   LINE      ---      ---       #405
+      01000998H   LINE      ---      ---       #409
+      010009CAH   LINE      ---      ---       #412
+      010009CAH   LINE      ---      ---       #413
+      010009D0H   LINE      ---      ---       #414
+      010009D4H   LINE      ---      ---       #415
+      010009D8H   LINE      ---      ---       #416
+      010009DCH   LINE      ---      ---       #417
+      010009E4H   LINE      ---      ---       #418
+      010009E4H   LINE      ---      ---       #419
+      010009EBH   LINE      ---      ---       #420
+      010009EDH   LINE      ---      ---       #422
+      010009EDH   LINE      ---      ---       #423
+      010009F4H   LINE      ---      ---       #424
+      010009F4H   LINE      ---      ---       #425
+      010009F6H   LINE      ---      ---       #427
+      010009F6H   LINE      ---      ---       #428
+      010009FDH   LINE      ---      ---       #429
+      010009FDH   LINE      ---      ---       #433
+      01000A03H   LINE      ---      ---       #434
+      01000A1CH   LINE      ---      ---       #437
+      01000A1CH   LINE      ---      ---       #439
+      01000A1CH   LINE      ---      ---       #442
+      01000A24H   LINE      ---      ---       #443
+      01000A24H   LINE      ---      ---       #444
+      01000A36H   LINE      ---      ---       #445
+      01000A36H   LINE      ---      ---       #446
+      01000A60H   LINE      ---      ---       #448
+      01000A60H   LINE      ---      ---       #449
+      01000A66H   LINE      ---      ---       #451
+      01000A66H   LINE      ---      ---       #452
+      01000A6EH   LINE      ---      ---       #453
+      01000A6EH   LINE      ---      ---       #455
+      01000A7BH   LINE      ---      ---       #457
+      01000A83H   LINE      ---      ---       #458
+      01000A83H   LINE      ---      ---       #459
+      01000A86H   LINE      ---      ---       #460
+      01000A8AH   LINE      ---      ---       #461
+      01000A94H   LINE      ---      ---       #462
+      01000A94H   LINE      ---      ---       #463
+      01000A9CH   LINE      ---      ---       #464
+      01000A9CH   LINE      ---      ---       #465
+      01000A9FH   LINE      ---      ---       #466
+      01000AA5H   LINE      ---      ---       #467
+      01000AAFH   LINE      ---      ---       #468
+      01000AAFH   LINE      ---      ---       #469
+      01000AC2H   LINE      ---      ---       #470
+      01000AC2H   LINE      ---      ---       #471
+      01000AC7H   LINE      ---      ---       #472
+      01000ACBH   LINE      ---      ---       #473
+      01000AD1H   LINE      ---      ---       #474
+      01000AD1H   LINE      ---      ---       #475
+      01000AD3H   LINE      ---      ---       #476
+      01000AD9H   LINE      ---      ---       #477
+      01000ADBH   LINE      ---      ---       #479
+      01000AE1H   LINE      ---      ---       #480
+      01000AEBH   LINE      ---      ---       #481
+      01000AEBH   LINE      ---      ---       #483
+      01000AEBH   LINE      ---      ---       #484
+      01000AF1H   LINE      ---      ---       #485
+      01000B07H   LINE      ---      ---       #487
+      01000B0DH   LINE      ---      ---       #488
+      01000B1FH   LINE      ---      ---       #489
+      01000B27H   LINE      ---      ---       #490
+      01000B31H   LINE      ---      ---       #492
+      01000B36H   LINE      ---      ---       #494
+      01000B3BH   LINE      ---      ---       #495
+      01000B41H   LINE      ---      ---       #496
+      01000B41H   LINE      ---      ---       #497
+      01000B4BH   LINE      ---      ---       #498
+      01000B60H   LINE      ---      ---       #500
+      01000B7CH   LINE      ---      ---       #502
+      01000B90H   LINE      ---      ---       #503
+      01000B90H   LINE      ---      ---       #504
+      01000B9FH   LINE      ---      ---       #505
+      01000BAEH   LINE      ---      ---       #506
+      01000BB6H   LINE      ---      ---       #507
+      01000BB6H   LINE      ---      ---       #509
+      01000BD2H   LINE      ---      ---       #510
+      01000BDCH   LINE      ---      ---       #511
+      01000BDCH   LINE      ---      ---       #513
+      02004EC8H   SYMBOL    XDATA    VOID      temp
+      02004EC9H   SYMBOL    XDATA    VOID      i
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      010026FBH   BLOCK     CODE     ---       LVL=0
+      010026FBH   LINE      ---      ---       #517
+      01002706H   LINE      ---      ---       #518
+      01002706H   BLOCK     CODE     NEAR LAB  LVL=1
+      01002706H   LINE      ---      ---       #519
+      01002708H   LINE      ---      ---       #520
+      01002709H   LINE      ---      ---       #522
+      01002713H   LINE      ---      ---       #523
+      01002713H   LINE      ---      ---       #524
+      01002715H   LINE      ---      ---       #526
+      0100271EH   LINE      ---      ---       #527
+      0100271EH   LINE      ---      ---       #528
+      0100273AH   LINE      ---      ---       #530
+      0100273EH   LINE      ---      ---       #531
+      0100273EH   LINE      ---      ---       #532
+      01002744H   LINE      ---      ---       #534
+      0100274BH   LINE      ---      ---       #535
+      0100274EH   LINE      ---      ---       #536
+      01002761H   LINE      ---      ---       #537
+      01002761H   LINE      ---      ---       #538
+      01002766H   LINE      ---      ---       #539
+      0100276CH   LINE      ---      ---       #540
+      01002771H   LINE      ---      ---       #541
+      01002771H   LINE      ---      ---       #542
+      01002774H   LINE      ---      ---       #543
+      01002774H   LINE      ---      ---       #545
+      01002774H   LINE      ---      ---       #546
+      0100277BH   LINE      ---      ---       #547
+      0100277BH   LINE      ---      ---       #550
+      01002790H   LINE      ---      ---       #551
+      01002790H   LINE      ---      ---       #552
+      01002796H   LINE      ---      ---       #553
+      0100279BH   LINE      ---      ---       #554
+      010027A2H   LINE      ---      ---       #555
+      010027A5H   LINE      ---      ---       #556
+      010027A5H   LINE      ---      ---       #558
+      010027ACH   LINE      ---      ---       #559
+      010027AEH   LINE      ---      ---       #560
+      010027AEH   LINE      ---      ---       #562
+      010027AEH   LINE      ---      ---       #568
+      010027C6H   LINE      ---      ---       #569
+      010027C6H   LINE      ---      ---       #570
+      010027CCH   LINE      ---      ---       #571
+      010027D3H   LINE      ---      ---       #572
+      010027D6H   LINE      ---      ---       #573
+      010027E0H   LINE      ---      ---       #574
+      010027E0H   LINE      ---      ---       #575
+      010027E6H   LINE      ---      ---       #576
+      010027EBH   LINE      ---      ---       #577
+      010027EFH   LINE      ---      ---       #579
+      010027EFH   LINE      ---      ---       #580
+      010027F2H   LINE      ---      ---       #581
+      010027F2H   LINE      ---      ---       #583
+      0100280DH   LINE      ---      ---       #584
+      0100280DH   LINE      ---      ---       #585
+      01002813H   LINE      ---      ---       #586
+      0100281AH   LINE      ---      ---       #587
+      0100281DH   LINE      ---      ---       #588
+      01002840H   LINE      ---      ---       #589
+      01002840H   LINE      ---      ---       #590
+      01002845H   LINE      ---      ---       #591
+      0100284BH   LINE      ---      ---       #592
+      01002850H   LINE      ---      ---       #593
+      01002850H   LINE      ---      ---       #594
+      01002853H   LINE      ---      ---       #595
+      01002853H   LINE      ---      ---       #598
+      0100285AH   LINE      ---      ---       #599
+      0100285DH   LINE      ---      ---       #600
+      0100285DH   LINE      ---      ---       #601
+      0100285FH   LINE      ---      ---       #602
+      00000005H   SYMBOL    DATA     VOID      temp
+      00000004H   SYMBOL    DATA     VOID      i
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01002860H   BLOCK     CODE     ---       LVL=0
+      01002860H   LINE      ---      ---       #607
+      01002860H   LINE      ---      ---       #608
+      01002860H   LINE      ---      ---       #609
+      01002865H   LINE      ---      ---       #610
+      01002868H   LINE      ---      ---       #612
+      0100286CH   LINE      ---      ---       #613
+      0100286CH   LINE      ---      ---       #614
+      01002874H   LINE      ---      ---       #615
+      01002878H   LINE      ---      ---       #617
+      0100287EH   LINE      ---      ---       #618
+      0100287FH   LINE      ---      ---       #620
+      0100287FH   LINE      ---      ---       #621
+      01002885H   LINE      ---      ---       #622
+      01002885H   LINE      ---      ---       #624
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01002886H   BLOCK     CODE     ---       LVL=0
+      01002886H   LINE      ---      ---       #627
+      0100288AH   LINE      ---      ---       #628
+      0100288AH   BLOCK     CODE     NEAR LAB  LVL=1
+      0100288AH   LINE      ---      ---       #629
+      0100288FH   LINE      ---      ---       #631
+      01002893H   LINE      ---      ---       #632
+      01002898H   LINE      ---      ---       #634
+      0100289DH   LINE      ---      ---       #635
+      010028A4H   LINE      ---      ---       #636
+      010028A4H   LINE      ---      ---       #637
+      010028ACH   LINE      ---      ---       #638
+      010028B4H   LINE      ---      ---       #639
+      010028BAH   LINE      ---      ---       #640
+      010028C2H   LINE      ---      ---       #641
+      010028C8H   LINE      ---      ---       #642
+      010028D0H   LINE      ---      ---       #643
+      010028D6H   LINE      ---      ---       #644
+      010028DCH   LINE      ---      ---       #645
+      010028DCH   LINE      ---      ---       #646
+      010028DFH   LINE      ---      ---       #647
+      010028DFH   LINE      ---      ---       #648
+      010028E4H   LINE      ---      ---       #649
+      010028E4H   LINE      ---      ---       #650
+      010028ECH   LINE      ---      ---       #651
+      010028F1H   LINE      ---      ---       #652
+      010028F1H   LINE      ---      ---       #653
+      010028F1H   LINE      ---      ---       #654
+      010028FBH   LINE      ---      ---       #655
+      010028FBH   LINE      ---      ---       #656
+      01002903H   LINE      ---      ---       #657
+      01002903H   LINE      ---      ---       #658
+      01002909H   LINE      ---      ---       #659
+      0100290BH   LINE      ---      ---       #660
+      01002911H   LINE      ---      ---       #661
+      01002911H   LINE      ---      ---       #662
+      01002917H   LINE      ---      ---       #663
+      01002919H   LINE      ---      ---       #664
+      0100291FH   LINE      ---      ---       #665
+      0100291FH   LINE      ---      ---       #666
+      01002925H   LINE      ---      ---       #667
+      01002927H   LINE      ---      ---       #668
+      0100292DH   LINE      ---      ---       #669
+      0100292DH   LINE      ---      ---       #670
+      01002933H   LINE      ---      ---       #671
+      01002935H   LINE      ---      ---       #672
+      0100293BH   LINE      ---      ---       #673
+      0100293BH   LINE      ---      ---       #674
+      01002941H   LINE      ---      ---       #675
+      01002943H   LINE      ---      ---       #676
+      01002949H   LINE      ---      ---       #677
+      01002949H   LINE      ---      ---       #678
+      0100294DH   LINE      ---      ---       #679
+      0100294DH   LINE      ---      ---       #680
+      01002953H   LINE      ---      ---       #681
+      01002953H   LINE      ---      ---       #682
+      01002955H   LINE      ---      ---       #683
+      01002957H   LINE      ---      ---       #685
+      0100295DH   LINE      ---      ---       #687
+      0100296AH   LINE      ---      ---       #688
+      0100296AH   LINE      ---      ---       #689
+      01002970H   LINE      ---      ---       #690
+      01002972H   LINE      ---      ---       #691
+      01002988H   LINE      ---      ---       #692
+      01002988H   LINE      ---      ---       #693
+      010029A0H   LINE      ---      ---       #694
+      010029A6H   LINE      ---      ---       #695
+      010029A6H   LINE      ---      ---       #696
+      010029A6H   LINE      ---      ---       #697
+      010029ABH   LINE      ---      ---       #698
+      010029ABH   LINE      ---      ---       #699
+      010029ABH   LINE      ---      ---       #701
+      010029D3H   LINE      ---      ---       #702
+      010029D3H   LINE      ---      ---       #703
+      01002A0FH   LINE      ---      ---       #704
+      01002A0FH   LINE      ---      ---       #705
+      01002A0FH   LINE      ---      ---       #706
+      01002A15H   LINE      ---      ---       #707
+      01002A17H   LINE      ---      ---       #708
+      01002A17H   LINE      ---      ---       #709
+      01002A1DH   LINE      ---      ---       #710
+      01002A1FH   LINE      ---      ---       #711
+      01002A1FH   LINE      ---      ---       #712
+      01002A25H   LINE      ---      ---       #713
+      01002A27H   LINE      ---      ---       #714
+      01002A27H   LINE      ---      ---       #715
+      01002A2EH   LINE      ---      ---       #716
+      01002A2EH   LINE      ---      ---       #717
+      01002A36H   LINE      ---      ---       #718
+      01002A3AH   LINE      ---      ---       #719
+      01002A3AH   LINE      ---      ---       #720
+      01002A40H   LINE      ---      ---       #721
+      01002A40H   LINE      ---      ---       #722
+      01002A42H   LINE      ---      ---       #723
+      01002A47H   LINE      ---      ---       #724
+      01002A47H   LINE      ---      ---       #725
+      01002A4FH   LINE      ---      ---       #726
+      01002A51H   LINE      ---      ---       #727
+      01002A59H   LINE      ---      ---       #728
+      01002A59H   LINE      ---      ---       #729
+      01002A61H   LINE      ---      ---       #730
+      01002A65H   LINE      ---      ---       #731
+      01002A65H   LINE      ---      ---       #732
+      01002A6BH   LINE      ---      ---       #733
+      01002A6BH   LINE      ---      ---       #734
+      01002A6BH   LINE      ---      ---       #735
+      01002A70H   LINE      ---      ---       #736
+      01002A72H   LINE      ---      ---       #737
+      01002A72H   LINE      ---      ---       #738
+      01002A78H   LINE      ---      ---       #739
+      01002A78H   LINE      ---      ---       #740
+      01002A7EH   LINE      ---      ---       #741
+      01002A80H   LINE      ---      ---       #743
+      01002A80H   LINE      ---      ---       #744
+      01002A88H   LINE      ---      ---       #745
+      01002A8DH   LINE      ---      ---       #746
+      01002A8DH   LINE      ---      ---       #747
+      01002A8FH   LINE      ---      ---       #748
+      01002A8FH   LINE      ---      ---       #749
+      01002A95H   LINE      ---      ---       #750
+      01002A97H   LINE      ---      ---       #751
+      01002A97H   LINE      ---      ---       #752
+      01002A9DH   LINE      ---      ---       #753
+      01002A9FH   LINE      ---      ---       #754
+      01002A9FH   LINE      ---      ---       #755
+      01002AA5H   LINE      ---      ---       #756
+      01002AA7H   LINE      ---      ---       #757
+      01002AA7H   LINE      ---      ---       #758
+      01002AADH   LINE      ---      ---       #759
+      01002AAFH   LINE      ---      ---       #760
+      01002AAFH   LINE      ---      ---       #761
+      01002AB5H   LINE      ---      ---       #762
+      01002AB7H   LINE      ---      ---       #763
+      01002AB7H   LINE      ---      ---       #764
+      01002ABDH   LINE      ---      ---       #765
+      01002ABFH   LINE      ---      ---       #766
+      01002ABFH   LINE      ---      ---       #767
+      01002AC5H   LINE      ---      ---       #768
+      01002AC5H   LINE      ---      ---       #769
+      01002AC5H   LINE      ---      ---       #770
+      01002AC5H   LINE      ---      ---       #771
+      01002AC5H   LINE      ---      ---       #772
+      01002AC5H   LINE      ---      ---       #774
+      01002ACAH   LINE      ---      ---       #775
+      02004F02H   SYMBOL    XDATA    VOID      temp
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01000BDDH   BLOCK     CODE     ---       LVL=0
+      01000BDDH   LINE      ---      ---       #779
+      01000BE8H   LINE      ---      ---       #780
+      01000BE8H   BLOCK     CODE     NEAR LAB  LVL=1
+      01000BE8H   LINE      ---      ---       #781
+      01000BEBH   LINE      ---      ---       #783
+      01000BFCH   LINE      ---      ---       #784
+      01000BFCH   LINE      ---      ---       #785
+      01000C27H   LINE      ---      ---       #787
+      01000C27H   LINE      ---      ---       #789
+      01000C32H   LINE      ---      ---       #790
+      01000C32H   LINE      ---      ---       #791
+      01000C38H   LINE      ---      ---       #792
+      01000C3AH   LINE      ---      ---       #794
+      01000C40H   LINE      ---      ---       #795
+      01000C40H   LINE      ---      ---       #796
+      01000C45H   LINE      ---      ---       #797
+      01000C47H   LINE      ---      ---       #798
+      01000C4FH   LINE      ---      ---       #799
+      01000C4FH   LINE      ---      ---       #800
+      01000C54H   LINE      ---      ---       #801
+      01000C56H   LINE      ---      ---       #802
+      01000C5CH   LINE      ---      ---       #803
+      01000C5CH   LINE      ---      ---       #804
+      01000C61H   LINE      ---      ---       #805
+      01000C63H   LINE      ---      ---       #806
+      01000C6BH   LINE      ---      ---       #807
+      01000C6BH   LINE      ---      ---       #808
+      01000C70H   LINE      ---      ---       #809
+      01000C72H   LINE      ---      ---       #810
+      01000C78H   LINE      ---      ---       #811
+      01000C78H   LINE      ---      ---       #812
+      01000C7DH   LINE      ---      ---       #813
+      01000C7FH   LINE      ---      ---       #814
+      01000C87H   LINE      ---      ---       #815
+      01000C87H   LINE      ---      ---       #816
+      01000C8CH   LINE      ---      ---       #817
+      01000C8EH   LINE      ---      ---       #818
+      01000C94H   LINE      ---      ---       #819
+      01000C94H   LINE      ---      ---       #820
+      01000C99H   LINE      ---      ---       #821
+      01000C9BH   LINE      ---      ---       #822
+      01000CA3H   LINE      ---      ---       #823
+      01000CA3H   LINE      ---      ---       #824
+      01000CA9H   LINE      ---      ---       #825
+      01000CABH   LINE      ---      ---       #826
+      01000CB1H   LINE      ---      ---       #827
+      01000CB1H   LINE      ---      ---       #828
+      01000CB7H   LINE      ---      ---       #829
+      01000CB9H   LINE      ---      ---       #830
+      01000CC1H   LINE      ---      ---       #831
+      01000CC1H   LINE      ---      ---       #832
+      01000CC7H   LINE      ---      ---       #833
+      01000CC9H   LINE      ---      ---       #834
+      01000CCFH   LINE      ---      ---       #835
+      01000CCFH   LINE      ---      ---       #836
+      01000CD5H   LINE      ---      ---       #837
+      01000CD7H   LINE      ---      ---       #838
+      01000CDFH   LINE      ---      ---       #839
+      01000CDFH   LINE      ---      ---       #840
+      01000CE5H   LINE      ---      ---       #841
+      01000CE7H   LINE      ---      ---       #842
+      01000CEDH   LINE      ---      ---       #843
+      01000CEDH   LINE      ---      ---       #844
+      01000CF3H   LINE      ---      ---       #845
+      01000CF5H   LINE      ---      ---       #846
+      01000CFDH   LINE      ---      ---       #847
+      01000CFDH   LINE      ---      ---       #848
+      01000D03H   LINE      ---      ---       #849
+      01000D05H   LINE      ---      ---       #850
+      01000D0BH   LINE      ---      ---       #851
+      01000D0BH   LINE      ---      ---       #852
+      01000D11H   LINE      ---      ---       #853
+      01000D13H   LINE      ---      ---       #854
+      01000D1BH   LINE      ---      ---       #855
+      01000D1BH   LINE      ---      ---       #856
+      01000D21H   LINE      ---      ---       #857
+      01000D23H   LINE      ---      ---       #858
+      01000D29H   LINE      ---      ---       #859
+      01000D29H   LINE      ---      ---       #860
+      01000D2FH   LINE      ---      ---       #861
+      01000D31H   LINE      ---      ---       #862
+      01000D39H   LINE      ---      ---       #863
+      01000D39H   LINE      ---      ---       #864
+      01000D3EH   LINE      ---      ---       #865
+      01000D40H   LINE      ---      ---       #866
+      01000D46H   LINE      ---      ---       #867
+      01000D46H   LINE      ---      ---       #868
+      01000D4BH   LINE      ---      ---       #869
+      01000D4DH   LINE      ---      ---       #870
+      01000D55H   LINE      ---      ---       #871
+      01000D55H   LINE      ---      ---       #872
+      01000D5AH   LINE      ---      ---       #873
+      01000D5CH   LINE      ---      ---       #874
+      01000D62H   LINE      ---      ---       #875
+      01000D62H   LINE      ---      ---       #876
+      01000D67H   LINE      ---      ---       #877
+      01000D69H   LINE      ---      ---       #878
+      01000D71H   LINE      ---      ---       #879
+      01000D71H   LINE      ---      ---       #880
+      01000D77H   LINE      ---      ---       #881
+      01000D79H   LINE      ---      ---       #882
+      01000D7FH   LINE      ---      ---       #883
+      01000D7FH   LINE      ---      ---       #884
+      01000D85H   LINE      ---      ---       #885
+      01000D87H   LINE      ---      ---       #886
+      01000D8FH   LINE      ---      ---       #887
+      01000D8FH   LINE      ---      ---       #888
+      01000D93H   LINE      ---      ---       #889
+      01000D95H   LINE      ---      ---       #890
+      01000D9BH   LINE      ---      ---       #891
+      01000D9BH   LINE      ---      ---       #892
+      01000D9FH   LINE      ---      ---       #893
+      01000DA1H   LINE      ---      ---       #894
+      01000DA6H   LINE      ---      ---       #895
+      01000DA6H   LINE      ---      ---       #896
+      01000DAAH   LINE      ---      ---       #897
+      01000DAAH   LINE      ---      ---       #899
+      01000DB2H   LINE      ---      ---       #900
+      01000DB2H   LINE      ---      ---       #901
+      01000DD2H   LINE      ---      ---       #902
+      01000DD6H   LINE      ---      ---       #903
+      01000DD6H   LINE      ---      ---       #904
+      01000DD6H   LINE      ---      ---       #905
+      01000DDEH   LINE      ---      ---       #906
+      02004ED7H   SYMBOL    XDATA    VOID      i
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      ---         MODULE    ---      ---       KEYSCAN
+      02004EA4H   PUBLIC    XDATA    ---       ksEvtPool
+      01002ACBH   PUBLIC    CODE     ---       KS_GetCurrentEvt
+      01002D3BH   PUBLIC    CODE     ---       _array_is_empty
+      01002EDEH   PUBLIC    CODE     ---       KS_ScanMatrix
+      01001D8BH   PUBLIC    CODE     ---       KS_Unistall
+      010018F4H   PUBLIC    CODE     ---       KS_Initialize
+
+      01002D2DH   BLOCK     CODE     ---       LVL=0
+      01002D2DH   LINE      ---      ---       #24
+      01002D2DH   LINE      ---      ---       #25
+      01002D2DH   BLOCK     CODE     NEAR LAB  LVL=1
+      01002D2DH   LINE      ---      ---       #27
+      01002D32H   LINE      ---      ---       #28
+      01002D35H   LINE      ---      ---       #29
+      01002D38H   LINE      ---      ---       #30
+      01002D3AH   LINE      ---      ---       #31
+      00000006H   SYMBOL    DATA     VOID      c
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01002DB5H   BLOCK     CODE     ---       LVL=0
+      01002DB5H   LINE      ---      ---       #35
+      01002DB5H   LINE      ---      ---       #36
+      01002DB5H   BLOCK     CODE     NEAR LAB  LVL=1
+      01002DB5H   LINE      ---      ---       #37
+      01002DB7H   LINE      ---      ---       #39
+      01002DCEH   LINE      ---      ---       #40
+      01002DCEH   LINE      ---      ---       #41
+      01002DE7H   LINE      ---      ---       #43
+      01002DE7H   LINE      ---      ---       #89
+      01002DF3H   LINE      ---      ---       #90
+      01002DF3H   LINE      ---      ---       #91
+      01002E02H   LINE      ---      ---       #92
+      01002E02H   LINE      ---      ---       #93
+      01002E05H   LINE      ---      ---       #94
+      01002E05H   LINE      ---      ---       #95
+      01002E0CH   LINE      ---      ---       #96
+      01002E18H   LINE      ---      ---       #97
+      01002E19H   LINE      ---      ---       #98
+      01002E19H   LINE      ---      ---       #99
+      01002E1CH   LINE      ---      ---       #100
+      00000006H   SYMBOL    DATA     VOID      i
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01002E1DH   BLOCK     CODE     ---       LVL=0
+      01002E1DH   LINE      ---      ---       #102
+      01002E1DH   LINE      ---      ---       #103
+      01002E1DH   BLOCK     CODE     NEAR LAB  LVL=1
+      01002E1DH   LINE      ---      ---       #104
+      01002E1FH   LINE      ---      ---       #105
+      01002E20H   LINE      ---      ---       #107
+      01002E2EH   LINE      ---      ---       #108
+      01002E2EH   LINE      ---      ---       #109
+      01002E36H   LINE      ---      ---       #110
+      01002E36H   LINE      ---      ---       #111
+      01002E39H   LINE      ---      ---       #112
+      01002E39H   LINE      ---      ---       #113
+      01002E3BH   LINE      ---      ---       #115
+      01002E41H   LINE      ---      ---       #117
+      01002E58H   LINE      ---      ---       #118
+      01002E58H   LINE      ---      ---       #119
+      01002E72H   LINE      ---      ---       #121
+      01002E72H   LINE      ---      ---       #166
+      01002E7EH   LINE      ---      ---       #167
+      01002E7EH   LINE      ---      ---       #168
+      01002E81H   LINE      ---      ---       #169
+      01002E81H   LINE      ---      ---       #170
+      01002E8FH   LINE      ---      ---       #171
+      01002E94H   LINE      ---      ---       #172
+      01002EA0H   LINE      ---      ---       #173
+      01002EA0H   LINE      ---      ---       #174
+      01002EA2H   LINE      ---      ---       #175
+      01002EA2H   LINE      ---      ---       #176
+      01002EA4H   LINE      ---      ---       #178
+      01002EA4H   LINE      ---      ---       #179
+      01002EBCH   LINE      ---      ---       #180
+      01002EC9H   LINE      ---      ---       #181
+      01002EC9H   LINE      ---      ---       #182
+      01002ECEH   LINE      ---      ---       #183
+      01002EDAH   LINE      ---      ---       #184
+      01002EDAH   LINE      ---      ---       #185
+      01002EDAH   LINE      ---      ---       #186
+      01002EDDH   LINE      ---      ---       #187
+      00000006H   SYMBOL    DATA     VOID      i
+      00000005H   SYMBOL    DATA     VOID      found
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01001901H   BLOCK     CODE     ---       LVL=0
+      01001901H   LINE      ---      ---       #189
+      01001901H   LINE      ---      ---       #190
+      01001901H   BLOCK     CODE     NEAR LAB  LVL=1
+      01001901H   LINE      ---      ---       #191
+      01001906H   LINE      ---      ---       #193
+      01001915H   LINE      ---      ---       #194
+      01001919H   LINE      ---      ---       #195
+      01001921H   LINE      ---      ---       #196
+      02004F03H   SYMBOL    XDATA    VOID      i
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      010018D6H   BLOCK     CODE     ---       LVL=0
+      010018D6H   LINE      ---      ---       #198
+      010018D6H   LINE      ---      ---       #199
+      010018D6H   BLOCK     CODE     NEAR LAB  LVL=1
+      010018D6H   LINE      ---      ---       #200
+      010018DBH   LINE      ---      ---       #201
+      010018E7H   LINE      ---      ---       #202
+      010018EBH   LINE      ---      ---       #203
+      010018F3H   LINE      ---      ---       #204
+      02004F04H   SYMBOL    XDATA    VOID      i
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      010018F4H   BLOCK     CODE     ---       LVL=0
+      010018F4H   LINE      ---      ---       #206
+      010018F4H   LINE      ---      ---       #207
+      010018F4H   LINE      ---      ---       #208
+      010018F9H   LINE      ---      ---       #209
+      010018FBH   LINE      ---      ---       #210
+      010018FDH   LINE      ---      ---       #211
+      010018FFH   LINE      ---      ---       #212
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001D8BH   BLOCK     CODE     ---       LVL=0
+      01001D8BH   LINE      ---      ---       #215
+      01001D8BH   LINE      ---      ---       #216
+      01001D8BH   BLOCK     CODE     NEAR LAB  LVL=1
+      01001D8BH   LINE      ---      ---       #217
+      01001D8DH   LINE      ---      ---       #218
+      01001D91H   LINE      ---      ---       #219
+      01001D92H   LINE      ---      ---       #220
+      01001D93H   LINE      ---      ---       #221
+      01001D9AH   LINE      ---      ---       #222
+      01001DA3H   LINE      ---      ---       #223
+      01001DB2H   LINE      ---      ---       #224
+      01001DC5H   LINE      ---      ---       #225
+      01001DD2H   LINE      ---      ---       #226
+      01001DDFH   LINE      ---      ---       #227
+      01001DE2H   LINE      ---      ---       #229
+      01001DE5H   LINE      ---      ---       #231
+      01001DEDH   LINE      ---      ---       #233
+      01001DF3H   LINE      ---      ---       #234
+      01001DF3H   LINE      ---      ---       #235
+      01001DF7H   LINE      ---      ---       #236
+      01001DFBH   LINE      ---      ---       #237
+      01001DFFH   LINE      ---      ---       #238
+      01001E03H   LINE      ---      ---       #239
+      01001E07H   LINE      ---      ---       #240
+      01001E0BH   LINE      ---      ---       #241
+      01001E0FH   LINE      ---      ---       #242
+      01001E13H   LINE      ---      ---       #243
+      01001E13H   LINE      ---      ---       #245
+      01001E13H   LINE      ---      ---       #246
+      01001E1CH   LINE      ---      ---       #247
+      01001E22H   LINE      ---      ---       #248
+      01001E22H   LINE      ---      ---       #250
+      00000007H   SYMBOL    DATA     VOID      i
+      02004F05H   SYMBOL    XDATA    VOID      temp
+      00000006H   SYMBOL    DATA     VOID      tgroup
+      00000005H   SYMBOL    DATA     VOID      tgpionum
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01002EDEH   BLOCK     CODE     ---       LVL=0
+      01002EDEH   LINE      ---      ---       #253
+      01002EDEH   LINE      ---      ---       #254
+      01002EDEH   BLOCK     CODE     NEAR LAB  LVL=1
+      01002EDEH   LINE      ---      ---       #255
+      01002EE0H   LINE      ---      ---       #256
+      01002EE4H   LINE      ---      ---       #257
+      01002EE5H   LINE      ---      ---       #258
+      01002EE6H   LINE      ---      ---       #259
+      01002EE8H   LINE      ---      ---       #260
+      01002EEAH   LINE      ---      ---       #261
+      01002EF1H   LINE      ---      ---       #262
+      01002EFAH   LINE      ---      ---       #263
+      01002F09H   LINE      ---      ---       #264
+      01002F69H   LINE      ---      ---       #265
+      01002F6CH   LINE      ---      ---       #267
+      01002F75H   LINE      ---      ---       #268
+      01002F7EH   LINE      ---      ---       #269
+      01002F8DH   LINE      ---      ---       #270
+      01002FEDH   LINE      ---      ---       #271
+      01002FF0H   LINE      ---      ---       #273
+      01002FF9H   LINE      ---      ---       #274
+      01003013H   LINE      ---      ---       #275
+      01003036H   LINE      ---      ---       #276
+      01003036H   LINE      ---      ---       #277
+      01003039H   LINE      ---      ---       #278
+      00000007H   SYMBOL    DATA     VOID      i
+      02004EE6H   SYMBOL    XDATA    VOID      j
+      00000006H   SYMBOL    DATA     VOID      tgroup
+      00000005H   SYMBOL    DATA     VOID      tgpionum
+      02004EE7H   SYMBOL    XDATA    VOID      temp
+      02004EE8H   SYMBOL    XDATA    VOID      check
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01002D3BH   BLOCK     CODE     ---       LVL=0
+      01002D3BH   LINE      ---      ---       #280
+      01002D46H   LINE      ---      ---       #281
+      01002D46H   BLOCK     CODE     NEAR LAB  LVL=1
+      01002D46H   LINE      ---      ---       #283
+      01002D4DH   LINE      ---      ---       #284
+      01002D4DH   LINE      ---      ---       #285
+      01002D62H   LINE      ---      ---       #286
+      01002D65H   LINE      ---      ---       #287
+      01002D68H   LINE      ---      ---       #288
+      01002D6AH   LINE      ---      ---       #289
+      00000007H   SYMBOL    DATA     VOID      i
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01002ACBH   BLOCK     CODE     ---       LVL=0
+      01002ACBH   LINE      ---      ---       #292
+      01002ACBH   LINE      ---      ---       #293
+      01002ACBH   BLOCK     CODE     NEAR LAB  LVL=1
+      01002ACBH   LINE      ---      ---       #295
+      01002AD0H   LINE      ---      ---       #296
+      01002AD2H   LINE      ---      ---       #297
+      01002AD4H   LINE      ---      ---       #298
+      01002AD6H   LINE      ---      ---       #299
+      01002AD8H   LINE      ---      ---       #300
+      01002ADAH   LINE      ---      ---       #301
+      01002ADCH   LINE      ---      ---       #302
+      01002ADEH   LINE      ---      ---       #303
+      01002AE0H   LINE      ---      ---       #304
+      01002AE2H   LINE      ---      ---       #305
+      01002AE4H   LINE      ---      ---       #307
+      01002AE6H   LINE      ---      ---       #309
+      01002B14H   LINE      ---      ---       #311
+      01002B14H   LINE      ---      ---       #312
+      01002B1BH   LINE      ---      ---       #313
+      01002B21H   LINE      ---      ---       #314
+      01002B23H   LINE      ---      ---       #316
+      01002B23H   LINE      ---      ---       #317
+      01002B2AH   LINE      ---      ---       #318
+      01002B2FH   LINE      ---      ---       #319
+      01002B2FH   LINE      ---      ---       #321
+      01002B41H   LINE      ---      ---       #322
+      01002B41H   LINE      ---      ---       #323
+      01002B50H   LINE      ---      ---       #324
+      01002B59H   LINE      ---      ---       #325
+      01002B64H   LINE      ---      ---       #326
+      01002B64H   LINE      ---      ---       #327
+      01002B77H   LINE      ---      ---       #328
+      01002B77H   LINE      ---      ---       #329
+      01002B92H   LINE      ---      ---       #330
+      01002B92H   LINE      ---      ---       #331
+      01002BA2H   LINE      ---      ---       #332
+      01002BA2H   LINE      ---      ---       #333
+      01002BABH   LINE      ---      ---       #334
+      01002BABH   LINE      ---      ---       #335
+      01002BDAH   LINE      ---      ---       #336
+      01002BDAH   LINE      ---      ---       #337
+      01002BE0H   LINE      ---      ---       #338
+      01002BE2H   LINE      ---      ---       #339
+      01002BE2H   LINE      ---      ---       #340
+      01002BE2H   LINE      ---      ---       #341
+      01002BEAH   LINE      ---      ---       #342
+      01002BEAH   LINE      ---      ---       #343
+      01002BF2H   LINE      ---      ---       #344
+      01002BF2H   LINE      ---      ---       #346
+      01002BF9H   LINE      ---      ---       #347
+      01002BF9H   LINE      ---      ---       #348
+      01002C01H   LINE      ---      ---       #349
+      01002C01H   LINE      ---      ---       #350
+      01002C09H   LINE      ---      ---       #351
+      01002C11H   LINE      ---      ---       #353
+      01002C23H   LINE      ---      ---       #354
+      01002C23H   LINE      ---      ---       #355
+      01002C43H   LINE      ---      ---       #356
+      01002C52H   LINE      ---      ---       #357
+      01002C5AH   LINE      ---      ---       #358
+      01002C5AH   LINE      ---      ---       #359
+      01002C5AH   LINE      ---      ---       #360
+      01002C5AH   LINE      ---      ---       #362
+      01002C5AH   LINE      ---      ---       #364
+      01002C60H   LINE      ---      ---       #365
+      01002C67H   LINE      ---      ---       #366
+      01002C83H   LINE      ---      ---       #367
+      01002C96H   LINE      ---      ---       #368
+      01002C96H   LINE      ---      ---       #369
+      01002C9DH   LINE      ---      ---       #370
+      01002C9DH   LINE      ---      ---       #371
+      01002CAEH   LINE      ---      ---       #372
+      01002CC1H   LINE      ---      ---       #373
+      01002CC8H   LINE      ---      ---       #374
+      01002CC8H   LINE      ---      ---       #375
+      01002CCFH   LINE      ---      ---       #376
+      01002CD1H   LINE      ---      ---       #378
+      01002CD1H   LINE      ---      ---       #379
+      01002CD8H   LINE      ---      ---       #380
+      01002CD8H   LINE      ---      ---       #381
+      01002CD8H   LINE      ---      ---       #382
+      01002CE0H   LINE      ---      ---       #383
+      01002CE8H   LINE      ---      ---       #384
+      01002CF0H   LINE      ---      ---       #385
+      01002CF6H   LINE      ---      ---       #386
+      01002CF6H   LINE      ---      ---       #387
+      01002CFEH   LINE      ---      ---       #389
+      01002D0EH   LINE      ---      ---       #390
+      01002D0EH   LINE      ---      ---       #391
+      01002D11H   LINE      ---      ---       #392
+      01002D11H   LINE      ---      ---       #395
+      01002D1FH   LINE      ---      ---       #396
+      01002D1FH   LINE      ---      ---       #397
+      01002D26H   LINE      ---      ---       #398
+      01002D26H   LINE      ---      ---       #400
+      01002D26H   LINE      ---      ---       #401
+      01002D2CH   LINE      ---      ---       #402
+      01002D2CH   LINE      ---      ---       #405
+      02004E88H   SYMBOL    XDATA    VOID      i
+      02004E89H   SYMBOL    XDATA    VOID      j
+      02004E8AH   SYMBOL    XDATA    VOID      k
+      02004E8BH   SYMBOL    XDATA    VOID      temp
+      02004E8CH   SYMBOL    XDATA    VOID      flag
+      02004E8DH   SYMBOL    XDATA    VOID      offset
+      02004E8EH   SYMBOL    XDATA    VOID      state
+      02004E8FH   SYMBOL    XDATA    VOID      keyCounttemp
+      02004E90H   SYMBOL    XDATA    VOID      key_value_temp
+      02004E91H   SYMBOL    XDATA    VOID      ghost
+      02004E92H   SYMBOL    XDATA    VOID      rawCount
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      ---         MODULE    ---      ---       LED
+      010011C4H   PUBLIC    CODE     ---       LED_handle
+      010017C8H   PUBLIC    CODE     ---       LED_device_poweroff
+      010017B0H   PUBLIC    CODE     ---       LED_device_poweron
+      010017F0H   PUBLIC    CODE     ---       LED_all_shutdown
+
+      010017F0H   BLOCK     CODE     ---       LVL=0
+      010017F0H   LINE      ---      ---       #4
+      010017F0H   LINE      ---      ---       #5
+      010017F0H   LINE      ---      ---       #7
+      010017F7H   LINE      ---      ---       #8
+      010017FEH   LINE      ---      ---       #9
+      01001804H   LINE      ---      ---       #10
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010017B0H   BLOCK     CODE     ---       LVL=0
+      010017B0H   LINE      ---      ---       #15
+      010017B0H   LINE      ---      ---       #16
+      010017B0H   LINE      ---      ---       #38
+      010017B6H   LINE      ---      ---       #39
+      010017BCH   LINE      ---      ---       #40
+      010017C2H   LINE      ---      ---       #41
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010017C8H   BLOCK     CODE     ---       LVL=0
+      010017C8H   LINE      ---      ---       #47
+      010017C8H   LINE      ---      ---       #48
+      010017C8H   LINE      ---      ---       #68
+      010017CEH   LINE      ---      ---       #69
+      010017D4H   LINE      ---      ---       #70
+      010017DAH   LINE      ---      ---       #71
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010011C4H   BLOCK     CODE     ---       LVL=0
+      010011C4H   LINE      ---      ---       #76
+      010011C4H   LINE      ---      ---       #77
+      010011C4H   LINE      ---      ---       #78
+      010011CEH   LINE      ---      ---       #81
+      010011DEH   LINE      ---      ---       #82
+      010011DEH   LINE      ---      ---       #84
+      010011E6H   LINE      ---      ---       #85
+      010011E6H   LINE      ---      ---       #86
+      010011E8H   LINE      ---      ---       #87
+      010011EAH   LINE      ---      ---       #88
+      010011F2H   LINE      ---      ---       #89
+      010011F2H   LINE      ---      ---       #90
+      010011F8H   LINE      ---      ---       #91
+      010011F8H   LINE      ---      ---       #92
+      010011FEH   LINE      ---      ---       #93
+      01001204H   LINE      ---      ---       #94
+      01001204H   LINE      ---      ---       #95
+      01001206H   LINE      ---      ---       #97
+      01001206H   LINE      ---      ---       #98
+      0100120EH   LINE      ---      ---       #99
+      0100120EH   LINE      ---      ---       #100
+      0100120FH   LINE      ---      ---       #101
+      01001213H   LINE      ---      ---       #102
+      01001219H   LINE      ---      ---       #103
+      01001219H   LINE      ---      ---       #104
+      01001219H   LINE      ---      ---       #107
+      01001228H   LINE      ---      ---       #108
+      01001228H   LINE      ---      ---       #109
+      01001236H   LINE      ---      ---       #110
+      01001236H   LINE      ---      ---       #111
+      0100123AH   LINE      ---      ---       #112
+      0100123AH   LINE      ---      ---       #113
+      01001240H   LINE      ---      ---       #114
+      01001246H   LINE      ---      ---       #115
+      01001248H   LINE      ---      ---       #117
+      01001248H   LINE      ---      ---       #118
+      0100124EH   LINE      ---      ---       #119
+      01001253H   LINE      ---      ---       #120
+      01001253H   LINE      ---      ---       #122
+      0100125AH   LINE      ---      ---       #123
+      0100125AH   LINE      ---      ---       #124
+      01001260H   LINE      ---      ---       #125
+      01001266H   LINE      ---      ---       #126
+      01001268H   LINE      ---      ---       #128
+      01001268H   LINE      ---      ---       #129
+      0100126EH   LINE      ---      ---       #130
+      01001273H   LINE      ---      ---       #131
+      01001273H   LINE      ---      ---       #134
+      0100127AH   LINE      ---      ---       #135
+      0100127AH   LINE      ---      ---       #136
+      01001280H   LINE      ---      ---       #137
+      0100128CH   LINE      ---      ---       #138
+      01001292H   LINE      ---      ---       #139
+      01001294H   LINE      ---      ---       #141
+      01001294H   LINE      ---      ---       #142
+      010012A0H   LINE      ---      ---       #143
+      010012A6H   LINE      ---      ---       #144
+      010012ABH   LINE      ---      ---       #145
+      010012ABH   LINE      ---      ---       #146
+      010012B0H   LINE      ---      ---       #147
+      010012B8H   LINE      ---      ---       #148
+      010012B8H   LINE      ---      ---       #149
+      010012B9H   LINE      ---      ---       #151
+      010012B9H   LINE      ---      ---       #152
+      010012BFH   LINE      ---      ---       #154
+      010012BFH   LINE      ---      ---       #155
+      010012BFH   LINE      ---      ---       #157
+      010012BFH   LINE      ---      ---       #158
+      010012C5H   LINE      ---      ---       #160
+      010012C5H   LINE      ---      ---       #162
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      ---         MODULE    ---      ---       SYS
+      01001D3CH   PUBLIC    CODE     ---       YC_System_Main
+      010019F0H   PUBLIC    CODE     ---       kb_button_press_timer500ms
+      010022B9H   PUBLIC    CODE     ---       YC_pairing_timerout_500ms
+      0100225FH   PUBLIC    CODE     ---       YC_wait_disconnect_timer500ms
+      01002334H   PUBLIC    CODE     ---       YC_connect_timeout_500ms
+      010010E9H   PUBLIC    CODE     ---       LED_timer500ms
+      01001D33H   PUBLIC    CODE     ---       System_Reset_Connect
+      01002433H   PUBLIC    CODE     ---       System_G24_long_lpm
+      0100178FH   PUBLIC    CODE     ---       System_long_sleep
+      0100304DH   PUBLIC    CODE     ---       System_Software_init
+
+      01000E26H   BLOCK     CODE     ---       LVL=0
+      01000E26H   LINE      ---      ---       #11
+      01000E26H   LINE      ---      ---       #12
+      01000E26H   LINE      ---      ---       #13
+      01000E32H   LINE      ---      ---       #14
+      01000E3EH   LINE      ---      ---       #15
+      01000E4AH   LINE      ---      ---       #16
+      01000E56H   LINE      ---      ---       #17
+      01000E62H   LINE      ---      ---       #18
+      01000E6EH   LINE      ---      ---       #20
+      01000E73H   LINE      ---      ---       #21
+      01000E77H   LINE      ---      ---       #23
+      01000E7BH   LINE      ---      ---       #24
+      01000E7FH   LINE      ---      ---       #25
+      01000E83H   LINE      ---      ---       #26
+      01000E87H   LINE      ---      ---       #27
+      01000E8BH   LINE      ---      ---       #28
+      01000E8FH   LINE      ---      ---       #29
+      01000E93H   LINE      ---      ---       #30
+      01000E97H   LINE      ---      ---       #31
+      01000E9BH   LINE      ---      ---       #32
+      01000E9FH   LINE      ---      ---       #33
+      01000EA3H   LINE      ---      ---       #34
+      01000EA7H   LINE      ---      ---       #36
+      01000EABH   LINE      ---      ---       #37
+      01000EB1H   LINE      ---      ---       #38
+      01000EB5H   LINE      ---      ---       #39
+      01000EBAH   LINE      ---      ---       #40
+      01000EBEH   LINE      ---      ---       #41
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      0100303AH   BLOCK     CODE     ---       LVL=0
+      0100303AH   LINE      ---      ---       #43
+      0100303AH   LINE      ---      ---       #44
+      0100303AH   LINE      ---      ---       #45
+      01003040H   LINE      ---      ---       #46
+      01003043H   LINE      ---      ---       #47
+      01003045H   LINE      ---      ---       #48
+      01003047H   LINE      ---      ---       #49
+      01003049H   LINE      ---      ---       #50
+      0100304CH   LINE      ---      ---       #51
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010017EAH   BLOCK     CODE     ---       LVL=0
+      010017EAH   LINE      ---      ---       #53
+      010017EAH   LINE      ---      ---       #54
+      010017EAH   LINE      ---      ---       #55
+      010017EDH   LINE      ---      ---       #56
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      0100304DH   BLOCK     CODE     ---       LVL=0
+      0100304DH   LINE      ---      ---       #61
+      0100304DH   LINE      ---      ---       #62
+      0100304DH   LINE      ---      ---       #63
+      01003050H   LINE      ---      ---       #64
+      01003052H   LINE      ---      ---       #65
+      01003058H   LINE      ---      ---       #66
+      0100305EH   LINE      ---      ---       #68
+      01003063H   LINE      ---      ---       #69
+      01003069H   LINE      ---      ---       #70
+      01003071H   LINE      ---      ---       #71
+      01003079H   LINE      ---      ---       #72
+      01003081H   LINE      ---      ---       #73
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001D33H   BLOCK     CODE     ---       LVL=0
+      01001D33H   LINE      ---      ---       #75
+      01001D33H   LINE      ---      ---       #76
+      01001D33H   LINE      ---      ---       #77
+      01001D39H   LINE      ---      ---       #78
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      0100178FH   BLOCK     CODE     ---       LVL=0
+      0100178FH   LINE      ---      ---       #81
+      0100178FH   LINE      ---      ---       #82
+      0100178FH   LINE      ---      ---       #83
+      01001794H   LINE      ---      ---       #84
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01002433H   BLOCK     CODE     ---       LVL=0
+      01002433H   LINE      ---      ---       #87
+      01002433H   LINE      ---      ---       #88
+      01002433H   LINE      ---      ---       #89
+      01002436H   LINE      ---      ---       #90
+      0100243CH   LINE      ---      ---       #91
+      01002442H   LINE      ---      ---       #93
+      01002447H   LINE      ---      ---       #94
+      01002449H   LINE      ---      ---       #95
+      0100244BH   LINE      ---      ---       #96
+      01002451H   LINE      ---      ---       #97
+      01002455H   LINE      ---      ---       #99
+      0100245BH   LINE      ---      ---       #100
+      0100245DH   LINE      ---      ---       #101
+      0100245FH   LINE      ---      ---       #102
+      01002461H   LINE      ---      ---       #103
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001D33H   BLOCK     CODE     ---       LVL=0
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010031A1H   BLOCK     CODE     ---       LVL=0
+      010031A1H   LINE      ---      ---       #115
+      010031A6H   BLOCK     CODE     NEAR LAB  LVL=1
+      010031A6H   LINE      ---      ---       #117
+      010031B0H   LINE      ---      ---       #119
+      010031B0H   LINE      ---      ---       #121
+      010031B0H   LINE      ---      ---       #122
+      02004EFBH   SYMBOL    XDATA    VOID      temp
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      010014C8H   BLOCK     CODE     ---       LVL=0
+      010014C8H   LINE      ---      ---       #124
+      010014CDH   LINE      ---      ---       #125
+      010014CDH   LINE      ---      ---       #127
+      010014FEH   LINE      ---      ---       #128
+      010014FEH   LINE      ---      ---       #129
+      010014FEH   LINE      ---      ---       #130
+      010014FEH   LINE      ---      ---       #131
+      01001500H   LINE      ---      ---       #132
+      01001503H   LINE      ---      ---       #133
+      01001514H   LINE      ---      ---       #134
+      01001521H   LINE      ---      ---       #135
+      01001523H   LINE      ---      ---       #136
+      0100152BH   LINE      ---      ---       #137
+      0100152DH   LINE      ---      ---       #138
+      01001531H   LINE      ---      ---       #139
+      01001542H   LINE      ---      ---       #140
+      0100154EH   LINE      ---      ---       #141
+      0100154EH   LINE      ---      ---       #142
+      01001558H   LINE      ---      ---       #143
+      01001562H   LINE      ---      ---       #144
+      01001562H   LINE      ---      ---       #145
+      01001565H   LINE      ---      ---       #146
+      01001565H   LINE      ---      ---       #147
+      01001565H   LINE      ---      ---       #148
+      01001568H   LINE      ---      ---       #149
+      0100156BH   LINE      ---      ---       #150
+      01001570H   LINE      ---      ---       #151
+      01001571H   LINE      ---      ---       #154
+      01001571H   LINE      ---      ---       #155
+      01001571H   LINE      ---      ---       #156
+      0100158BH   LINE      ---      ---       #157
+      0100158BH   LINE      ---      ---       #158
+      010015A1H   LINE      ---      ---       #159
+      010015A5H   LINE      ---      ---       #160
+      010015ABH   LINE      ---      ---       #161
+      010015BCH   LINE      ---      ---       #162
+      010015C2H   LINE      ---      ---       #163
+      010015C2H   LINE      ---      ---       #164
+      010015C2H   LINE      ---      ---       #165
+      010015C2H   LINE      ---      ---       #166
+      010015CAH   LINE      ---      ---       #167
+      010015CAH   LINE      ---      ---       #170
+      010015CAH   LINE      ---      ---       #171
+      010015CAH   LINE      ---      ---       #172
+      010015D0H   LINE      ---      ---       #173
+      010015D3H   LINE      ---      ---       #174
+      010015D5H   LINE      ---      ---       #175
+      010015DAH   LINE      ---      ---       #176
+      010015DEH   LINE      ---      ---       #177
+      010015E4H   LINE      ---      ---       #178
+      010015E8H   LINE      ---      ---       #179
+      010015EEH   LINE      ---      ---       #180
+      010015F4H   LINE      ---      ---       #182
+      010015FCH   LINE      ---      ---       #183
+      010015FCH   LINE      ---      ---       #184
+      01001600H   LINE      ---      ---       #185
+      01001604H   LINE      ---      ---       #186
+      01001608H   LINE      ---      ---       #187
+      0100160EH   LINE      ---      ---       #188
+      0100162AH   LINE      ---      ---       #190
+      0100162AH   LINE      ---      ---       #191
+      01001630H   LINE      ---      ---       #192
+      01001633H   LINE      ---      ---       #193
+      01001636H   LINE      ---      ---       #194
+      01001636H   LINE      ---      ---       #195
+      01001636H   LINE      ---      ---       #197
+      01001636H   LINE      ---      ---       #198
+      0100163EH   LINE      ---      ---       #200
+      0100163EH   LINE      ---      ---       #201
+      0100163FH   LINE      ---      ---       #203
+      0100163FH   LINE      ---      ---       #204
+      01001644H   LINE      ---      ---       #205
+      01001646H   LINE      ---      ---       #206
+      0100164CH   LINE      ---      ---       #207
+      01001651H   LINE      ---      ---       #209
+      01001657H   LINE      ---      ---       #210
+      01001657H   LINE      ---      ---       #211
+      01001659H   LINE      ---      ---       #212
+      01001660H   LINE      ---      ---       #213
+      01001660H   LINE      ---      ---       #214
+      01001660H   LINE      ---      ---       #216
+      01001668H   LINE      ---      ---       #217
+      01001668H   LINE      ---      ---       #218
+      01001669H   LINE      ---      ---       #219
+      0100166BH   LINE      ---      ---       #220
+      0100166BH   LINE      ---      ---       #221
+      0100166BH   LINE      ---      ---       #222
+      01001673H   LINE      ---      ---       #223
+      01001673H   LINE      ---      ---       #224
+      0100167BH   LINE      ---      ---       #225
+      0100167BH   LINE      ---      ---       #226
+      0100167BH   LINE      ---      ---       #231
+      0100167BH   LINE      ---      ---       #232
+      01001681H   LINE      ---      ---       #233
+      01001685H   LINE      ---      ---       #234
+      01001688H   LINE      ---      ---       #235
+      0100168AH   LINE      ---      ---       #236
+      0100168EH   LINE      ---      ---       #237
+      01001692H   LINE      ---      ---       #238
+      01001698H   LINE      ---      ---       #239
+      01001698H   LINE      ---      ---       #240
+      0100169DH   LINE      ---      ---       #241
+      010016A1H   LINE      ---      ---       #242
+      010016B4H   LINE      ---      ---       #243
+      010016CCH   LINE      ---      ---       #244
+      010016CCH   LINE      ---      ---       #245
+      010016D2H   LINE      ---      ---       #246
+      010016D8H   LINE      ---      ---       #247
+      010016DEH   LINE      ---      ---       #248
+      010016E0H   LINE      ---      ---       #249
+      010016E5H   LINE      ---      ---       #250
+      010016EBH   LINE      ---      ---       #251
+      010016ECH   LINE      ---      ---       #252
+      010016ECH   LINE      ---      ---       #253
+      010016F2H   LINE      ---      ---       #254
+      010016F5H   LINE      ---      ---       #255
+      010016F7H   LINE      ---      ---       #256
+      010016FCH   LINE      ---      ---       #257
+      01001702H   LINE      ---      ---       #258
+      0100170AH   LINE      ---      ---       #259
+      01001710H   LINE      ---      ---       #260
+      01001711H   LINE      ---      ---       #261
+      01001711H   LINE      ---      ---       #262
+      0100171CH   LINE      ---      ---       #263
+      01001724H   LINE      ---      ---       #264
+      0100172AH   LINE      ---      ---       #265
+      0100172BH   LINE      ---      ---       #267
+      0100172BH   LINE      ---      ---       #268
+      01001735H   LINE      ---      ---       #269
+      0100173AH   LINE      ---      ---       #270
+      0100173FH   LINE      ---      ---       #271
+      01001744H   LINE      ---      ---       #272
+      01001749H   LINE      ---      ---       #273
+      0100174AH   LINE      ---      ---       #275
+      0100174AH   LINE      ---      ---       #276
+      01001752H   LINE      ---      ---       #277
+      01001757H   LINE      ---      ---       #278
+      01001759H   LINE      ---      ---       #279
+      0100175EH   LINE      ---      ---       #280
+      01001763H   LINE      ---      ---       #281
+      0100176BH   LINE      ---      ---       #282
+      0100176BH   LINE      ---      ---       #283
+      0100176CH   LINE      ---      ---       #284
+      0100176EH   LINE      ---      ---       #285
+      0100176EH   LINE      ---      ---       #286
+      0100176EH   LINE      ---      ---       #288
+      01001774H   LINE      ---      ---       #289
+      01001774H   LINE      ---      ---       #290
+      01001777H   LINE      ---      ---       #291
+      01001777H   LINE      ---      ---       #292
+      01001777H   LINE      ---      ---       #295
+      0100177DH   LINE      ---      ---       #296
+      0100177DH   LINE      ---      ---       #297
+      01001785H   LINE      ---      ---       #298
+      01001785H   LINE      ---      ---       #299
+      01001785H   LINE      ---      ---       #301
+      01001787H   LINE      ---      ---       #302
+      0100178EH   LINE      ---      ---       #303
+      0100178EH   LINE      ---      ---       #304
+      0100178EH   LINE      ---      ---       #305
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010010E9H   BLOCK     CODE     ---       LVL=0
+      010010E9H   LINE      ---      ---       #308
+      010010E9H   LINE      ---      ---       #309
+      010010E9H   LINE      ---      ---       #310
+      010010F3H   LINE      ---      ---       #312
+      010010F9H   LINE      ---      ---       #313
+      010010F9H   LINE      ---      ---       #314
+      01001101H   LINE      ---      ---       #315
+      01001101H   LINE      ---      ---       #316
+      01001109H   LINE      ---      ---       #317
+      01001110H   LINE      ---      ---       #318
+      01001118H   LINE      ---      ---       #319
+      0100111DH   LINE      ---      ---       #320
+      0100111FH   LINE      ---      ---       #322
+      0100111FH   LINE      ---      ---       #323
+      01001125H   LINE      ---      ---       #324
+      0100112BH   LINE      ---      ---       #325
+      01001131H   LINE      ---      ---       #326
+      01001131H   LINE      ---      ---       #327
+      01001133H   LINE      ---      ---       #328
+      01001139H   LINE      ---      ---       #329
+      01001139H   LINE      ---      ---       #330
+      0100113EH   LINE      ---      ---       #331
+      0100113EH   LINE      ---      ---       #333
+      0100113EH   LINE      ---      ---       #335
+      0100113EH   LINE      ---      ---       #338
+      01001149H   LINE      ---      ---       #339
+      01001149H   LINE      ---      ---       #340
+      0100114DH   LINE      ---      ---       #341
+      0100114DH   LINE      ---      ---       #342
+      0100114FH   LINE      ---      ---       #343
+      01001155H   LINE      ---      ---       #344
+      0100115BH   LINE      ---      ---       #345
+      01001161H   LINE      ---      ---       #346
+      01001163H   LINE      ---      ---       #348
+      01001169H   LINE      ---      ---       #350
+      0100116FH   LINE      ---      ---       #351
+      0100116FH   LINE      ---      ---       #352
+      01001171H   LINE      ---      ---       #353
+      01001177H   LINE      ---      ---       #354
+      0100117DH   LINE      ---      ---       #355
+      01001183H   LINE      ---      ---       #356
+      01001185H   LINE      ---      ---       #358
+      0100118BH   LINE      ---      ---       #361
+      01001191H   LINE      ---      ---       #362
+      01001191H   LINE      ---      ---       #363
+      01001193H   LINE      ---      ---       #364
+      0100119FH   LINE      ---      ---       #365
+      0100119FH   LINE      ---      ---       #366
+      010011A5H   LINE      ---      ---       #367
+      010011ABH   LINE      ---      ---       #368
+      010011B1H   LINE      ---      ---       #369
+      010011B1H   LINE      ---      ---       #370
+      010011B1H   LINE      ---      ---       #372
+      010011B1H   LINE      ---      ---       #373
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01002334H   BLOCK     CODE     ---       LVL=0
+      01002334H   LINE      ---      ---       #375
+      01002334H   LINE      ---      ---       #376
+      01002334H   LINE      ---      ---       #378
+      0100233AH   LINE      ---      ---       #379
+      0100233AH   LINE      ---      ---       #380
+      0100233DH   LINE      ---      ---       #381
+      01002340H   LINE      ---      ---       #382
+      01002340H   LINE      ---      ---       #383
+      01002345H   LINE      ---      ---       #384
+      01002349H   LINE      ---      ---       #385
+      01002349H   LINE      ---      ---       #386
+      01002349H   LINE      ---      ---       #389
+      01002352H   LINE      ---      ---       #390
+      01002352H   LINE      ---      ---       #391
+      01002357H   LINE      ---      ---       #392
+      01002357H   LINE      ---      ---       #393
+      0100236DH   LINE      ---      ---       #394
+      0100236DH   LINE      ---      ---       #395
+      01002372H   LINE      ---      ---       #396
+      01002378H   LINE      ---      ---       #397
+      01002380H   LINE      ---      ---       #398
+      0100238BH   LINE      ---      ---       #399
+      0100238BH   LINE      ---      ---       #400
+      0100238BH   LINE      ---      ---       #401
+      0100239BH   LINE      ---      ---       #402
+      0100239BH   LINE      ---      ---       #403
+      0100239EH   LINE      ---      ---       #404
+      010023A4H   LINE      ---      ---       #405
+      010023A4H   LINE      ---      ---       #406
+      010023A5H   LINE      ---      ---       #407
+      010023ADH   LINE      ---      ---       #408
+      010023ADH   LINE      ---      ---       #409
+      010023C0H   LINE      ---      ---       #410
+      010023C0H   LINE      ---      ---       #411
+      010023C2H   LINE      ---      ---       #412
+      010023C2H   LINE      ---      ---       #415
+      010023C9H   LINE      ---      ---       #416
+      010023C9H   LINE      ---      ---       #417
+      010023D5H   LINE      ---      ---       #419
+      010023DAH   LINE      ---      ---       #420
+      010023DFH   LINE      ---      ---       #421
+      010023E9H   LINE      ---      ---       #422
+      010023E9H   LINE      ---      ---       #424
+      010023F8H   LINE      ---      ---       #425
+      010023F8H   LINE      ---      ---       #426
+      010023FAH   LINE      ---      ---       #427
+      010023FAH   LINE      ---      ---       #428
+      010023FAH   LINE      ---      ---       #429
+      01002402H   LINE      ---      ---       #430
+      01002402H   LINE      ---      ---       #431
+      01002411H   LINE      ---      ---       #432
+      01002411H   LINE      ---      ---       #433
+      01002413H   LINE      ---      ---       #434
+      01002413H   LINE      ---      ---       #435
+      01002413H   LINE      ---      ---       #437
+      01002413H   LINE      ---      ---       #438
+      01002422H   LINE      ---      ---       #439
+      01002422H   LINE      ---      ---       #440
+      01002428H   LINE      ---      ---       #441
+      01002428H   LINE      ---      ---       #442
+      0100242AH   LINE      ---      ---       #443
+      0100242FH   LINE      ---      ---       #444
+      0100242FH   LINE      ---      ---       #445
+      01002432H   LINE      ---      ---       #446
+      01002432H   LINE      ---      ---       #447
+      01002432H   LINE      ---      ---       #448
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      0100225FH   BLOCK     CODE     ---       LVL=0
+      0100225FH   LINE      ---      ---       #451
+      0100225FH   LINE      ---      ---       #452
+      0100225FH   LINE      ---      ---       #454
+      01002265H   LINE      ---      ---       #455
+      01002265H   LINE      ---      ---       #456
+      01002268H   LINE      ---      ---       #457
+      0100226BH   LINE      ---      ---       #458
+      0100226BH   LINE      ---      ---       #459
+      0100227AH   LINE      ---      ---       #462
+      0100227AH   LINE      ---      ---       #464
+      0100227FH   LINE      ---      ---       #465
+      01002285H   LINE      ---      ---       #466
+      0100228AH   LINE      ---      ---       #467
+      0100228EH   LINE      ---      ---       #468
+      01002292H   LINE      ---      ---       #469
+      01002294H   LINE      ---      ---       #470
+      01002299H   LINE      ---      ---       #471
+      0100229EH   LINE      ---      ---       #472
+      0100229EH   LINE      ---      ---       #473
+      0100229EH   LINE      ---      ---       #474
+      0100229EH   LINE      ---      ---       #476
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010022B9H   BLOCK     CODE     ---       LVL=0
+      010022B9H   LINE      ---      ---       #479
+      010022B9H   LINE      ---      ---       #480
+      010022B9H   LINE      ---      ---       #482
+      010022BFH   LINE      ---      ---       #483
+      010022BFH   LINE      ---      ---       #484
+      010022C6H   LINE      ---      ---       #485
+      010022CCH   LINE      ---      ---       #486
+      010022CFH   LINE      ---      ---       #487
+      010022CFH   LINE      ---      ---       #488
+      010022D7H   LINE      ---      ---       #489
+      010022DBH   LINE      ---      ---       #491
+      010022E0H   LINE      ---      ---       #492
+      010022E3H   LINE      ---      ---       #493
+      010022E3H   LINE      ---      ---       #494
+      010022E3H   LINE      ---      ---       #496
+      010022E9H   LINE      ---      ---       #497
+      010022E9H   LINE      ---      ---       #498
+      010022F0H   LINE      ---      ---       #499
+      010022F6H   LINE      ---      ---       #500
+      010022F9H   LINE      ---      ---       #501
+      010022F9H   LINE      ---      ---       #503
+      010022FEH   LINE      ---      ---       #504
+      01002301H   LINE      ---      ---       #505
+      01002301H   LINE      ---      ---       #506
+      01002301H   LINE      ---      ---       #507
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010019F0H   BLOCK     CODE     ---       LVL=0
+      010019F0H   LINE      ---      ---       #509
+      010019F0H   LINE      ---      ---       #510
+      010019F0H   LINE      ---      ---       #527
+      010019F7H   LINE      ---      ---       #528
+      010019F7H   LINE      ---      ---       #529
+      01001A04H   LINE      ---      ---       #530
+      01001A07H   LINE      ---      ---       #531
+      01001A0FH   LINE      ---      ---       #532
+      01001A0FH   LINE      ---      ---       #533
+      01001A15H   LINE      ---      ---       #534
+      01001A1FH   LINE      ---      ---       #535
+      01001A1FH   LINE      ---      ---       #536
+      01001A24H   LINE      ---      ---       #537
+      01001A26H   LINE      ---      ---       #538
+      01001A2EH   LINE      ---      ---       #539
+      01001A2EH   LINE      ---      ---       #540
+      01001A33H   LINE      ---      ---       #541
+      01001A38H   LINE      ---      ---       #542
+      01001A3BH   LINE      ---      ---       #543
+      01001A3BH   LINE      ---      ---       #544
+      01001A3BH   LINE      ---      ---       #545
+      01001A3DH   LINE      ---      ---       #547
+      01001A3DH   LINE      ---      ---       #548
+      01001A42H   LINE      ---      ---       #549
+      01001A46H   LINE      ---      ---       #550
+      01001A4AH   LINE      ---      ---       #551
+      01001A4AH   LINE      ---      ---       #554
+      01001A51H   LINE      ---      ---       #555
+      01001A51H   LINE      ---      ---       #556
+      01001A57H   LINE      ---      ---       #557
+      01001A64H   LINE      ---      ---       #558
+      01001A67H   LINE      ---      ---       #559
+      01001A6FH   LINE      ---      ---       #560
+      01001A6FH   LINE      ---      ---       #561
+      01001A79H   LINE      ---      ---       #562
+      01001A79H   LINE      ---      ---       #563
+      01001A7EH   LINE      ---      ---       #564
+      01001A80H   LINE      ---      ---       #565
+      01001A85H   LINE      ---      ---       #566
+      01001A8AH   LINE      ---      ---       #567
+      01001A8DH   LINE      ---      ---       #569
+      01001A8DH   LINE      ---      ---       #570
+      01001A8DH   LINE      ---      ---       #571
+      01001A8FH   LINE      ---      ---       #573
+      01001A8FH   LINE      ---      ---       #574
+      01001A95H   LINE      ---      ---       #575
+      01001A95H   LINE      ---      ---       #576
+      01001A97H   LINE      ---      ---       #577
+      01001A9CH   LINE      ---      ---       #578
+      01001AA2H   LINE      ---      ---       #579
+      01001AAAH   LINE      ---      ---       #580
+      01001AB0H   LINE      ---      ---       #581
+      01001AB2H   LINE      ---      ---       #582
+      01001AB4H   LINE      ---      ---       #583
+      01001AB4H   LINE      ---      ---       #584
+      01001AB9H   LINE      ---      ---       #585
+      01001AB9H   LINE      ---      ---       #588
+      01001AC0H   LINE      ---      ---       #589
+      01001AC0H   LINE      ---      ---       #590
+      01001AC6H   LINE      ---      ---       #591
+      01001AD3H   LINE      ---      ---       #592
+      01001AD6H   LINE      ---      ---       #593
+      01001ADEH   LINE      ---      ---       #594
+      01001ADEH   LINE      ---      ---       #596
+      01001AE4H   LINE      ---      ---       #597
+      01001AE9H   LINE      ---      ---       #598
+      01001AEEH   LINE      ---      ---       #599
+      01001AF1H   LINE      ---      ---       #600
+      01001AF6H   LINE      ---      ---       #601
+      01001AFBH   LINE      ---      ---       #602
+      01001B03H   LINE      ---      ---       #603
+      01001B0BH   LINE      ---      ---       #604
+      01001B0BH   LINE      ---      ---       #605
+      01001B0DH   LINE      ---      ---       #607
+      01001B0DH   LINE      ---      ---       #608
+      01001B13H   LINE      ---      ---       #609
+      01001B13H   LINE      ---      ---       #610
+      01001B15H   LINE      ---      ---       #612
+      01001B21H   LINE      ---      ---       #613
+      01001B21H   LINE      ---      ---       #614
+      01001B27H   LINE      ---      ---       #615
+      01001B2AH   LINE      ---      ---       #616
+      01001B32H   LINE      ---      ---       #617
+      01001B38H   LINE      ---      ---       #619
+      01001B3AH   LINE      ---      ---       #620
+      01001B3CH   LINE      ---      ---       #621
+      01001B3EH   LINE      ---      ---       #622
+      01001B3EH   LINE      ---      ---       #623
+      01001B3EH   LINE      ---      ---       #624
+      01001B43H   LINE      ---      ---       #625
+      01001B43H   LINE      ---      ---       #629
+      01001B4CH   LINE      ---      ---       #630
+      01001B4CH   LINE      ---      ---       #631
+      01001B57H   LINE      ---      ---       #632
+      01001B5AH   LINE      ---      ---       #633
+      01001B64H   LINE      ---      ---       #634
+      01001B64H   LINE      ---      ---       #635
+      01001B6CH   LINE      ---      ---       #636
+      01001B6CH   LINE      ---      ---       #637
+      01001B72H   LINE      ---      ---       #638
+      01001B74H   LINE      ---      ---       #639
+      01001B7CH   LINE      ---      ---       #640
+      01001B7CH   LINE      ---      ---       #641
+      01001B81H   LINE      ---      ---       #643
+      01001B83H   LINE      ---      ---       #644
+      01001B90H   LINE      ---      ---       #645
+      01001B90H   LINE      ---      ---       #646
+      01001B95H   LINE      ---      ---       #648
+      01001B95H   LINE      ---      ---       #649
+      01001B9BH   LINE      ---      ---       #650
+      01001BA8H   LINE      ---      ---       #651
+      01001BA8H   LINE      ---      ---       #652
+      01001BAEH   LINE      ---      ---       #653
+      01001BAFH   LINE      ---      ---       #654
+      01001BC5H   LINE      ---      ---       #655
+      01001BC5H   LINE      ---      ---       #656
+      01001BDDH   LINE      ---      ---       #657
+      01001BE3H   LINE      ---      ---       #658
+      01001BE3H   LINE      ---      ---       #659
+      01001BE3H   LINE      ---      ---       #660
+      01001BE4H   LINE      ---      ---       #662
+      01001BE4H   LINE      ---      ---       #663
+      01001BE9H   LINE      ---      ---       #664
+      01001BE9H   LINE      ---      ---       #666
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      0100229FH   BLOCK     CODE     ---       LVL=0
+      0100229FH   LINE      ---      ---       #670
+      0100229FH   LINE      ---      ---       #671
+      0100229FH   LINE      ---      ---       #672
+      010022A2H   LINE      ---      ---       #674
+      010022B0H   LINE      ---      ---       #676
+      010022B2H   LINE      ---      ---       #677
+      010022B4H   LINE      ---      ---       #678
+      010022B7H   LINE      ---      ---       #679
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010031B1H   BLOCK     CODE     ---       LVL=0
+      010031B1H   LINE      ---      ---       #692
+      010031B1H   LINE      ---      ---       #693
+      010031B1H   LINE      ---      ---       #695
+      010031B7H   LINE      ---      ---       #696
+      010031B7H   LINE      ---      ---       #697
+      010031B9H   LINE      ---      ---       #698
+      010031B9H   LINE      ---      ---       #700
+      010031BFH   LINE      ---      ---       #701
+      010031C1H   LINE      ---      ---       #703
+      010031C7H   LINE      ---      ---       #704
+      010031C7H   LINE      ---      ---       #705
+      010031C9H   LINE      ---      ---       #706
+      010031CCH   LINE      ---      ---       #707
+      010031D2H   LINE      ---      ---       #708
+      010031D2H   LINE      ---      ---       #710
+      010031D8H   LINE      ---      ---       #711
+      010031D8H   LINE      ---      ---       #712
+      010031DEH   LINE      ---      ---       #713
+      010031DEH   LINE      ---      ---       #714
+      010031E4H   LINE      ---      ---       #716
+      010031E4H   LINE      ---      ---       #718
+      010031EAH   LINE      ---      ---       #719
+      010031EDH   LINE      ---      ---       #720
+      010031F3H   LINE      ---      ---       #721
+      010031F3H   LINE      ---      ---       #722
+      010031F6H   LINE      ---      ---       #723
+      010031F6H   LINE      ---      ---       #724
+      010031F8H   LINE      ---      ---       #725
+      01003204H   LINE      ---      ---       #726
+      01003204H   LINE      ---      ---       #727
+      0100320AH   LINE      ---      ---       #728
+      0100320AH   LINE      ---      ---       #729
+      0100320CH   LINE      ---      ---       #730
+      01003217H   LINE      ---      ---       #731
+      01003217H   LINE      ---      ---       #732
+      0100321BH   LINE      ---      ---       #733
+      0100321BH   LINE      ---      ---       #734
+      01003222H   LINE      ---      ---       #735
+      01003224H   LINE      ---      ---       #737
+      01003224H   LINE      ---      ---       #738
+      0100322BH   LINE      ---      ---       #739
+      0100322BH   LINE      ---      ---       #740
+      0100322DH   LINE      ---      ---       #742
+      01003234H   LINE      ---      ---       #743
+      0100323AH   LINE      ---      ---       #744
+      0100323DH   LINE      ---      ---       #745
+      0100323DH   LINE      ---      ---       #746
+      0100323DH   LINE      ---      ---       #749
+      01003243H   LINE      ---      ---       #750
+      01003243H   LINE      ---      ---       #751
+      0100324BH   LINE      ---      ---       #752
+      0100324BH   LINE      ---      ---       #753
+      01003251H   LINE      ---      ---       #754
+      01003255H   LINE      ---      ---       #756
+      0100325BH   LINE      ---      ---       #757
+      0100325BH   LINE      ---      ---       #758
+      01003266H   LINE      ---      ---       #759
+      01003268H   LINE      ---      ---       #760
+      0100326EH   LINE      ---      ---       #761
+      0100326EH   LINE      ---      ---       #763
+      01003279H   LINE      ---      ---       #764
+      01003279H   LINE      ---      ---       #765
+      01003279H   LINE      ---      ---       #766
+      01003279H   LINE      ---      ---       #770
+      0100327FH   LINE      ---      ---       #771
+      0100327FH   LINE      ---      ---       #772
+      01003282H   LINE      ---      ---       #773
+      01003285H   LINE      ---      ---       #774
+      01003285H   LINE      ---      ---       #775
+      0100328BH   LINE      ---      ---       #776
+      0100328BH   LINE      ---      ---       #777
+      01003290H   LINE      ---      ---       #778
+      01003290H   LINE      ---      ---       #779
+      01003290H   LINE      ---      ---       #780
+      01003290H   LINE      ---      ---       #782
+      01003296H   LINE      ---      ---       #783
+      01003299H   LINE      ---      ---       #784
+      0100329CH   LINE      ---      ---       #785
+      0100329CH   LINE      ---      ---       #787
+      010032A4H   LINE      ---      ---       #788
+      010032A4H   LINE      ---      ---       #789
+      010032AAH   LINE      ---      ---       #790
+      010032AAH   LINE      ---      ---       #791
+      010032AAH   LINE      ---      ---       #792
+      010032AAH   LINE      ---      ---       #793
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001F93H   BLOCK     CODE     ---       LVL=0
+      01001F93H   LINE      ---      ---       #807
+      01001F93H   LINE      ---      ---       #808
+      01001F93H   LINE      ---      ---       #809
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001D3CH   BLOCK     CODE     ---       LVL=0
+      01001D3CH   LINE      ---      ---       #814
+      01001D3CH   LINE      ---      ---       #815
+      01001D3CH   LINE      ---      ---       #817
+      01001D3EH   LINE      ---      ---       #818
+      01001D3EH   LINE      ---      ---       #819
+      01001D41H   LINE      ---      ---       #820
+      01001D43H   LINE      ---      ---       #821
+      01001D45H   LINE      ---      ---       #822
+      01001D48H   LINE      ---      ---       #824
+      01001D4EH   LINE      ---      ---       #825
+      01001D4EH   LINE      ---      ---       #826
+      01001D51H   LINE      ---      ---       #827
+      01001D51H   LINE      ---      ---       #829
+      01001D5CH   LINE      ---      ---       #830
+      01001D5CH   LINE      ---      ---       #831
+      01001D5EH   LINE      ---      ---       #833
+      01001D61H   LINE      ---      ---       #834
+      01001D63H   LINE      ---      ---       #835
+      01001D65H   LINE      ---      ---       #836
+      01001D65H   LINE      ---      ---       #838
+      01001D65H   LINE      ---      ---       #839
+      01001D7DH   LINE      ---      ---       #841
+      01001D7DH   LINE      ---      ---       #842
+      01001D80H   LINE      ---      ---       #843
+      01001D82H   LINE      ---      ---       #844
+      01001D82H   LINE      ---      ---       #846
+      01001D82H   LINE      ---      ---       #847
+      01001D84H   LINE      ---      ---       #848
+      01001D86H   LINE      ---      ---       #849
+      01001D88H   LINE      ---      ---       #850
+      01001D88H   LINE      ---      ---       #851
+      01001D88H   LINE      ---      ---       #852
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      ---         MODULE    ---      ---       ADC
+      01002323H   PUBLIC    CODE     ---       YC_adc_check_timer500ms
+      01002302H   PUBLIC    CODE     ---       YC_adc_motion_check_timer500ms
+      010024A6H   PUBLIC    CODE     ---       YC_adc_check
+      01003082H   PUBLIC    CODE     ---       YC_adc_init
+
+      01003082H   BLOCK     CODE     ---       LVL=0
+      01003082H   LINE      ---      ---       #3
+      01003082H   LINE      ---      ---       #4
+      01003082H   BLOCK     CODE     NEAR LAB  LVL=1
+      01003082H   LINE      ---      ---       #8
+      01003088H   LINE      ---      ---       #9
+      0100308BH   LINE      ---      ---       #10
+      01003091H   LINE      ---      ---       #31
+      01003097H   LINE      ---      ---       #32
+      010030A3H   LINE      ---      ---       #33
+      010030A3H   LINE      ---      ---       #34
+      010030B4H   LINE      ---      ---       #35
+      010030B7H   LINE      ---      ---       #36
+      01003105H   LINE      ---      ---       #37
+      01003152H   LINE      ---      ---       #38
+      010031A0H   LINE      ---      ---       #41
+      00000007H   SYMBOL    DATA     VOID      i
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      010024A6H   BLOCK     CODE     ---       LVL=0
+      010024A6H   LINE      ---      ---       #43
+      010024A6H   LINE      ---      ---       #44
+      010024A6H   BLOCK     CODE     NEAR LAB  LVL=1
+      010024A6H   LINE      ---      ---       #47
+      010024B0H   LINE      ---      ---       #49
+      010024BCH   LINE      ---      ---       #52
+      010024DCH   LINE      ---      ---       #53
+      010024E9H   LINE      ---      ---       #54
+      010024EBH   LINE      ---      ---       #55
+      010024FDH   LINE      ---      ---       #56
+      010024FDH   LINE      ---      ---       #57
+      01002532H   LINE      ---      ---       #58
+      0100253AH   LINE      ---      ---       #59
+      01002557H   LINE      ---      ---       #61
+      01002576H   LINE      ---      ---       #62
+      0100257DH   LINE      ---      ---       #63
+      0100259CH   LINE      ---      ---       #64
+      010025A4H   LINE      ---      ---       #66
+      010025FFH   LINE      ---      ---       #68
+      01002614H   LINE      ---      ---       #69
+      01002614H   LINE      ---      ---       #70
+      0100261AH   LINE      ---      ---       #71
+      0100261BH   LINE      ---      ---       #73
+      0100261BH   LINE      ---      ---       #74
+      0100263AH   LINE      ---      ---       #75
+      0100263AH   LINE      ---      ---       #76
+      01002640H   LINE      ---      ---       #77
+      01002646H   LINE      ---      ---       #78
+      01002646H   LINE      ---      ---       #79
+      0100264AH   LINE      ---      ---       #80
+      0100264EH   LINE      ---      ---       #81
+      01002652H   LINE      ---      ---       #82
+      01002655H   LINE      ---      ---       #83
+      01002655H   LINE      ---      ---       #84
+      01002656H   LINE      ---      ---       #86
+      01002656H   LINE      ---      ---       #87
+      0100265BH   LINE      ---      ---       #88
+      01002661H   LINE      ---      ---       #89
+      01002661H   LINE      ---      ---       #90
+      01002665H   LINE      ---      ---       #91
+      01002669H   LINE      ---      ---       #92
+      0100266DH   LINE      ---      ---       #93
+      01002670H   LINE      ---      ---       #94
+      01002670H   LINE      ---      ---       #95
+      01002670H   LINE      ---      ---       #96
+      01002670H   LINE      ---      ---       #98
+      02004ECAH   SYMBOL    XDATA    VOID      i
+      02004ECBH   SYMBOL    XDATA    VOID      batValue
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01002302H   BLOCK     CODE     ---       LVL=0
+      01002302H   LINE      ---      ---       #100
+      01002302H   LINE      ---      ---       #101
+      01002302H   BLOCK     CODE     NEAR LAB  LVL=1
+      01002302H   LINE      ---      ---       #103
+      01002304H   LINE      ---      ---       #105
+      01002316H   LINE      ---      ---       #106
+      01002316H   LINE      ---      ---       #107
+      01002318H   LINE      ---      ---       #108
+      0100231BH   LINE      ---      ---       #109
+      01002320H   LINE      ---      ---       #111
+      01002322H   LINE      ---      ---       #112
+      01002322H   LINE      ---      ---       #116
+      00000007H   SYMBOL    DATA     VOID      i
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01002323H   BLOCK     CODE     ---       LVL=0
+      01002323H   LINE      ---      ---       #118
+      01002323H   LINE      ---      ---       #119
+      01002323H   LINE      ---      ---       #123
+      01002329H   LINE      ---      ---       #124
+      01002329H   LINE      ---      ---       #125
+      0100232BH   LINE      ---      ---       #126
+      0100232EH   LINE      ---      ---       #127
+      0100232EH   LINE      ---      ---       #128
+      01002331H   LINE      ---      ---       #129
+      01002333H   LINE      ---      ---       #130
+      01002333H   LINE      ---      ---       #131
+      01002333H   LINE      ---      ---       #133
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      ---         MODULE    ---      ---       RAM
+      01001FEBH   PUBLIC    CODE     ---       main
+
+      01001FEBH   BLOCK     CODE     ---       LVL=0
+      01001FEBH   LINE      ---      ---       #5
+      01001FEBH   LINE      ---      ---       #6
+      01001FEBH   LINE      ---      ---       #7
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      ---         MODULE    ---      ---       IPC
+      02004BA5H   PUBLIC    XDATA    WORD      bttimer
+      02004C8DH   PUBLIC    XDATA    BYTE      btstimer
+      02004C5EH   PUBLIC    XDATA    WORD      c51timer
+      02000550H   PUBLIC    XDATA    ---       ipcPin
+      02004C8EH   PUBLIC    XDATA    BYTE      c51stimer
+      02000BE7H   PUBLIC    XDATA    ---       ipcSendBuff
+      02000B7FH   PUBLIC    XDATA    BYTE      lpm_flag
+      02000C4BH   PUBLIC    XDATA    ---       ipcReadBuff
+      0200054FH   PUBLIC    XDATA    BYTE      ipcPinlen
+      02000B7EH   PUBLIC    XDATA    BYTE      current_task
+      010032FBH   PUBLIC    CODE     ---       IPC_DealSingleStep
+      010026E3H   PUBLIC    CODE     ---       IPC_IsTxBuffEmpty
+      01003532H   PUBLIC    CODE     ---       IPC_AbandonLpm
+      01001EC2H   PUBLIC    CODE     ---       IPC_WaitLpm
+      01001F99H   PUBLIC    CODE     ---       _IPC_Initialize
+      0100352CH   PUBLIC    CODE     ---       IPC_GetBBDIsconnectReason
+      01003523H   PUBLIC    CODE     ---       _IPC_TxBleData
+      0100351AH   PUBLIC    CODE     ---       _IPC_TxSppData
+      01003511H   PUBLIC    CODE     ---       _IPC_Tx24GData
+      01003504H   PUBLIC    CODE     ---       _IPC_TxBREDRHidData
+      01000FC2H   PUBLIC    CODE     ---       _IPC_TxData
+      0100149DH   PUBLIC    CODE     ---       _IPC_TxControlCmd
+
+      01001079H   BLOCK     CODE     ---       LVL=0
+      01001079H   LINE      ---      ---       #44
+      01001089H   LINE      ---      ---       #45
+      01001089H   LINE      ---      ---       #46
+      010010D2H   LINE      ---      ---       #47
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010032ABH   BLOCK     CODE     ---       LVL=0
+      010032ABH   LINE      ---      ---       #49
+      010032B5H   LINE      ---      ---       #50
+      010032B5H   BLOCK     CODE     NEAR LAB  LVL=1
+      010032B5H   LINE      ---      ---       #51
+      010032BDH   LINE      ---      ---       #52
+      010032C3H   LINE      ---      ---       #53
+      010032E2H   LINE      ---      ---       #54
+      010032ECH   LINE      ---      ---       #55
+      010032F0H   LINE      ---      ---       #56
+      010032F0H   LINE      ---      ---       #57
+      010032F2H   LINE      ---      ---       #58
+      010032FAH   LINE      ---      ---       #59
+      00000006H   SYMBOL    DATA     VOID      src
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01000FE5H   BLOCK     CODE     ---       LVL=0
+      01000FE5H   LINE      ---      ---       #61
+      01000FF3H   LINE      ---      ---       #62
+      01000FF3H   BLOCK     CODE     NEAR LAB  LVL=1
+      01000FF3H   LINE      ---      ---       #63
+      01001002H   LINE      ---      ---       #64
+      01001020H   LINE      ---      ---       #65
+      0100102AH   LINE      ---      ---       #66
+      0100104FH   LINE      ---      ---       #67
+      0100105DH   LINE      ---      ---       #68
+      01001067H   LINE      ---      ---       #69
+      01001067H   LINE      ---      ---       #70
+      01001069H   LINE      ---      ---       #71
+      01001078H   LINE      ---      ---       #72
+      02004EBDH   SYMBOL    XDATA    VOID      dest
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      0100149DH   BLOCK     CODE     ---       LVL=0
+      0100149DH   LINE      ---      ---       #74
+      010014A2H   LINE      ---      ---       #75
+      010014A2H   BLOCK     CODE     NEAR LAB  LVL=1
+      010014A2H   LINE      ---      ---       #76
+      010014B5H   LINE      ---      ---       #79
+      010014BDH   LINE      ---      ---       #80
+      02004EDDH   SYMBOL    XDATA    VOID      cmdBuff
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01000FC2H   BLOCK     CODE     ---       LVL=0
+      01000FC2H   LINE      ---      ---       #83
+      01000FC7H   LINE      ---      ---       #84
+      01000FC7H   LINE      ---      ---       #85
+      01000FCDH   LINE      ---      ---       #86
+      01000FD8H   LINE      ---      ---       #87
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01003504H   BLOCK     CODE     ---       LVL=0
+      01003504H   LINE      ---      ---       #90
+      01003504H   LINE      ---      ---       #91
+      01003504H   LINE      ---      ---       #92
+      0100350AH   LINE      ---      ---       #93
+      0100350DH   LINE      ---      ---       #94
+      01003510H   LINE      ---      ---       #95
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01003511H   BLOCK     CODE     ---       LVL=0
+      01003511H   LINE      ---      ---       #97
+      01003511H   LINE      ---      ---       #98
+      01003511H   LINE      ---      ---       #99
+      01003517H   LINE      ---      ---       #100
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      0100351AH   BLOCK     CODE     ---       LVL=0
+      0100351AH   LINE      ---      ---       #103
+      0100351AH   LINE      ---      ---       #104
+      0100351AH   LINE      ---      ---       #105
+      01003520H   LINE      ---      ---       #106
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01003523H   BLOCK     CODE     ---       LVL=0
+      01003523H   LINE      ---      ---       #109
+      01003523H   LINE      ---      ---       #110
+      01003523H   LINE      ---      ---       #111
+      01003529H   LINE      ---      ---       #112
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      0100352CH   BLOCK     CODE     ---       LVL=0
+      0100352CH   LINE      ---      ---       #115
+      0100352CH   LINE      ---      ---       #116
+      0100352CH   LINE      ---      ---       #117
+      01003531H   LINE      ---      ---       #118
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001F99H   BLOCK     CODE     ---       LVL=0
+      01001F99H   LINE      ---      ---       #120
+      01001F99H   LINE      ---      ---       #121
+      01001F99H   LINE      ---      ---       #122
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001EC2H   BLOCK     CODE     ---       LVL=0
+      01001EC2H   LINE      ---      ---       #125
+      01001EC2H   LINE      ---      ---       #126
+      01001EC2H   LINE      ---      ---       #127
+      01001EC7H   LINE      ---      ---       #128
+      01001ECBH   LINE      ---      ---       #129
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01003532H   BLOCK     CODE     ---       LVL=0
+      01003532H   LINE      ---      ---       #132
+      01003532H   LINE      ---      ---       #133
+      01003532H   LINE      ---      ---       #134
+      01003538H   LINE      ---      ---       #135
+      0100353DH   LINE      ---      ---       #136
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010026E3H   BLOCK     CODE     ---       LVL=0
+      010026E3H   LINE      ---      ---       #138
+      010026E3H   LINE      ---      ---       #139
+      010026E3H   LINE      ---      ---       #140
+      010026F7H   LINE      ---      ---       #141
+      010026F9H   LINE      ---      ---       #142
+      010026FAH   LINE      ---      ---       #143
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010032FBH   BLOCK     CODE     ---       LVL=0
+      010032FBH   LINE      ---      ---       #146
+      010032FBH   LINE      ---      ---       #147
+      010032FBH   BLOCK     CODE     NEAR LAB  LVL=1
+      010032FBH   LINE      ---      ---       #148
+      0100330DH   LINE      ---      ---       #149
+      01003323H   LINE      ---      ---       #150
+      01003323H   LINE      ---      ---       #151
+      0100332BH   LINE      ---      ---       #152
+      0100333CH   LINE      ---      ---       #153
+      01003346H   LINE      ---      ---       #154
+      01003365H   LINE      ---      ---       #155
+      01003367H   LINE      ---      ---       #156
+      01003379H   LINE      ---      ---       #157
+      01003382H   LINE      ---      ---       #158
+      01003398H   LINE      ---      ---       #159
+      010033D0H   LINE      ---      ---       #160
+      010033D2H   LINE      ---      ---       #161
+      010033E4H   LINE      ---      ---       #162
+      010033EDH   LINE      ---      ---       #163
+      01003403H   LINE      ---      ---       #164
+      0100343BH   LINE      ---      ---       #165
+      0100343DH   LINE      ---      ---       #166
+      0100344FH   LINE      ---      ---       #167
+      01003458H   LINE      ---      ---       #168
+      0100346EH   LINE      ---      ---       #169
+      010034A6H   LINE      ---      ---       #170
+      010034A8H   LINE      ---      ---       #171
+      010034A8H   LINE      ---      ---       #172
+      010034AAH   LINE      ---      ---       #173
+      010034AAH   LINE      ---      ---       #174
+      010034AAH   LINE      ---      ---       #175
+      010034BEH   LINE      ---      ---       #176
+      010034CCH   LINE      ---      ---       #178
+      010034CFH   LINE      ---      ---       #180
+      010034DEH   LINE      ---      ---       #181
+      010034E0H   LINE      ---      ---       #182
+      010034EAH   LINE      ---      ---       #183
+      010034F8H   LINE      ---      ---       #185
+      010034FBH   LINE      ---      ---       #187
+      01003501H   LINE      ---      ---       #188
+      01003503H   LINE      ---      ---       #190
+      010034AAH   SYMBOL    CODE     NEAR LAB  IPC_TIMER
+      02004EECH   SYMBOL    XDATA    VOID      pbuff
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      ---         MODULE    ---      ---       UTILITIES
+      02004EABH   PUBLIC    XDATA    BYTE      ?_compare_str?BYTE
+      01002D6BH   PUBLIC    CODE     ---       _compare_str
+      01001798H   PUBLIC    CODE     ---       _Delay1ms
+      01003545H   PUBLIC    CODE     ---       _xmemclear_ff
+      01000DFAH   PUBLIC    CODE     ---       _xmemclear
+      02004E9CH   PUBLIC    XDATA    BYTE      ?_dmemcpy?BYTE
+      01002462H   PUBLIC    CODE     ---       _dmemcpy
+      02004EBFH   PUBLIC    XDATA    BYTE      ?_xmemcpy?BYTE
+      01000878H   PUBLIC    CODE     ---       _xmemcpy
+      0100353EH   PUBLIC    CODE     ---       YC_Ice_break
+
+      0100353EH   BLOCK     CODE     ---       LVL=0
+      0100353EH   LINE      ---      ---       #3
+      0100353EH   LINE      ---      ---       #4
+      0100353EH   LINE      ---      ---       #5
+      01003544H   LINE      ---      ---       #7
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01000878H   BLOCK     CODE     ---       LVL=0
+      01000878H   LINE      ---      ---       #9
+      01000889H   LINE      ---      ---       #10
+      01000889H   LINE      ---      ---       #11
+      01000893H   LINE      ---      ---       #12
+      010008BAH   LINE      ---      ---       #14
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01002462H   BLOCK     CODE     ---       LVL=0
+      01002462H   LINE      ---      ---       #16
+      0100246DH   LINE      ---      ---       #17
+      0100246DH   LINE      ---      ---       #18
+      0100247BH   LINE      ---      ---       #19
+      010024A5H   LINE      ---      ---       #21
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01000DFAH   BLOCK     CODE     ---       LVL=0
+      01000DFAH   LINE      ---      ---       #23
+      01000E05H   LINE      ---      ---       #24
+      01000E05H   LINE      ---      ---       #25
+      01000E0FH   LINE      ---      ---       #26
+      01000E25H   LINE      ---      ---       #28
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01003545H   BLOCK     CODE     ---       LVL=0
+      01003545H   LINE      ---      ---       #30
+      01003550H   LINE      ---      ---       #31
+      01003550H   LINE      ---      ---       #32
+      0100355AH   LINE      ---      ---       #33
+      01003571H   LINE      ---      ---       #35
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001798H   BLOCK     CODE     ---       LVL=0
+      01001798H   LINE      ---      ---       #46
+      01001798H   LINE      ---      ---       #47
+      01001798H   BLOCK     CODE     NEAR LAB  LVL=1
+      01001798H   LINE      ---      ---       #49
+      0100179EH   LINE      ---      ---       #50
+      010017ACH   LINE      ---      ---       #51
+      010017AFH   LINE      ---      ---       #52
+      00000004H   SYMBOL    DATA     VOID      j
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01002D6BH   BLOCK     CODE     ---       LVL=0
+      01002D6BH   LINE      ---      ---       #54
+      01002D76H   LINE      ---      ---       #55
+      01002D76H   BLOCK     CODE     NEAR LAB  LVL=1
+      01002D76H   LINE      ---      ---       #57
+      01002D82H   LINE      ---      ---       #58
+      01002DACH   LINE      ---      ---       #59
+      01002DAFH   LINE      ---      ---       #60
+      01002DB2H   LINE      ---      ---       #61
+      01002DB4H   LINE      ---      ---       #62
+      00000007H   SYMBOL    DATA     VOID      i
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      ---         MODULE    ---      ---       GPIO
+      020000A3H   PUBLIC    XDATA    ---       YC_GPIOWakeupL
+      020000A7H   PUBLIC    XDATA    ---       YC_GPIOWakeupH
+      010035CEH   PUBLIC    CODE     ---       GPIO_fillpd
+      010035B1H   PUBLIC    CODE     ---       _GPIO_FlipOutBit
+      01001E23H   PUBLIC    CODE     ---       _GPIO_SetWakeupByCurrentState
+      01003572H   PUBLIC    CODE     ---       _GPIO_ClearWakeup
+      00000020H.7 PUBLIC    BIT      BIT       ?_GPIO_SetWakeup?BIT
+      01001E36H   PUBLIC    CODE     ---       _GPIO_SetWakeup
+      00000020H.6 PUBLIC    BIT      BIT       ?_GPIO_SetOutput?BIT
+      01001808H   PUBLIC    CODE     ---       _GPIO_SetOutput
+      00000020H.5 PUBLIC    BIT      BIT       ?_GPIO_SetInput?BIT
+      01001846H   PUBLIC    CODE     ---       _GPIO_SetInput
+      00000020H.4 PUBLIC    BIT      BIT       ?_GPIO_Setoe?BIT
+      01001835H   PUBLIC    CODE     ---       _GPIO_Setoe
+      00000020H.3 PUBLIC    BIT      BIT       ?_GPIO_SetPd?BIT
+      01001864H   PUBLIC    CODE     ---       _GPIO_SetPd
+      00000020H.2 PUBLIC    BIT      BIT       ?_GPIO_SetPu?BIT
+      01001824H   PUBLIC    CODE     ---       _GPIO_SetPu
+      00000020H.1 PUBLIC    BIT      BIT       ?_GPIO_Setout?BIT
+      010011B2H   PUBLIC    CODE     ---       _GPIO_Setout
+      01001FA6H   PUBLIC    CODE     ---       _GPIO_GetInputStatus
+
+      01001875H   BLOCK     CODE     ---       LVL=0
+      01001875H   LINE      ---      ---       #9
+      01001880H   LINE      ---      ---       #10
+      01001880H   BLOCK     CODE     NEAR LAB  LVL=1
+      01001880H   LINE      ---      ---       #11
+      01001882H   LINE      ---      ---       #12
+      01001883H   LINE      ---      ---       #14
+      01001887H   LINE      ---      ---       #15
+      0100188EH   LINE      ---      ---       #17
+      01001891H   LINE      ---      ---       #18
+      010018B3H   LINE      ---      ---       #19
+      010018B3H   LINE      ---      ---       #21
+      010018B3H   LINE      ---      ---       #22
+      00000006H   SYMBOL    DATA     VOID      queue
+      00000005H   SYMBOL    DATA     VOID      group
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01001FACH   BLOCK     CODE     ---       LVL=0
+      01001FACH   LINE      ---      ---       #26
+      01001FAEH   LINE      ---      ---       #27
+      01001FAEH   BLOCK     CODE     NEAR LAB  LVL=1
+      01001FAEH   LINE      ---      ---       #28
+      01001FB3H   LINE      ---      ---       #29
+      01001FB4H   LINE      ---      ---       #31
+      01001FB8H   LINE      ---      ---       #32
+      01001FBFH   LINE      ---      ---       #33
+      01001FEAH   LINE      ---      ---       #35
+      02004F08H   SYMBOL    XDATA    VOID      queue
+      00000006H   SYMBOL    DATA     VOID      group
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01001FA6H   BLOCK     CODE     ---       LVL=0
+      01001FA6H   LINE      ---      ---       #37
+      01001FA6H   LINE      ---      ---       #38
+      01001FA6H   LINE      ---      ---       #39
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010011B2H   BLOCK     CODE     ---       LVL=0
+      010011B2H   LINE      ---      ---       #42
+      010011B2H   LINE      ---      ---       #43
+      010011B2H   LINE      ---      ---       #44
+      010011B6H   LINE      ---      ---       #46
+      010011C3H   LINE      ---      ---       #47
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001824H   BLOCK     CODE     ---       LVL=0
+      01001824H   LINE      ---      ---       #49
+      01001824H   LINE      ---      ---       #50
+      01001824H   LINE      ---      ---       #51
+      01001828H   LINE      ---      ---       #53
+      01001834H   LINE      ---      ---       #54
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001864H   BLOCK     CODE     ---       LVL=0
+      01001864H   LINE      ---      ---       #56
+      01001864H   LINE      ---      ---       #57
+      01001864H   LINE      ---      ---       #58
+      01001868H   LINE      ---      ---       #60
+      01001874H   LINE      ---      ---       #61
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001835H   BLOCK     CODE     ---       LVL=0
+      01001835H   LINE      ---      ---       #63
+      01001835H   LINE      ---      ---       #64
+      01001835H   LINE      ---      ---       #65
+      01001839H   LINE      ---      ---       #67
+      01001845H   LINE      ---      ---       #68
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001846H   BLOCK     CODE     ---       LVL=0
+      01001846H   LINE      ---      ---       #70
+      01001848H   LINE      ---      ---       #71
+      01001848H   LINE      ---      ---       #72
+      0100184CH   LINE      ---      ---       #74
+      01001854H   LINE      ---      ---       #75
+      0100185DH   LINE      ---      ---       #76
+      01001863H   LINE      ---      ---       #77
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001808H   BLOCK     CODE     ---       LVL=0
+      01001808H   LINE      ---      ---       #79
+      0100180AH   LINE      ---      ---       #80
+      0100180AH   LINE      ---      ---       #81
+      0100180EH   LINE      ---      ---       #83
+      01001814H   LINE      ---      ---       #84
+      0100181DH   LINE      ---      ---       #85
+      01001823H   LINE      ---      ---       #86
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001E36H   BLOCK     CODE     ---       LVL=0
+      01001E36H   LINE      ---      ---       #88
+      01001E36H   LINE      ---      ---       #89
+      01001E36H   BLOCK     CODE     NEAR LAB  LVL=1
+      01001E36H   LINE      ---      ---       #92
+      01001E3CH   LINE      ---      ---       #94
+      01001E40H   LINE      ---      ---       #95
+      01001E47H   LINE      ---      ---       #96
+      01001E4AH   LINE      ---      ---       #97
+      01001E6BH   LINE      ---      ---       #98
+      01001E8CH   LINE      ---      ---       #99
+      01001E8DH   LINE      ---      ---       #101
+      01001E8DH   LINE      ---      ---       #102
+      01001EAFH   LINE      ---      ---       #103
+      01001EC1H   LINE      ---      ---       #104
+      01001EC1H   LINE      ---      ---       #105
+      00000006H   SYMBOL    DATA     VOID      queue
+      00000007H   SYMBOL    DATA     VOID      group
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01003572H   BLOCK     CODE     ---       LVL=0
+      01003572H   LINE      ---      ---       #107
+      01003572H   LINE      ---      ---       #108
+      01003572H   BLOCK     CODE     NEAR LAB  LVL=1
+      01003572H   LINE      ---      ---       #111
+      01003576H   LINE      ---      ---       #113
+      0100357AH   LINE      ---      ---       #114
+      01003581H   LINE      ---      ---       #115
+      010035A3H   LINE      ---      ---       #116
+      010035B0H   LINE      ---      ---       #117
+      00000006H   SYMBOL    DATA     VOID      queue
+      00000007H   SYMBOL    DATA     VOID      group
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01001E23H   BLOCK     CODE     ---       LVL=0
+      01001E23H   LINE      ---      ---       #119
+      01001E28H   LINE      ---      ---       #120
+      01001E28H   BLOCK     CODE     NEAR LAB  LVL=1
+      01001E28H   LINE      ---      ---       #121
+      01001E2CH   LINE      ---      ---       #122
+      00000021H.0 SYMBOL    BIT      VOID      st
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      010035B1H   BLOCK     CODE     ---       LVL=0
+      010035B1H   LINE      ---      ---       #125
+      010035B6H   LINE      ---      ---       #126
+      010035B6H   BLOCK     CODE     NEAR LAB  LVL=1
+      010035B6H   LINE      ---      ---       #127
+      010035C1H   LINE      ---      ---       #128
+      00000021H.1 SYMBOL    BIT      VOID      st
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      010035CEH   BLOCK     CODE     ---       LVL=0
+      010035CEH   LINE      ---      ---       #131
+      010035CEH   LINE      ---      ---       #132
+      010035CEH   BLOCK     CODE     NEAR LAB  LVL=1
+      010035CEH   LINE      ---      ---       #134
+      010035D0H   LINE      ---      ---       #135
+      01003601H   LINE      ---      ---       #136
+      00000007H   SYMBOL    DATA     VOID      i
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      ---         MODULE    ---      ---       IIC
+      01001C84H   PUBLIC    CODE     ---       _IIC_WriteBlock
+      01002182H   PUBLIC    CODE     ---       _IIC_write
+      010020CAH   PUBLIC    CODE     ---       _IIC_Read
+
+      0100217AH   BLOCK     CODE     ---       LVL=0
+      0100217AH   LINE      ---      ---       #11
+      0100217AH   LINE      ---      ---       #12
+      0100217AH   LINE      ---      ---       #13
+      01002181H   LINE      ---      ---       #14
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      010020CAH   BLOCK     CODE     ---       LVL=0
+      010020CAH   LINE      ---      ---       #16
+      010020DBH   LINE      ---      ---       #17
+      010020DBH   BLOCK     CODE     NEAR LAB  LVL=1
+      010020DBH   LINE      ---      ---       #18
+      010020DBH   LINE      ---      ---       #19
+      010020E4H   LINE      ---      ---       #20
+      010020EAH   LINE      ---      ---       #21
+      010020F0H   LINE      ---      ---       #22
+      010020F6H   LINE      ---      ---       #23
+      0100210FH   LINE      ---      ---       #24
+      01002124H   LINE      ---      ---       #25
+      0100213DH   LINE      ---      ---       #26
+      01002143H   LINE      ---      ---       #27
+      0100214BH   LINE      ---      ---       #28
+      01002152H   LINE      ---      ---       #29
+      01002152H   LINE      ---      ---       #30
+      01002159H   LINE      ---      ---       #31
+      0100215BH   LINE      ---      ---       #32
+      00000006H   SYMBOL    DATA     VOID      mem_src
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      01002182H   BLOCK     CODE     ---       LVL=0
+      01002182H   LINE      ---      ---       #35
+      0100219DH   LINE      ---      ---       #36
+      0100219DH   LINE      ---      ---       #37
+      010021BEH   LINE      ---      ---       #38
+      010021C4H   LINE      ---      ---       #39
+      010021D3H   LINE      ---      ---       #40
+      010021F0H   LINE      ---      ---       #41
+      01002207H   LINE      ---      ---       #42
+      0100220EH   LINE      ---      ---       #43
+      01002213H   LINE      ---      ---       #44
+      0100221AH   LINE      ---      ---       #45
+      ---         BLOCKEND  ---      ---       LVL=0
+
+      01001C84H   BLOCK     CODE     ---       LVL=0
+      01001C84H   LINE      ---      ---       #48
+      01001C9BH   LINE      ---      ---       #49
+      01001C9BH   BLOCK     CODE     NEAR LAB  LVL=1
+      01001C9BH   LINE      ---      ---       #51
+      01001CA7H   LINE      ---      ---       #52
+      01001CB7H   LINE      ---      ---       #53
+      01001CC5H   LINE      ---      ---       #54
+      01001CEBH   LINE      ---      ---       #55
+      01001CF8H   LINE      ---      ---       #56
+      01001D0EH   LINE      ---      ---       #57
+      01001D13H   LINE      ---      ---       #58
+      01001D24H   LINE      ---      ---       #59
+      01001D30H   LINE      ---      ---       #60
+      01001D32H   LINE      ---      ---       #61
+      00000004H   SYMBOL    DATA     VOID      cris
+      02004E9AH   SYMBOL    XDATA    VOID      curr_len
+      ---         BLOCKEND  CODE     ---       LVL=1
+      ---         BLOCKEND  CODE     ---       LVL=0
+
+      ---         MODULE    ---      ---       ?C?FPADD
+      0100000AH   PUBLIC    CODE     ---       ?C?FPADD
+      01000006H   PUBLIC    CODE     ---       ?C?FPSUB
+
+      ---         MODULE    ---      ---       ?C?FPMUL
+      010000FBH   PUBLIC    CODE     ---       ?C?FPMUL
+
+      ---         MODULE    ---      ---       ?C?FCAST
+      0100020BH   PUBLIC    CODE     ---       ?C?FCASTC
+      01000206H   PUBLIC    CODE     ---       ?C?FCASTI
+      01000201H   PUBLIC    CODE     ---       ?C?FCASTL
+
+      ---         MODULE    ---      ---       ?C?CASTF
+      0100023FH   PUBLIC    CODE     ---       ?C?CASTF
+
+      ---         MODULE    ---      ---       ?C?FPGETOPN
+      01000276H   PUBLIC    CODE     ---       ?C?FPGETOPN2
+      010002ABH   PUBLIC    CODE     ---       ?C?FPNANRESULT
+      010002B5H   PUBLIC    CODE     ---       ?C?FPOVERFLOW
+      0100028DH   PUBLIC    CODE     ---       ?C?FPRESULT
+      010002A1H   PUBLIC    CODE     ---       ?C?FPRESULT2
+      010002B2H   PUBLIC    CODE     ---       ?C?FPUNDERFLOW
+
+      ---         MODULE    ---      ---       ?C_STARTUP
+      01000000H   PUBLIC    CODE     ---       ?C_STARTUP
+
+      ---         MODULE    ---      ---       ?C?COPY
+      01000390H   PUBLIC    CODE     ---       ?C?COPY
+
+      ---         MODULE    ---      ---       ?C?CLDPTR
+      010003B6H   PUBLIC    CODE     ---       ?C?CLDPTR
+
+      ---         MODULE    ---      ---       ?C?CLDOPTR
+      010003CFH   PUBLIC    CODE     ---       ?C?CLDOPTR
+
+      ---         MODULE    ---      ---       ?C?CSTPTR
+      010003FCH   PUBLIC    CODE     ---       ?C?CSTPTR
+
+      ---         MODULE    ---      ---       ?C?IILDX
+      0100040EH   PUBLIC    CODE     ---       ?C?IILDX
+
+      ---         MODULE    ---      ---       ?C?ILDIX
+      01000424H   PUBLIC    CODE     ---       ?C?ILDIX
+
+      ---         MODULE    ---      ---       ?C?LMUL
+      0100043AH   PUBLIC    CODE     ---       ?C?LMUL
+
+      ---         MODULE    ---      ---       ?C?ULDIV
+      010004C5H   PUBLIC    CODE     ---       ?C?ULDIV
+
+      ---         MODULE    ---      ---       ?C?LNEG
+      01000557H   PUBLIC    CODE     ---       ?C?LNEG
+
+      ---         MODULE    ---      ---       ?C?ULCMP
+      01000565H   PUBLIC    CODE     ---       ?C?ULCMP
+
+      ---         MODULE    ---      ---       ?C?LSTXDATA
+      01000576H   PUBLIC    CODE     ---       ?C?LSTXDATA
+
+      ---         MODULE    ---      ---       ?C?LSTKXDATA
+      01000582H   PUBLIC    CODE     ---       ?C?LSTKXDATA
+
+      ---         MODULE    ---      ---       ?C?CCASE
+      010005B3H   PUBLIC    CODE     ---       ?C?CCASE
+
+      ---         MODULE    ---      ---       ?C?ICALL
+      010005D9H   PUBLIC    CODE     ---       ?C?ICALL
+      010005DDH   PUBLIC    CODE     ---       ?C?ICALL2
+
+      ---         MODULE    ---      ---       ?C_INIT
+      01000626H   PUBLIC    CODE     ---       ?C_START
+
+Program Size: data=10.2 xdata=899 const=182 code=13644
+LX51 RUN COMPLETE.  0 WARNING(S),  0 ERROR(S)
Index: c51/output/FW.SBR
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/output/FW.SBR
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/output/eeprom.dat
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/eeprom.dat	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/eeprom.dat	(working copy)
@@ -0,0 +1,32768 @@
+00
+02
+aa
+55
+b2
+19
+c5
+12
+80
+10
+c0
+00
+00
+2c
+c0
+01
+00
+30
+c0
+01
+80
+38
+c0
+02
+80
+42
+c0
+48
+01
+b5
+c0
+49
+01
+7b
+c0
+4a
+01
+81
+c0
+4a
+81
+6b
+c0
+58
+02
+99
+c0
+58
+81
+2f
+c0
+59
+01
+43
+c0
+59
+81
+5d
+c0
+5b
+01
+66
+c0
+5c
+81
+37
+20
+20
+3b
+f1
+c0
+19
+02
+a7
+c0
+1d
+d3
+b0
+c0
+1f
+02
+2d
+c0
+1f
+82
+31
+c0
+25
+03
+14
+c0
+25
+82
+a0
+c0
+26
+02
+aa
+c0
+27
+02
+b0
+c0
+2b
+02
+b7
+c0
+2d
+02
+c3
+c0
+30
+82
+be
+c0
+31
+82
+e3
+c0
+32
+03
+08
+c0
+32
+83
+3e
+c0
+34
+84
+a0
+c0
+35
+04
+84
+c0
+35
+84
+86
+c0
+37
+04
+ab
+c0
+37
+83
+1f
+c0
+43
+81
+03
+c0
+46
+82
+4c
+c0
+47
+02
+63
+c0
+47
+82
+35
+c0
+5e
+82
+43
+c0
+66
+81
+bf
+c0
+67
+81
+0f
+c0
+68
+01
+19
+20
+20
+3b
+f1
+68
+10
+81
+3b
+60
+00
+8b
+81
+70
+80
+06
+08
+20
+20
+30
+03
+20
+40
+77
+19
+20
+55
+bc
+f1
+20
+40
+78
+13
+68
+00
+c7
+dc
+20
+3a
+30
+13
+68
+00
+c7
+93
+20
+3a
+00
+32
+20
+20
+30
+13
+20
+40
+00
+9d
+20
+40
+00
+8f
+20
+40
+00
+47
+20
+40
+00
+3d
+20
+20
+30
+15
+68
+09
+47
+f4
+68
+00
+c3
+d8
+7d
+3a
+04
+0b
+60
+09
+47
+f4
+20
+60
+00
+00
+20
+40
+33
+92
+20
+40
+34
+07
+20
+40
+30
+24
+20
+40
+04
+cc
+20
+20
+30
+22
+68
+00
+c7
+dc
+20
+3a
+00
+4b
+68
+00
+c7
+93
+20
+7a
+00
+00
+20
+40
+00
+fe
+20
+74
+00
+00
+1f
+f0
+fe
+00
+1f
+e2
+0c
+00
+20
+40
+00
+df
+60
+00
+cb
+a7
+c0
+00
+80
+5f
+c0
+03
+00
+69
+1f
+e2
+04
+00
+18
+c2
+22
+00
+68
+00
+c0
+40
+c3
+00
+00
+5c
+1a
+22
+0c
+00
+c6
+84
+80
+00
+18
+42
+7e
+00
+c0
+02
+80
+6b
+20
+20
+3b
+f1
+1a
+22
+0c
+00
+d8
+a0
+00
+f8
+20
+20
+00
+d7
+20
+40
+00
+df
+20
+40
+00
+df
+60
+00
+8b
+7d
+20
+40
+00
+64
+20
+20
+7c
+33
+20
+40
+00
+e2
+18
+c2
+04
+00
+18
+50
+84
+00
+60
+09
+4b
+9a
+20
+60
+00
+00
+d8
+a0
+4d
+57
+20
+20
+00
+d7
+18
+c2
+22
+00
+68
+00
+cb
+a9
+1f
+e0
+84
+01
+18
+41
+04
+03
+60
+08
+cb
+a9
+1f
+ef
+fe
+07
+d8
+a0
+4b
+ad
+98
+a0
+8a
+00
+1a
+22
+0c
+00
+20
+40
+00
+df
+18
+c2
+22
+00
+1f
+e0
+ff
+ff
+1f
+e2
+72
+00
+1f
+e0
+fe
+07
+60
+00
+cc
+82
+1a
+22
+0c
+00
+20
+40
+00
+df
+18
+c2
+22
+00
+c0
+00
+80
+81
+c0
+01
+00
+89
+c0
+01
+80
+8b
+c0
+02
+00
+8d
+68
+01
+4c
+b8
+e0
+a1
+00
+00
+1a
+22
+0c
+00
+20
+40
+00
+d9
+20
+40
+56
+1e
+24
+7a
+00
+00
+70
+0b
+7d
+1b
+20
+20
+56
+20
+68
+01
+4c
+ba
+20
+20
+00
+82
+68
+01
+4c
+bc
+20
+20
+00
+82
+68
+01
+4d
+3e
+20
+20
+00
+82
+68
+0a
+4d
+4b
+1c
+42
+7e
+00
+98
+46
+7e
+00
+68
+09
+4d
+4f
+98
+46
+fc
+00
+20
+40
+7e
+fd
+18
+07
+fe
+00
+20
+7a
+00
+00
+1c
+42
+04
+00
+60
+0a
+4d
+4b
+68
+00
+cd
+51
+1f
+e0
+fe
+01
+60
+00
+cd
+51
+20
+60
+00
+00
+68
+0a
+4c
+59
+1c
+42
+7e
+00
+98
+46
+7e
+00
+d8
+40
+06
+40
+98
+46
+fc
+00
+20
+40
+7e
+fd
+18
+07
+fe
+00
+20
+7a
+00
+00
+1c
+42
+04
+00
+60
+0a
+4c
+59
+68
+09
+4b
+a5
+18
+50
+84
+00
+98
+40
+fe
+00
+1f
+f0
+fe
+00
+60
+01
+4b
+a5
+1f
+f0
+fe
+00
+1f
+e1
+7e
+03
+c1
+80
+00
+00
+68
+00
+cc
+8f
+c2
+80
+00
+ba
+c2
+80
+80
+bc
+da
+20
+00
+00
+20
+40
+00
+ce
+70
+89
+71
+8f
+68
+00
+cc
+90
+60
+10
+89
+73
+20
+40
+00
+bd
+da
+20
+00
+01
+20
+20
+00
+ce
+70
+89
+71
+bf
+20
+20
+00
+bd
+70
+89
+71
+af
+68
+10
+80
+53
+79
+20
+7e
+07
+60
+10
+80
+53
+68
+10
+89
+73
+1f
+e1
+fe
+30
+60
+10
+89
+73
+70
+89
+06
+74
+70
+89
+06
+7c
+70
+89
+72
+aa
+20
+00
+13
+88
+68
+19
+01
+50
+68
+10
+80
+53
+79
+3f
+fe
+07
+60
+10
+80
+53
+18
+50
+84
+00
+60
+09
+4c
+95
+20
+60
+00
+00
+d8
+40
+00
+21
+68
+00
+cc
+90
+98
+46
+04
+00
+1a
+22
+7e
+00
+79
+20
+04
+07
+24
+3a
+00
+d5
+79
+3f
+84
+07
+d8
+a0
+80
+78
+20
+20
+69
+f4
+20
+40
+00
+df
+1f
+e2
+72
+00
+20
+40
+00
+db
+20
+20
+00
+64
+20
+40
+00
+df
+e0
+a0
+80
+00
+c2
+00
+00
+db
+20
+60
+00
+00
+20
+40
+00
+e2
+e8
+c0
+80
+00
+20
+60
+00
+00
+58
+00
+4b
+36
+98
+c6
+7c
+00
+24
+62
+80
+00
+d8
+c0
+4a
+a0
+20
+60
+00
+00
+df
+20
+00
+03
+d8
+c0
+4b
+a2
+18
+c2
+22
+00
+68
+01
+4b
+a0
+1f
+f0
+fe
+00
+1f
+e2
+0a
+00
+1a
+22
+0c
+00
+e8
+c0
+80
+00
+e0
+a0
+80
+00
+20
+40
+00
+f6
+c2
+00
+00
+ee
+18
+a2
+7e
+00
+1f
+f0
+fe
+00
+60
+01
+4b
+a0
+20
+60
+00
+00
+58
+00
+4b
+9a
+98
+a6
+7c
+00
+24
+62
+80
+00
+d8
+a0
+4b
+36
+20
+60
+00
+00
+68
+01
+4b
+9e
+68
+09
+4b
+a0
+20
+20
+01
+00
+68
+01
+4b
+9a
+68
+09
+4b
+9c
+98
+46
+7c
+00
+20
+22
+e9
+b1
+20
+20
+32
+0b
+1c
+42
+7e
+00
+60
+02
+4d
+47
+68
+08
+c7
+ef
+68
+00
+cd
+4a
+98
+46
+7c
+00
+24
+41
+01
+0a
+20
+20
+7c
+06
+68
+0a
+4d
+47
+60
+0a
+47
+ec
+60
+0a
+4c
+59
+60
+0a
+4d
+4b
+20
+60
+00
+00
+da
+20
+47
+df
+20
+40
+7f
+9f
+20
+7a
+00
+00
+1f
+e2
+26
+00
+20
+40
+01
+15
+20
+20
+3e
+a5
+c1
+0c
+00
+00
+c0
+0a
+04
+bd
+c0
+0a
+82
+9e
+20
+20
+3e
+7d
+60
+08
+82
+59
+68
+00
+cc
+8d
+1f
+e0
+fe
+01
+60
+00
+cc
+8d
+68
+00
+82
+59
+20
+7a
+00
+00
+1f
+e0
+ff
+ff
+60
+00
+82
+59
+20
+40
+01
+23
+20
+20
+01
+1d
+68
+00
+cc
+15
+20
+7a
+00
+00
+1f
+e0
+ff
+ff
+60
+00
+cc
+15
+20
+60
+00
+00
+1a
+62
+7e
+00
+1f
+e1
+7e
+f0
+c1
+28
+00
+00
+1a
+62
+7e
+00
+20
+7a
+00
+00
+60
+00
+cb
+a4
+20
+20
+00
+e7
+70
+41
+6e
+7f
+20
+40
+3c
+f3
+68
+00
+cc
+97
+20
+7a
+00
+00
+70
+4c
+97
+00
+1c
+42
+7e
+00
+60
+02
+4c
+59
+20
+60
+00
+00
+68
+00
+c2
+19
+24
+7a
+00
+00
+70
+80
+42
+06
+58
+00
+0f
+0c
+20
+40
+3d
+a7
+58
+03
+0d
+40
+20
+40
+3b
+f3
+37
+d9
+82
+00
+1e
+22
+60
+00
+20
+40
+3b
+36
+20
+00
+13
+88
+20
+20
+3d
+9d
+c6
+11
+80
+00
+68
+01
+47
+f4
+c2
+84
+bd
+1e
+20
+40
+3c
+ab
+68
+01
+c2
+10
+20
+7a
+00
+00
+68
+00
+c1
+31
+20
+7a
+00
+00
+20
+40
+52
+7e
+24
+7a
+00
+00
+20
+40
+3d
+ca
+24
+7a
+00
+00
+20
+40
+3b
+36
+68
+00
+c7
+dc
+20
+3a
+3d
+25
+68
+00
+c7
+93
+20
+7a
+00
+00
+20
+20
+3d
+25
+20
+40
+00
+fe
+24
+74
+00
+00
+20
+40
+00
+fb
+24
+74
+00
+00
+70
+0b
+7f
+01
+70
+0b
+7e
+01
+20
+40
+01
+62
+20
+20
+00
+fe
+20
+40
+01
+55
+24
+74
+00
+00
+68
+00
+8b
+7f
+24
+7a
+00
+00
+20
+20
+3d
+2d
+68
+00
+8b
+7e
+20
+00
+00
+0a
+c0
+80
+01
+62
+20
+60
+00
+00
+20
+40
+01
+55
+24
+74
+00
+00
+68
+00
+8b
+7f
+24
+7a
+00
+00
+20
+20
+3d
+4f
+20
+40
+01
+6d
+20
+20
+3a
+af
+68
+00
+c2
+19
+24
+3a
+01
+73
+20
+40
+3d
+91
+20
+00
+75
+30
+20
+00
+75
+30
+20
+00
+75
+30
+20
+40
+3b
+0a
+70
+80
+42
+04
+68
+10
+89
+6b
+1f
+e1
+7e
+cf
+60
+10
+89
+6b
+1f
+e1
+fe
+30
+60
+10
+89
+6b
+20
+60
+00
+00
+60
+08
+80
+17
+18
+40
+a2
+04
+20
+20
+3a
+86
+60
+08
+80
+17
+18
+40
+a2
+00
+20
+20
+3a
+b6
+20
+40
+01
+7e
+58
+00
+05
+00
+20
+40
+3b
+f3
+70
+89
+06
+01
+70
+89
+00
+3c
+70
+89
+01
+e0
+70
+89
+6d
+12
+20
+00
+00
+0a
+70
+89
+02
+01
+70
+89
+02
+3d
+20
+00
+00
+0a
+70
+89
+03
+b7
+20
+00
+00
+0a
+70
+89
+02
+7d
+68
+00
+cb
+ef
+c0
+ff
+81
+99
+68
+02
+ca
+91
+e0
+a2
+80
+00
+e8
+c2
+80
+00
+e0
+a2
+80
+00
+70
+89
+56
+df
+20
+40
+01
+a4
+70
+89
+55
+df
+20
+60
+00
+00
+68
+02
+ca
+87
+e0
+a2
+80
+00
+e8
+c2
+80
+00
+e0
+a2
+80
+00
+68
+00
+cc
+7d
+20
+5a
+01
+a2
+60
+10
+89
+56
+70
+89
+55
+d0
+20
+60
+00
+00
+58
+00
+00
+c2
+20
+60
+00
+00
+20
+00
+00
+04
+70
+89
+55
+d1
+20
+00
+00
+04
+70
+89
+55
+d2
+20
+00
+00
+04
+70
+89
+55
+d4
+20
+00
+00
+04
+20
+60
+00
+00
+70
+89
+55
+d4
+20
+00
+00
+04
+70
+89
+55
+d2
+20
+00
+00
+04
+70
+89
+55
+d1
+20
+00
+00
+04
+70
+89
+55
+d0
+70
+89
+56
+c0
+20
+60
+00
+00
+20
+30
+ba
+6f
+20
+40
+01
+ac
+20
+20
+3a
+6f
+78
+34
+7c
+00
+68
+12
+01
+38
+79
+34
+7e
+1a
+60
+12
+00
+4c
+20
+40
+3d
+b0
+70
+00
+a2
+01
+20
+60
+00
+00
+68
+00
+c4
+19
+1f
+e0
+fe
+02
+60
+00
+c3
+f9
+70
+0b
+7e
+00
+70
+01
+77
+06
+20
+40
+3f
+a4
+58
+00
+01
+be
+60
+01
+42
+8a
+58
+00
+01
+28
+60
+01
+42
+92
+58
+00
+02
+34
+60
+01
+42
+90
+58
+00
+00
+47
+60
+01
+42
+8c
+58
+00
+01
+b8
+60
+01
+42
+88
+58
+00
+4a
+a0
+1f
+f0
+fe
+00
+60
+01
+4b
+9a
+60
+01
+4b
+9c
+20
+40
+3e
+0b
+58
+00
+4b
+36
+1f
+f0
+fe
+00
+60
+01
+4b
+9e
+60
+01
+4b
+a0
+68
+00
+cc
+97
+c0
+2d
+01
+f0
+20
+35
+81
+ee
+68
+01
+4c
+91
+1f
+f0
+fe
+00
+60
+01
+4c
+91
+68
+01
+4c
+93
+1f
+f0
+fe
+00
+60
+01
+4c
+93
+20
+40
+01
+fb
+68
+04
+02
+a0
+24
+3a
+01
+e8
+68
+01
+4a
+d4
+1f
+f0
+fe
+00
+20
+3a
+01
+e8
+60
+01
+4c
+93
+20
+40
+04
+c9
+70
+4b
+a4
+2f
+20
+40
+00
+e7
+70
+4c
+97
+00
+70
+82
+80
+03
+20
+60
+00
+00
+70
+4b
+a4
+30
+20
+20
+01
+ea
+1c
+e2
+7e
+00
+20
+3a
+02
+3b
+20
+40
+5b
+63
+20
+40
+4d
+99
+58
+00
+00
+00
+60
+04
+40
+40
+60
+01
+47
+f4
+1c
+42
+7e
+00
+60
+02
+4c
+59
+70
+4b
+a4
+33
+20
+20
+01
+ea
+20
+40
+68
+8a
+58
+00
+07
+e0
+da
+20
+02
+a0
+d8
+40
+00
+0e
+20
+40
+68
+d3
+20
+40
+68
+8d
+68
+00
+82
+a0
+c2
+80
+bb
+f1
+68
+04
+02
+a2
+20
+7a
+00
+00
+68
+00
+cc
+8f
+c2
+80
+02
+0f
+c2
+80
+82
+1d
+68
+01
+02
+a2
+1f
+f0
+fe
+00
+60
+01
+4c
+91
+68
+01
+02
+a8
+1f
+f0
+fe
+00
+60
+01
+4c
+93
+20
+60
+00
+00
+68
+09
+02
+a6
+68
+01
+02
+ac
+18
+42
+24
+00
+1f
+e2
+22
+00
+1f
+f0
+fe
+00
+60
+01
+4c
+93
+1a
+22
+7e
+00
+98
+46
+26
+00
+1a
+63
+a6
+00
+1a
+42
+7e
+00
+9a
+66
+7e
+00
+1f
+f0
+fe
+00
+60
+01
+4c
+91
+20
+60
+00
+00
+68
+09
+02
+a4
+68
+01
+02
+aa
+18
+42
+24
+00
+1f
+e2
+22
+00
+98
+46
+26
+00
+1a
+6b
+26
+00
+1a
+42
+7e
+00
+9a
+66
+7e
+00
+1f
+f0
+fe
+00
+60
+01
+4c
+91
+1a
+63
+a6
+00
+1a
+22
+7e
+00
+9a
+66
+7e
+00
+1f
+f0
+fe
+00
+60
+01
+4c
+93
+20
+60
+00
+00
+70
+00
+16
+27
+70
+89
+0f
+36
+70
+89
+0b
+5f
+20
+20
+53
+d4
+70
+89
+0f
+2e
+70
+89
+0b
+ff
+20
+20
+53
+d9
+20
+60
+00
+00
+68
+01
+4b
+a0
+60
+01
+4b
+9e
+68
+01
+4b
+9c
+60
+01
+4b
+9a
+70
+0b
+7e
+03
+20
+40
+01
+62
+70
+4c
+97
+5a
+20
+40
+3d
+b8
+68
+12
+01
+38
+79
+3f
+fe
+0f
+60
+12
+00
+4c
+20
+40
+3d
+b0
+d8
+5f
+ff
+ff
+20
+20
+3c
+da
+ea
+2a
+80
+00
+18
+41
+7e
+ff
+24
+3a
+02
+48
+18
+4c
+fe
+00
+e2
+22
+80
+00
+1a
+20
+a2
+04
+ea
+20
+80
+00
+24
+7a
+00
+00
+20
+20
+7f
+9c
+20
+40
+7c
+20
+da
+20
+47
+e4
+20
+40
+7f
+9f
+1f
+e2
+04
+00
+20
+40
+7c
+24
+18
+42
+7e
+00
+20
+7a
+00
+00
+c0
+10
+82
+5c
+c0
+11
+02
+5e
+c0
+11
+85
+5c
+c0
+06
+82
+6c
+c0
+16
+02
+6c
+c0
+15
+82
+77
+c0
+15
+02
+91
+c0
+09
+7c
+85
+20
+20
+7c
+5a
+70
+4b
+ef
+ff
+20
+20
+05
+8f
+79
+3f
+80
+23
+70
+4b
+ef
+ff
+20
+20
+05
+47
+70
+0b
+7d
+22
+20
+20
+56
+20
+68
+00
+80
+7c
+20
+3a
+02
+68
+20
+40
+61
+d9
+68
+00
+80
+7c
+24
+3a
+7c
+8c
+68
+00
+8b
+7d
+c5
+84
+fc
+87
+c0
+08
+82
+61
+20
+20
+7c
+7b
+20
+40
+3e
+ff
+20
+40
+7c
+d5
+70
+41
+31
+00
+18
+0a
+7e
+00
+60
+00
+c4
+f9
+70
+43
+dc
+05
+58
+18
+12
+03
+60
+01
+c3
+e2
+d8
+40
+00
+07
+20
+40
+02
+7d
+20
+20
+7c
+ae
+70
+43
+dc
+04
+58
+00
+00
+ff
+60
+01
+c3
+e2
+d8
+40
+00
+00
+20
+40
+02
+7d
+20
+20
+7c
+ae
+68
+00
+c3
+f9
+98
+40
+fe
+00
+1f
+e0
+fe
+0b
+1f
+e6
+7c
+1f
+24
+21
+02
+8d
+60
+00
+c3
+d9
+d8
+a0
+43
+e5
+18
+42
+7e
+00
+24
+5a
+02
+8a
+68
+00
+c3
+f9
+1f
+e2
+72
+00
+d8
+c0
+43
+fa
+20
+20
+7e
+45
+1f
+e2
+72
+00
+d8
+c0
+4d
+6b
+20
+20
+7e
+45
+68
+00
+c3
+f9
+1f
+e0
+fe
+0b
+60
+00
+c3
+d9
+20
+60
+00
+00
+68
+01
+47
+f4
+c2
+84
+bf
+90
+c2
+83
+fc
+d5
+c5
+11
+85
+47
+70
+43
+d8
+00
+20
+40
+3f
+7e
+70
+0b
+7d
+37
+20
+20
+7c
+27
+20
+40
+3b
+36
+20
+20
+3c
+dc
+e8
+c0
+80
+00
+60
+00
+cc
+b7
+20
+60
+00
+00
+70
+4d
+7e
+00
+20
+20
+04
+c2
+20
+40
+54
+bd
+68
+08
+80
+17
+20
+40
+3a
+82
+20
+40
+3a
+87
+78
+28
+7c
+00
+d9
+60
+15
+7c
+20
+20
+54
+7f
+70
+44
+3e
+01
+70
+44
+3f
+00
+20
+20
+53
+4e
+20
+40
+53
+dd
+20
+40
+02
+ad
+20
+20
+54
+c1
+20
+36
+81
+84
+20
+40
+53
+ee
+20
+20
+3a
+91
+68
+00
+cc
+60
+60
+02
+46
+f9
+68
+00
+c4
+db
+c0
+00
+82
+b5
+20
+20
+54
+e0
+70
+44
+db
+00
+20
+20
+54
+ef
+68
+00
+83
+c0
+c4
+02
+80
+00
+68
+01
+03
+da
+68
+09
+03
+e0
+98
+46
+7e
+00
+24
+61
+00
+00
+20
+20
+55
+7e
+68
+00
+83
+d7
+c3
+82
+80
+00
+68
+00
+83
+41
+20
+3a
+56
+26
+20
+20
+58
+90
+68
+08
+83
+d7
+28
+4c
+00
+05
+20
+60
+80
+00
+68
+00
+83
+40
+1f
+e3
+fe
+00
+98
+42
+fe
+00
+c4
+01
+80
+00
+79
+3f
+84
+05
+79
+40
+04
+03
+60
+08
+83
+d7
+28
+40
+06
+03
+24
+60
+80
+00
+68
+00
+c4
+40
+c0
+02
+82
+d4
+68
+00
+cd
+7e
+c0
+00
+82
+d8
+20
+60
+00
+00
+68
+00
+83
+c0
+79
+20
+7e
+04
+60
+00
+83
+c0
+20
+60
+00
+00
+70
+4d
+7e
+00
+df
+e0
+00
+00
+60
+02
+44
+6f
+60
+00
+c4
+8b
+60
+02
+c4
+65
+79
+20
+7e
+27
+60
+02
+c4
+6a
+68
+00
+83
+c0
+79
+3f
+fe
+04
+60
+00
+83
+c0
+20
+60
+00
+00
+68
+00
+c4
+40
+c0
+03
+82
+fd
+c0
+07
+83
+01
+c0
+03
+02
+f0
+c0
+01
+02
+ed
+c0
+09
+82
+eb
+c0
+05
+82
+eb
+20
+20
+56
+3a
+18
+00
+04
+01
+20
+20
+58
+92
+58
+00
+00
+0a
+60
+01
+03
+ef
+20
+20
+56
+93
+70
+0b
+7d
+12
+20
+40
+7c
+33
+18
+00
+04
+01
+20
+34
+d8
+92
+70
+0b
+7d
+34
+20
+40
+7c
+27
+68
+00
+cc
+69
+c0
+01
+02
+f9
+20
+20
+02
+fb
+70
+0b
+7d
+46
+20
+40
+56
+20
+18
+00
+04
+01
+20
+20
+58
+92
+68
+00
+cc
+68
+e0
+a0
+80
+00
+18
+00
+04
+02
+20
+20
+58
+92
+18
+a0
+8b
+ff
+68
+04
+4c
+6c
+e0
+a4
+00
+00
+e8
+c4
+00
+00
+e0
+a4
+00
+00
+18
+00
+02
+02
+20
+20
+58
+8a
+68
+00
+c4
+44
+c0
+04
+d7
+19
+c0
+01
+03
+0d
+c0
+03
+d7
+0d
+20
+20
+56
+56
+59
+00
+03
+02
+60
+01
+c4
+b5
+58
+00
+00
+01
+e0
+a0
+80
+00
+58
+01
+00
+10
+e0
+a1
+80
+00
+20
+20
+56
+f1
+09
+80
+00
+18
+78
+28
+7c
+00
+db
+60
+06
+64
+1f
+ef
+7e
+00
+1f
+f1
+7e
+00
+e0
+a1
+80
+00
+20
+23
+37
+5c
+78
+36
+fc
+00
+68
+00
+80
+17
+1f
+e0
+a2
+00
+20
+20
+54
+af
+e8
+c1
+80
+00
+60
+01
+83
+f9
+c0
+29
+03
+25
+c0
+01
+03
+3c
+c0
+09
+03
+2b
+20
+20
+59
+07
+70
+4d
+38
+01
+68
+01
+03
+fa
+c0
+10
+83
+29
+20
+20
+59
+ed
+d8
+c0
+03
+49
+20
+20
+02
+9b
+68
+01
+03
+fa
+1f
+e6
+7c
+21
+20
+42
+83
+29
+68
+01
+03
+fa
+1f
+e6
+7c
+2d
+20
+42
+83
+3a
+68
+01
+03
+fa
+68
+09
+4c
+bc
+18
+40
+84
+01
+98
+46
+7c
+00
+20
+22
+83
+37
+20
+20
+59
+ca
+70
+0b
+7d
+34
+20
+40
+7c
+27
+20
+20
+59
+ca
+70
+41
+31
+01
+20
+60
+00
+00
+70
+0b
+7d
+03
+20
+20
+56
+20
+68
+00
+c4
+44
+c0
+0d
+84
+76
+c0
+0e
+84
+76
+c0
+08
+84
+0a
+c0
+04
+83
+bc
+c0
+02
+83
+aa
+c0
+03
+83
+5e
+c0
+09
+d8
+5c
+c0
+01
+83
+4f
+c0
+05
+83
+52
+c0
+06
+83
+4a
+20
+20
+56
+66
+68
+01
+03
+fa
+c0
+03
+83
+4d
+20
+20
+57
+d6
+70
+03
+fc
+07
+20
+20
+57
+29
+68
+01
+4c
+6a
+e0
+a1
+00
+00
+20
+20
+58
+8a
+68
+01
+03
+fa
+c0
+07
+03
+55
+20
+20
+57
+c6
+68
+00
+cc
+69
+c0
+80
+57
+c6
+68
+00
+cc
+7c
+c0
+01
+d7
+c6
+18
+a2
+04
+00
+70
+4c
+69
+01
+18
+42
+0a
+00
+70
+03
+fc
+05
+20
+20
+57
+29
+20
+40
+57
+7b
+20
+74
+00
+00
+68
+09
+44
+c0
+58
+00
+18
+12
+98
+46
+7c
+00
+20
+22
+83
+77
+58
+00
+18
+0f
+98
+46
+7c
+00
+20
+22
+83
+79
+58
+00
+18
+0a
+98
+46
+7c
+00
+20
+22
+83
+7d
+58
+00
+18
+01
+98
+46
+7c
+00
+20
+22
+83
+7b
+20
+20
+57
+54
+68
+00
+cc
+7f
+d8
+40
+00
+00
+f9
+20
+04
+00
+98
+41
+7e
+00
+c0
+80
+57
+28
+68
+00
+cc
+7f
+f9
+20
+7e
+00
+60
+00
+cc
+7f
+20
+20
+03
+7f
+d8
+e0
+00
+00
+20
+20
+03
+6e
+d8
+e0
+00
+01
+20
+20
+03
+6e
+d8
+e0
+00
+03
+20
+20
+03
+6e
+d8
+e0
+00
+02
+20
+20
+03
+6e
+68
+01
+44
+c0
+1f
+e2
+22
+00
+68
+09
+44
+c4
+18
+42
+24
+00
+20
+40
+03
+86
+20
+22
+83
+91
+20
+20
+57
+28
+d8
+c0
+45
+04
+e8
+c1
+00
+00
+20
+7a
+00
+00
+e8
+c1
+80
+00
+e8
+c1
+00
+00
+9a
+26
+7c
+00
+20
+62
+80
+00
+18
+c0
+8d
+fd
+e8
+c0
+80
+00
+98
+c0
+8c
+00
+20
+20
+03
+87
+18
+c0
+8d
+f9
+e8
+c1
+00
+00
+60
+01
+4c
+61
+20
+40
+03
+9f
+20
+3a
+57
+28
+18
+c0
+8d
+fc
+e8
+c1
+00
+00
+1f
+e0
+ff
+ff
+60
+01
+4c
+63
+70
+44
+44
+07
+68
+02
+4c
+61
+60
+02
+44
+45
+18
+00
+04
+09
+20
+20
+58
+92
+e8
+c1
+00
+00
+e8
+c0
+80
+00
+98
+c0
+8c
+00
+e8
+c1
+00
+00
+20
+7a
+00
+00
+e8
+c1
+00
+00
+9a
+46
+7c
+00
+20
+62
+80
+00
+e8
+c0
+80
+00
+98
+c0
+8c
+00
+20
+20
+03
+a2
+d9
+60
+00
+03
+18
+00
+7e
+01
+60
+00
+c4
+45
+20
+40
+5a
+74
+20
+40
+5a
+7d
+20
+3a
+57
+46
+24
+21
+03
+ba
+78
+54
+7c
+00
+e0
+a1
+00
+00
+e8
+c1
+00
+00
+e0
+a1
+00
+00
+19
+60
+97
+ff
+20
+22
+d7
+46
+e8
+c0
+80
+00
+98
+c0
+8c
+00
+20
+20
+03
+ae
+18
+c0
+8c
+02
+20
+20
+03
+b7
+68
+09
+44
+c0
+58
+00
+2a
+00
+98
+46
+7c
+00
+20
+22
+83
+fc
+58
+00
+2a
+50
+98
+46
+7c
+00
+20
+22
+84
+07
+58
+00
+28
+03
+98
+46
+7c
+00
+24
+22
+d7
+28
+68
+01
+44
+bc
+60
+01
+02
+a0
+78
+34
+7c
+00
+20
+40
+04
+4e
+24
+21
+03
+d8
+68
+09
+02
+a0
+20
+40
+04
+56
+c0
+00
+83
+d8
+20
+40
+04
+52
+24
+22
+83
+d6
+78
+54
+7c
+00
+20
+40
+03
+da
+20
+40
+04
+3c
+20
+40
+04
+56
+20
+40
+03
+e2
+20
+20
+03
+d8
+20
+40
+04
+3c
+20
+20
+03
+c9
+20
+34
+57
+28
+20
+20
+04
+74
+68
+01
+02
+a0
+60
+01
+44
+46
+68
+00
+cc
+67
+1f
+e2
+72
+00
+20
+40
+04
+6b
+d8
+a0
+44
+48
+20
+40
+7e
+45
+20
+20
+04
+6e
+68
+09
+4c
+65
+18
+4c
+fe
+00
+c0
+82
+83
+f4
+20
+40
+04
+68
+68
+01
+02
+a0
+e0
+a1
+00
+00
+20
+40
+04
+6e
+58
+00
+45
+04
+98
+40
+8c
+00
+e8
+c0
+80
+00
+18
+c2
+04
+00
+1f
+e2
+72
+00
+1f
+e0
+fe
+05
+60
+00
+c4
+45
+20
+40
+04
+68
+18
+42
+0c
+00
+20
+40
+7e
+45
+20
+20
+04
+6e
+20
+40
+04
+68
+68
+01
+02
+a0
+e0
+a1
+00
+00
+68
+01
+4c
+65
+e0
+a1
+00
+00
+20
+40
+04
+6e
+70
+44
+45
+07
+20
+60
+00
+00
+20
+40
+5b
+08
+e8
+c0
+80
+00
+1f
+e2
+72
+00
+1f
+e0
+fe
+02
+60
+00
+c4
+45
+18
+c0
+8d
+fb
+e8
+c1
+00
+00
+e0
+a1
+00
+00
+18
+c0
+8c
+03
+20
+40
+7e
+45
+20
+20
+58
+8a
+d8
+40
+2a
+50
+20
+40
+5b
+0c
+20
+20
+03
+fd
+d9
+60
+00
+02
+68
+01
+44
+bc
+60
+01
+02
+a0
+70
+0d
+5c
+00
+78
+34
+7c
+00
+20
+40
+04
+4e
+24
+21
+04
+32
+68
+09
+02
+a0
+20
+40
+04
+56
+c0
+00
+84
+35
+20
+40
+04
+52
+24
+22
+84
+2e
+68
+00
+8d
+5c
+c0
+00
+84
+35
+24
+34
+04
+1f
+78
+54
+7c
+00
+68
+00
+cc
+67
+1f
+e0
+fe
+04
+60
+00
+c4
+45
+20
+40
+04
+6e
+20
+20
+04
+29
+68
+00
+cc
+67
+1f
+e6
+7c
+10
+20
+22
+84
+35
+68
+00
+c4
+45
+1f
+e6
+7c
+10
+20
+22
+84
+35
+68
+01
+02
+a0
+1f
+e0
+ff
+ff
+60
+01
+0d
+5a
+20
+40
+04
+45
+68
+01
+02
+a0
+60
+01
+0d
+58
+20
+40
+04
+40
+19
+60
+97
+ff
+20
+22
+84
+30
+20
+40
+04
+3c
+20
+20
+04
+0f
+70
+0d
+5c
+01
+20
+20
+04
+2e
+68
+01
+02
+a0
+60
+01
+0d
+5a
+20
+20
+04
+39
+68
+01
+02
+a0
+1f
+e0
+ff
+ff
+60
+01
+0d
+5a
+20
+20
+04
+39
+20
+34
+57
+28
+20
+40
+04
+45
+20
+20
+04
+74
+68
+09
+02
+a0
+18
+40
+84
+01
+60
+09
+02
+a0
+20
+60
+00
+00
+68
+00
+cc
+67
+60
+00
+81
+03
+1f
+e2
+72
+00
+20
+40
+04
+6b
+20
+20
+7e
+45
+20
+40
+04
+68
+68
+01
+0d
+58
+e0
+a1
+00
+00
+68
+01
+0d
+5a
+e0
+a1
+00
+00
+68
+00
+81
+03
+1f
+e2
+72
+00
+20
+40
+7e
+45
+20
+20
+04
+6e
+68
+09
+02
+a0
+68
+01
+44
+be
+98
+46
+7c
+00
+20
+60
+00
+00
+68
+01
+44
+c0
+68
+09
+4c
+65
+98
+46
+7c
+00
+20
+60
+00
+00
+d8
+c0
+45
+04
+18
+42
+22
+00
+e8
+c1
+00
+00
+20
+3a
+04
+61
+e8
+c9
+00
+00
+60
+09
+4c
+65
+9a
+26
+7c
+00
+20
+22
+84
+63
+e8
+c0
+80
+00
+98
+c0
+8c
+00
+20
+20
+04
+58
+58
+00
+00
+01
+20
+60
+00
+00
+e8
+c0
+80
+00
+60
+00
+cc
+67
+20
+40
+04
+71
+58
+00
+00
+00
+20
+60
+00
+00
+68
+01
+02
+b9
+1f
+e2
+0a
+00
+20
+60
+00
+00
+68
+01
+02
+b7
+1f
+e2
+0c
+00
+20
+60
+00
+00
+18
+a2
+7e
+00
+60
+01
+02
+b9
+20
+60
+00
+00
+18
+c2
+7e
+00
+60
+01
+02
+b7
+20
+60
+00
+00
+20
+40
+04
+68
+20
+20
+58
+8a
+68
+00
+cb
+ab
+1f
+e0
+84
+01
+18
+41
+04
+03
+60
+08
+cb
+ab
+1f
+ef
+fe
+07
+d8
+c0
+4b
+ad
+98
+c0
+8c
+00
+68
+00
+cc
+82
+1f
+e0
+ff
+fb
+1f
+e2
+72
+00
+d8
+a0
+44
+45
+20
+40
+7e
+45
+68
+08
+cc
+82
+20
+20
+58
+92
+20
+40
+56
+1c
+20
+20
+58
+b0
+1a
+62
+7e
+00
+c0
+01
+84
+96
+c0
+05
+04
+9a
+c0
+00
+04
+91
+c0
+09
+04
+98
+c0
+01
+04
+9d
+1f
+e6
+7c
+0d
+20
+21
+58
+c0
+60
+00
+cc
+68
+70
+0b
+7d
+27
+20
+20
+56
+20
+20
+40
+59
+24
+68
+01
+44
+37
+1f
+ef
+84
+04
+60
+09
+4d
+4f
+20
+60
+00
+00
+70
+4c
+7c
+00
+20
+20
+59
+38
+70
+0b
+7d
+33
+20
+20
+56
+20
+70
+4d
+7e
+01
+70
+0b
+7d
+2b
+20
+20
+56
+20
+58
+00
+00
+14
+60
+01
+03
+ef
+20
+60
+00
+00
+68
+00
+c4
+3e
+28
+20
+06
+01
+20
+20
+84
+a4
+20
+20
+58
+a7
+68
+00
+c4
+3f
+20
+3a
+04
+a7
+20
+20
+58
+a7
+68
+00
+c4
+3e
+79
+3f
+fe
+04
+60
+00
+c4
+3e
+20
+60
+00
+00
+e8
+c0
+80
+00
+c0
+00
+84
+b2
+c0
+02
+04
+b8
+c0
+04
+84
+b0
+20
+20
+58
+f8
+70
+4c
+69
+03
+20
+20
+59
+74
+70
+4d
+3d
+01
+60
+00
+c4
+ae
+e8
+c3
+00
+00
+e0
+a3
+00
+00
+70
+0b
+7d
+42
+20
+20
+56
+20
+20
+40
+74
+a8
+20
+22
+84
+bb
+20
+20
+59
+68
+70
+4c
+69
+02
+20
+20
+59
+6a
+70
+4c
+7d
+00
+20
+40
+3f
+86
+20
+40
+3f
+7e
+20
+40
+3f
+a4
+20
+20
+3e
+cc
+70
+42
+13
+00
+70
+44
+8b
+00
+70
+4c
+7c
+00
+70
+4c
+69
+00
+70
+4c
+7f
+00
+70
+4c
+7d
+00
+20
+20
+3e
+d0
+58
+00
+00
+00
+60
+02
+4b
+a9
+20
+60
+00
+00
+c6
+91
+80
+00
+68
+02
+4d
+40
+60
+02
+4d
+72
+20
+40
+04
+f2
+24
+34
+04
+e5
+70
+4c
+15
+0a
+20
+40
+05
+13
+68
+00
+cb
+ef
+c1
+ff
+80
+00
+70
+4c
+3d
+02
+68
+00
+cd
+45
+24
+7a
+00
+00
+20
+40
+01
+55
+24
+74
+00
+00
+68
+00
+8b
+7f
+24
+7a
+00
+00
+20
+40
+3c
+ab
+68
+01
+c2
+10
+20
+7a
+00
+00
+68
+00
+c1
+31
+20
+7a
+00
+00
+68
+01
+cd
+7a
+20
+40
+7e
+8a
+60
+0a
+41
+fc
+20
+20
+3c
+da
+20
+40
+01
+55
+24
+74
+00
+00
+68
+00
+8b
+7f
+24
+7a
+00
+00
+20
+40
+3c
+ab
+68
+01
+c2
+10
+20
+7a
+00
+00
+68
+00
+c1
+31
+20
+7a
+00
+00
+68
+00
+cc
+15
+24
+3a
+04
+e1
+68
+02
+4d
+72
+20
+20
+04
+e2
+68
+00
+cb
+ef
+c0
+ff
+85
+65
+20
+40
+04
+f9
+20
+54
+05
+10
+20
+54
+05
+d4
+70
+4b
+e6
+01
+20
+60
+00
+00
+78
+54
+7c
+00
+70
+4b
+e2
+02
+68
+00
+cd
+57
+c0
+02
+05
+03
+c0
+02
+85
+06
+c0
+03
+85
+0c
+c0
+03
+05
+09
+68
+00
+cd
+45
+24
+5a
+34
+df
+20
+60
+00
+00
+70
+4d
+57
+00
+70
+4b
+e1
+0a
+20
+20
+05
+0e
+70
+4d
+57
+03
+70
+4b
+e1
+04
+20
+20
+05
+0e
+70
+4d
+57
+02
+70
+4b
+e1
+03
+20
+20
+05
+0e
+70
+4b
+e2
+01
+70
+4b
+e1
+08
+70
+4b
+e7
+00
+20
+20
+34
+df
+68
+04
+cd
+57
+60
+04
+8c
+d5
+20
+60
+00
+00
+70
+4b
+e8
+00
+d9
+60
+0d
+00
+34
+73
+02
+00
+20
+40
+05
+3a
+24
+37
+85
+23
+20
+40
+05
+4a
+68
+00
+cb
+e0
+1f
+e0
+fe
+01
+60
+00
+cb
+e0
+70
+4d
+45
+00
+68
+00
+cb
+ef
+c0
+ff
+85
+39
+20
+40
+05
+35
+70
+4b
+e7
+00
+70
+4b
+e6
+00
+20
+60
+00
+00
+70
+4d
+45
+01
+68
+00
+cb
+e7
+1f
+e0
+fe
+01
+60
+00
+cb
+e7
+68
+00
+cb
+ef
+c0
+ff
+85
+45
+68
+00
+cb
+e7
+c0
+7f
+85
+47
+68
+00
+cb
+e7
+d8
+40
+00
+10
+98
+46
+7c
+00
+20
+21
+05
+f3
+68
+00
+cb
+e8
+1f
+e0
+fe
+01
+60
+00
+cb
+e8
+20
+00
+00
+0a
+c0
+83
+85
+14
+20
+20
+05
+f3
+58
+00
+00
+00
+60
+04
+8c
+d5
+60
+04
+cd
+57
+20
+60
+00
+00
+20
+20
+05
+7f
+78
+57
+fc
+00
+20
+40
+06
+4b
+18
+00
+2a
+00
+68
+02
+4c
+00
+98
+00
+12
+00
+68
+08
+80
+17
+20
+40
+3a
+82
+20
+40
+3a
+87
+20
+40
+06
+0b
+20
+57
+86
+45
+20
+60
+00
+00
+70
+4d
+45
+00
+20
+60
+00
+00
+70
+4d
+45
+00
+70
+0b
+7d
+32
+20
+20
+7c
+27
+20
+40
+05
+b4
+68
+00
+8c
+b3
+c1
+81
+00
+00
+68
+00
+cb
+df
+20
+7a
+00
+00
+98
+00
+72
+00
+d8
+c0
+0c
+b5
+d8
+a0
+0d
+17
+20
+40
+7e
+45
+68
+00
+8c
+b4
+2f
+e1
+f0
+08
+24
+60
+80
+00
+68
+00
+8c
+b5
+c0
+7f
+85
+5a
+60
+00
+cc
+b7
+20
+60
+00
+00
+70
+4d
+7d
+01
+20
+60
+00
+00
+79
+20
+00
+23
+20
+40
+05
+61
+20
+40
+05
+1f
+70
+4b
+ef
+01
+20
+60
+00
+00
+70
+4b
+e0
+00
+70
+4b
+e9
+4e
+68
+02
+4b
+eb
+20
+20
+05
+c6
+20
+40
+05
+61
+68
+00
+cb
+e6
+c0
+00
+b4
+df
+68
+00
+cb
+ef
+c0
+00
+85
+6d
+c0
+01
+05
+70
+c0
+01
+85
+73
+20
+20
+3b
+f1
+70
+4b
+ef
+11
+70
+0d
+37
+aa
+20
+20
+05
+75
+70
+4b
+ef
+12
+70
+0d
+37
+55
+20
+20
+05
+75
+70
+4b
+ef
+13
+70
+0d
+37
+22
+70
+0d
+38
+02
+68
+02
+4c
+06
+60
+02
+0d
+39
+70
+0d
+3d
+00
+da
+20
+0d
+37
+d8
+40
+00
+07
+20
+40
+05
+af
+20
+40
+05
+d4
+20
+40
+04
+f7
+20
+20
+34
+df
+68
+00
+cb
+ef
+c1
+7f
+80
+00
+c0
+08
+85
+85
+c0
+09
+05
+87
+c0
+09
+85
+89
+20
+60
+00
+00
+70
+4b
+ef
+02
+20
+20
+05
+1f
+70
+4b
+ef
+03
+20
+20
+05
+1f
+70
+4b
+ef
+ff
+70
+0b
+7d
+31
+20
+40
+7c
+27
+68
+02
+0d
+19
+20
+40
+05
+c6
+20
+20
+05
+1f
+79
+20
+00
+23
+20
+40
+05
+c7
+20
+40
+05
+f3
+68
+00
+cb
+ef
+c1
+ff
+80
+00
+20
+40
+05
+a1
+58
+00
+00
+00
+60
+01
+4c
+04
+20
+40
+3c
+ab
+20
+00
+07
+d0
+68
+00
+cc
+04
+c0
+7f
+85
+47
+20
+40
+05
+3a
+24
+37
+85
+aa
+20
+40
+05
+35
+79
+20
+00
+23
+70
+0b
+7d
+3c
+20
+20
+7c
+27
+70
+0d
+37
+ff
+68
+00
+cb
+e2
+60
+00
+8d
+38
+68
+02
+4c
+06
+60
+02
+0d
+39
+d8
+40
+00
+06
+da
+20
+0d
+37
+20
+40
+05
+af
+20
+20
+05
+d4
+68
+01
+4c
+04
+1f
+e0
+fe
+01
+60
+01
+4c
+04
+20
+40
+05
+f3
+20
+20
+05
+97
+60
+08
+cb
+e1
+18
+42
+72
+00
+d8
+a0
+0c
+d5
+1a
+22
+0c
+00
+20
+20
+7e
+45
+68
+00
+8c
+b4
+1f
+e9
+7e
+00
+60
+00
+cb
+df
+1f
+e0
+fe
+01
+d8
+c0
+0c
+b4
+98
+c0
+8c
+00
+e8
+c1
+80
+00
+60
+01
+cc
+0b
+20
+60
+00
+00
+68
+08
+cc
+3c
+58
+00
+4c
+2b
+98
+40
+8a
+00
+1a
+22
+7e
+00
+e0
+a0
+80
+00
+18
+40
+84
+01
+18
+41
+04
+07
+60
+08
+cc
+3c
+20
+60
+00
+00
+60
+02
+4c
+00
+da
+20
+00
+00
+df
+20
+00
+04
+d8
+c0
+4c
+00
+e8
+c0
+80
+00
+9a
+20
+a2
+00
+c2
+00
+05
+ca
+1a
+22
+7e
+00
+60
+01
+4c
+16
+68
+00
+cc
+16
+68
+08
+cc
+17
+98
+40
+fe
+00
+60
+00
+cc
+18
+20
+60
+00
+00
+68
+00
+cb
+e1
+1f
+e0
+fe
+02
+60
+00
+cb
+e3
+68
+00
+cb
+e2
+60
+00
+8c
+f5
+68
+00
+cb
+e1
+1f
+e9
+fe
+00
+68
+08
+cb
+e0
+18
+41
+04
+03
+18
+43
+84
+00
+98
+41
+fe
+00
+68
+08
+cc
+0a
+98
+40
+fe
+00
+e0
+a0
+80
+00
+68
+00
+cb
+ef
+c0
+ff
+85
+e6
+68
+00
+cb
+e2
+e0
+a0
+80
+00
+68
+00
+cb
+e1
+98
+00
+72
+00
+68
+00
+cb
+e2
+c0
+00
+85
+f1
+d8
+c0
+0c
+d5
+20
+40
+7e
+45
+68
+00
+8c
+d5
+c0
+01
+85
+ef
+20
+60
+00
+00
+70
+0c
+d5
+02
+20
+60
+00
+00
+d8
+c0
+0c
+d6
+20
+20
+7e
+45
+68
+08
+cb
+ea
+20
+40
+05
+f9
+18
+40
+84
+01
+18
+41
+04
+03
+60
+08
+cb
+ea
+20
+60
+00
+00
+68
+00
+cc
+00
+1f
+e1
+7e
+03
+1f
+ef
+a2
+04
+58
+00
+4b
+f0
+9a
+20
+fe
+00
+98
+40
+8c
+00
+e8
+c0
+80
+00
+60
+00
+cb
+e9
+20
+60
+00
+00
+78
+44
+fc
+00
+78
+43
+fc
+00
+58
+55
+55
+55
+98
+00
+1e
+00
+68
+00
+cb
+e9
+1f
+ed
+84
+00
+79
+20
+04
+01
+18
+43
+1c
+00
+20
+60
+00
+00
+20
+40
+06
+02
+78
+26
+fc
+00
+78
+30
+fc
+00
+78
+50
+7c
+00
+78
+28
+7c
+00
+68
+01
+4b
+e4
+98
+00
+36
+00
+37
+c1
+84
+00
+24
+2c
+06
+45
+78
+46
+fc
+00
+78
+25
+fc
+00
+78
+23
+fc
+00
+78
+24
+fc
+00
+09
+80
+00
+08
+19
+89
+7e
+00
+60
+00
+cc
+19
+68
+08
+cc
+18
+98
+46
+7c
+00
+24
+22
+86
+45
+09
+80
+00
+08
+19
+89
+7e
+00
+60
+00
+8c
+b3
+68
+00
+8c
+b3
+68
+08
+cb
+e2
+a8
+40
+0e
+00
+24
+20
+86
+45
+09
+80
+00
+08
+19
+89
+7e
+00
+e0
+a0
+80
+00
+1f
+e9
+7e
+00
+1f
+e1
+72
+1f
+20
+22
+86
+2f
+09
+80
+00
+08
+19
+89
+7e
+00
+e0
+a0
+80
+00
+c2
+00
+06
+2b
+18
+a2
+22
+00
+09
+80
+00
+08
+19
+89
+7e
+00
+60
+00
+cc
+2a
+1a
+22
+0a
+00
+09
+80
+00
+18
+78
+28
+7c
+00
+db
+60
+06
+64
+1f
+ef
+7e
+00
+1f
+f1
+7e
+00
+e0
+a1
+80
+00
+78
+45
+fc
+00
+20
+23
+06
+45
+78
+37
+fc
+00
+68
+00
+80
+17
+1f
+e0
+a2
+00
+20
+40
+3a
+b6
+78
+46
+fc
+00
+20
+40
+3a
+7a
+68
+00
+cc
+2a
+1f
+e2
+22
+00
+20
+20
+05
+bd
+78
+4d
+fc
+00
+78
+45
+fc
+00
+20
+20
+37
+5c
+20
+40
+3a
+7a
+68
+08
+cb
+e9
+20
+20
+3a
+91
+20
+40
+53
+d2
+68
+02
+4c
+00
+98
+00
+12
+00
+20
+40
+06
+02
+20
+40
+06
+48
+79
+20
+2a
+00
+78
+2e
+fc
+00
+78
+30
+7c
+00
+78
+50
+fc
+00
+19
+31
+7e
+00
+1f
+ec
+fe
+00
+1f
+f1
+fe
+00
+08
+00
+86
+28
+78
+4e
+fc
+00
+78
+2d
+fc
+00
+78
+23
+fc
+00
+78
+24
+fc
+00
+68
+00
+cc
+18
+08
+00
+86
+08
+68
+00
+cb
+e3
+98
+00
+72
+00
+d8
+c0
+0c
+f5
+e8
+c0
+80
+00
+08
+00
+86
+08
+c2
+00
+06
+61
+78
+24
+7c
+00
+08
+00
+86
+18
+78
+44
+7c
+00
+37
+d3
+82
+00
+20
+00
+00
+64
+78
+4e
+fc
+00
+78
+4d
+fc
+00
+20
+20
+3a
+7a
+b6
+61
+aa
+55
+04
+36
+02
+05
+df
+02
+02
+ab
+e8
+64
+80
+f8
+e9
+33
+e8
+33
+60
+11
+04
+60
+f0
+ed
+33
+ec
+33
+70
+09
+e8
+fc
+e9
+fd
+ea
+fe
+eb
+ff
+22
+04
+60
+de
+d3
+eb
+9f
+ea
+9e
+e9
+9d
+e8
+c2
+e7
+8c
+f0
+c2
+f7
+95
+f0
+40
+0c
+e8
+cc
+f8
+e9
+cd
+f9
+ea
+ce
+fa
+eb
+cf
+fb
+12
+02
+76
+85
+d0
+f0
+58
+04
+70
+03
+20
+d5
+b3
+e8
+04
+70
+07
+50
+02
+b2
+d5
+02
+02
+b5
+92
+d5
+ec
+04
+60
+f7
+e4
+cc
+c0
+e0
+c3
+98
+f8
+60
+3b
+94
+18
+60
+08
+40
+0d
+d0
+e0
+fb
+02
+02
+8d
+e4
+fb
+fa
+c9
+fc
+80
+28
+e8
+30
+e4
+06
+e4
+c9
+fb
+e4
+ca
+fc
+e8
+30
+e3
+05
+e4
+c9
+ca
+cb
+fc
+e8
+54
+07
+60
+10
+f8
+c3
+e9
+13
+f9
+ea
+13
+fa
+eb
+13
+fb
+ec
+13
+fc
+d8
+f1
+30
+f5
+2f
+c3
+e4
+9c
+fc
+ef
+9b
+ff
+ee
+9a
+fe
+ed
+99
+fd
+d0
+e0
+fb
+ef
+4e
+4d
+4c
+70
+12
+22
+db
+03
+02
+02
+b2
+ec
+2c
+fc
+ef
+33
+ff
+ee
+33
+fe
+ed
+33
+fd
+ed
+30
+e7
+eb
+02
+02
+8d
+ef
+2b
+ff
+ee
+3a
+fe
+ed
+39
+fd
+d0
+e0
+fb
+50
+13
+0b
+bb
+00
+03
+02
+02
+b5
+ed
+13
+fd
+ee
+13
+fe
+ef
+13
+ff
+ec
+13
+fc
+02
+02
+8d
+ec
+4d
+60
+11
+e8
+49
+70
+17
+ed
+33
+ec
+33
+04
+60
+0d
+e4
+fc
+ff
+fe
+fd
+22
+e9
+33
+e8
+33
+04
+70
+f8
+02
+02
+ab
+12
+02
+76
+58
+04
+60
+09
+e4
+cc
+24
+81
+50
+06
+28
+50
+09
+02
+02
+b5
+28
+40
+03
+02
+02
+b2
+c0
+e0
+eb
+4a
+70
+44
+b9
+80
+06
+d0
+e0
+fb
+02
+02
+a1
+ef
+4e
+70
+1c
+bd
+80
+08
+eb
+ff
+ea
+fe
+e9
+fd
+80
+eb
+e9
+8d
+f0
+a4
+fe
+e5
+f0
+02
+01
+e4
+e9
+cd
+f9
+ea
+fe
+eb
+ff
+ef
+89
+f0
+a4
+fc
+e5
+f0
+ce
+89
+f0
+a4
+2e
+ff
+e4
+35
+f0
+cd
+89
+f0
+a4
+2d
+fe
+e4
+35
+f0
+80
+67
+ef
+4e
+70
+05
+bd
+80
+d7
+80
+c3
+ef
+8b
+f0
+a4
+ac
+f0
+ee
+8b
+f0
+a4
+2c
+fc
+e4
+35
+f0
+f8
+ef
+8a
+f0
+a4
+2c
+e5
+f0
+38
+fc
+e4
+33
+cb
+8d
+f0
+a4
+2c
+fc
+e5
+f0
+3b
+f8
+ee
+8a
+f0
+a4
+2c
+fc
+e5
+f0
+38
+f8
+e4
+33
+cf
+89
+f0
+a4
+2c
+fc
+e5
+f0
+38
+cf
+34
+00
+ce
+89
+f0
+a4
+2f
+ff
+e5
+f0
+3e
+fe
+e4
+33
+c9
+8d
+f0
+a4
+2e
+fe
+e5
+f0
+39
+cd
+8a
+f0
+a4
+2f
+ff
+e5
+f0
+3e
+fe
+e4
+3d
+fd
+33
+d0
+e0
+fb
+50
+07
+0b
+bb
+00
+0f
+02
+02
+b5
+ec
+2c
+fc
+ef
+33
+ff
+ee
+33
+fe
+ed
+33
+fd
+02
+02
+8d
+75
+f0
+20
+80
+0e
+75
+f0
+10
+80
+05
+75
+f0
+08
+7d
+00
+7e
+00
+7f
+00
+33
+92
+d5
+30
+d5
+03
+12
+05
+57
+ec
+33
+40
+10
+ef
+33
+ff
+ee
+33
+fe
+ed
+33
+fd
+ec
+33
+fc
+d5
+f0
+ed
+22
+e5
+f0
+24
+7e
+a2
+d5
+13
+cc
+92
+e7
+cd
+ce
+ff
+22
+ed
+d2
+e7
+cd
+33
+ec
+33
+92
+d5
+24
+81
+40
+06
+e4
+ff
+fe
+fd
+fc
+22
+fc
+e4
+cf
+ce
+cd
+cc
+24
+e0
+50
+11
+74
+ff
+80
+ed
+c3
+cc
+13
+cc
+cd
+13
+cd
+ce
+13
+ce
+cf
+13
+cf
+04
+70
+f0
+30
+d5
+de
+02
+05
+57
+e9
+d2
+e7
+c9
+33
+e8
+33
+f8
+92
+d5
+ed
+d2
+e7
+cd
+33
+ec
+33
+fc
+50
+02
+b2
+d5
+22
+ec
+30
+e7
+10
+0f
+bf
+00
+0c
+0e
+be
+00
+08
+0d
+bd
+00
+04
+0b
+eb
+60
+14
+a2
+d5
+eb
+13
+fc
+ed
+92
+e7
+fd
+22
+74
+ff
+fc
+fd
+fe
+ff
+22
+e4
+80
+f8
+a2
+d5
+74
+ff
+13
+fc
+7d
+80
+e4
+80
+ef
+e7
+09
+f6
+08
+df
+fa
+80
+46
+e7
+09
+f2
+08
+df
+fa
+80
+3e
+88
+82
+8c
+83
+e7
+09
+f0
+a3
+df
+fa
+80
+32
+e3
+09
+f6
+08
+df
+fa
+80
+78
+e3
+09
+f2
+08
+df
+fa
+80
+70
+88
+82
+8c
+83
+e3
+09
+f0
+a3
+df
+fa
+80
+64
+89
+82
+8a
+83
+e0
+a3
+f6
+08
+df
+fa
+80
+58
+89
+82
+8a
+83
+e0
+a3
+f2
+08
+df
+fa
+80
+4c
+80
+d2
+80
+fa
+80
+c6
+80
+d4
+80
+69
+80
+f2
+80
+33
+80
+10
+80
+a6
+80
+ea
+80
+9a
+80
+a8
+80
+da
+80
+e2
+80
+ca
+80
+33
+89
+82
+8a
+83
+ec
+fa
+e4
+93
+a3
+c8
+c5
+82
+c8
+cc
+c5
+83
+cc
+f0
+a3
+c8
+c5
+82
+c8
+cc
+c5
+83
+cc
+df
+e9
+de
+e7
+80
+0d
+89
+82
+8a
+83
+e4
+93
+a3
+f6
+08
+df
+f9
+ec
+fa
+a9
+f0
+ed
+fb
+22
+89
+82
+8a
+83
+ec
+fa
+e0
+a3
+c8
+c5
+82
+c8
+cc
+c5
+83
+cc
+f0
+a3
+c8
+c5
+82
+c8
+cc
+c5
+83
+cc
+df
+ea
+de
+e8
+80
+db
+89
+82
+8a
+83
+e4
+93
+a3
+f2
+08
+df
+f9
+80
+cc
+88
+f0
+ef
+60
+01
+0e
+4e
+60
+c3
+88
+f0
+ed
+24
+02
+b4
+04
+00
+50
+b9
+f5
+82
+eb
+24
+02
+b4
+04
+00
+50
+af
+23
+23
+45
+82
+23
+90
+03
+10
+73
+bb
+01
+06
+89
+82
+8a
+83
+e0
+22
+50
+02
+e7
+22
+bb
+fe
+02
+e3
+22
+89
+82
+8a
+83
+e4
+93
+22
+bb
+01
+0c
+e5
+82
+29
+f5
+82
+e5
+83
+3a
+f5
+83
+e0
+22
+50
+06
+e9
+25
+82
+f8
+e6
+22
+bb
+fe
+06
+e9
+25
+82
+f8
+e2
+22
+e5
+82
+29
+f5
+82
+e5
+83
+3a
+f5
+83
+e4
+93
+22
+bb
+01
+06
+89
+82
+8a
+83
+f0
+22
+50
+02
+f7
+22
+bb
+fe
+01
+f3
+22
+c5
+f0
+f8
+a3
+e0
+28
+f0
+c5
+f0
+f8
+e5
+82
+15
+82
+70
+02
+15
+83
+e0
+38
+f0
+22
+a3
+f8
+e0
+c5
+f0
+25
+f0
+f0
+e5
+82
+15
+82
+70
+02
+15
+83
+e0
+c8
+38
+f0
+e8
+22
+e8
+8f
+f0
+a4
+cc
+8b
+f0
+a4
+2c
+fc
+e9
+8e
+f0
+a4
+2c
+fc
+8a
+f0
+ed
+a4
+2c
+fc
+ea
+8e
+f0
+a4
+cd
+a8
+f0
+8b
+f0
+a4
+2d
+cc
+38
+25
+f0
+fd
+e9
+8f
+f0
+a4
+2c
+cd
+35
+f0
+fc
+eb
+8e
+f0
+a4
+fe
+a9
+f0
+eb
+8f
+f0
+a4
+cf
+c5
+f0
+2e
+cd
+39
+fe
+e4
+3c
+fc
+ea
+a4
+2d
+ce
+35
+f0
+fd
+e4
+3c
+fc
+22
+75
+f0
+08
+75
+82
+00
+ef
+2f
+ff
+ee
+33
+fe
+cd
+33
+cd
+cc
+33
+cc
+c5
+82
+33
+c5
+82
+9b
+ed
+9a
+ec
+99
+e5
+82
+98
+40
+0c
+f5
+82
+ee
+9b
+fe
+ed
+9a
+fd
+ec
+99
+fc
+0f
+d5
+f0
+d6
+e4
+ce
+fb
+e4
+cd
+fa
+e4
+cc
+f9
+a8
+82
+22
+b8
+00
+c1
+b9
+00
+59
+ba
+00
+2d
+ec
+8b
+f0
+84
+cf
+ce
+cd
+fc
+e5
+f0
+cb
+f9
+78
+18
+ef
+2f
+ff
+ee
+33
+fe
+ed
+33
+fd
+ec
+33
+fc
+eb
+33
+fb
+10
+d7
+03
+99
+40
+04
+eb
+99
+fb
+0f
+d8
+e5
+e4
+f9
+fa
+22
+78
+18
+ef
+2f
+ff
+ee
+33
+fe
+ed
+33
+fd
+ec
+33
+fc
+c9
+33
+c9
+10
+d7
+05
+9b
+e9
+9a
+40
+07
+ec
+9b
+fc
+e9
+9a
+f9
+0f
+d8
+e0
+e4
+c9
+fa
+e4
+cc
+fb
+22
+75
+f0
+10
+ef
+2f
+ff
+ee
+33
+fe
+ed
+33
+fd
+cc
+33
+cc
+c8
+33
+c8
+10
+d7
+07
+9b
+ec
+9a
+e8
+99
+40
+0a
+ed
+9b
+fd
+ec
+9a
+fc
+e8
+99
+f8
+0f
+d5
+f0
+da
+e4
+cd
+fb
+e4
+cc
+fa
+e4
+c8
+f9
+22
+c3
+e4
+9f
+ff
+e4
+9e
+fe
+e4
+9d
+fd
+e4
+9c
+fc
+22
+eb
+9f
+f5
+f0
+ea
+9e
+42
+f0
+e9
+9d
+42
+f0
+e8
+9c
+45
+f0
+22
+ec
+f0
+a3
+ed
+f0
+a3
+ee
+f0
+a3
+ef
+f0
+22
+a8
+82
+85
+83
+f0
+d0
+83
+d0
+82
+12
+05
+99
+12
+05
+99
+12
+05
+99
+12
+05
+99
+e4
+73
+e4
+93
+a3
+c5
+83
+c5
+f0
+c5
+83
+c8
+c5
+82
+c8
+f0
+a3
+c5
+83
+c5
+f0
+c5
+83
+c8
+c5
+82
+c8
+22
+d0
+83
+d0
+82
+f8
+e4
+93
+70
+12
+74
+01
+93
+70
+0d
+a3
+a3
+93
+f8
+74
+01
+93
+f5
+82
+88
+83
+e4
+73
+74
+02
+93
+68
+60
+ef
+a3
+a3
+a3
+80
+df
+8a
+83
+89
+82
+e4
+73
+78
+7f
+e4
+f6
+d8
+fd
+75
+81
+cf
+02
+06
+26
+02
+1f
+eb
+e4
+93
+a3
+f8
+e4
+93
+a3
+40
+03
+f6
+80
+01
+f2
+08
+df
+f4
+80
+29
+e4
+93
+a3
+f8
+54
+07
+24
+0c
+c8
+c3
+33
+c4
+54
+0f
+44
+20
+c8
+83
+40
+04
+f4
+56
+80
+01
+46
+f6
+df
+e4
+80
+0b
+01
+02
+04
+08
+10
+20
+40
+80
+90
+06
+6b
+e4
+7e
+01
+93
+60
+bc
+a3
+ff
+54
+3f
+30
+e5
+09
+54
+1f
+fe
+e4
+93
+a3
+60
+01
+0e
+cf
+54
+c0
+25
+e0
+60
+a8
+40
+b8
+e4
+93
+a3
+fa
+e4
+93
+a3
+f8
+e4
+93
+a3
+c8
+c5
+82
+c8
+ca
+c5
+83
+ca
+f0
+a3
+c8
+c5
+82
+c8
+ca
+c5
+83
+ca
+df
+e9
+de
+e7
+80
+be
+52
+4e
+56
+ff
+14
+c8
+00
+00
+00
+ff
+22
+9f
+ff
+31
+b1
+00
+00
+00
+ff
+31
+a1
+00
+0a
+1c
+15
+16
+17
+18
+19
+1a
+0c
+09
+0b
+0f
+10
+11
+1b
+0e
+08
+0d
+00
+00
+00
+3e
+e0
+00
+e4
+de
+00
+66
+47
+1e
+35
+8b
+1d
+29
+04
+2b
+14
+1f
+3a
+8a
+1b
+64
+16
+39
+1a
+20
+3b
+88
+06
+3d
+07
+3c
+08
+21
+22
+05
+19
+0a
+09
+17
+15
+24
+23
+11
+10
+0b
+0d
+1c
+18
+25
+2e
+87
+36
+3f
+0e
+30
+0c
+26
+41
+65
+37
+00
+0f
+40
+12
+27
+2d
+38
+32
+34
+33
+2f
+13
+48
+b0
+e6
+00
+e2
+7f
+00
+46
+43
+42
+45
+28
+44
+31
+2a
+89
+66
+4c
+51
+53
+2c
+59
+5c
+5f
+de
+49
+4f
+54
+62
+5a
+5d
+60
+4e
+4b
+56
+55
+63
+5b
+5e
+61
+4d
+4a
+50
+f2
+52
+58
+85
+57
+7c
+da
+ea
+e9
+ef
+e5
+e1
+df
+00
+f8
+d4
+d2
+d3
+d1
+e3
+7b
+90
+d6
+7d
+f3
+00
+e7
+d0
+91
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+01
+01
+00
+90
+4e
+fe
+ef
+f0
+90
+4c
+f0
+e0
+70
+02
+e1
+fd
+14
+f0
+e4
+90
+4d
+e5
+f0
+90
+4e
+55
+f0
+90
+4e
+fe
+e0
+ff
+75
+f0
+1f
+a4
+24
+ee
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+64
+01
+70
+70
+ef
+75
+f0
+1f
+a4
+24
+ef
+f9
+74
+4d
+35
+f0
+fa
+7b
+01
+7e
+42
+7f
+74
+90
+4e
+c4
+74
+06
+f0
+12
+08
+78
+90
+4e
+fe
+e0
+75
+f0
+1f
+a4
+24
+f5
+f9
+74
+4d
+35
+f0
+fa
+7b
+01
+7e
+44
+7f
+7b
+90
+4e
+c4
+74
+10
+f0
+12
+08
+78
+90
+4e
+fe
+e0
+75
+f0
+1f
+a4
+24
+05
+f9
+74
+4e
+35
+f0
+fa
+7b
+01
+7e
+44
+7f
+f9
+90
+4e
+c4
+74
+06
+f0
+12
+08
+78
+7f
+2b
+12
+14
+9d
+90
+4d
+e5
+74
+01
+f0
+e4
+90
+4c
+f0
+f0
+90
+44
+8b
+04
+f0
+22
+90
+4e
+55
+74
+01
+f0
+90
+44
+f9
+74
+0f
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+90
+4d
+d3
+74
+01
+f0
+7f
+2b
+12
+14
+9d
+90
+42
+5e
+74
+01
+f0
+22
+90
+4e
+ff
+ed
+f0
+ef
+64
+01
+70
+6f
+e0
+ff
+75
+f0
+1f
+a4
+24
+ee
+f5
+82
+e4
+34
+4d
+f5
+83
+74
+01
+f0
+ef
+75
+f0
+1f
+a4
+24
+ef
+f5
+82
+e4
+34
+4d
+af
+82
+fe
+7b
+01
+7a
+03
+79
+d0
+90
+4e
+c4
+74
+06
+f0
+11
+78
+90
+4e
+ff
+e0
+75
+f0
+1f
+a4
+24
+f5
+f5
+82
+e4
+34
+4d
+af
+82
+fe
+7b
+01
+7a
+44
+79
+7b
+90
+4e
+c4
+74
+10
+f0
+11
+78
+90
+4e
+ff
+e0
+75
+f0
+1f
+a4
+24
+05
+f5
+82
+e4
+34
+4e
+af
+82
+fe
+7b
+01
+7a
+44
+79
+f9
+90
+4e
+c4
+74
+06
+f0
+11
+78
+22
+90
+4e
+bf
+ee
+f0
+a3
+ef
+f0
+a3
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+90
+4e
+c4
+e0
+ff
+14
+f0
+ef
+60
+27
+90
+4e
+c1
+e0
+fb
+a3
+e4
+75
+f0
+01
+12
+04
+24
+a9
+f0
+fa
+12
+03
+b6
+ff
+90
+4e
+bf
+e4
+75
+f0
+01
+12
+04
+24
+85
+f0
+82
+f5
+83
+ef
+f0
+80
+cf
+22
+90
+4e
+c5
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+e4
+a3
+f0
+a3
+f0
+90
+4d
+e2
+f0
+90
+4e
+c9
+f0
+90
+4e
+c9
+e0
+ff
+c3
+94
+05
+74
+80
+94
+80
+50
+2c
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+7e
+00
+e9
+2f
+f9
+ee
+3a
+fa
+12
+03
+b6
+64
+7f
+70
+05
+90
+4d
+e2
+04
+f0
+90
+4e
+c9
+e0
+04
+f0
+80
+c6
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+26
+fb
+ef
+60
+02
+61
+dc
+90
+4e
+c5
+e0
+a3
+e0
+fa
+a3
+e0
+4a
+70
+02
+61
+dc
+90
+4d
+7d
+e0
+60
+08
+e4
+f0
+90
+4d
+46
+74
+03
+f0
+90
+4c
+c7
+e0
+64
+04
+70
+06
+90
+42
+13
+74
+03
+f0
+90
+4d
+e6
+74
+0a
+f0
+e4
+90
+4c
+e3
+f0
+a3
+f0
+90
+4c
+d5
+e0
+64
+01
+70
+11
+90
+4d
+40
+f0
+a3
+74
+48
+f0
+a3
+74
+12
+f0
+e4
+a3
+f0
+80
+10
+e4
+90
+4d
+40
+f0
+a3
+74
+48
+f0
+a3
+74
+5d
+f0
+e4
+a3
+f0
+7b
+01
+7a
+48
+79
+00
+7d
+09
+7c
+00
+b1
+fa
+7b
+01
+7a
+4e
+79
+4c
+7d
+09
+7c
+00
+b1
+fa
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+90
+00
+01
+12
+03
+cf
+ff
+7e
+00
+64
+0e
+70
+0a
+90
+00
+02
+12
+03
+cf
+64
+29
+60
+10
+ef
+64
+29
+4e
+70
+36
+90
+00
+02
+12
+03
+cf
+64
+0e
+70
+2c
+90
+4b
+eb
+74
+20
+f0
+a3
+74
+15
+f0
+a3
+74
+10
+f0
+a3
+74
+05
+f0
+90
+4c
+c5
+e0
+64
+01
+60
+09
+90
+4c
+ce
+e0
+44
+10
+f0
+80
+10
+90
+4c
+ce
+e0
+54
+ef
+f0
+80
+07
+90
+4c
+ce
+e0
+54
+ef
+f0
+90
+4c
+b6
+74
+01
+f0
+90
+4c
+f4
+e0
+ff
+64
+01
+70
+02
+61
+dc
+ef
+64
+04
+70
+02
+61
+dc
+ef
+64
+02
+70
+02
+61
+dc
+90
+4c
+c5
+e0
+64
+03
+70
+4a
+90
+4e
+c9
+f0
+90
+4e
+c9
+e0
+ff
+c3
+94
+05
+74
+80
+94
+80
+50
+38
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+7e
+00
+e9
+2f
+f9
+ee
+3a
+fa
+12
+03
+b6
+ff
+64
+39
+60
+0a
+ef
+64
+53
+60
+05
+ef
+64
+47
+70
+06
+90
+4d
+46
+74
+03
+f0
+90
+4e
+c9
+e0
+04
+f0
+80
+ba
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+71
+dd
+90
+4e
+4b
+e0
+64
+01
+70
+11
+74
+02
+f0
+90
+4e
+4c
+f0
+7b
+01
+7a
+4e
+79
+4c
+7d
+03
+c1
+da
+90
+4e
+4b
+e0
+64
+04
+70
+13
+74
+02
+f0
+90
+4e
+4c
+74
+06
+f0
+7b
+01
+7a
+4e
+79
+4c
+7d
+03
+c1
+da
+90
+4e
+4b
+e0
+64
+03
+60
+0b
+e0
+64
+02
+70
+2f
+90
+4d
+e4
+e0
+70
+29
+e4
+90
+4e
+4b
+f0
+90
+4d
+ed
+f0
+90
+4d
+e9
+e0
+60
+0a
+e4
+f0
+90
+4e
+4c
+74
+06
+f0
+80
+06
+90
+4e
+4c
+74
+02
+f0
+7b
+01
+7a
+4e
+79
+4c
+7d
+03
+c1
+da
+90
+4d
+e4
+e0
+70
+16
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+7d
+06
+7c
+00
+b1
+fa
+90
+48
+00
+74
+01
+f0
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+90
+48
+01
+f0
+90
+4c
+c5
+e0
+64
+03
+70
+0a
+90
+4d
+46
+e0
+90
+48
+02
+f0
+80
+05
+e4
+90
+48
+02
+f0
+e4
+90
+4d
+df
+f0
+90
+4e
+55
+e0
+70
+75
+90
+00
+01
+12
+03
+cf
+64
+7f
+70
+15
+7e
+48
+7f
+03
+e9
+24
+02
+f9
+e4
+3a
+fa
+90
+4e
+c4
+74
+05
+f0
+11
+78
+80
+1c
+7e
+48
+7f
+03
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+90
+4e
+c4
+74
+06
+f0
+11
+78
+90
+4e
+c9
+74
+03
+f0
+90
+4e
+c9
+e0
+ff
+c3
+94
+09
+74
+80
+94
+80
+50
+42
+74
+00
+2f
+f5
+82
+e4
+34
+48
+f5
+83
+e0
+64
+7f
+70
+0f
+90
+4e
+c9
+e0
+24
+00
+f5
+82
+e4
+34
+48
+f5
+83
+e4
+f0
+90
+4e
+c9
+e0
+04
+f0
+80
+cc
+7e
+48
+7f
+03
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+90
+4e
+c4
+74
+06
+f0
+11
+78
+7b
+01
+7a
+48
+79
+00
+7d
+09
+d1
+da
+22
+90
+4e
+d4
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+e4
+a3
+f0
+f0
+90
+4e
+d7
+e0
+ff
+c3
+94
+06
+74
+80
+94
+80
+40
+02
+a1
+de
+90
+4e
+d4
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+7e
+00
+e9
+2f
+f9
+ee
+3a
+fa
+12
+03
+b6
+ff
+54
+f0
+64
+f0
+60
+09
+ef
+54
+d0
+64
+d0
+60
+02
+a1
+d6
+12
+03
+b6
+f9
+fb
+7a
+00
+64
+f1
+70
+08
+7f
+83
+7e
+01
+b1
+df
+a1
+aa
+eb
+64
+f2
+4a
+70
+07
+7f
+cd
+fe
+b1
+df
+a1
+aa
+e9
+fb
+7a
+00
+64
+f3
+70
+07
+7f
+b7
+fe
+b1
+df
+a1
+aa
+eb
+64
+f4
+4a
+70
+07
+7f
+b6
+fe
+b1
+df
+a1
+aa
+e9
+fb
+7a
+00
+64
+f5
+70
+07
+7f
+b5
+fe
+b1
+df
+a1
+aa
+eb
+64
+f6
+4a
+70
+07
+7f
+ea
+fe
+b1
+df
+a1
+aa
+e9
+fb
+7a
+00
+64
+f7
+70
+07
+7f
+e9
+fe
+b1
+df
+a1
+aa
+eb
+64
+f8
+4a
+70
+07
+7f
+e2
+fe
+b1
+df
+a1
+aa
+e9
+fb
+7a
+00
+64
+f9
+70
+08
+7f
+94
+7e
+01
+b1
+df
+a1
+aa
+eb
+64
+fa
+4a
+70
+08
+7f
+8a
+7e
+01
+b1
+df
+a1
+aa
+e9
+fb
+7a
+00
+64
+fb
+70
+08
+7f
+92
+7e
+01
+b1
+df
+a1
+aa
+eb
+64
+d0
+4a
+70
+08
+7f
+2a
+7e
+02
+b1
+df
+a1
+aa
+e9
+fb
+7a
+00
+64
+d1
+70
+08
+7f
+25
+7e
+02
+b1
+df
+a1
+aa
+eb
+64
+d3
+4a
+70
+08
+7f
+26
+7e
+02
+b1
+df
+a1
+aa
+e9
+fb
+7a
+00
+64
+d2
+70
+08
+7f
+24
+7e
+02
+b1
+df
+a1
+aa
+eb
+64
+d4
+4a
+70
+08
+7f
+27
+7e
+02
+b1
+df
+a1
+aa
+e9
+fb
+7a
+00
+64
+d5
+70
+08
+7f
+21
+7e
+02
+b1
+df
+a1
+aa
+eb
+64
+d6
+4a
+70
+08
+7f
+23
+7e
+02
+b1
+df
+80
+79
+e9
+fb
+7a
+00
+64
+d7
+70
+07
+7f
+70
+fe
+b1
+df
+80
+6a
+eb
+64
+d8
+4a
+70
+07
+7f
+6f
+fe
+b1
+df
+80
+5d
+e9
+fb
+7a
+00
+64
+d9
+70
+07
+7f
+b8
+fe
+b1
+df
+80
+4e
+eb
+64
+da
+4a
+70
+07
+7f
+30
+fe
+b1
+df
+80
+41
+e9
+fb
+7a
+00
+64
+db
+70
+08
+7f
+06
+7e
+03
+b1
+df
+80
+31
+eb
+64
+dc
+4a
+70
+08
+7f
+07
+7e
+03
+b1
+df
+80
+23
+e9
+fd
+7c
+00
+64
+dd
+70
+06
+7f
+01
+d1
+bf
+80
+15
+ed
+64
+de
+4c
+70
+06
+7f
+02
+d1
+bf
+80
+09
+e9
+64
+df
+70
+04
+7f
+04
+d1
+bf
+90
+4e
+4b
+e0
+64
+02
+70
+24
+90
+4e
+d4
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+a3
+e0
+7e
+00
+29
+f9
+ee
+3a
+fa
+12
+03
+b6
+90
+4d
+ed
+f0
+e4
+12
+03
+fc
+90
+4e
+d7
+e0
+04
+f0
+61
+ec
+22
+ad
+07
+ac
+06
+90
+4e
+4b
+e0
+64
+02
+60
+0e
+74
+01
+f0
+90
+4e
+4c
+04
+f0
+ef
+a3
+f0
+ee
+a3
+f0
+22
+90
+4e
+ef
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+ed
+1d
+ae
+04
+70
+01
+1c
+4e
+60
+16
+90
+4e
+ef
+e0
+fb
+a3
+e4
+75
+f0
+01
+12
+04
+24
+a9
+f0
+fa
+e4
+12
+03
+fc
+80
+e0
+22
+7b
+01
+7a
+4c
+79
+bf
+7d
+48
+7c
+00
+b1
+fa
+7b
+01
+7a
+4d
+79
+93
+7d
+14
+7c
+00
+b1
+fa
+7b
+01
+7a
+4d
+79
+a8
+7d
+14
+7c
+00
+b1
+fa
+7b
+01
+7a
+4d
+79
+bc
+7d
+14
+7c
+00
+b1
+fa
+7b
+01
+7a
+48
+79
+00
+7d
+09
+7c
+00
+b1
+fa
+7b
+01
+7a
+4e
+79
+4c
+7d
+09
+7c
+00
+b1
+fa
+e4
+90
+4d
+e6
+f0
+90
+4d
+ec
+f0
+90
+4d
+eb
+f0
+90
+4d
+dd
+f0
+90
+4d
+d5
+f0
+90
+4d
+e5
+f0
+90
+4d
+e3
+f0
+90
+4e
+4b
+f0
+90
+4d
+dc
+f0
+90
+4d
+df
+f0
+90
+4d
+e2
+f0
+90
+4d
+ea
+f0
+90
+4d
+d8
+f0
+90
+4d
+e7
+f0
+90
+4d
+ed
+f0
+90
+4c
+b7
+74
+f0
+f0
+90
+4d
+e0
+f0
+e4
+90
+4d
+38
+f0
+90
+4d
+d4
+f0
+22
+90
+4e
+4b
+e0
+64
+02
+60
+12
+74
+04
+f0
+90
+4d
+e9
+74
+01
+f0
+90
+4e
+4c
+74
+06
+f0
+a3
+ef
+f0
+22
+90
+4e
+7a
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+a3
+ed
+f0
+e4
+ff
+90
+4e
+7d
+e0
+fe
+ef
+c3
+9e
+50
+23
+90
+4e
+7a
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+8f
+82
+75
+83
+00
+12
+03
+cf
+fe
+74
+7e
+2f
+f5
+82
+e4
+34
+4e
+f5
+83
+ee
+f0
+0f
+80
+d3
+12
+19
+22
+ef
+70
+02
+e1
+c1
+90
+4c
+eb
+e0
+60
+02
+e1
+c1
+90
+4c
+c7
+e0
+ff
+64
+04
+60
+0b
+ef
+64
+03
+70
+1f
+90
+4d
+d3
+e0
+60
+19
+90
+4e
+7e
+e0
+64
+06
+70
+03
+74
+03
+f0
+7b
+01
+7a
+4e
+79
+7e
+90
+4e
+7d
+e0
+fd
+12
+35
+23
+90
+4c
+c5
+e0
+64
+03
+70
+65
+90
+4e
+7e
+e0
+64
+01
+70
+23
+74
+04
+f0
+a3
+e0
+70
+14
+90
+4e
+81
+e0
+70
+0e
+a3
+e0
+70
+0a
+a3
+e0
+70
+06
+90
+4d
+dd
+f0
+80
+34
+90
+4d
+dd
+74
+01
+f0
+80
+2c
+90
+4e
+7e
+e0
+64
+02
+70
+19
+74
+05
+f0
+a3
+e0
+70
+0a
+a3
+e0
+70
+06
+90
+4d
+dd
+f0
+80
+13
+90
+4d
+dd
+74
+01
+f0
+80
+0b
+90
+4e
+7e
+e0
+64
+03
+70
+03
+74
+07
+f0
+7b
+01
+7a
+4e
+79
+7e
+90
+4e
+7d
+e0
+fd
+12
+35
+11
+22
+90
+4f
+07
+ed
+f0
+e0
+fd
+90
+0b
+e8
+f0
+7e
+0b
+7f
+e9
+90
+4e
+c4
+ed
+f0
+11
+78
+7b
+01
+7a
+0b
+79
+e7
+90
+4f
+07
+e0
+24
+02
+fd
+90
+4e
+b9
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+a3
+ed
+f0
+90
+4b
+9c
+e0
+ff
+a3
+e0
+90
+4e
+bd
+cf
+f0
+a3
+ef
+f0
+90
+4b
+9a
+e0
+fe
+a3
+e0
+ff
+90
+4b
+9c
+e0
+fc
+a3
+e0
+fd
+7b
+64
+11
+79
+90
+4e
+bc
+e0
+fe
+ef
+c3
+9e
+40
+e2
+90
+4e
+bc
+e0
+ff
+14
+f0
+ef
+60
+3f
+90
+4e
+b9
+e0
+fb
+a3
+e4
+75
+f0
+01
+12
+04
+24
+a9
+f0
+fa
+12
+03
+b6
+ff
+90
+4e
+bd
+e4
+75
+f0
+01
+12
+04
+24
+85
+f0
+82
+f5
+83
+ef
+f0
+90
+4e
+bd
+e0
+fe
+a3
+e0
+ff
+be
+4b
+c6
+bf
+36
+c3
+90
+4e
+bd
+74
+4a
+f0
+a3
+74
+a0
+f0
+80
+b7
+90
+4e
+bd
+e0
+ff
+a3
+e0
+90
+4b
+9c
+cf
+f0
+a3
+ef
+f0
+22
+90
+4e
+d8
+ee
+f0
+a3
+ef
+f0
+90
+4e
+da
+ec
+f0
+a3
+ed
+f0
+90
+4e
+da
+e0
+fe
+a3
+e0
+ff
+d3
+90
+4e
+d9
+e0
+9f
+90
+4e
+d8
+e0
+9e
+40
+16
+90
+4e
+da
+e0
+fe
+a3
+e0
+ff
+90
+4e
+d9
+e0
+9f
+ff
+90
+4e
+d8
+e0
+9e
+fe
+80
+1e
+90
+4e
+d8
+e0
+fe
+a3
+e0
+ff
+c3
+90
+4e
+db
+e0
+9f
+ff
+90
+4e
+da
+e0
+9e
+fe
+ad
+03
+c3
+eb
+9f
+ff
+e4
+9e
+fe
+22
+90
+4c
+c7
+e0
+64
+04
+60
+08
+90
+4c
+c5
+e0
+64
+03
+70
+03
+7f
+01
+22
+7f
+00
+22
+90
+4d
+eb
+e0
+64
+02
+60
+02
+21
+b1
+90
+4c
+e9
+e0
+60
+3a
+90
+4c
+cc
+e0
+64
+01
+60
+1e
+90
+4c
+c3
+e0
+64
+01
+70
+07
+7f
+1f
+12
+35
+b1
+80
+2e
+90
+4c
+c3
+e0
+64
+02
+70
+26
+7f
+1e
+12
+35
+b1
+80
+1f
+c2
+01
+7f
+1f
+31
+b2
+c2
+01
+7f
+1e
+31
+b2
+c2
+01
+7f
+14
+31
+b2
+80
+0b
+90
+4c
+ee
+e0
+60
+05
+7f
+14
+12
+35
+b1
+11
+d3
+ef
+60
+6e
+90
+4c
+e5
+e0
+70
+68
+a3
+e0
+60
+16
+14
+f0
+d2
+01
+7f
+ff
+31
+b2
+90
+4c
+e6
+e0
+70
+0e
+c2
+01
+7f
+ff
+31
+b2
+80
+06
+c2
+01
+7f
+ff
+31
+b2
+90
+4c
+e7
+e0
+60
+16
+14
+f0
+d2
+01
+7f
+1d
+31
+b2
+90
+4c
+e7
+e0
+70
+0e
+c2
+01
+7f
+1d
+31
+b2
+80
+06
+c2
+01
+7f
+1d
+31
+b2
+90
+4c
+e8
+e0
+60
+20
+14
+f0
+90
+4c
+e5
+e0
+70
+18
+90
+4c
+e2
+e0
+70
+12
+d2
+01
+7f
+14
+31
+b2
+90
+4c
+e8
+e0
+70
+06
+c2
+01
+7f
+14
+31
+b2
+22
+ef
+f4
+60
+0d
+7b
+01
+7a
+80
+79
+74
+a2
+01
+92
+00
+12
+18
+75
+22
+90
+4d
+eb
+e0
+64
+02
+60
+02
+41
+c5
+90
+4c
+e9
+e0
+60
+02
+41
+bf
+90
+4c
+ee
+e0
+60
+02
+41
+bf
+90
+4c
+d5
+e0
+64
+02
+70
+04
+f1
+8f
+80
+2f
+90
+4c
+d5
+e0
+64
+01
+70
+14
+90
+4c
+f7
+e0
+70
+21
+90
+4c
+e2
+74
+0a
+f0
+90
+4c
+f7
+74
+01
+f0
+80
+13
+90
+4c
+f7
+e0
+64
+01
+70
+0b
+f0
+90
+4c
+e2
+f0
+c2
+01
+7f
+14
+31
+b2
+11
+d3
+ef
+70
+02
+41
+b9
+90
+4c
+e5
+e0
+60
+02
+41
+b9
+90
+4d
+e0
+e0
+ff
+90
+4c
+b7
+e0
+6f
+70
+02
+41
+c5
+e0
+30
+e0
+0e
+90
+4c
+e6
+74
+14
+f0
+d2
+01
+7f
+ff
+31
+b2
+80
+0b
+c2
+01
+7f
+ff
+31
+b2
+e4
+90
+4c
+e6
+f0
+90
+4c
+b7
+e0
+30
+e1
+0e
+90
+4c
+e7
+74
+14
+f0
+d2
+01
+7f
+1d
+31
+b2
+80
+0b
+c2
+01
+7f
+1d
+31
+b2
+e4
+90
+4c
+e7
+f0
+90
+4c
+b7
+e0
+30
+e2
+1a
+90
+4c
+e8
+74
+14
+f0
+90
+4c
+e5
+e0
+70
+25
+90
+4c
+e2
+e0
+70
+1f
+d2
+01
+7f
+14
+31
+b2
+80
+17
+90
+4c
+e5
+e0
+70
+0c
+90
+4c
+e2
+e0
+70
+06
+c2
+01
+7f
+14
+31
+b2
+e4
+90
+4c
+e8
+f0
+e4
+90
+4d
+46
+f0
+90
+4c
+b7
+e0
+90
+4d
+e0
+f0
+22
+c2
+01
+7f
+ff
+21
+b2
+c2
+01
+7f
+ff
+31
+b2
+22
+90
+4f
+01
+ef
+f0
+14
+b4
+0d
+00
+40
+02
+81
+97
+90
+12
+e1
+75
+f0
+03
+a4
+c5
+83
+25
+f0
+c5
+83
+73
+02
+13
+08
+02
+13
+08
+02
+13
+08
+02
+14
+97
+02
+13
+4c
+02
+13
+8e
+02
+13
+97
+02
+13
+e4
+02
+13
+e4
+02
+14
+4c
+02
+14
+97
+02
+14
+97
+02
+13
+48
+90
+4c
+c5
+e0
+ff
+64
+03
+60
+05
+ef
+64
+02
+70
+0d
+7f
+22
+91
+9d
+90
+4f
+01
+e0
+90
+4c
+ed
+f0
+22
+90
+4f
+01
+e0
+14
+90
+4d
+d6
+f0
+90
+42
+13
+74
+05
+f0
+90
+4c
+f0
+f0
+7f
+04
+91
+9d
+7f
+0a
+f1
+98
+7f
+2a
+91
+9d
+e4
+90
+4c
+ed
+f0
+22
+7f
+0e
+81
+9d
+e4
+90
+4c
+f0
+f0
+12
+19
+c1
+ef
+70
+0c
+12
+19
+ae
+ef
+70
+06
+12
+1f
+ed
+ef
+60
+0f
+90
+4f
+01
+e0
+90
+4c
+ed
+f0
+90
+4d
+ec
+74
+03
+f0
+22
+f1
+e0
+e4
+90
+4d
+d4
+f0
+90
+4d
+d3
+f0
+90
+4e
+55
+f0
+12
+22
+1c
+7f
+0d
+91
+9d
+e4
+90
+4c
+ed
+f0
+22
+12
+19
+c1
+e4
+90
+4c
+ed
+f0
+22
+7b
+01
+7a
+4d
+79
+ee
+7d
+5d
+7c
+00
+12
+35
+45
+90
+4c
+c0
+74
+ff
+f0
+a3
+f0
+7f
+c8
+f1
+98
+c2
+01
+7f
+ff
+31
+b2
+7b
+01
+7a
+4d
+79
+ee
+7d
+5d
+7c
+00
+7f
+60
+7e
+7f
+12
+1c
+84
+7b
+01
+7a
+4c
+79
+c0
+7d
+01
+7c
+00
+7f
+bd
+7e
+7f
+12
+1c
+84
+d2
+01
+7f
+ff
+31
+b2
+e4
+90
+4c
+ed
+f0
+22
+e4
+90
+4c
+f0
+f0
+12
+19
+ae
+ef
+60
+09
+90
+4f
+01
+e0
+90
+4c
+ed
+f0
+22
+7b
+01
+7a
+4c
+79
+00
+7d
+04
+7c
+00
+7f
+52
+7e
+7f
+12
+20
+ca
+7f
+0a
+f1
+98
+e4
+90
+4e
+55
+f0
+90
+4c
+00
+e0
+f4
+70
+21
+a3
+e0
+f4
+70
+1c
+a3
+e0
+f4
+70
+17
+a3
+e0
+f4
+70
+12
+90
+4c
+00
+74
+0f
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+90
+4e
+55
+74
+01
+f0
+7f
+21
+91
+9d
+90
+4c
+c5
+74
+02
+f0
+e4
+a3
+f0
+90
+4c
+ed
+f0
+22
+e4
+90
+4c
+f0
+f0
+12
+19
+c1
+ef
+70
+06
+12
+19
+ae
+ef
+60
+09
+90
+4f
+01
+e0
+90
+4c
+ed
+f0
+22
+90
+4c
+c5
+e0
+64
+01
+60
+23
+e4
+90
+4e
+55
+f0
+7f
+23
+91
+9d
+90
+4c
+c5
+74
+01
+f0
+e4
+a3
+f0
+90
+4c
+ee
+74
+28
+f0
+c2
+01
+7f
+14
+31
+b2
+e4
+90
+4c
+e9
+f0
+e4
+90
+4c
+ed
+f0
+22
+e4
+90
+4c
+ed
+f0
+22
+90
+4e
+dc
+ef
+f0
+78
+dd
+7c
+4e
+7d
+01
+7b
+ff
+7a
+07
+79
+34
+7e
+00
+7f
+03
+12
+03
+90
+90
+4e
+dc
+e0
+90
+4e
+df
+f0
+7b
+01
+7a
+4e
+79
+dd
+7d
+03
+02
+0f
+e5
+90
+4f
+06
+ef
+f0
+12
+05
+b3
+16
+7b
+14
+17
+4a
+15
+15
+71
+27
+17
+11
+29
+14
+fe
+2f
+15
+65
+30
+15
+ca
+31
+16
+3f
+32
+14
+fe
+33
+16
+ec
+34
+17
+2b
+35
+15
+c2
+37
+15
+71
+39
+15
+ca
+3c
+00
+00
+17
+8e
+f1
+ea
+12
+30
+4d
+7b
+01
+7a
+4c
+79
+c0
+7d
+01
+7c
+00
+7f
+bd
+7e
+7f
+12
+20
+ca
+90
+4c
+c0
+e0
+d3
+94
+03
+74
+80
+94
+80
+40
+02
+e4
+f0
+90
+4c
+c0
+e0
+90
+4c
+c3
+f0
+f1
+b0
+7f
+0a
+f1
+98
+7b
+01
+7a
+4c
+79
+f2
+7d
+02
+7c
+00
+7f
+be
+7e
+7f
+12
+20
+ca
+90
+4c
+f2
+e0
+f4
+70
+19
+a3
+e0
+f4
+70
+14
+90
+4c
+93
+e0
+a3
+e0
+90
+4c
+f2
+f0
+90
+4c
+91
+e0
+a3
+e0
+90
+4c
+f3
+f0
+02
+20
+04
+12
+30
+3a
+12
+18
+f4
+e4
+90
+4c
+fc
+f0
+22
+90
+4c
+c3
+e0
+d3
+94
+00
+74
+80
+94
+80
+50
+02
+e1
+8e
+e0
+94
+04
+74
+80
+94
+80
+40
+02
+e1
+8e
+e0
+75
+f0
+1f
+a4
+24
+cf
+f9
+74
+4d
+35
+f0
+fa
+7b
+01
+7d
+1f
+7c
+00
+12
+35
+45
+7f
+c8
+f1
+98
+c2
+01
+7f
+ff
+31
+b2
+7b
+01
+7a
+4d
+79
+ee
+7d
+5d
+7c
+00
+7f
+60
+7e
+7f
+12
+1c
+84
+d2
+01
+7f
+ff
+21
+b2
+90
+4d
+d6
+e0
+ff
+02
+07
+37
+90
+4c
+c5
+74
+03
+f0
+e4
+a3
+f0
+f1
+e0
+e4
+90
+4c
+ee
+f0
+90
+4c
+eb
+f0
+90
+4c
+c0
+74
+fe
+f0
+90
+4c
+c3
+f0
+90
+4d
+46
+74
+03
+f0
+90
+4d
+e6
+74
+0a
+f0
+90
+4f
+06
+e0
+64
+31
+70
+3a
+90
+4d
+e7
+f0
+90
+4e
+55
+f0
+90
+4c
+c1
+f0
+90
+4c
+e5
+74
+0a
+f0
+90
+4b
+eb
+e0
+64
+0f
+70
+14
+a3
+e0
+64
+0f
+70
+0e
+a3
+e0
+64
+0f
+70
+08
+a3
+e0
+64
+0f
+70
+02
+e1
+8e
+90
+4c
+bf
+74
+02
+f0
+12
+1b
+ea
+02
+1d
+33
+90
+4c
+e5
+e0
+60
+02
+e1
+8e
+22
+e4
+90
+4c
+c5
+f0
+a3
+f0
+90
+4c
+e3
+f0
+a3
+f0
+90
+4c
+eb
+04
+f0
+90
+4c
+ed
+e0
+60
+09
+f1
+e0
+90
+4c
+ed
+e0
+ff
+41
+c6
+90
+4c
+ec
+e0
+64
+01
+70
+03
+f0
+e1
+8f
+90
+4c
+f0
+e0
+70
+02
+e1
+8e
+90
+4d
+d6
+e0
+ff
+02
+07
+37
+90
+4c
+c7
+74
+03
+f0
+a3
+74
+01
+f0
+e4
+a3
+f0
+a3
+f0
+7f
+0e
+91
+9d
+7f
+02
+91
+9d
+90
+4c
+e9
+e0
+60
+34
+e4
+90
+4d
+e7
+f0
+90
+4c
+c1
+f0
+90
+4c
+c3
+e0
+75
+f0
+1f
+a4
+24
+ec
+f5
+82
+e4
+34
+4d
+f5
+83
+e4
+f0
+90
+4d
+e7
+e0
+ff
+90
+4c
+c3
+e0
+75
+f0
+1f
+a4
+24
+ed
+f5
+82
+e4
+34
+4d
+f5
+83
+ef
+f0
+90
+4d
+e5
+e0
+70
+06
+90
+4d
+d4
+74
+14
+f0
+90
+4c
+e5
+e0
+70
+02
+f1
+c8
+e4
+90
+4c
+e9
+f0
+90
+4c
+e3
+f0
+a3
+f0
+22
+90
+4c
+c7
+74
+04
+f0
+e4
+a3
+f0
+f1
+e0
+e4
+90
+4c
+eb
+f0
+90
+4d
+db
+74
+0a
+f0
+90
+4c
+c3
+e0
+90
+4c
+c0
+f0
+90
+4c
+bf
+74
+03
+f0
+22
+90
+4c
+c3
+e0
+14
+fd
+7f
+01
+12
+07
+fe
+90
+4c
+c3
+e0
+90
+4c
+c0
+f0
+90
+4c
+bf
+74
+03
+f0
+22
+90
+4d
+39
+12
+05
+82
+00
+00
+00
+00
+e4
+90
+4d
+d7
+f0
+90
+4d
+de
+04
+f0
+90
+4c
+c8
+04
+f0
+90
+4c
+c7
+04
+f0
+22
+90
+4c
+c7
+e0
+90
+4c
+cb
+f0
+e4
+90
+4c
+c7
+f0
+a3
+f0
+90
+4c
+eb
+04
+f0
+e4
+90
+4d
+3d
+f0
+90
+4c
+ec
+e0
+64
+01
+70
+03
+f0
+80
+21
+90
+4c
+ed
+e0
+60
+03
+ff
+41
+c6
+90
+4c
+f0
+e0
+60
+08
+90
+4d
+d6
+e0
+ff
+02
+07
+37
+f1
+8f
+e4
+90
+4c
+e3
+f0
+a3
+f0
+22
+e4
+90
+4d
+38
+f0
+7f
+19
+81
+9d
+ef
+d3
+94
+00
+40
+11
+e4
+fd
+fc
+0d
+bd
+00
+01
+0c
+bc
+04
+f8
+bd
+a6
+f5
+1f
+80
+e9
+22
+d2
+01
+7f
+1d
+31
+b2
+d2
+01
+7f
+1f
+31
+b2
+d2
+01
+7f
+1e
+31
+b2
+d2
+01
+7f
+14
+21
+b2
+c2
+01
+7f
+1f
+31
+b2
+c2
+01
+7f
+1e
+31
+b2
+c2
+01
+7f
+14
+31
+b2
+c2
+01
+7f
+1d
+21
+b2
+e4
+90
+4c
+f0
+f0
+90
+4d
+e5
+f0
+22
+12
+30
+3a
+12
+18
+f4
+c2
+06
+7f
+1d
+12
+18
+08
+c2
+06
+7f
+1f
+12
+18
+08
+c2
+06
+7f
+1e
+11
+08
+c2
+06
+7f
+14
+ac
+07
+ec
+f4
+60
+15
+af
+04
+d2
+04
+11
+35
+af
+04
+a2
+06
+92
+01
+12
+11
+b2
+af
+04
+c2
+02
+11
+24
+22
+ef
+f4
+60
+0c
+7b
+01
+7a
+80
+79
+78
+a2
+02
+92
+00
+11
+75
+22
+ef
+f4
+60
+0c
+7b
+01
+7a
+80
+79
+70
+a2
+04
+92
+00
+11
+75
+22
+ac
+07
+ec
+f4
+60
+17
+af
+04
+a2
+05
+92
+03
+11
+64
+af
+04
+a2
+05
+b3
+92
+02
+11
+24
+af
+04
+c2
+04
+11
+35
+22
+ef
+f4
+60
+0c
+7b
+01
+7a
+80
+79
+7c
+a2
+03
+92
+00
+11
+75
+22
+90
+4e
+f5
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+e4
+fe
+fd
+ef
+54
+07
+fe
+ef
+13
+13
+13
+54
+03
+fd
+30
+00
+22
+90
+4e
+f5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+2d
+f9
+e4
+3a
+fa
+12
+03
+b6
+ff
+74
+01
+a8
+06
+08
+80
+02
+c3
+33
+d8
+fc
+4f
+02
+03
+fc
+90
+4e
+f5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+2d
+f9
+e4
+3a
+fa
+12
+03
+b6
+ff
+74
+01
+a8
+06
+08
+80
+02
+c3
+33
+d8
+fc
+f4
+5f
+02
+03
+fc
+e4
+90
+4f
+04
+f0
+f0
+90
+4f
+04
+e0
+90
+06
+81
+93
+ff
+60
+0c
+c2
+05
+11
+46
+90
+4f
+04
+e0
+04
+f0
+80
+e9
+22
+90
+80
+80
+e4
+f0
+a3
+f0
+a3
+f0
+31
+01
+80
+d5
+e4
+90
+4f
+03
+f0
+f0
+90
+4f
+03
+e0
+ff
+c3
+94
+08
+74
+80
+94
+80
+50
+0c
+c2
+05
+11
+46
+90
+4f
+03
+e0
+04
+f0
+80
+e6
+22
+e4
+90
+4f
+00
+f0
+90
+4c
+c8
+e0
+64
+02
+70
+06
+90
+4f
+00
+e0
+ff
+22
+90
+47
+f5
+e0
+30
+e3
+06
+90
+4f
+00
+e0
+ff
+22
+90
+4c
+ee
+e0
+60
+06
+90
+4f
+00
+e0
+ff
+22
+90
+4c
+c7
+e0
+70
+4a
+90
+4c
+c5
+e0
+64
+03
+60
+42
+90
+4c
+ef
+e0
+70
+46
+74
+0a
+f0
+a3
+e0
+70
+3f
+90
+4d
+eb
+e0
+64
+02
+70
+37
+90
+4c
+c3
+e0
+ff
+7e
+00
+c3
+94
+01
+74
+80
+94
+80
+40
+10
+d3
+ef
+94
+03
+74
+80
+94
+80
+50
+06
+e0
+12
+12
+c6
+80
+17
+7f
+09
+12
+12
+c6
+90
+4f
+00
+74
+01
+f0
+80
+0a
+e4
+90
+4c
+eb
+f0
+90
+4f
+00
+04
+f0
+90
+4f
+00
+e0
+ff
+22
+90
+4c
+c7
+e0
+64
+02
+70
+08
+7f
+0e
+12
+14
+9d
+7f
+01
+22
+7f
+00
+22
+90
+4c
+c7
+e0
+ff
+64
+04
+60
+05
+ef
+64
+03
+70
+08
+7f
+11
+12
+14
+9d
+7f
+01
+22
+90
+4c
+c5
+e0
+ff
+64
+03
+60
+05
+ef
+64
+02
+70
+08
+7f
+22
+12
+14
+9d
+7f
+01
+22
+7f
+00
+22
+90
+4c
+ce
+e0
+30
+e1
+46
+90
+4c
+d0
+e0
+c3
+94
+fa
+74
+80
+94
+80
+50
+03
+e0
+04
+f0
+90
+4c
+d0
+e0
+64
+b4
+70
+3b
+90
+4d
+e3
+e0
+04
+f0
+e0
+d3
+94
+02
+74
+80
+94
+80
+50
+07
+e4
+90
+4c
+d0
+f0
+80
+24
+90
+4d
+e3
+e0
+64
+03
+70
+1c
+90
+4d
+dc
+04
+f0
+e4
+90
+4c
+d0
+f0
+12
+17
+8f
+80
+0d
+e4
+90
+4d
+e3
+f0
+90
+4d
+dc
+f0
+90
+4c
+d0
+f0
+90
+4c
+ce
+e0
+30
+e4
+3e
+90
+4c
+ea
+74
+0a
+f0
+90
+4c
+d1
+e0
+c3
+94
+fa
+74
+80
+94
+80
+50
+03
+e0
+04
+f0
+90
+4c
+d1
+e0
+64
+06
+70
+4a
+90
+4c
+c3
+e0
+60
+04
+64
+fe
+70
+40
+e4
+90
+4c
+cd
+f0
+31
+c1
+7f
+0a
+12
+17
+98
+7f
+0a
+12
+12
+c6
+12
+17
+f0
+80
+2a
+90
+4c
+cd
+e0
+60
+1f
+e4
+f0
+7f
+0d
+12
+12
+c6
+90
+4c
+eb
+74
+01
+f0
+90
+4c
+c3
+e0
+90
+4c
+c0
+f0
+90
+4c
+bf
+74
+01
+f0
+71
+ea
+b1
+33
+e4
+90
+4c
+d1
+f0
+90
+4c
+ce
+e0
+30
+e3
+4d
+90
+4c
+ea
+74
+0a
+f0
+90
+4c
+d2
+e0
+c3
+94
+fa
+74
+80
+94
+80
+50
+03
+e0
+04
+f0
+90
+4c
+d2
+e0
+64
+06
+70
+65
+90
+4c
+e9
+74
+f0
+f0
+e4
+90
+4c
+ee
+f0
+7f
+05
+12
+12
+c6
+12
+17
+f0
+e4
+90
+4c
+cc
+f0
+90
+4c
+eb
+04
+f0
+90
+4c
+c0
+e0
+90
+4c
+c4
+f0
+90
+4c
+c3
+e0
+90
+4c
+c0
+f0
+80
+36
+90
+4c
+cc
+e0
+60
+2b
+e4
+f0
+90
+4c
+c3
+e0
+ff
+90
+4c
+c0
+e0
+6f
+60
+1d
+90
+4c
+eb
+74
+01
+f0
+12
+17
+f0
+90
+4c
+c3
+e0
+90
+4c
+c0
+f0
+90
+4c
+bf
+74
+01
+f0
+31
+c1
+71
+ea
+b1
+33
+e4
+90
+4c
+d2
+f0
+90
+4c
+ce
+e0
+20
+e5
+02
+61
+e4
+a3
+e0
+c3
+94
+fa
+74
+80
+94
+80
+50
+03
+e0
+04
+f0
+90
+4c
+cf
+e0
+64
+06
+60
+02
+61
+e9
+90
+4d
+e8
+e0
+64
+14
+70
+08
+90
+4c
+c1
+74
+02
+f0
+80
+21
+90
+4d
+e8
+e0
+64
+12
+70
+07
+90
+4c
+c1
+04
+f0
+80
+12
+90
+4d
+e8
+e0
+64
+1a
+60
+05
+e0
+64
+08
+70
+05
+e4
+90
+4c
+c1
+f0
+90
+4c
+e5
+74
+0a
+f0
+90
+4c
+c3
+e0
+ff
+7e
+00
+60
+04
+64
+fe
+70
+07
+90
+4c
+bf
+74
+02
+f0
+22
+d3
+ef
+94
+03
+ee
+64
+80
+94
+80
+50
+2f
+c3
+ef
+94
+01
+ee
+64
+80
+94
+80
+40
+24
+90
+4c
+c1
+e0
+ff
+90
+4c
+c3
+e0
+75
+f0
+1f
+a4
+24
+ec
+f5
+82
+e4
+34
+4d
+f5
+83
+ef
+f0
+90
+4c
+bf
+74
+03
+f0
+22
+e4
+90
+4c
+cf
+f0
+22
+90
+4c
+bf
+e0
+70
+02
+81
+83
+64
+01
+60
+05
+7f
+c8
+12
+17
+98
+c2
+01
+7f
+ff
+12
+11
+b2
+90
+4c
+bf
+e0
+64
+02
+70
+31
+7b
+01
+7a
+4c
+79
+00
+7d
+04
+fc
+7f
+52
+7e
+7f
+91
+84
+7b
+01
+7a
+4c
+79
+c1
+7d
+01
+7c
+00
+7f
+57
+7e
+7f
+91
+84
+7b
+01
+7a
+4d
+79
+e7
+7d
+01
+7c
+00
+7f
+56
+7e
+7f
+91
+84
+80
+17
+90
+4c
+bf
+e0
+64
+03
+70
+0f
+7b
+01
+7a
+4d
+79
+ee
+7d
+5d
+fc
+7f
+60
+7e
+7f
+91
+84
+7b
+01
+7a
+4c
+79
+c0
+7d
+01
+7c
+00
+7f
+bd
+7e
+7f
+91
+84
+7b
+01
+7a
+4c
+79
+f2
+7d
+02
+7c
+00
+7f
+be
+7e
+7f
+91
+84
+d2
+01
+7f
+ff
+12
+11
+b2
+7f
+0a
+12
+17
+98
+e4
+90
+4c
+bf
+f0
+22
+90
+4e
+93
+ee
+f0
+a3
+ef
+f0
+a3
+ec
+f0
+a3
+ed
+f0
+a3
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+90
+4e
+95
+e0
+70
+02
+a3
+e0
+70
+02
+a1
+32
+90
+4e
+93
+e0
+fe
+a3
+e0
+ff
+44
+0f
+24
+01
+fd
+e4
+3e
+fc
+c3
+ed
+9f
+ff
+ec
+9e
+fe
+90
+4e
+9a
+f0
+a3
+ef
+f0
+90
+4e
+95
+e0
+fc
+a3
+e0
+fd
+d3
+9f
+ec
+9e
+40
+0a
+90
+4e
+9a
+e0
+fe
+a3
+e0
+ff
+80
+04
+ae
+04
+af
+05
+90
+4e
+9a
+ee
+f0
+fc
+a3
+ef
+f0
+fd
+c3
+90
+4e
+96
+e0
+9d
+f0
+90
+4e
+95
+e0
+9c
+f0
+90
+4e
+93
+e0
+fe
+a3
+e0
+ff
+90
+4e
+97
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+21
+82
+7f
+0a
+12
+17
+98
+90
+4e
+9a
+e0
+fe
+a3
+e0
+ff
+90
+4e
+98
+ee
+8f
+f0
+12
+04
+0e
+90
+4e
+94
+e0
+2f
+f0
+90
+4e
+93
+e0
+3e
+f0
+81
+9b
+22
+90
+80
+10
+74
+01
+f0
+80
+fe
+22
+f1
+93
+12
+32
+fb
+d1
+d0
+71
+ea
+12
+11
+c4
+90
+4d
+7d
+e0
+60
+03
+12
+24
+33
+90
+0b
+7e
+e0
+14
+60
+0d
+24
+fe
+70
+e2
+b1
+8b
+12
+17
+f0
+d1
+c2
+80
+fe
+90
+4c
+ea
+e0
+70
+12
+90
+4c
+ec
+e0
+70
+0c
+90
+4c
+e5
+e0
+70
+06
+90
+4c
+f8
+e0
+60
+05
+12
+35
+32
+80
+bc
+b1
+8b
+d1
+c2
+80
+b6
+80
+b4
+22
+e4
+ff
+90
+4f
+05
+f0
+fe
+fd
+ef
+90
+06
+81
+93
+60
+48
+ef
+93
+fd
+13
+13
+13
+54
+1f
+fe
+ed
+54
+07
+fd
+f8
+74
+01
+08
+80
+02
+c3
+33
+d8
+fc
+fd
+ee
+24
+78
+fb
+e4
+34
+80
+8b
+82
+f5
+83
+e0
+fc
+ed
+f4
+fb
+ec
+5b
+f0
+ee
+24
+70
+f5
+82
+e4
+34
+80
+f5
+83
+e0
+4d
+f0
+ee
+24
+74
+f5
+82
+e4
+34
+80
+f5
+83
+e0
+5b
+f0
+0f
+80
+b1
+12
+35
+ce
+90
+81
+1c
+e0
+90
+4f
+05
+f0
+90
+4d
+dc
+e0
+60
+20
+e4
+ff
+d1
+23
+7f
+01
+d1
+23
+7f
+02
+d1
+23
+7f
+03
+d1
+23
+7f
+04
+d1
+23
+7f
+05
+d1
+23
+7f
+06
+d1
+23
+7f
+07
+80
+10
+90
+4f
+05
+e0
+ff
+90
+00
+a3
+f0
+ef
+f4
+90
+00
+a7
+f0
+22
+90
+4f
+09
+ef
+f0
+f1
+a6
+92
+08
+90
+4f
+09
+e0
+ff
+a2
+08
+b3
+92
+07
+ef
+f4
+70
+02
+c1
+c1
+ef
+54
+07
+fe
+ef
+13
+13
+13
+54
+03
+ff
+30
+07
+43
+24
+a3
+f5
+82
+e4
+34
+00
+f5
+83
+c0
+83
+c0
+82
+e0
+fd
+74
+01
+a8
+06
+08
+80
+02
+c3
+33
+d8
+fc
+f4
+5d
+d0
+82
+d0
+83
+f0
+74
+a7
+2f
+f5
+82
+e4
+34
+00
+f5
+83
+c0
+83
+c0
+82
+e0
+ff
+74
+01
+a8
+06
+08
+80
+02
+c3
+33
+d8
+fc
+4f
+d0
+82
+d0
+83
+f0
+22
+74
+a3
+2f
+f5
+82
+e4
+34
+00
+f5
+83
+c0
+83
+c0
+82
+e0
+fd
+74
+01
+a8
+06
+08
+80
+02
+c3
+33
+d8
+fc
+fc
+4d
+d0
+82
+d0
+83
+f0
+74
+a7
+2f
+f5
+82
+e4
+34
+00
+f5
+83
+e0
+ff
+ec
+f4
+fe
+ef
+5e
+f0
+22
+e4
+90
+0b
+7f
+f0
+90
+0b
+7e
+f0
+7f
+01
+02
+17
+98
+90
+4c
+f4
+e0
+ff
+60
+09
+64
+03
+60
+05
+ef
+64
+05
+70
+03
+02
+26
+af
+90
+4c
+f4
+e0
+64
+01
+70
+0e
+a3
+e0
+ff
+e4
+fd
+f1
+57
+90
+4c
+f4
+74
+02
+f0
+22
+90
+4c
+f4
+e0
+64
+02
+70
+0b
+74
+03
+f0
+a3
+e0
+ff
+a3
+e0
+fd
+80
+4b
+90
+4c
+f4
+e0
+64
+04
+70
+26
+90
+4c
+f6
+f0
+90
+4c
+f5
+e0
+ff
+e4
+fd
+f1
+57
+e4
+90
+4c
+f5
+f0
+90
+4c
+f8
+e0
+70
+07
+90
+4c
+f4
+74
+06
+f0
+22
+90
+4c
+f4
+74
+05
+f0
+22
+90
+4c
+f4
+e0
+64
+06
+70
+14
+90
+4c
+f6
+f0
+90
+4c
+f5
+f0
+a3
+e0
+fd
+e4
+ff
+f1
+57
+e4
+90
+4c
+f4
+f0
+22
+90
+4e
+f8
+ef
+f0
+a3
+ed
+f0
+7b
+01
+7a
+48
+79
+00
+7d
+09
+7c
+00
+12
+0d
+fa
+90
+48
+00
+74
+01
+f0
+a3
+e0
+ff
+90
+4e
+f8
+e0
+fe
+ef
+4e
+90
+48
+01
+f0
+90
+4e
+f9
+e0
+90
+48
+03
+f0
+7b
+01
+7a
+48
+79
+00
+7d
+09
+02
+0e
+da
+7b
+01
+7a
+4e
+79
+56
+78
+68
+7c
+4e
+7d
+01
+7e
+00
+7f
+12
+02
+03
+90
+7b
+01
+7a
+81
+79
+1c
+ad
+07
+e4
+90
+4f
+08
+f0
+fe
+ef
+54
+07
+f0
+ef
+13
+13
+13
+54
+03
+fe
+f5
+82
+75
+83
+00
+12
+03
+cf
+fd
+33
+95
+e0
+fc
+90
+4f
+08
+e0
+ff
+74
+01
+7e
+00
+a8
+07
+08
+80
+05
+c3
+33
+ce
+33
+ce
+d8
+f9
+ff
+ee
+5c
+fe
+ef
+5d
+4e
+24
+ff
+22
+a1
+3c
+90
+4c
+c0
+e0
+ff
+64
+fe
+60
+03
+ef
+70
+08
+7f
+22
+12
+14
+9d
+7f
+01
+22
+7f
+00
+22
+90
+4d
+eb
+74
+02
+f0
+7b
+01
+7a
+4d
+79
+ee
+7d
+5d
+7c
+00
+7f
+60
+7e
+7f
+11
+ca
+7f
+0a
+12
+17
+98
+7b
+01
+7a
+4c
+79
+00
+7d
+04
+7c
+00
+7f
+52
+7e
+7f
+11
+ca
+7f
+0a
+12
+17
+98
+7b
+01
+7a
+4d
+79
+e7
+7d
+01
+7c
+00
+7f
+56
+7e
+7f
+11
+ca
+7f
+0a
+12
+17
+98
+7b
+01
+7a
+4c
+79
+c1
+7d
+01
+7c
+00
+7f
+57
+7e
+7f
+11
+ca
+7f
+0a
+12
+17
+98
+90
+4c
+c3
+e0
+ff
+7e
+00
+d3
+94
+03
+74
+80
+94
+80
+50
+38
+c3
+ef
+94
+01
+74
+80
+94
+80
+40
+2e
+e0
+75
+f0
+1f
+a4
+24
+ec
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+90
+4c
+c1
+f0
+90
+4c
+c3
+e0
+75
+f0
+1f
+a4
+24
+ed
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+90
+4d
+e7
+f0
+12
+12
+c6
+80
+05
+7f
+08
+12
+12
+c6
+90
+4d
+e7
+e0
+d3
+94
+01
+74
+80
+94
+80
+40
+02
+e4
+f0
+90
+4c
+c1
+e0
+d3
+94
+02
+74
+80
+94
+80
+40
+02
+e4
+f0
+22
+90
+4e
+cf
+ec
+f0
+a3
+ed
+f0
+a3
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+90
+80
+98
+74
+04
+f0
+a3
+e4
+f0
+90
+0c
+af
+74
+a0
+f0
+a3
+ee
+f0
+a3
+ef
+f0
+90
+0c
+b2
+74
+a1
+f0
+7a
+0c
+79
+af
+7e
+0c
+7f
+af
+74
+af
+fc
+74
+0c
+ff
+ec
+fe
+ef
+90
+80
+9a
+ee
+f0
+a3
+ef
+f0
+90
+4e
+cf
+e0
+fc
+a3
+e0
+fa
+ec
+ff
+ea
+fe
+ef
+90
+80
+9e
+ee
+f0
+a3
+ef
+f0
+7a
+0b
+79
+83
+7e
+0b
+7f
+83
+74
+83
+fc
+74
+0b
+ff
+ec
+fe
+ef
+90
+80
+9c
+ee
+f0
+a3
+ef
+f0
+90
+80
+90
+74
+02
+f0
+90
+80
+9c
+a3
+e0
+20
+e7
+07
+90
+80
+90
+e0
+44
+01
+f0
+90
+80
+06
+e0
+44
+04
+f0
+31
+7a
+90
+4e
+d1
+e0
+a3
+e0
+fa
+a3
+e0
+ae
+02
+ff
+7b
+01
+7a
+0b
+79
+83
+90
+4e
+cf
+e0
+a3
+e0
+90
+4e
+c4
+f0
+02
+08
+78
+90
+81
+2c
+e0
+30
+e5
+f9
+22
+90
+4e
+b2
+ee
+f0
+a3
+ef
+f0
+90
+4e
+b6
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+90
+4e
+b4
+ec
+f0
+a3
+ed
+f0
+a3
+e0
+f9
+a3
+e0
+fa
+a3
+e0
+90
+4e
+9f
+c9
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+a3
+ec
+f0
+a3
+ed
+f0
+7b
+01
+7a
+0b
+79
+86
+91
+62
+90
+0b
+83
+74
+a0
+f0
+90
+4e
+b2
+e0
+ff
+a3
+e0
+90
+0b
+84
+cf
+f0
+a3
+ef
+f0
+90
+4e
+b5
+e0
+24
+03
+fd
+90
+4e
+b4
+e0
+34
+00
+fc
+ed
+fa
+ec
+ff
+ea
+fe
+ef
+90
+80
+98
+ee
+f0
+a3
+ef
+f0
+7a
+0b
+79
+83
+7e
+0b
+7f
+83
+74
+83
+fc
+74
+0b
+ff
+ec
+fe
+ef
+a3
+ee
+f0
+a3
+ef
+f0
+90
+80
+9e
+e4
+f0
+a3
+f0
+90
+80
+90
+04
+f0
+90
+80
+06
+e0
+44
+04
+f0
+21
+7a
+7b
+01
+7a
+4c
+79
+f2
+7d
+02
+7c
+00
+7f
+be
+7e
+7f
+11
+ca
+90
+4c
+f2
+e0
+04
+f0
+a3
+e0
+04
+f0
+90
+4c
+f2
+e0
+90
+44
+fa
+f0
+90
+4c
+f3
+e0
+90
+44
+fb
+f0
+90
+4d
+d0
+e0
+90
+44
+fc
+f0
+90
+4d
+d1
+e0
+90
+44
+fd
+f0
+90
+4d
+d2
+e0
+90
+44
+fe
+f0
+22
+90
+4d
+ec
+e0
+60
+39
+e0
+14
+f0
+e0
+70
+33
+90
+4c
+ed
+e0
+64
+05
+70
+2b
+90
+47
+f5
+e0
+20
+e3
+24
+e4
+90
+4d
+d4
+f0
+90
+4c
+e9
+74
+f0
+f0
+e4
+90
+4c
+ee
+f0
+90
+4e
+55
+f0
+90
+4d
+d3
+f0
+51
+1c
+7f
+0d
+12
+14
+9d
+e4
+90
+4c
+ed
+f0
+22
+12
+10
+e9
+90
+4c
+e4
+e0
+04
+f0
+70
+06
+90
+4c
+e3
+e0
+04
+f0
+71
+02
+71
+34
+12
+19
+f0
+51
+5f
+90
+4c
+e9
+e0
+60
+24
+e4
+90
+4c
+e3
+f0
+a3
+f0
+90
+4c
+e9
+e0
+14
+f0
+e0
+70
+14
+90
+4c
+c4
+e0
+90
+4c
+c3
+f0
+90
+4c
+c0
+f0
+7f
+0d
+12
+12
+c6
+12
+17
+8f
+90
+4c
+ee
+e0
+60
+18
+e4
+90
+4c
+e3
+f0
+a3
+f0
+90
+4c
+ee
+e0
+14
+f0
+e0
+70
+08
+7f
+0a
+12
+17
+98
+12
+17
+8f
+22
+e4
+ff
+24
+bc
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+70
+12
+90
+4d
+06
+e0
+60
+0c
+14
+f0
+e0
+70
+05
+90
+4c
+d5
+f0
+22
+71
+23
+22
+90
+4c
+d3
+e0
+60
+0a
+14
+f0
+e0
+70
+05
+74
+05
+f0
+91
+a6
+22
+90
+4d
+db
+e0
+60
+0f
+e0
+14
+f0
+e0
+70
+09
+90
+41
+31
+04
+f0
+90
+4d
+da
+f0
+90
+4c
+c7
+e0
+ff
+64
+04
+70
+53
+ef
+64
+04
+70
+34
+90
+4d
+da
+e0
+70
+10
+90
+4c
+e3
+e0
+fe
+a3
+e0
+ff
+4e
+60
+23
+ef
+54
+1f
+70
+1e
+e4
+90
+4d
+da
+f0
+90
+4e
+4c
+74
+04
+f0
+90
+4c
+f9
+e0
+90
+4e
+4d
+f0
+7b
+01
+7a
+4e
+79
+4c
+7d
+02
+12
+0e
+da
+90
+4c
+e3
+e0
+64
+38
+70
+04
+a3
+e0
+64
+40
+60
+02
+81
+32
+12
+19
+c1
+90
+4c
+ec
+74
+01
+f0
+22
+90
+4c
+c5
+e0
+64
+03
+70
+4d
+90
+4c
+e3
+e0
+fe
+a3
+e0
+ff
+64
+0a
+4e
+70
+08
+90
+4d
+46
+e0
+60
+02
+e4
+f0
+ef
+54
+1f
+64
+10
+70
+20
+7b
+01
+7a
+48
+79
+00
+7d
+09
+fc
+12
+0d
+fa
+e4
+90
+4e
+4b
+f0
+90
+48
+00
+04
+f0
+fb
+7a
+48
+79
+00
+7d
+09
+12
+0e
+da
+c3
+90
+4c
+e4
+e0
+94
+b0
+90
+4c
+e3
+e0
+94
+04
+40
+3a
+80
+39
+90
+4c
+c5
+e0
+64
+01
+70
+11
+c3
+90
+4c
+e4
+e0
+94
+78
+90
+4c
+e3
+e0
+94
+00
+40
+21
+80
+20
+c3
+90
+4c
+e4
+e0
+94
+14
+90
+4c
+e3
+e0
+94
+00
+40
+10
+90
+4d
+e5
+e0
+60
+07
+e4
+f0
+7f
+0e
+12
+14
+9d
+12
+17
+8f
+22
+12
+17
+f0
+90
+4b
+ef
+74
+ff
+f0
+90
+4c
+fc
+74
+01
+f0
+e4
+90
+4c
+e6
+f0
+a3
+f0
+a3
+f0
+90
+4c
+b7
+74
+f0
+f0
+90
+4d
+e0
+f0
+90
+4d
+40
+74
+ff
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+22
+90
+4e
+9c
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+90
+4e
+a2
+74
+ff
+f5
+f0
+12
+04
+24
+45
+f0
+60
+2a
+90
+4e
+9f
+e0
+fb
+a3
+e4
+75
+f0
+01
+12
+04
+24
+a9
+f0
+fa
+12
+03
+b6
+ff
+90
+4e
+9c
+e0
+fb
+a3
+e4
+75
+f0
+01
+12
+04
+24
+a9
+f0
+fa
+ef
+12
+03
+fc
+80
+c8
+22
+90
+4e
+cb
+12
+05
+82
+00
+00
+00
+00
+90
+4c
+95
+e0
+70
+02
+a3
+e0
+70
+02
+c1
+70
+90
+4c
+95
+e0
+fe
+a3
+e0
+ff
+90
+4c
+d4
+e0
+fd
+04
+f0
+ed
+25
+e0
+24
+d6
+f5
+82
+e4
+34
+4c
+f5
+83
+ee
+f0
+a3
+ef
+f0
+90
+4c
+d4
+e0
+c3
+94
+04
+74
+80
+94
+80
+40
+02
+e4
+f0
+e4
+90
+4e
+ca
+f0
+90
+4e
+ca
+e0
+c3
+94
+04
+74
+80
+94
+80
+50
+3d
+a3
+e0
+f8
+a3
+e0
+f9
+a3
+e0
+fa
+a3
+e0
+fb
+90
+4e
+ca
+e0
+25
+e0
+24
+d6
+f5
+82
+e4
+34
+4c
+f5
+83
+e0
+fe
+a3
+e0
+ff
+e4
+fc
+fd
+eb
+2f
+ff
+ea
+3e
+fe
+ed
+39
+fd
+ec
+38
+fc
+90
+4e
+cb
+12
+05
+76
+90
+4e
+ca
+e0
+04
+f0
+80
+b6
+90
+4e
+cb
+e0
+fc
+a3
+e0
+fd
+a3
+e0
+fe
+a3
+e0
+ff
+e4
+7b
+04
+fa
+f9
+f8
+12
+04
+c5
+90
+4e
+cb
+12
+05
+76
+90
+4c
+e0
+e0
+fe
+a3
+e0
+ff
+e4
+fc
+fd
+90
+4e
+cb
+e0
+f8
+a3
+e0
+f9
+a3
+e0
+fa
+a3
+e0
+fb
+d3
+12
+05
+65
+50
+07
+e4
+90
+4c
+f9
+f0
+a1
+ff
+90
+4c
+fa
+e0
+fe
+a3
+e0
+ff
+e4
+fc
+fd
+90
+4e
+cb
+e0
+f8
+a3
+e0
+f9
+a3
+e0
+fa
+a3
+e0
+fb
+c3
+12
+05
+65
+40
+08
+90
+4c
+f9
+74
+64
+f0
+80
+5b
+90
+4c
+e0
+e0
+fe
+a3
+e0
+ff
+fb
+aa
+06
+e4
+90
+4e
+cb
+e0
+fc
+a3
+e0
+fd
+a3
+e0
+fe
+a3
+e0
+c3
+9b
+ff
+ee
+9a
+fe
+ed
+94
+00
+fd
+ec
+94
+00
+fc
+e4
+7b
+64
+fa
+f9
+f8
+12
+04
+3a
+c0
+06
+c0
+07
+90
+4c
+e0
+e0
+fe
+a3
+e0
+ff
+c3
+90
+4c
+fb
+e0
+9f
+ff
+90
+4c
+fa
+e0
+9e
+fe
+ab
+07
+fa
+e4
+f9
+f8
+d0
+07
+d0
+06
+12
+04
+c5
+90
+4c
+f9
+ef
+f0
+90
+4c
+e0
+e0
+fe
+a3
+e0
+ff
+c3
+90
+4c
+d7
+e0
+9f
+90
+4c
+d6
+e0
+9e
+50
+07
+90
+4c
+d5
+74
+02
+f0
+22
+90
+4c
+de
+e0
+fe
+a3
+e0
+ff
+e4
+fc
+fd
+90
+4e
+cb
+e0
+f8
+a3
+e0
+f9
+a3
+e0
+fa
+a3
+e0
+fb
+c3
+12
+05
+65
+50
+1c
+90
+4c
+d5
+74
+01
+f0
+90
+4c
+fc
+e0
+70
+2a
+90
+4d
+40
+f0
+a3
+74
+48
+f0
+a3
+74
+12
+f0
+e4
+a3
+f0
+22
+e4
+90
+4c
+d5
+f0
+90
+4c
+fc
+e0
+70
+0f
+90
+4d
+40
+f0
+a3
+74
+48
+f0
+a3
+74
+5d
+f0
+e4
+a3
+f0
+22
+90
+4d
+46
+e0
+60
+37
+90
+4d
+dd
+e0
+70
+31
+90
+4c
+c5
+e0
+64
+03
+70
+29
+7b
+01
+7a
+48
+79
+00
+7d
+09
+fc
+12
+0d
+fa
+e4
+90
+4e
+4b
+f0
+90
+48
+00
+04
+f0
+90
+4d
+46
+e0
+90
+48
+02
+f0
+7b
+01
+7a
+48
+79
+00
+7d
+09
+12
+0e
+da
+22
+90
+4e
+e0
+e4
+f0
+a3
+f0
+a3
+f0
+d1
+e3
+50
+26
+12
+2a
+cb
+90
+4e
+e0
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+4a
+70
+07
+90
+4c
+b6
+04
+f0
+80
+9d
+90
+4e
+e0
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+08
+bb
+22
+90
+4b
+9c
+e0
+fe
+a3
+e0
+ff
+90
+4b
+9a
+e0
+b5
+06
+07
+a3
+e0
+b5
+07
+02
+d3
+22
+c3
+22
+90
+4e
+e3
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+e4
+fd
+fc
+90
+4d
+e2
+e0
+64
+01
+60
+02
+e1
+ae
+7c
+05
+af
+04
+1c
+ef
+70
+03
+02
+28
+5d
+90
+4e
+e3
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+ec
+7e
+00
+29
+f9
+ee
+3a
+fa
+12
+03
+b6
+fd
+64
+13
+70
+36
+90
+4c
+ea
+74
+0a
+f0
+90
+4c
+ce
+e0
+44
+08
+f0
+54
+ef
+f0
+ed
+24
+ee
+ff
+90
+4c
+c3
+e0
+b5
+07
+08
+90
+4c
+c5
+e0
+64
+03
+70
+10
+90
+4c
+c3
+ef
+f0
+90
+4c
+cc
+74
+01
+f0
+e4
+90
+4c
+e5
+f0
+7f
+01
+22
+90
+4c
+ce
+e0
+54
+e7
+f0
+ed
+ff
+64
+14
+60
+0f
+ef
+64
+1a
+60
+0a
+ef
+64
+12
+60
+05
+ef
+64
+08
+70
+15
+90
+4c
+ea
+74
+0a
+f0
+90
+4d
+e8
+ed
+f0
+90
+4c
+ce
+e0
+44
+20
+f0
+7f
+01
+22
+90
+4c
+ce
+e0
+54
+df
+f0
+e1
+15
+90
+4e
+e3
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+90
+00
+01
+12
+03
+cf
+fd
+7c
+00
+64
+ef
+70
+2c
+90
+4c
+ea
+74
+0a
+f0
+90
+4c
+ce
+e0
+54
+f7
+f0
+44
+10
+f0
+90
+4c
+c3
+e0
+60
+13
+64
+fe
+60
+0f
+90
+4c
+cd
+74
+01
+f0
+e4
+90
+4c
+c3
+f0
+90
+4c
+e5
+f0
+7f
+01
+22
+ed
+64
+e9
+4c
+60
+15
+90
+4e
+e3
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+90
+00
+01
+12
+03
+cf
+64
+ea
+70
+46
+90
+4c
+ea
+74
+0a
+f0
+90
+4c
+ce
+e0
+44
+08
+f0
+54
+ef
+f0
+90
+4e
+e3
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+90
+00
+01
+12
+03
+cf
+24
+18
+ff
+90
+4c
+c3
+e0
+b5
+07
+08
+90
+4c
+c5
+e0
+64
+03
+70
+10
+90
+4c
+c3
+ef
+f0
+90
+4c
+cc
+74
+01
+f0
+e4
+90
+4c
+e5
+f0
+7f
+01
+22
+90
+4c
+ce
+e0
+54
+e7
+f0
+54
+df
+f0
+7f
+00
+22
+90
+4c
+f5
+ed
+f0
+a3
+eb
+f0
+ef
+30
+e0
+13
+90
+4c
+f4
+e0
+64
+03
+70
+04
+74
+02
+f0
+22
+90
+4c
+f4
+74
+01
+f0
+22
+90
+4c
+f4
+74
+04
+f0
+22
+ae
+05
+ac
+07
+e4
+90
+4f
+02
+f0
+ec
+30
+e0
+05
+e4
+90
+4c
+f8
+f0
+90
+4f
+02
+ee
+f0
+90
+4c
+c1
+e0
+ff
+60
+38
+ee
+fb
+7a
+00
+64
+e6
+70
+08
+90
+4f
+02
+74
+e7
+f0
+80
+28
+eb
+64
+e4
+4a
+70
+08
+90
+4f
+02
+74
+e6
+f0
+80
+1a
+eb
+64
+e3
+4a
+70
+08
+90
+4f
+02
+74
+e2
+f0
+80
+0c
+eb
+64
+e2
+4a
+70
+06
+90
+4f
+02
+74
+e3
+f0
+ef
+70
+12
+ee
+64
+da
+70
+0d
+af
+04
+7b
+0f
+7d
+08
+11
+60
+e4
+90
+4f
+02
+f0
+90
+4d
+e2
+e0
+64
+01
+60
+02
+21
+ab
+ee
+fb
+7a
+00
+64
+4a
+70
+08
+90
+4f
+02
+74
+46
+f0
+21
+ab
+eb
+64
+4d
+4a
+70
+08
+90
+4f
+02
+74
+48
+f0
+21
+ab
+eb
+64
+51
+4a
+70
+08
+90
+4f
+02
+74
+d7
+f0
+21
+ab
+eb
+64
+28
+4a
+70
+08
+90
+4f
+02
+74
+47
+f0
+80
+76
+eb
+64
+2a
+4a
+70
+08
+90
+4f
+02
+74
+da
+f0
+80
+68
+eb
+64
+29
+4a
+70
+62
+ec
+30
+e0
+59
+90
+4d
+e7
+e0
+60
+04
+e4
+f0
+80
+06
+90
+4d
+e7
+74
+01
+f0
+90
+4c
+c3
+e0
+fb
+7a
+00
+60
+04
+64
+fe
+70
+08
+90
+4c
+bf
+74
+02
+f0
+80
+34
+d3
+eb
+94
+03
+ea
+64
+80
+94
+80
+50
+29
+c3
+eb
+94
+01
+ea
+64
+80
+94
+80
+40
+1e
+90
+4d
+e7
+e0
+ff
+90
+4c
+c3
+e0
+75
+f0
+1f
+a4
+24
+ed
+f5
+82
+e4
+34
+4d
+f5
+83
+ef
+f0
+90
+4c
+bf
+74
+03
+f0
+e4
+90
+4f
+02
+f0
+90
+4e
+55
+e0
+60
+02
+41
+c5
+90
+4d
+e2
+e0
+70
+06
+90
+4d
+e7
+e0
+60
+14
+90
+4d
+e2
+e0
+64
+01
+60
+02
+41
+c5
+90
+4d
+e7
+e0
+64
+01
+60
+02
+41
+c5
+ee
+24
+c6
+b4
+0c
+00
+40
+02
+41
+c5
+90
+29
+eb
+75
+f0
+03
+a4
+c5
+83
+25
+f0
+c5
+83
+73
+02
+2a
+0f
+02
+2a
+17
+02
+2a
+1f
+02
+2a
+27
+02
+2a
+72
+02
+2a
+8f
+02
+2a
+97
+02
+2a
+9f
+02
+2a
+a7
+02
+2a
+af
+02
+2a
+b7
+02
+2a
+bf
+90
+4f
+02
+74
+d7
+f0
+41
+c5
+90
+4f
+02
+74
+d8
+f0
+41
+c5
+90
+4f
+02
+74
+d6
+f0
+41
+c5
+90
+4c
+c1
+e0
+fe
+70
+14
+af
+04
+7b
+2b
+7d
+04
+11
+60
+ec
+30
+e0
+31
+90
+4c
+f8
+74
+0a
+f0
+80
+29
+ee
+64
+01
+70
+0a
+af
+04
+7b
+52
+7d
+01
+11
+60
+80
+1a
+90
+4c
+c1
+e0
+64
+02
+70
+12
+af
+04
+7b
+2b
+7d
+08
+11
+60
+ec
+30
+e0
+06
+90
+4c
+f8
+74
+0a
+f0
+e4
+90
+4f
+02
+f0
+80
+53
+90
+4c
+c1
+e0
+70
+08
+90
+4f
+02
+74
+d2
+f0
+80
+45
+af
+04
+7b
+50
+7d
+08
+11
+60
+e4
+90
+4f
+02
+f0
+80
+36
+90
+4f
+02
+74
+d5
+f0
+80
+2e
+90
+4f
+02
+74
+f4
+f0
+80
+26
+90
+4f
+02
+74
+f2
+f0
+80
+1e
+90
+4f
+02
+74
+f5
+f0
+80
+16
+90
+4f
+02
+74
+f8
+f0
+80
+0e
+90
+4f
+02
+74
+f6
+f0
+80
+06
+90
+4f
+02
+74
+f7
+f0
+90
+4f
+02
+e0
+ff
+22
+e4
+90
+4e
+88
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+d1
+de
+7a
+4d
+79
+a8
+90
+4e
+ae
+74
+01
+f0
+a3
+74
+4d
+f0
+a3
+74
+a8
+f0
+a3
+74
+14
+f0
+7b
+01
+7a
+4d
+79
+bc
+b1
+6b
+ef
+60
+1c
+7b
+01
+7a
+4d
+79
+bc
+7d
+14
+b1
+3b
+ef
+70
+0f
+90
+4c
+ce
+e0
+44
+02
+f0
+90
+4d
+06
+74
+14
+f0
+80
+0c
+90
+4c
+ce
+e0
+54
+fd
+f0
+e4
+90
+4c
+d0
+f0
+e4
+90
+4e
+88
+f0
+90
+4e
+88
+e0
+ff
+90
+06
+81
+93
+70
+02
+81
+09
+74
+bc
+2f
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+90
+4e
+8b
+f0
+e0
+ff
+b1
+2d
+90
+4e
+92
+ef
+f0
+c3
+94
+02
+74
+80
+94
+80
+50
+02
+61
+f2
+e4
+90
+4e
+89
+f0
+90
+4e
+89
+e0
+ff
+c3
+94
+08
+74
+80
+94
+80
+50
+7b
+7e
+00
+74
+01
+a8
+07
+08
+80
+05
+c3
+33
+ce
+33
+ce
+d8
+f9
+ff
+90
+4e
+8b
+e0
+fd
+e4
+ef
+5d
+60
+58
+e4
+90
+4e
+8a
+f0
+90
+4e
+8a
+e0
+ff
+90
+06
+81
+93
+60
+48
+90
+4e
+88
+e0
+fe
+ef
+6e
+60
+37
+90
+4e
+8a
+e0
+24
+bc
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+fd
+7c
+00
+90
+4e
+89
+e0
+ff
+7e
+00
+74
+01
+a8
+07
+08
+80
+05
+c3
+33
+ce
+33
+ce
+d8
+f9
+ff
+ee
+5c
+fe
+ef
+5d
+4e
+60
+08
+90
+4e
+91
+74
+01
+f0
+80
+08
+90
+4e
+8a
+e0
+04
+f0
+80
+ad
+90
+4e
+89
+e0
+04
+f0
+61
+69
+90
+4e
+8b
+e0
+ff
+60
+08
+b1
+2d
+90
+4e
+8f
+e0
+2f
+f0
+90
+4e
+88
+e0
+04
+f0
+61
+34
+90
+4e
+8f
+e0
+90
+4d
+e4
+f0
+e4
+90
+4e
+88
+f0
+90
+4e
+88
+e0
+fb
+90
+06
+81
+93
+70
+02
+81
+fe
+90
+4e
+88
+e0
+fe
+24
+93
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+fd
+74
+bc
+2e
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+6d
+90
+4e
+8b
+f0
+74
+bc
+2b
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+90
+4e
+8e
+f0
+90
+4e
+8b
+e0
+70
+02
+81
+f6
+90
+4e
+91
+e0
+60
+07
+7b
+00
+7a
+00
+79
+00
+22
+90
+4e
+88
+e0
+ff
+24
+bc
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+fe
+74
+93
+2f
+f5
+82
+e4
+34
+4d
+f5
+83
+ee
+f0
+e4
+90
+4e
+89
+f0
+90
+4e
+89
+e0
+ff
+c3
+94
+08
+74
+80
+94
+80
+50
+5a
+90
+4e
+8b
+e0
+30
+e0
+3b
+90
+4e
+88
+e0
+fe
+33
+33
+33
+54
+f8
+fe
+ef
+4e
+90
+4e
+8d
+f0
+a3
+e0
+ff
+90
+4e
+8d
+e0
+90
+06
+96
+93
+fd
+11
+86
+90
+4e
+90
+ef
+f0
+90
+4e
+8e
+e0
+30
+e0
+09
+90
+4e
+90
+e0
+ff
+b1
+b5
+80
+07
+90
+4e
+90
+e0
+ff
+d1
+1d
+90
+4e
+8b
+e0
+ff
+c3
+13
+f0
+90
+4e
+8e
+e0
+ff
+c3
+13
+f0
+90
+4e
+89
+e0
+04
+f0
+80
+98
+90
+4e
+8c
+74
+01
+f0
+90
+4e
+88
+e0
+04
+f0
+81
+16
+90
+4e
+4b
+e0
+64
+03
+70
+0b
+90
+4d
+df
+e0
+64
+01
+70
+03
+74
+02
+f0
+90
+4e
+8c
+e0
+70
+08
+90
+4d
+df
+e0
+64
+02
+70
+07
+7b
+01
+7a
+4e
+79
+a4
+22
+7b
+00
+7a
+00
+79
+00
+22
+e4
+fe
+ef
+60
+06
+14
+5f
+ff
+0e
+80
+f7
+af
+06
+22
+90
+4e
+e9
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+e4
+ff
+ef
+c3
+9d
+50
+1b
+90
+4e
+e9
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+8f
+82
+75
+83
+00
+12
+03
+cf
+60
+03
+7f
+00
+22
+0f
+80
+e0
+7f
+01
+22
+90
+4e
+ab
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+e4
+ff
+90
+4e
+b1
+e0
+fe
+ef
+c3
+9e
+50
+30
+90
+4e
+ae
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+8f
+82
+75
+83
+00
+12
+03
+cf
+fe
+90
+4e
+ab
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+8f
+82
+75
+83
+00
+12
+03
+cf
+6e
+60
+03
+7f
+00
+22
+0f
+80
+c6
+7f
+01
+22
+e4
+fe
+ef
+fd
+7c
+00
+c3
+94
+e0
+74
+80
+94
+80
+40
+23
+d3
+ed
+94
+e7
+74
+80
+94
+80
+50
+19
+90
+4e
+a4
+e0
+fe
+ef
+54
+07
+ff
+f8
+74
+01
+08
+80
+02
+c3
+33
+d8
+fc
+4e
+90
+4e
+a4
+f0
+22
+e4
+fe
+ee
+c3
+94
+06
+74
+80
+94
+80
+50
+29
+74
+a5
+2e
+f5
+82
+e4
+34
+4e
+f5
+83
+e0
+fd
+6f
+60
+1a
+ed
+70
+14
+90
+4d
+ed
+e0
+6f
+60
+10
+74
+a5
+2e
+f5
+82
+e4
+34
+4e
+f5
+83
+ef
+f0
+22
+0e
+80
+cd
+22
+e4
+fe
+fd
+ef
+54
+f0
+64
+f0
+60
+07
+ef
+54
+d0
+64
+d0
+70
+0d
+90
+4e
+4b
+e0
+64
+02
+70
+0b
+74
+03
+f0
+80
+06
+90
+4d
+df
+74
+01
+f0
+ef
+fb
+7a
+00
+c3
+94
+e0
+74
+80
+94
+80
+40
+24
+d3
+eb
+94
+e7
+74
+80
+94
+80
+50
+1a
+90
+4e
+a4
+e0
+fe
+ef
+54
+07
+ff
+f8
+74
+01
+08
+80
+02
+c3
+33
+d8
+fc
+f4
+5e
+90
+4e
+a4
+f0
+22
+e4
+fe
+ee
+c3
+94
+06
+74
+80
+94
+80
+50
+5f
+ed
+70
+23
+74
+a5
+2e
+f5
+82
+e4
+34
+4e
+f5
+83
+e0
+6f
+70
+4b
+ee
+64
+05
+70
+0c
+74
+a5
+2e
+f5
+82
+e4
+34
+4e
+f5
+83
+e4
+f0
+7d
+01
+80
+36
+74
+a5
+2e
+f5
+82
+e4
+34
+4e
+f5
+83
+e0
+fc
+74
+a4
+2e
+f5
+82
+e4
+34
+4e
+f5
+83
+ec
+f0
+74
+a5
+2e
+f5
+82
+e4
+34
+4e
+f5
+83
+e0
+60
+14
+ee
+64
+05
+70
+0c
+74
+a5
+2e
+f5
+82
+e4
+34
+4e
+f5
+83
+e4
+f0
+0e
+80
+97
+22
+e4
+ff
+90
+4e
+e6
+f0
+fe
+fd
+a3
+f0
+a3
+f0
+ef
+90
+06
+81
+93
+60
+7b
+ef
+93
+fd
+13
+13
+13
+54
+1f
+fe
+ed
+54
+07
+fd
+f8
+74
+01
+08
+80
+02
+c3
+33
+d8
+fc
+fd
+ee
+24
+78
+fb
+e4
+34
+80
+8b
+82
+f5
+83
+e0
+fc
+ed
+f4
+fb
+ec
+5b
+f0
+ee
+24
+70
+f5
+82
+e4
+34
+80
+f5
+83
+e0
+4d
+f0
+ee
+24
+74
+f5
+82
+e4
+34
+80
+f5
+83
+e0
+5b
+f0
+90
+81
+1c
+e0
+f4
+fc
+74
+bc
+2f
+f5
+82
+e4
+34
+4d
+f5
+83
+ec
+f0
+ee
+24
+78
+fb
+e4
+34
+80
+8b
+82
+f5
+83
+e0
+4d
+f0
+ee
+24
+70
+fb
+e4
+34
+80
+8b
+82
+f5
+83
+e0
+fc
+ed
+f4
+fb
+ec
+5b
+f0
+0f
+c1
+ea
+e4
+ff
+ef
+90
+06
+81
+93
+60
+7b
+ef
+93
+fd
+13
+13
+13
+54
+1f
+fe
+ed
+54
+07
+fd
+f8
+74
+01
+08
+80
+02
+c3
+33
+d8
+fc
+fd
+ee
+24
+78
+fb
+e4
+34
+80
+8b
+82
+f5
+83
+e0
+fc
+ed
+f4
+fb
+ec
+5b
+f0
+ee
+24
+70
+f5
+82
+e4
+34
+80
+f5
+83
+e0
+4d
+f0
+ee
+24
+74
+f5
+82
+e4
+34
+80
+f5
+83
+e0
+5b
+f0
+90
+81
+1c
+e0
+f4
+fc
+74
+a8
+2f
+f5
+82
+e4
+34
+4d
+f5
+83
+ec
+f0
+ee
+24
+78
+fb
+e4
+34
+80
+8b
+82
+f5
+83
+e0
+4d
+f0
+ee
+24
+70
+fb
+e4
+34
+80
+8b
+82
+f5
+83
+e0
+fc
+ed
+f4
+fb
+ec
+5b
+f0
+0f
+e1
+6e
+e4
+ff
+ef
+90
+06
+81
+93
+60
+40
+74
+bc
+2f
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+fe
+74
+a8
+2f
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+6e
+60
+23
+74
+bc
+2f
+f5
+82
+e4
+34
+4d
+f5
+83
+c0
+83
+c0
+82
+e0
+fe
+74
+a8
+2f
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+fd
+ee
+5d
+d0
+82
+d0
+83
+f0
+0f
+80
+b9
+22
+90
+80
+91
+74
+0d
+f0
+a3
+04
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+14
+f0
+22
+12
+0e
+26
+11
+82
+90
+4c
+eb
+74
+01
+f0
+90
+4c
+e5
+74
+0a
+f0
+e4
+90
+4c
+f0
+f0
+90
+4d
+05
+74
+ff
+f0
+90
+44
+fc
+e0
+90
+4d
+d0
+f0
+90
+44
+fd
+e0
+90
+4d
+d1
+f0
+90
+44
+fe
+e0
+90
+4d
+d2
+f0
+22
+90
+4c
+d3
+74
+05
+f0
+e4
+a3
+f0
+90
+4d
+06
+74
+14
+f0
+90
+4c
+90
+74
+33
+f0
+e4
+ff
+ef
+c3
+94
+04
+74
+80
+94
+80
+50
+14
+ef
+25
+e0
+24
+d6
+f5
+82
+e4
+34
+4c
+f5
+83
+74
+62
+f0
+a3
+f0
+0f
+80
+e2
+90
+4c
+91
+e0
+fe
+a3
+e0
+ff
+c3
+90
+4c
+94
+e0
+9f
+fd
+90
+4c
+93
+e0
+9e
+fc
+e4
+12
+02
+06
+7b
+ae
+7a
+47
+79
+61
+78
+3f
+12
+00
+fb
+c0
+04
+c0
+05
+c0
+06
+c0
+07
+90
+4c
+91
+e0
+fc
+a3
+e0
+fd
+e4
+12
+02
+06
+d0
+03
+d0
+02
+d0
+01
+d0
+00
+12
+00
+0a
+12
+02
+3f
+90
+4c
+fa
+ee
+f0
+a3
+ef
+f0
+90
+4c
+91
+e0
+fe
+a3
+e0
+ff
+c3
+90
+4c
+94
+e0
+9f
+fd
+90
+4c
+93
+e0
+9e
+fc
+e4
+12
+02
+06
+74
+33
+fb
+fa
+f9
+78
+3f
+12
+00
+fb
+c0
+04
+c0
+05
+c0
+06
+c0
+07
+90
+4c
+91
+e0
+fc
+a3
+e0
+fd
+e4
+12
+02
+06
+d0
+03
+d0
+02
+d0
+01
+d0
+00
+12
+00
+0a
+12
+02
+3f
+90
+4c
+de
+ee
+f0
+a3
+ef
+f0
+90
+4c
+91
+e0
+fe
+a3
+e0
+ff
+c3
+90
+4c
+94
+e0
+9f
+fd
+90
+4c
+93
+e0
+9e
+fc
+e4
+12
+02
+06
+7b
+85
+7a
+eb
+79
+11
+78
+3f
+12
+00
+fb
+c0
+04
+c0
+05
+c0
+06
+c0
+07
+90
+4c
+91
+e0
+fc
+a3
+e0
+fd
+e4
+12
+02
+06
+d0
+03
+d0
+02
+d0
+01
+d0
+00
+12
+00
+0a
+12
+02
+3f
+90
+4c
+e0
+ee
+f0
+a3
+ef
+f0
+22
+90
+4e
+fa
+ed
+f0
+90
+00
+01
+12
+03
+cf
+90
+4e
+fb
+f0
+22
+90
+4c
+ea
+e0
+60
+02
+14
+f0
+90
+4c
+ef
+e0
+60
+02
+14
+f0
+90
+4c
+f8
+e0
+60
+0b
+14
+f0
+e0
+70
+06
+90
+4c
+f4
+74
+06
+f0
+90
+4c
+e5
+e0
+60
+20
+90
+4c
+ee
+e0
+60
+06
+e4
+90
+4c
+e5
+f0
+22
+90
+4c
+e5
+e0
+14
+f0
+12
+17
+b0
+90
+4c
+e5
+e0
+70
+4a
+12
+17
+c8
+80
+45
+90
+4c
+e9
+e0
+70
+3f
+90
+4c
+ee
+e0
+70
+39
+90
+4c
+e2
+e0
+60
+33
+14
+f0
+e0
+ff
+c3
+94
+04
+74
+80
+94
+80
+50
+16
+ef
+30
+e1
+09
+d2
+01
+7f
+14
+12
+11
+b2
+80
+10
+c2
+01
+7f
+14
+12
+11
+b2
+80
+07
+c2
+01
+7f
+14
+12
+11
+b2
+90
+4c
+e2
+e0
+70
+03
+74
+0a
+f0
+90
+4d
+dc
+e0
+70
+36
+90
+4d
+dd
+e0
+64
+01
+70
+2e
+90
+4c
+e3
+f0
+a3
+f0
+90
+4d
+dd
+f0
+90
+4e
+4c
+e0
+60
+0d
+7b
+01
+7a
+4e
+79
+4c
+7d
+03
+12
+0e
+da
+80
+11
+90
+48
+00
+e0
+60
+0b
+7b
+01
+7a
+48
+79
+00
+7d
+09
+12
+0e
+da
+90
+4d
+d4
+e0
+60
+11
+e0
+14
+f0
+e0
+70
+0b
+90
+4d
+3d
+e0
+70
+05
+7f
+1b
+12
+14
+9d
+90
+4d
+e6
+e0
+60
+14
+e0
+14
+f0
+e0
+70
+0e
+90
+4c
+c7
+e0
+64
+04
+70
+06
+90
+42
+13
+74
+0c
+f0
+22
+90
+4e
+fc
+ee
+f0
+a3
+ef
+f0
+a9
+05
+90
+4b
+9e
+e0
+fe
+a3
+e0
+ff
+ad
+01
+19
+ed
+60
+2f
+0f
+ef
+ac
+06
+70
+01
+0e
+14
+f5
+82
+8c
+83
+e0
+fd
+90
+4e
+fc
+e4
+75
+f0
+01
+12
+04
+24
+85
+f0
+82
+f5
+83
+ed
+f0
+ad
+07
+ac
+06
+bc
+4b
+d4
+bd
+9a
+d1
+7e
+4b
+7f
+36
+80
+cb
+90
+4b
+9e
+ee
+f0
+a3
+ef
+f0
+22
+7a
+0c
+79
+4b
+90
+4e
+ec
+74
+01
+f0
+a3
+74
+0c
+f0
+a3
+74
+4b
+f0
+90
+4b
+a0
+e0
+fe
+a3
+e0
+ff
+90
+4b
+9e
+e0
+6e
+70
+03
+a3
+e0
+6f
+70
+02
+81
+aa
+7e
+0c
+7f
+4b
+7d
+03
+51
+ab
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+b4
+02
+2b
+90
+4e
+ed
+e4
+75
+f0
+02
+12
+04
+0e
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+ff
+90
+4e
+68
+e0
+a3
+e0
+fa
+a3
+e0
+f5
+82
+8a
+83
+12
+05
+dd
+81
+aa
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+64
+04
+70
+59
+90
+4e
+ed
+75
+f0
+01
+12
+04
+0e
+7e
+0c
+7f
+4e
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+14
+fd
+51
+ab
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+c0
+02
+c0
+01
+90
+4e
+ec
+e0
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+fd
+7c
+00
+90
+4e
+6b
+e0
+a3
+e0
+fa
+a3
+e0
+f5
+82
+8a
+83
+d0
+01
+d0
+02
+12
+05
+dd
+81
+aa
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+64
+05
+70
+59
+90
+4e
+ed
+75
+f0
+01
+12
+04
+0e
+7e
+0c
+7f
+4e
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+14
+fd
+51
+ab
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+c0
+02
+c0
+01
+90
+4e
+ec
+e0
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+fd
+7c
+00
+90
+4e
+74
+e0
+a3
+e0
+fa
+a3
+e0
+f5
+82
+8a
+83
+d0
+01
+d0
+02
+12
+05
+dd
+80
+6d
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+64
+03
+70
+59
+90
+4e
+ed
+75
+f0
+01
+12
+04
+0e
+7e
+0c
+7f
+4e
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+14
+fd
+51
+ab
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+c0
+02
+c0
+01
+90
+4e
+ec
+e0
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+fd
+7c
+00
+90
+4e
+77
+e0
+a3
+e0
+fa
+a3
+e0
+f5
+82
+8a
+83
+d0
+01
+d0
+02
+12
+05
+dd
+80
+02
+80
+fe
+90
+4b
+a5
+e0
+fe
+a3
+e0
+ff
+90
+4c
+5e
+e0
+6e
+70
+03
+a3
+e0
+6f
+60
+22
+90
+4e
+6e
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+4a
+60
+37
+12
+05
+d9
+90
+4b
+a5
+e0
+ff
+a3
+e0
+90
+4c
+5e
+cf
+f0
+a3
+ef
+f0
+80
+ca
+90
+4c
+8d
+e0
+ff
+a3
+e0
+6f
+60
+19
+90
+4e
+71
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+4a
+60
+0b
+12
+05
+d9
+90
+4c
+8d
+e0
+a3
+f0
+80
+dd
+22
+90
+0b
+e7
+74
+03
+f0
+ed
+60
+03
+12
+0f
+c2
+22
+90
+0b
+e7
+74
+06
+f0
+02
+0f
+c2
+90
+0b
+e7
+74
+04
+f0
+02
+0f
+c2
+90
+0b
+e7
+74
+05
+f0
+02
+0f
+c2
+90
+04
+46
+e0
+ff
+22
+90
+0b
+7f
+74
+01
+f0
+e4
+90
+0b
+7e
+f0
+22
+90
+82
+80
+74
+01
+f0
+22
+90
+4e
+f2
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+ed
+1d
+ae
+04
+70
+01
+1c
+4e
+60
+17
+90
+4e
+f2
+e0
+fb
+a3
+e4
+75
+f0
+01
+12
+04
+24
+a9
+f0
+fa
+74
+ff
+12
+03
+fc
+80
+df
+22
+ef
+f4
+60
+3a
+ef
+54
+07
+fe
+ef
+13
+13
+13
+54
+03
+ff
+24
+a3
+f5
+82
+e4
+34
+00
+f5
+83
+c0
+83
+c0
+82
+e0
+fd
+74
+01
+a8
+06
+08
+80
+02
+c3
+33
+d8
+fc
+f4
+fc
+5d
+d0
+82
+d0
+83
+f0
+74
+a7
+2f
+f5
+82
+e4
+34
+00
+f5
+83
+e0
+5c
+f0
+22
+90
+4f
+0a
+ef
+f0
+7b
+01
+7a
+80
+79
+74
+12
+1f
+ac
+92
+09
+90
+4f
+0a
+e0
+ff
+a2
+09
+b3
+92
+01
+02
+11
+b2
+e4
+ff
+ef
+fd
+7c
+00
+24
+78
+fb
+ec
+34
+80
+8b
+82
+f5
+83
+e0
+fe
+ed
+24
+70
+fd
+ec
+34
+80
+8d
+82
+f5
+83
+e0
+4e
+f4
+fe
+ef
+24
+7c
+fd
+ec
+34
+80
+8d
+82
+f5
+83
+ee
+f0
+0f
+ef
+b4
+04
+cf
+22
+eb
+4f
+aa
+55
+40
+00
+00
+40
+2d
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+35
+00
+00
+00
+4f
+02
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+04
+c8
+00
+5c
+40
+04
+3a
+ce
+00
+00
+80
+e0
+00
+00
+00
+00
+00
+20
+00
+a0
+01
+00
+00
+00
+00
+00
+aa
+55
+02
+00
+4f
+4d
+20
+00
+aa
+55
+01
+00
+31
+41
+01
+aa
+55
+02
+00
+13
+42
+40
+03
+aa
+55
+01
+00
+f7
+41
+0a
+aa
+55
+02
+00
+f5
+41
+10
+00
+aa
+55
+01
+00
+33
+41
+00
+aa
+55
+02
+00
+b1
+4c
+00
+00
+aa
+55
+03
+00
+4a
+41
+40
+25
+00
+aa
+55
+06
+00
+40
+41
+36
+08
+c2
+08
+66
+22
+aa
+55
+0f
+00
+02
+47
+0e
+42
+54
+33
+2e
+30
+20
+4b
+65
+79
+62
+6f
+61
+72
+64
+aa
+55
+03
+00
+80
+42
+0e
+00
+01
+aa
+55
+01
+00
+84
+42
+01
+aa
+55
+01
+00
+47
+47
+0a
+aa
+55
+01
+00
+dc
+47
+00
+aa
+55
+01
+00
+f6
+47
+01
+aa
+55
+01
+00
+72
+41
+01
+aa
+55
+01
+00
+dc
+07
+00
+aa
+55
+01
+00
+a2
+00
+00
+aa
+55
+01
+00
+dd
+07
+00
+aa
+55
+01
+00
+16
+00
+27
+aa
+55
+01
+00
+fd
+47
+ff
+aa
+55
+01
+00
+f7
+47
+ff
+aa
+55
+01
+00
+6e
+41
+80
+aa
+55
+02
+00
+a2
+4b
+02
+01
+aa
+55
+ee
+01
+04
+45
+01
+00
+00
+28
+02
+01
+18
+02
+00
+03
+28
+01
+20
+03
+00
+05
+2a
+01
+00
+04
+00
+02
+29
+02
+00
+00
+05
+00
+00
+28
+02
+00
+18
+06
+00
+03
+28
+01
+02
+07
+00
+00
+2a
+0e
+42
+54
+34
+2e
+32
+20
+4b
+65
+79
+62
+6f
+61
+72
+64
+08
+00
+03
+28
+01
+02
+09
+00
+01
+2a
+02
+c1
+03
+0a
+00
+03
+28
+01
+02
+0b
+00
+04
+2a
+08
+06
+00
+06
+00
+64
+00
+2c
+01
+0c
+00
+00
+28
+02
+0a
+18
+0d
+00
+03
+28
+01
+02
+0e
+00
+29
+2a
+06
+59
+69
+43
+68
+69
+70
+0f
+00
+03
+28
+01
+02
+10
+00
+50
+2a
+07
+02
+e8
+04
+21
+70
+01
+00
+11
+00
+00
+28
+02
+12
+18
+12
+00
+03
+28
+01
+06
+13
+00
+4e
+2a
+01
+01
+14
+00
+03
+28
+01
+12
+15
+00
+4d
+2a
+08
+00
+00
+00
+00
+00
+00
+00
+00
+16
+00
+02
+29
+02
+00
+00
+17
+00
+08
+29
+02
+01
+01
+18
+00
+03
+28
+01
+12
+19
+00
+4d
+2a
+05
+00
+00
+00
+00
+00
+1a
+00
+02
+29
+02
+00
+00
+1b
+00
+08
+29
+02
+03
+01
+1c
+00
+03
+28
+01
+12
+1d
+00
+4d
+2a
+02
+00
+00
+1e
+00
+02
+29
+02
+00
+00
+1f
+00
+08
+29
+02
+02
+01
+20
+00
+03
+28
+01
+0e
+21
+00
+4d
+2a
+02
+00
+00
+22
+00
+02
+29
+02
+00
+00
+23
+00
+08
+29
+02
+01
+02
+24
+00
+03
+28
+01
+0a
+25
+00
+4b
+2a
+a0
+05
+01
+09
+06
+a1
+01
+85
+01
+75
+01
+95
+08
+05
+07
+19
+e0
+29
+e7
+15
+00
+25
+01
+81
+02
+95
+01
+75
+08
+81
+03
+95
+05
+75
+01
+05
+08
+19
+01
+29
+05
+91
+02
+95
+01
+75
+03
+91
+03
+95
+06
+75
+08
+15
+00
+26
+ff
+00
+05
+07
+19
+00
+29
+ff
+81
+00
+c0
+05
+0c
+09
+01
+a1
+01
+85
+02
+19
+00
+2a
+ff
+03
+15
+00
+26
+ff
+03
+95
+01
+75
+10
+81
+00
+c0
+05
+01
+09
+02
+a1
+01
+85
+03
+09
+01
+a1
+00
+05
+09
+19
+01
+29
+08
+15
+00
+25
+01
+75
+01
+95
+08
+81
+02
+05
+01
+09
+30
+09
+31
+16
+01
+80
+26
+ff
+7f
+75
+10
+95
+02
+81
+06
+09
+38
+15
+81
+25
+7f
+75
+08
+95
+01
+81
+06
+05
+0c
+0a
+38
+02
+95
+01
+81
+06
+c0
+c0
+26
+00
+03
+28
+01
+02
+27
+00
+4a
+2a
+04
+11
+01
+00
+01
+28
+00
+03
+28
+01
+04
+29
+00
+4c
+2a
+01
+00
+2a
+00
+00
+28
+02
+0f
+18
+2b
+00
+03
+28
+01
+12
+2c
+00
+19
+2a
+01
+64
+2d
+00
+02
+29
+02
+00
+00
+00
+00
+aa
+55
+01
+00
+6a
+4c
+17
+aa
+55
+01
+00
+f9
+46
+50
+aa
+55
+01
+00
+c2
+44
+14
+aa
+55
+06
+00
+f9
+44
+11
+46
+34
+54
+77
+dd
+aa
+55
+01
+00
+7e
+4c
+00
+aa
+55
+06
+00
+b8
+4c
+15
+00
+1d
+00
+19
+00
+aa
+55
+02
+00
+3e
+4d
+2c
+00
+aa
+55
+01
+00
+60
+4c
+50
+aa
+55
+10
+00
+6c
+4c
+0c
+00
+05
+00
+12
+b4
+08
+00
+08
+00
+08
+00
+00
+00
+2c
+01
+aa
+55
+0c
+00
+19
+44
+0b
+42
+54
+20
+4b
+65
+79
+62
+6f
+61
+72
+64
+aa
+55
+01
+00
+e4
+44
+07
+aa
+55
+01
+00
+dd
+44
+01
+aa
+55
+0c
+00
+d9
+43
+1f
+02
+01
+05
+03
+19
+c1
+03
+03
+03
+12
+18
+aa
+55
+07
+00
+6b
+4d
+06
+ff
+06
+00
+03
+00
+80
+aa
+55
+0e
+00
+f9
+43
+1f
+0c
+09
+42
+54
+20
+4b
+65
+79
+62
+6f
+61
+72
+64
+aa
+55
+04
+00
+53
+4d
+20
+21
+12
+24
+aa
+55
+04
+00
+91
+4c
+9f
+3e
+cd
+4d
+aa
+55
+01
+00
+8f
+4c
+04
+aa
+55
+01
+00
+10
+4c
+01
+aa
+55
+01
+00
+e2
+4b
+02
+aa
+55
+01
+00
+0f
+4c
+40
+aa
+55
+01
+00
+0a
+4c
+00
+aa
+55
+02
+00
+e4
+4b
+c0
+12
+aa
+55
+10
+00
+f0
+4b
+00
+13
+2c
+42
+06
+15
+36
+48
+0f
+1a
+3a
+4c
+11
+23
+31
+4d
+aa
+55
+01
+00
+ef
+4b
+ff
+aa
+55
+04
+00
+eb
+4b
+20
+15
+10
+05
+aa
+55
+01
+00
+7d
+4c
+c2
+aa
+55
+0a
+00
+37
+0d
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+aa
+55
+04
+00
+40
+4d
+00
+48
+5d
+00
+aa
+55
+07
+00
+76
+4d
+ff
+ff
+ff
+ff
+e8
+fd
+00
+aa
+55
+08
+00
+16
+42
+8f
+10
+ce
+00
+0a
+0b
+ef
+0f
+aa
+55
+01
+00
+f8
+41
+00
+aa
+55
+08
+00
+a3
+00
+00
+00
+00
+00
+00
+00
+00
+00
+aa
+55
+02
+00
+5d
+41
+02
+24
+aa
+55
+08
+00
+4d
+41
+12
+00
+00
+02
+12
+00
+00
+02
+aa
+55
+02
+00
+5b
+41
+20
+00
+aa
+55
+04
+00
+57
+41
+20
+00
+00
+20
+aa
+55
+04
+00
+5f
+41
+80
+03
+00
+06
+aa
+55
+02
+00
+98
+4c
+00
+13
+aa
+55
+02
+00
+9b
+42
+30
+3f
+aa
+55
+01
+00
+aa
+42
+20
+aa
+55
+7f
+00
+70
+4f
+07
+ff
+0a
+fb
+0b
+ff
+1a
+fb
+1b
+fb
+1c
+fb
+1d
+f6
+1e
+f2
+1f
+ee
+20
+ea
+21
+e6
+22
+e2
+23
+de
+24
+da
+25
+d6
+26
+d2
+27
+ce
+28
+ca
+29
+c6
+2a
+c2
+2b
+bd
+2c
+b9
+2d
+b5
+2e
+b1
+2f
+ad
+30
+a9
+31
+80
+32
+80
+33
+80
+34
+c0
+35
+c1
+36
+c2
+37
+c3
+38
+c4
+39
+c5
+3a
+c6
+3b
+c7
+3c
+06
+3d
+07
+3e
+46
+3f
+85
+40
+86
+41
+87
+42
+c6
+43
+c7
+44
+d6
+45
+d7
+46
+e6
+47
+f5
+48
+00
+49
+f8
+4a
+7f
+4e
+ec
+4f
+5e
+55
+d0
+56
+c0
+57
+4c
+58
+6c
+59
+50
+68
+e4
+69
+00
+6a
+00
+6b
+30
+ff
+aa
+55
+02
+00
+63
+41
+70
+4f
+aa
+55
+0a
+00
+91
+4a
+55
+d0
+56
+c0
+57
+4c
+58
+6c
+59
+50
+aa
+55
+0a
+00
+87
+4a
+55
+d0
+56
+c0
+57
+4c
+58
+6c
+59
+50
+77
+94
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+ff
+9d
+10
Index: c51/output/fw.hex
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/fw.hex	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/fw.hex	(working copy)
@@ -0,0 +1,866 @@
+:100000000205DF0202ABE86480F8E933E8336011EF
+:100010000460F0ED33EC337009E8FCE9FDEAFEEB37
+:10002000FF220460DED3EB9FEA9EE99DE8C2E78CE5
+:10003000F0C2F795F0400CE8CCF8E9CDF9EACEFA39
+:10004000EBCFFB12027685D0F05804700320D5B3B5
+:10005000E80470075002B2D50202B592D5EC0460F4
+:10006000F7E4CCC0E0C398F8603B94186008400DFA
+:10007000D0E0FB02028DE4FBFAC9FC8028E830E402
+:1000800006E4C9FBE4CAFCE830E305E4C9CACBFCDA
+:10009000E854076010F8C3E913F9EA13FAEB13FB0D
+:1000A000EC13FCD8F130F52FC3E49CFCEF9BFFEE82
+:1000B0009AFEED99FDD0E0FBEF4E4D4C701222DB25
+:1000C000030202B2EC2CFCEF33FFEE33FEED33FD06
+:1000D000ED30E7EB02028DEF2BFFEE3AFEED39FD3E
+:1000E000D0E0FB50130BBB00030202B5ED13FDEE95
+:1000F00013FEEF13FFEC13FC02028DEC4D6011E8D0
+:10010000497017ED33EC3304600DE4FCFFFEFD2273
+:10011000E933E8330470F80202AB12027658046047
+:1001200009E4CC248150062850090202B528400376
+:100130000202B2C0E0EB4A7044B98006D0E0FB0294
+:1001400002A1EF4E701CBD8008EBFFEAFEE9FD80C6
+:10015000EBE98DF0A4FEE5F00201E4E9CDF9EAFE59
+:10016000EBFFEF89F0A4FCE5F0CE89F0A42EFFE4CC
+:1001700035F0CD89F0A42DFEE435F08067EF4E70A8
+:1001800005BD80D780C3EF8BF0A4ACF0EE8BF0A45C
+:100190002CFCE435F0F8EF8AF0A42CE5F038FCE410
+:1001A00033CB8DF0A42CFCE5F03BF8EE8AF0A42CC8
+:1001B000FCE5F038F8E433CF89F0A42CFCE5F03806
+:1001C000CF3400CE89F0A42FFFE5F03EFEE433C922
+:1001D0008DF0A42EFEE5F039CD8AF0A42FFFE5F0D6
+:1001E0003EFEE43DFD33D0E0FB50070BBB000F02A9
+:1001F00002B5EC2CFCEF33FFEE33FEED33FD0202D3
+:100200008D75F020800E75F010800575F0087D006A
+:100210007E007F003392D530D503120557EC334072
+:1002200010EF33FFEE33FEED33FDEC33FCD5F0ED94
+:1002300022E5F0247EA2D513CC92E7CDCEFF22EDAD
+:10024000D2E7CD33EC3392D524814006E4FFFEFDA6
+:10025000FC22FCE4CFCECDCC24E0501174FF80ED25
+:10026000C3CC13CCCD13CDCE13CECF13CF0470F0AF
+:1002700030D5DE020557E9D2E7C933E833F892D525
+:10028000EDD2E7CD33EC33FC5002B2D522EC30E7AF
+:10029000100FBF000C0EBE00080DBD00040BEB607C
+:1002A00014A2D5EB13FCED92E7FD2274FFFCFDFEDA
+:1002B000FF22E480F8A2D574FF13FC7D80E480EF78
+:1002C000E709F608DFFA8046E709F208DFFA803E20
+:1002D00088828C83E709F0A3DFFA8032E309F6080D
+:1002E000DFFA8078E309F208DFFA807088828C8375
+:1002F000E309F0A3DFFA806489828A83E0A3F60829
+:10030000DFFA805889828A83E0A3F208DFFA804C02
+:1003100080D280FA80C680D4806980F280338010D9
+:1003200080A680EA809A80A880DA80E280CA803342
+:1003300089828A83ECFAE493A3C8C582C8CCC583BA
+:10034000CCF0A3C8C582C8CCC583CCDFE9DEE7808A
+:100350000D89828A83E493A3F608DFF9ECFAA9F009
+:10036000EDFB2289828A83ECFAE0A3C8C582C8CC5F
+:10037000C583CCF0A3C8C582C8CCC583CCDFEADE78
+:10038000E880DB89828A83E493A3F208DFF980CCDA
+:1003900088F0EF60010E4E60C388F0ED2402B404D3
+:1003A0000050B9F582EB2402B4040050AF2323457A
+:1003B000822390031073BB010689828A83E0225056
+:1003C00002E722BBFE02E32289828A83E49322BBF6
+:1003D000010CE58229F582E5833AF583E022500697
+:1003E000E92582F8E622BBFE06E92582F8E222E54D
+:1003F0008229F582E5833AF583E49322BB010689DD
+:10040000828A83F0225002F722BBFE01F322C5F05C
+:10041000F8A3E028F0C5F0F8E58215827002158394
+:10042000E038F022A3F8E0C5F025F0F0E58215826F
+:1004300070021583E0C838F0E822E88FF0A4CC8B76
+:10044000F0A42CFCE98EF0A42CFC8AF0EDA42CFC8A
+:10045000EA8EF0A4CDA8F08BF0A42DCC3825F0FDC9
+:10046000E98FF0A42CCD35F0FCEB8EF0A4FEA9F0C2
+:10047000EB8FF0A4CFC5F02ECD39FEE43CFCEAA40E
+:100480002DCE35F0FDE43CFC2275F008758200EFBE
+:100490002FFFEE33FECD33CDCC33CCC58233C582B6
+:1004A0009BED9AEC99E58298400CF582EE9BFEED6F
+:1004B0009AFDEC99FC0FD5F0D6E4CEFBE4CDFAE43E
+:1004C000CCF9A88222B800C1B90059BA002DEC8B32
+:1004D000F084CFCECDFCE5F0CBF97818EF2FFFEE0E
+:1004E00033FEED33FDEC33FCEB33FB10D7039940C7
+:1004F00004EB99FB0FD8E5E4F9FA227818EF2FFF07
+:10050000EE33FEED33FDEC33FCC933C910D7059B48
+:10051000E99A4007EC9BFCE99AF90FD8E0E4C9FAA4
+:10052000E4CCFB2275F010EF2FFFEE33FEED33FD30
+:10053000CC33CCC833C810D7079BEC9AE899400A53
+:10054000ED9BFDEC9AFCE899F80FD5F0DAE4CDFBD1
+:10055000E4CCFAE4C8F922C3E49FFFE49EFEE49DE4
+:10056000FDE49CFC22EB9FF5F0EA9E42F0E99D42FF
+:10057000F0E89C45F022ECF0A3EDF0A3EEF0A3EF41
+:10058000F022A8828583F0D083D0821205991205CB
+:1005900099120599120599E473E493A3C583C5F0F4
+:1005A000C583C8C582C8F0A3C583C5F0C583C8C5C7
+:1005B00082C822D083D082F8E493701274019370C1
+:1005C0000DA3A393F8740193F5828883E4737402F6
+:1005D000936860EFA3A3A380DF8A838982E47378A2
+:1005E0007FE4F6D8FD7581CF020626021FEBE49367
+:1005F000A3F8E493A34003F68001F208DFF4802916
+:10060000E493A3F85407240CC8C333C4540F442004
+:10061000C8834004F456800146F6DFE4800B0102F3
+:1006200004081020408090066BE47E019360BCA318
+:10063000FF543F30E509541FFEE493A360010ECF41
+:1006400054C025E060A840B8E493A3FAE493A3F86B
+:10065000E493A3C8C582C8CAC583CAF0A3C8C5822B
+:10066000C8CAC583CADFE9DEE780BE524E56FF1412
+:10067000C8000000FF229FFF31B1000000FF31A140
+:10068000000A1C15161718191A0C090B0F10111B4C
+:100690000E080D0000003EE000E4DE0066471E3557
+:1006A0008B1D29042B141F3A8A1B6416391A203B10
+:1006B00088063D073C08212205190A09171524233D
+:1006C00011100B0D1C18252E87363F0E300C2641BD
+:1006D0006537000F4012272D383234332F1348B0BE
+:1006E000E600E27F00464342452844312A89664CB1
+:1006F00051532C595C5FDE494F54625A5D604E4B3A
+:100700005655635B5E614D4A50F2525885577CDA0C
+:10071000EAE9EFE5E1DF00F8D4D2D3D1E37B90D66C
+:100720007DF300E7D0910000000000000000000011
+:1007300000000000010100904EFEEFF0904CF0E050
+:100740007002E1FD14F0E4904DE5F0904E55F0900C
+:100750004EFEE0FF75F01FA424EEF582E4344DF563
+:1007600083E064017070EF75F01FA424EFF9744DFD
+:1007700035F0FA7B017E427F74904EC47406F0120D
+:100780000878904EFEE075F01FA424F5F9744D35FD
+:10079000F0FA7B017E447F7B904EC47410F0120807
+:1007A00078904EFEE075F01FA42405F9744E35F0E4
+:1007B000FA7B017E447FF9904EC47406F0120878EB
+:1007C0007F2B12149D904DE57401F0E4904CF0F0F5
+:1007D00090448B04F022904E557401F09044F974CB
+:1007E0000FF0A3F0A3F0A3F0A3F0A3F0904DD37407
+:1007F00001F07F2B12149D90425E7401F022904E06
+:10080000FFEDF0EF6401706FE0FF75F01FA424EEC0
+:10081000F582E4344DF5837401F0EF75F01FA424E4
+:10082000EFF582E4344DAF82FE7B017A0379D090FC
+:100830004EC47406F01178904EFFE075F01FA424AA
+:10084000F5F582E4344DAF82FE7B017A44797B90EA
+:100850004EC47410F01178904EFFE075F01FA42480
+:1008600005F582E4344EAF82FE7B017A4479F9903B
+:100870004EC47406F0117822904EBFEEF0A3EFF054
+:10088000A3EBF0A3EAF0A3E9F0904EC4E0FF14F06C
+:10089000EF6027904EC1E0FBA3E475F00112042441
+:1008A000A9F0FA1203B6FF904EBFE475F0011204EE
+:1008B0002485F082F583EFF080CF22904EC5EBF0D7
+:1008C000A3EAF0A3E9F0E4A3F0A3F0904DE2F090E6
+:1008D0004EC9F0904EC9E0FFC394057480948050D7
+:1008E0002C904EC5E0FBA3E0FAA3E02401F9E43A22
+:1008F000FA7E00E92FF9EE3AFA1203B6647F70052A
+:10090000904DE204F0904EC9E004F080C6904EC5D0
+:10091000E0FBA3E0FAA3E0F91226FBEF600261DC42
+:10092000904EC5E0A3E0FAA3E04A700261DC904D6E
+:100930007DE06008E4F0904D467403F0904CC7E011
+:10094000640470069042137403F0904DE6740AF04C
+:10095000E4904CE3F0A3F0904CD5E064017011906A
+:100960004D40F0A37448F0A37412F0E4A3F080109B
+:10097000E4904D40F0A37448F0A3745DF0E4A3F05C
+:100980007B017A4879007D097C00B1FA7B017A4EBF
+:10099000794C7D097C00B1FA904EC5E0FBA3E0FAEA
+:1009A000A3E0F99000011203CFFF7E00640E700AED
+:1009B0009000021203CF64296010EF64294E703654
+:1009C0009000021203CF640E702C904BEB7420F059
+:1009D000A37415F0A37410F0A37405F0904CC5E057
+:1009E00064016009904CCEE04410F08010904CCE31
+:1009F000E054EFF08007904CCEE054EFF0904CB60E
+:100A00007401F0904CF4E0FF6401700261DCEF646B
+:100A100004700261DCEF6402700261DC904CC5E09E
+:100A20006403704A904EC9F0904EC9E0FFC394052C
+:100A3000748094805038904EC5E0FBA3E0FAA3E0A8
+:100A40002401F9E43AFA7E00E92FF9EE3AFA1203AA
+:100A5000B6FF6439600AEF64536005EF64477006BF
+:100A6000904D467403F0904EC9E004F080BA904E69
+:100A7000C5E0FBA3E0FAA3E0F971DD904E4BE06422
+:100A80000170117402F0904E4CF07B017A4E794C5B
+:100A90007D03C1DA904E4BE0640470137402F09051
+:100AA0004E4C7406F07B017A4E794C7D03C1DA908E
+:100AB0004E4BE06403600BE06402702F904DE4E065
+:100AC0007029E4904E4BF0904DEDF0904DE9E060D0
+:100AD0000AE4F0904E4C7406F08006904E4C74027E
+:100AE000F07B017A4E794C7D03C1DA904DE4E070E1
+:100AF00016904EC5E0FBA3E0FAA3E02401F9E43A26
+:100B0000FA7D067C00B1FA9048007401F0904EC561
+:100B1000E0FBA3E0FAA3E0F91203B6904801F090DD
+:100B20004CC5E06403700A904D46E0904802F080A6
+:100B300005E4904802F0E4904DDFF0904E55E070EF
+:100B4000759000011203CF647F70157E487F03E922
+:100B50002402F9E43AFA904EC47405F01178801C2E
+:100B60007E487F03904EC5E0FBA3E0FAA3E024019A
+:100B7000F9E43AFA904EC47406F01178904EC974B4
+:100B800003F0904EC9E0FFC39409748094805042F2
+:100B900074002FF582E43448F583E0647F700F9091
+:100BA0004EC9E02400F582E43448F583E4F0904E29
+:100BB000C9E004F080CC7E487F03904EC5E0FBA3E3
+:100BC000E0FAA3E02401F9E43AFA904EC47406F086
+:100BD00011787B017A4879007D09D1DA22904ED4D0
+:100BE000EBF0A3EAF0A3E9F0E4A3F0F0904ED7E035
+:100BF000FFC39406748094804002A1DE904ED4E03E
+:100C0000FBA3E0FAA3E02401F9E43AFA7E00E92F1D
+:100C1000F9EE3AFA1203B6FF54F064F06009EF54AB
+:100C2000D064D06002A1D61203B6F9FB7A0064F159
+:100C300070087F837E01B1DFA1AAEB64F24A7007DE
+:100C40007FCDFEB1DFA1AAE9FB7A0064F370077FD4
+:100C5000B7FEB1DFA1AAEB64F44A70077FB6FEB11C
+:100C6000DFA1AAE9FB7A0064F570077FB5FEB1DF6A
+:100C7000A1AAEB64F64A70077FEAFEB1DFA1AAE9F8
+:100C8000FB7A0064F770077FE9FEB1DFA1AAEB648D
+:100C9000F84A70077FE2FEB1DFA1AAE9FB7A00649F
+:100CA000F970087F947E01B1DFA1AAEB64FA4A7063
+:100CB000087F8A7E01B1DFA1AAE9FB7A0064FB709C
+:100CC000087F927E01B1DFA1AAEB64D04A70087F51
+:100CD0002A7E02B1DFA1AAE9FB7A0064D170087F05
+:100CE000257E02B1DFA1AAEB64D34A70087F267E7D
+:100CF00002B1DFA1AAE9FB7A0064D270087F247EEA
+:100D000002B1DFA1AAEB64D44A70087F277E02B14A
+:100D1000DFA1AAE9FB7A0064D570087F217E02B1C9
+:100D2000DFA1AAEB64D64A70087F237E02B1DF8080
+:100D300079E9FB7A0064D770077F70FEB1DF806AC3
+:100D4000EB64D84A70077F6FFEB1DF805DE9FB7A04
+:100D50000064D970077FB8FEB1DF804EEB64DA4AD9
+:100D600070077F30FEB1DF8041E9FB7A0064DB7001
+:100D7000087F067E03B1DF8031EB64DC4A70087FB8
+:100D8000077E03B1DF8023E9FD7C0064DD70067F10
+:100D900001D1BF8015ED64DE4C70067F02D1BF80AB
+:100DA00009E964DF70047F04D1BF904E4BE0640218
+:100DB0007024904ED4E0FBA3E0FAA3E02401F9E410
+:100DC0003AFAA3E07E0029F9EE3AFA1203B6904D02
+:100DD000EDF0E41203FC904ED7E004F061EC22AD9C
+:100DE00007AC06904E4BE06402600E7401F0904E2A
+:100DF0004C04F0EFA3F0EEA3F022904EEFEBF0A343
+:100E0000EAF0A3E9F0ED1DAE0470011C4E601690EF
+:100E10004EEFE0FBA3E475F001120424A9F0FAE41C
+:100E20001203FC80E0227B017A4C79BF7D487C0074
+:100E3000B1FA7B017A4D79937D147C00B1FA7B0184
+:100E40007A4D79A87D147C00B1FA7B017A4D79BC8A
+:100E50007D147C00B1FA7B017A4879007D097C0021
+:100E6000B1FA7B017A4E794C7D097C00B1FAE490AD
+:100E70004DE6F0904DECF0904DEBF0904DDDF090A4
+:100E80004DD5F0904DE5F0904DE3F0904E4BF09045
+:100E90004DDCF0904DDFF0904DE2F0904DEAF09097
+:100EA0004DD8F0904DE7F0904DEDF0904CB774F0C8
+:100EB000F0904DE0F0E4904D38F0904DD4F0229059
+:100EC0004E4BE0640260127404F0904DE97401F03E
+:100ED000904E4C7406F0A3EFF022904E7AEBF0A304
+:100EE000EAF0A3E9F0A3EDF0E4FF904E7DE0FEEF21
+:100EF000C39E5023904E7AE0FBA3E0FAA3E0F98F63
+:100F0000827583001203CFFE747E2FF582E4344E87
+:100F1000F583EEF00F80D3121922EF7002E1C19039
+:100F20004CEBE06002E1C1904CC7E0FF6404600B51
+:100F3000EF6403701F904DD3E06019904E7EE06423
+:100F40000670037403F07B017A4E797E904E7DE04B
+:100F5000FD123523904CC5E064037065904E7EE031
+:100F6000640170237404F0A3E07014904E81E0706B
+:100F70000EA3E0700AA3E07006904DDDF08034907F
+:100F80004DDD7401F0802C904E7EE0640270197487
+:100F900005F0A3E0700AA3E07006904DDDF0801329
+:100FA000904DDD7401F0800B904E7EE06403700381
+:100FB0007407F07B017A4E797E904E7DE0FD12350C
+:100FC0001122904F07EDF0E0FD900BE8F07E0B7FD3
+:100FD000E9904EC4EDF011787B017A0B79E7904FE0
+:100FE00007E02402FD904EB9EBF0A3EAF0A3E9F08C
+:100FF000A3EDF0904B9CE0FFA3E0904EBDCFF0A39B
+:10100000EFF0904B9AE0FEA3E0FF904B9CE0FCA336
+:10101000E0FD7B641179904EBCE0FEEFC39E40E2A0
+:10102000904EBCE0FF14F0EF603F904EB9E0FBA3A0
+:10103000E475F001120424A9F0FA1203B6FF904EF1
+:10104000BDE475F00112042485F082F583EFF09081
+:101050004EBDE0FEA3E0FFBE4BC6BF36C3904EBD03
+:10106000744AF0A374A0F080B7904EBDE0FFA3E0F7
+:10107000904B9CCFF0A3EFF022904ED8EEF0A3EF70
+:10108000F0904EDAECF0A3EDF0904EDAE0FEA3E043
+:10109000FFD3904ED9E09F904ED8E09E4016904EE0
+:1010A000DAE0FEA3E0FF904ED9E09FFF904ED8E03B
+:1010B0009EFE801E904ED8E0FEA3E0FFC3904EDB64
+:1010C000E09FFF904EDAE09EFEAD03C3EB9FFFE48E
+:1010D0009EFE22904CC7E064046008904CC5E0641A
+:1010E0000370037F01227F0022904DEBE0640260D9
+:1010F0000221B1904CE9E0603A904CCCE064016090
+:101100001E904CC3E0640170077F1F1235B1802E22
+:10111000904CC3E0640270267F1E1235B1801FC25E
+:10112000017F1F31B2C2017F1E31B2C2017F143173
+:10113000B2800B904CEEE060057F141235B111D3F4
+:10114000EF606E904CE5E07068A3E0601614F0D29A
+:10115000017FFF31B2904CE6E0700EC2017FFF319B
+:10116000B28006C2017FFF31B2904CE7E0601614F6
+:10117000F0D2017F1D31B2904CE7E0700EC2017FCA
+:101180001D31B28006C2017F1D31B2904CE8E06093
+:101190002014F0904CE5E07018904CE2E07012D210
+:1011A000017F1431B2904CE8E07006C2017F143127
+:1011B000B222EFF4600D7B017A807974A201920073
+:1011C00012187522904DEBE06402600241C5904C0C
+:1011D000E9E0600241BF904CEEE0600241BF904CFC
+:1011E000D5E064027004F18F802F904CD5E064014B
+:1011F0007014904CF7E07021904CE2740AF0904C1F
+:10120000F77401F08013904CF7E06401700BF090DC
+:101210004CE2F0C2017F1431B211D3EF700241B938
+:10122000904CE5E0600241B9904DE0E0FF904CB792
+:10123000E06F700241C5E030E00E904CE67414F0AF
+:10124000D2017FFF31B2800BC2017FFF31B2E49047
+:101250004CE6F0904CB7E030E10E904CE77414F09F
+:10126000D2017F1D31B2800BC2017F1D31B2E490EB
+:101270004CE7F0904CB7E030E21A904CE87414F070
+:10128000904CE5E07025904CE2E0701FD2017F1495
+:1012900031B28017904CE5E0700C904CE2E07006A3
+:1012A000C2017F1431B2E4904CE8F0E4904D46F076
+:1012B000904CB7E0904DE0F022C2017FFF21B2C216
+:1012C000017FFF31B222904F01EFF014B40D0040C6
+:1012D0000281979012E175F003A4C58325F0C583C0
+:1012E0007302130802130802130802149702134C26
+:1012F00002138E0213970213E40213E402144C0249
+:101300001497021497021348904CC5E0FF640360E1
+:1013100005EF6402700D7F22919D904F01E0904C8B
+:10132000EDF022904F01E014904DD6F090421374EE
+:1013300005F0904CF0F07F04919D7F0AF1987F2A90
+:10134000919DE4904CEDF0227F0E819DE4904CF055
+:10135000F01219C1EF700C1219AEEF7006121FEDEA
+:10136000EF600F904F01E0904CEDF0904DEC740366
+:10137000F022F1E0E4904DD4F0904DD3F0904E5532
+:10138000F012221C7F0D919DE4904CEDF022121979
+:10139000C1E4904CEDF0227B017A4D79EE7D5D7CCD
+:1013A00000123545904CC074FFF0A3F07FC8F1984F
+:1013B000C2017FFF31B27B017A4D79EE7D5D7C0009
+:1013C0007F607E7F121C847B017A4C79C07D017C1A
+:1013D000007FBD7E7F121C84D2017FFF31B2E4907A
+:1013E0004CEDF022E4904CF0F01219AEEF60099051
+:1013F0004F01E0904CEDF0227B017A4C79007D04A6
+:101400007C007F527E7F1220CA7F0AF198E4904EC2
+:1014100055F0904C00E0F47021A3E0F4701CA3E0C0
+:10142000F47017A3E0F47012904C00740FF0A3F066
+:10143000A3F0A3F0904E557401F07F21919D904C44
+:10144000C57402F0E4A3F0904CEDF022E4904CF06F
+:10145000F01219C1EF70061219AEEF6009904F013A
+:10146000E0904CEDF022904CC5E064016023E490E4
+:101470004E55F07F23919D904CC57401F0E4A3F08C
+:10148000904CEE7428F0C2017F1431B2E4904CE924
+:10149000F0E4904CEDF022E4904CEDF022904EDC24
+:1014A000EFF078DD7C4E7D017BFF7A0779347E009A
+:1014B0007F03120390904EDCE0904EDFF07B017AC8
+:1014C0004E79DD7D03020FE5904F06EFF01205B374
+:1014D000167B14174A1515712717112914FE2F159D
+:1014E000653015CA31163F3214FE3316EC34172B13
+:1014F0003515C23715713915CA3C0000178EF1EA4F
+:1015000012304D7B017A4C79C07D017C007FBD7E1D
+:101510007F1220CA904CC0E0D39403748094804022
+:1015200002E4F0904CC0E0904CC3F0F1B07F0AF1BF
+:10153000987B017A4C79F27D027C007FBE7E7F121F
+:1015400020CA904CF2E0F47019A3E0F47014904CAF
+:1015500093E0A3E0904CF2F0904C91E0A3E0904C2B
+:10156000F3F002200412303A1218F4E4904CFCF02C
+:1015700022904CC3E0D39400748094805002E18E9A
+:10158000E09404748094804002E18EE075F01FA422
+:1015900024CFF9744D35F0FA7B017D1F7C001235A4
+:1015A000457FC8F198C2017FFF31B27B017A4D7946
+:1015B000EE7D5D7C007F607E7F121C84D2017FFF08
+:1015C00021B2904DD6E0FF020737904CC57403F06E
+:1015D000E4A3F0F1E0E4904CEEF0904CEBF0904C92
+:1015E000C074FEF0904CC3F0904D467403F0904DE3
+:1015F000E6740AF0904F06E06431703A904DE7F0DF
+:10160000904E55F0904CC1F0904CE5740AF0904B20
+:10161000EBE0640F7014A3E0640F700EA3E0640F9E
+:101620007008A3E0640F7002E18E904CBF7402F06A
+:10163000121BEA021D33904CE5E06002E18E22E4C9
+:10164000904CC5F0A3F0904CE3F0A3F0904CEB0469
+:10165000F0904CEDE06009F1E0904CEDE0FF41C608
+:10166000904CECE064017003F0E18F904CF0E0707E
+:1016700002E18E904DD6E0FF020737904CC774030D
+:10168000F0A37401F0E4A3F0A3F07F0E919D7F021C
+:10169000919D904CE9E06034E4904DE7F0904CC1AE
+:1016A000F0904CC3E075F01FA424ECF582E4344DB7
+:1016B000F583E4F0904DE7E0FF904CC3E075F01F38
+:1016C000A424EDF582E4344DF583EFF0904DE5E090
+:1016D0007006904DD47414F0904CE5E07002F1C89F
+:1016E000E4904CE9F0904CE3F0A3F022904CC774E6
+:1016F00004F0E4A3F0F1E0E4904CEBF0904DDB74E7
+:101700000AF0904CC3E0904CC0F0904CBF7403F0D2
+:1017100022904CC3E014FD7F011207FE904CC3E001
+:10172000904CC0F0904CBF7403F022904D391205DC
+:101730008200000000E4904DD7F0904DDE04F09060
+:101740004CC804F0904CC704F022904CC7E0904C79
+:10175000CBF0E4904CC7F0A3F0904CEB04F0E49095
+:101760004D3DF0904CECE064017003F08021904C12
+:10177000EDE06003FF41C6904CF0E06008904DD66C
+:10178000E0FF020737F18FE4904CE3F0A3F022E48E
+:10179000904D38F07F19819DEFD394004011E4FD06
+:1017A000FC0DBD00010CBC04F8BDA6F51F80E922AC
+:1017B000D2017F1D31B2D2017F1F31B2D2017F1E13
+:1017C00031B2D2017F1421B2C2017F1F31B2C201F6
+:1017D0007F1E31B2C2017F1431B2C2017F1D21B21E
+:1017E000E4904CF0F0904DE5F02212303A1218F4EB
+:1017F000C2067F1D121808C2067F1F121808C206F3
+:101800007F1E1108C2067F14AC07ECF46015AF040C
+:10181000D2041135AF04A20692011211B2AF04C274
+:1018200002112422EFF4600C7B017A807978A20205
+:101830009200117522EFF4600C7B017A807970A21E
+:10184000049200117522AC07ECF46017AF04A205F6
+:1018500092031164AF04A205B392021124AF04C233
+:1018600004113522EFF4600C7B017A80797CA203AD
+:101870009200117522904EF5EBF0A3EAF0A3E9F087
+:10188000E4FEFDEF5407FEEF1313135403FD300085
+:1018900022904EF5E0FBA3E0FAA3E02DF9E43AFA3A
+:1018A0001203B6FF7401A806088002C333D8FC4FA8
+:1018B0000203FC904EF5E0FBA3E0FAA3E02DF9E46F
+:1018C0003AFA1203B6FF7401A806088002C333D89F
+:1018D000FCF45F0203FCE4904F04F0F0904F04E04E
+:1018E00090068193FF600CC2051146904F04E004FE
+:1018F000F080E922908080E4F0A3F0A3F031018031
+:10190000D5E4904F03F0F0904F03E0FFC3940874C8
+:10191000809480500CC2051146904F03E004F08083
+:10192000E622E4904F00F0904CC8E064027006900C
+:101930004F00E0FF229047F5E030E306904F00E0D3
+:10194000FF22904CEEE06006904F00E0FF22904CAA
+:10195000C7E0704A904CC5E064036042904CEFE0F1
+:101960007046740AF0A3E0703F904DEBE0640270A3
+:1019700037904CC3E0FF7E00C39401748094804094
+:1019800010D3EF9403748094805006E01212C68046
+:10199000177F091212C6904F007401F0800AE4907C
+:1019A0004CEBF0904F0004F0904F00E0FF22904C81
+:1019B000C7E0640270087F0E12149D7F01227F0031
+:1019C00022904CC7E0FF64046005EF640370087F59
+:1019D0001112149D7F0122904CC5E0FF6403600545
+:1019E000EF640270087F2212149D7F01227F002283
+:1019F000904CCEE030E146904CD0E0C394FA748035
+:101A000094805003E004F0904CD0E064B4703B90BC
+:101A10004DE3E004F0E0D39402748094805007E436
+:101A2000904CD0F08024904DE3E06403701C904D06
+:101A3000DC04F0E4904CD0F012178F800DE4904D50
+:101A4000E3F0904DDCF0904CD0F0904CCEE030E4E0
+:101A50003E904CEA740AF0904CD1E0C394FA748042
+:101A600094805003E004F0904CD1E06406704A90FA
+:101A70004CC3E0600464FE7040E4904CCDF031C192
+:101A80007F0A1217987F0A1212C61217F0802A9046
+:101A90004CCDE0601FE4F07F0D1212C6904CEB7449
+:101AA00001F0904CC3E0904CC0F0904CBF7401F03A
+:101AB00071EAB133E4904CD1F0904CCEE030E34D7C
+:101AC000904CEA740AF0904CD2E0C394FA7480947B
+:101AD000805003E004F0904CD2E064067065904CB6
+:101AE000E974F0F0E4904CEEF07F051212C6121784
+:101AF000F0E4904CCCF0904CEB04F0904CC0E090B3
+:101B00004CC4F0904CC3E0904CC0F08036904CCC6C
+:101B1000E0602BE4F0904CC3E0FF904CC0E06F60BD
+:101B20001D904CEB7401F01217F0904CC3E0904CF8
+:101B3000C0F0904CBF7401F031C171EAB133E49050
+:101B40004CD2F0904CCEE020E50261E4A3E0C394D7
+:101B5000FA748094805003E004F0904CCFE0640667
+:101B6000600261E9904DE8E064147008904CC17423
+:101B700002F08021904DE8E064127007904CC1049F
+:101B8000F08012904DE8E0641A6005E0640870058A
+:101B9000E4904CC1F0904CE5740AF0904CC3E0FF27
+:101BA0007E00600464FE7007904CBF7402F022D384
+:101BB000EF9403EE64809480502FC3EF9401EE64A1
+:101BC0008094804024904CC1E0FF904CC3E075F0BD
+:101BD0001FA424ECF582E4344DF583EFF0904CBF64
+:101BE0007403F022E4904CCFF022904CBFE07002DE
+:101BF0008183640160057FC8121798C2017FFF12BC
+:101C000011B2904CBFE0640270317B017A4C7900D4
+:101C10007D04FC7F527E7F91847B017A4C79C17D6B
+:101C2000017C007F577E7F91847B017A4D79E77D2F
+:101C3000017C007F567E7F91848017904CBFE064CA
+:101C400003700F7B017A4D79EE7D5DFC7F607E7FB6
+:101C500091847B017A4C79C07D017C007FBD7E7FC1
+:101C600091847B017A4C79F27D027C007FBE7E7F7D
+:101C70009184D2017FFF1211B27F0A121798E4906B
+:101C80004CBFF022904E93EEF0A3EFF0A3ECF0A344
+:101C9000EDF0A3EBF0A3EAF0A3E9F0904E95E0702D
+:101CA00002A3E07002A132904E93E0FEA3E0FF4455
+:101CB0000F2401FDE43EFCC3ED9FFFEC9EFE904E21
+:101CC0009AF0A3EFF0904E95E0FCA3E0FDD39FECDB
+:101CD0009E400A904E9AE0FEA3E0FF8004AE04AF5F
+:101CE00005904E9AEEF0FCA3EFF0FDC3904E96E007
+:101CF0009DF0904E95E09CF0904E93E0FEA3E0FFA7
+:101D0000904E97E0FBA3E0FAA3E0F91221827F0A4C
+:101D1000121798904E9AE0FEA3E0FF904E98EE8F37
+:101D2000F012040E904E94E02FF0904E93E03EF0AF
+:101D3000819B229080107401F080FE22F193123278
+:101D4000FBD1D071EA1211C4904D7DE060031224E2
+:101D500033900B7EE014600D24FE70E2B18B1217FD
+:101D6000F0D1C280FE904CEAE07012904CECE07032
+:101D70000C904CE5E07006904CF8E06005123532AE
+:101D800080BCB18BD1C280B680B422E4FF904F05F5
+:101D9000F0FEFDEF900681936048EF93FD1313135F
+:101DA000541FFEED5407FDF87401088002C333D8B8
+:101DB000FCFDEE2478FBE434808B82F583E0FCEDBF
+:101DC000F4FBEC5BF0EE2470F582E43480F583E004
+:101DD0004DF0EE2474F582E43480F583E05BF00F7F
+:101DE00080B11235CE90811CE0904F05F0904DDC13
+:101DF000E06020E4FFD1237F01D1237F02D1237F44
+:101E000003D1237F04D1237F05D1237F06D1237FF4
+:101E1000078010904F05E0FF9000A3F0EFF49000D2
+:101E2000A7F022904F09EFF0F1A69208904F09E039
+:101E3000FFA208B39207EFF47002C1C1EF5407FE8E
+:101E4000EF1313135403FF30074324A3F582E43444
+:101E500000F583C083C082E0FD7401A806088002FB
+:101E6000C333D8FCF45DD082D083F074A72FF58201
+:101E7000E43400F583C083C082E0FF7401A8060843
+:101E80008002C333D8FC4FD082D083F02274A32FBA
+:101E9000F582E43400F583C083C082E0FD7401A8BC
+:101EA00006088002C333D8FCFC4DD082D083F07486
+:101EB000A72FF582E43400F583E0FFECF4FEEF5E3B
+:101EC000F022E4900B7FF0900B7EF07F01021798D8
+:101ED000904CF4E0FF600964036005EF6405700353
+:101EE0000226AF904CF4E06401700EA3E0FFE4FD25
+:101EF000F157904CF47402F022904CF4E0640270BC
+:101F00000B7403F0A3E0FFA3E0FD804B904CF4E0E2
+:101F100064047026904CF6F0904CF5E0FFE4FDF17F
+:101F200057E4904CF5F0904CF8E07007904CF47446
+:101F300006F022904CF47405F022904CF4E0640614
+:101F40007014904CF6F0904CF5F0A3E0FDE4FFF136
+:101F500057E4904CF4F022904EF8EFF0A3EDF07BB4
+:101F6000017A4879007D097C00120DFA90480074CE
+:101F700001F0A3E0FF904EF8E0FEEF4E904801F034
+:101F8000904EF9E0904803F07B017A4879007D0992
+:101F9000020EDA7B017A4E795678687C4E7D017E9E
+:101FA000007F120203907B017A81791CAD07E490D7
+:101FB0004F08F0FEEF5407F0EF1313135403FEF530
+:101FC000827583001203CFFD3395E0FC904F08E04B
+:101FD000FF74017E00A807088005C333CE33CED836
+:101FE000F9FFEE5CFEEF5D4E24FF22A13C904CC059
+:101FF000E0FF64FE6003EF70087F2212149D7F01F2
+:10200000227F0022904DEB7402F07B017A4D79EE35
+:102010007D5D7C007F607E7F11CA7F0A1217987BEE
+:10202000017A4C79007D047C007F527E7F11CA7F4B
+:102030000A1217987B017A4D79E77D017C007F5663
+:102040007E7F11CA7F0A1217987B017A4C79C17D75
+:10205000017C007F577E7F11CA7F0A121798904C2F
+:10206000C3E0FF7E00D39403748094805038C3EFA4
+:10207000940174809480402EE075F01FA424ECF548
+:1020800082E4344DF583E0904CC1F0904CC3E07590
+:10209000F01FA424EDF582E4344DF583E0904DE784
+:1020A000F01212C680057F081212C6904DE7E0D3E9
+:1020B0009401748094804002E4F0904CC1E0D39489
+:1020C00002748094804002E4F022904ECFECF0A3A2
+:1020D000EDF0A3EBF0A3EAF0A3E9F090809874048C
+:1020E000F0A3E4F0900CAF74A0F0A3EEF0A3EFF037
+:1020F000900CB274A1F07A0C79AF7E0C7FAF74AF04
+:10210000FC740CFFECFEEF90809AEEF0A3EFF090E1
+:102110004ECFE0FCA3E0FAECFFEAFEEF90809EEEEB
+:10212000F0A3EFF07A0B79837E0B7F837483FC74CA
+:102130000BFFECFEEF90809CEEF0A3EFF090809010
+:102140007402F090809CA3E020E707908090E04428
+:1021500001F0908006E04404F0317A904ED1E0A383
+:10216000E0FAA3E0AE02FF7B017A0B7983904ECFB9
+:10217000E0A3E0904EC4F002087890812CE030E5B6
+:10218000F922904EB2EEF0A3EFF0904EB6EBF0A332
+:10219000EAF0A3E9F0904EB4ECF0A3EDF0A3E0F97F
+:1021A000A3E0FAA3E0904E9FC9F0A3EAF0A3E9F000
+:1021B000A3ECF0A3EDF07B017A0B79869162900B92
+:1021C0008374A0F0904EB2E0FFA3E0900B84CFF0B8
+:1021D000A3EFF0904EB5E02403FD904EB4E0340040
+:1021E000FCEDFAECFFEAFEEF908098EEF0A3EFF042
+:1021F0007A0B79837E0B7F837483FC740BFFECFE78
+:10220000EFA3EEF0A3EFF090809EE4F0A3F09080B7
+:102210009004F0908006E04404F0217A7B017A4C2F
+:1022200079F27D027C007FBE7E7F11CA904CF2E085
+:1022300004F0A3E004F0904CF2E09044FAF0904CEB
+:10224000F3E09044FBF0904DD0E09044FCF0904DD2
+:10225000D1E09044FDF0904DD2E09044FEF0229009
+:102260004DECE06039E014F0E07033904CEDE06448
+:1022700005702B9047F5E020E324E4904DD4F090D6
+:102280004CE974F0F0E4904CEEF0904E55F0904D27
+:10229000D3F0511C7F0D12149DE4904CEDF02212EE
+:1022A00010E9904CE4E004F07006904CE3E004F098
+:1022B000710271341219F0515F904CE9E06024E42E
+:1022C000904CE3F0A3F0904CE9E014F0E07014902F
+:1022D0004CC4E0904CC3F0904CC0F07F0D1212C67D
+:1022E00012178F904CEEE06018E4904CE3F0A3F0EE
+:1022F000904CEEE014F0E070087F0A121798121765
+:102300008F22E4FF24BCF582E4344DF583E07012A3
+:10231000904D06E0600C14F0E07005904CD5F02272
+:10232000712322904CD3E0600A14F0E0700574052C
+:10233000F091A622904DDBE0600FE014F0E0700910
+:1023400090413104F0904DDAF0904CC7E0FF640406
+:102350007053EF64047034904DDAE07010904CE3E9
+:10236000E0FEA3E0FF4E6023EF541F701EE4904D8B
+:10237000DAF0904E4C7404F0904CF9E0904E4DF031
+:102380007B017A4E794C7D02120EDA904CE3E064C8
+:10239000387004A3E06440600281321219C1904C8D
+:1023A000EC7401F022904CC5E06403704D904CE356
+:1023B000E0FEA3E0FF640A4E7008904D46E0600224
+:1023C000E4F0EF541F641070207B017A4879007D9F
+:1023D00009FC120DFAE4904E4BF090480004F0FB1B
+:1023E0007A4879007D09120EDAC3904CE4E094B08B
+:1023F000904CE3E09404403A8039904CC5E064018D
+:102400007011C3904CE4E09478904CE3E094004069
+:10241000218020C3904CE4E09414904CE3E09400BD
+:102420004010904DE5E06007E4F07F0E12149D121D
+:10243000178F221217F0904BEF74FFF0904CFC7442
+:1024400001F0E4904CE6F0A3F0A3F0904CB774F0E8
+:10245000F0904DE0F0904D4074FFF0A3F0A3F0A396
+:10246000F022904E9CEBF0A3EAF0A3E9F0904EA28C
+:1024700074FFF5F012042445F0602A904E9FE0FBB3
+:10248000A3E475F001120424A9F0FA1203B6FF9038
+:102490004E9CE0FBA3E475F001120424A9F0FAEFCE
+:1024A0001203FC80C822904ECB120582000000006F
+:1024B000904C95E07002A3E07002C170904C95E0E2
+:1024C000FEA3E0FF904CD4E0FD04F0ED25E024D61F
+:1024D000F582E4344CF583EEF0A3EFF0904CD4E0B9
+:1024E000C39404748094804002E4F0E4904ECAF0F7
+:1024F000904ECAE0C3940474809480503DA3E0F8E9
+:10250000A3E0F9A3E0FAA3E0FB904ECAE025E024A3
+:10251000D6F582E4344CF583E0FEA3E0FFE4FCFD55
+:10252000EB2FFFEA3EFEED39FDEC38FC904ECB126E
+:102530000576904ECAE004F080B6904ECBE0FCA346
+:10254000E0FDA3E0FEA3E0FFE47B04FAF9F8120447
+:10255000C5904ECB120576904CE0E0FEA3E0FFE480
+:10256000FCFD904ECBE0F8A3E0F9A3E0FAA3E0FB7A
+:10257000D31205655007E4904CF9F0A1FF904CFA96
+:10258000E0FEA3E0FFE4FCFD904ECBE0F8A3E0F911
+:10259000A3E0FAA3E0FBC31205654008904CF97470
+:1025A00064F0805B904CE0E0FEA3E0FFFBAA06E451
+:1025B000904ECBE0FCA3E0FDA3E0FEA3E0C39BFFB5
+:1025C000EE9AFEED9400FDEC9400FCE47B64FAF9D5
+:1025D000F812043AC006C007904CE0E0FEA3E0FF0A
+:1025E000C3904CFBE09FFF904CFAE09EFEAB07FAD5
+:1025F000E4F9F8D007D0061204C5904CF9EFF0903A
+:102600004CE0E0FEA3E0FFC3904CD7E09F904CD697
+:10261000E09E5007904CD57402F022904CDEE0FE14
+:10262000A3E0FFE4FCFD904ECBE0F8A3E0F9A3E0CB
+:10263000FAA3E0FBC3120565501C904CD57401F061
+:10264000904CFCE0702A904D40F0A37448F0A374C5
+:1026500012F0E4A3F022E4904CD5F0904CFCE07032
+:102660000F904D40F0A37448F0A3745DF0E4A3F024
+:1026700022904D46E06037904DDDE07031904CC5C2
+:10268000E0640370297B017A4879007D09FC120D12
+:10269000FAE4904E4BF090480004F0904D46E090E4
+:1026A0004802F07B017A4879007D09120EDA229007
+:1026B0004EE0E4F0A3F0A3F0D1E35026122ACB9031
+:1026C0004EE0EBF0A3EAF0A3E9F04A7007904CB6B5
+:1026D00004F0809D904EE0E0FBA3E0FAA3E0F91245
+:1026E00008BB22904B9CE0FEA3E0FF904B9AE0B524
+:1026F0000607A3E0B50702D322C322904EE3EBF016
+:10270000A3EAF0A3E9F0E4FDFC904DE2E06401608F
+:1027100002E1AE7C05AF041CEF700302285D904E11
+:10272000E3E0FBA3E0FAA3E02401F9E43AFAEC7E4B
+:102730000029F9EE3AFA1203B6FD64137036904C94
+:10274000EA740AF0904CCEE04408F054EFF0ED2427
+:10275000EEFF904CC3E0B50708904CC5E0640370F1
+:1027600010904CC3EFF0904CCC7401F0E4904CE529
+:10277000F07F0122904CCEE054E7F0EDFF6414604E
+:102780000FEF641A600AEF64126005EF64087015B9
+:10279000904CEA740AF0904DE8EDF0904CCEE04495
+:1027A00020F07F0122904CCEE054DFF0E115904EF6
+:1027B000E3E0FBA3E0FAA3E0F99000011203CFFDF0
+:1027C0007C0064EF702C904CEA740AF0904CCEE0E0
+:1027D00054F7F04410F0904CC3E0601364FE600FB7
+:1027E000904CCD7401F0E4904CC3F0904CE5F07F38
+:1027F0000122ED64E94C6015904EE3E0FBA3E0FAA2
+:10280000A3E0F99000011203CF64EA7046904CEA0D
+:10281000740AF0904CCEE04408F054EFF0904EE390
+:10282000E0FBA3E0FAA3E0F99000011203CF241823
+:10283000FF904CC3E0B50708904CC5E064037010EE
+:10284000904CC3EFF0904CCC7401F0E4904CE5F068
+:102850007F0122904CCEE054E7F054DFF07F00225D
+:10286000904CF5EDF0A3EBF0EF30E013904CF4E07A
+:10287000640370047402F022904CF47401F022900E
+:102880004CF47404F022AE05AC07E4904F02F0EC77
+:1028900030E005E4904CF8F0904F02EEF0904CC11F
+:1028A000E0FF6038EEFB7A0064E67008904F027437
+:1028B000E7F08028EB64E44A7008904F0274E6F079
+:1028C000801AEB64E34A7008904F0274E2F0800CC7
+:1028D000EB64E24A7006904F0274E3F0EF7012EE80
+:1028E00064DA700DAF047B0F7D081160E4904F0235
+:1028F000F0904DE2E06401600221ABEEFB7A0064EF
+:102900004A7008904F027446F021ABEB644D4A7058
+:1029100008904F027448F021ABEB64514A70089064
+:102920004F0274D7F021ABEB64284A7008904F0235
+:102930007447F08076EB642A4A7008904F0274DA8C
+:10294000F08068EB64294A7062EC30E059904DE702
+:10295000E06004E4F08006904DE77401F0904CC311
+:10296000E0FB7A00600464FE7008904CBF7402F0D3
+:102970008034D3EB9403EA648094805029C3EB94B1
+:1029800001EA64809480401E904DE7E0FF904CC3C4
+:10299000E075F01FA424EDF582E4344DF583EFF0EB
+:1029A000904CBF7403F0E4904F02F0904E55E060FD
+:1029B0000241C5904DE2E07006904DE7E060149052
+:1029C0004DE2E06401600241C5904DE7E0640160C2
+:1029D0000241C5EE24C6B40C00400241C59029EB6B
+:1029E00075F003A4C58325F0C58373022A0F022A5C
+:1029F00017022A1F022A27022A72022A8F022A9706
+:102A0000022A9F022AA7022AAF022AB7022ABF90EF
+:102A10004F0274D7F041C5904F0274D8F041C59071
+:102A20004F0274D6F041C5904CC1E0FE7014AF0463
+:102A30007B2B7D041160EC30E031904CF8740AF08F
+:102A40008029EE6401700AAF047B527D0111608021
+:102A50001A904CC1E064027012AF047B2B7D081108
+:102A600060EC30E006904CF8740AF0E4904F02F00D
+:102A70008053904CC1E07008904F0274D2F08045B2
+:102A8000AF047B507D081160E4904F02F0803690D7
+:102A90004F0274D5F0802E904F0274F4F08026908F
+:102AA0004F0274F2F0801E904F0274F5F080169081
+:102AB0004F0274F8F0800E904F0274F6F08006908A
+:102AC0004F0274F7F0904F02E0FF22E4904E88F03E
+:102AD000A3F0A3F0A3F0A3F0A3F0A3F0A3F0A3F05E
+:102AE000A3F0A3F0D1DE7A4D79A8904EAE7401F038
+:102AF000A3744DF0A374A8F0A37414F07B017A4D75
+:102B000079BCB16BEF601C7B017A4D79BC7D14B14F
+:102B10003BEF700F904CCEE04402F0904D067414E1
+:102B2000F0800C904CCEE054FDF0E4904CD0F0E4FA
+:102B3000904E88F0904E88E0FF900681937002815D
+:102B40000974BC2FF582E4344DF583E0904E8BF090
+:102B5000E0FFB12D904E92EFF0C394027480948008
+:102B6000500261F2E4904E89F0904E89E0FFC394E8
+:102B70000874809480507B7E007401A8070880054B
+:102B8000C333CE33CED8F9FF904E8BE0FDE4EF5D3A
+:102B90006058E4904E8AF0904E8AE0FF9006819350
+:102BA0006048904E88E0FEEF6E6037904E8AE024D9
+:102BB000BCF582E4344DF583E0FD7C00904E89E065
+:102BC000FF7E007401A807088005C333CE33CED83A
+:102BD000F9FFEE5CFEEF5D4E6008904E917401F0DF
+:102BE0008008904E8AE004F080AD904E89E004F0B9
+:102BF0006169904E8BE0FF6008B12D904E8FE02F01
+:102C0000F0904E88E004F06134904E8FE0904DE4F7
+:102C1000F0E4904E88F0904E88E0FB90068193702F
+:102C20000281FE904E88E0FE2493F582E4344DF557
+:102C300083E0FD74BC2EF582E4344DF583E06D90A5
+:102C40004E8BF074BC2BF582E4344DF583E0904E4E
+:102C50008EF0904E8BE0700281F6904E91E060070E
+:102C60007B007A00790022904E88E0FF24BCF58238
+:102C7000E4344DF583E0FE74932FF582E4344DF592
+:102C800083EEF0E4904E89F0904E89E0FFC3940803
+:102C900074809480505A904E8BE030E03B904E8888
+:102CA000E0FE33333354F8FEEF4E904E8DF0A3E048
+:102CB000FF904E8DE090069693FD1186904E90EF1A
+:102CC000F0904E8EE030E009904E90E0FFB1B5807C
+:102CD00007904E90E0FFD11D904E8BE0FFC313F0A4
+:102CE000904E8EE0FFC313F0904E89E004F0809880
+:102CF000904E8C7401F0904E88E004F08116904E56
+:102D00004BE06403700B904DDFE0640170037402CC
+:102D1000F0904E8CE07008904DDFE0640270077B0D
+:102D2000017A4E79A4227B007A00790022E4FEEF3A
+:102D30006006145FFF0E80F7AF0622904EE9EBF0BD
+:102D4000A3EAF0A3E9F0E4FFEFC39D501B904EE926
+:102D5000E0FBA3E0FAA3E0F98F827583001203CFB2
+:102D600060037F00220F80E07F0122904EABEBF0EA
+:102D7000A3EAF0A3E9F0E4FF904EB1E0FEEFC39EBA
+:102D80005030904EAEE0FBA3E0FAA3E0F98F8275DD
+:102D900083001203CFFE904EABE0FBA3E0FAA3E06A
+:102DA000F98F827583001203CF6E60037F00220FBC
+:102DB00080C67F0122E4FEEFFD7C00C394E07480B6
+:102DC00094804023D3ED94E7748094805019904E02
+:102DD000A4E0FEEF5407FFF87401088002C333D863
+:102DE000FC4E904EA4F022E4FEEEC3940674809450
+:102DF00080502974A52EF582E4344EF583E0FD6FF2
+:102E0000601AED7014904DEDE06F601074A52EF512
+:102E100082E4344EF583EFF0220E80CD22E4FEFDF5
+:102E2000EF54F064F06007EF54D064D0700D904E12
+:102E30004BE06402700B7403F08006904DDF740168
+:102E4000F0EFFB7A00C394E0748094804024D3EBCD
+:102E500094E774809480501A904EA4E0FEEF5407DB
+:102E6000FFF87401088002C333D8FCF45E904EA4CE
+:102E7000F022E4FEEEC3940674809480505FED70FF
+:102E80002374A52EF582E4344EF583E06F704BEE8B
+:102E90006405700C74A52EF582E4344EF583E4F0DD
+:102EA0007D01803674A52EF582E4344EF583E0FC76
+:102EB00074A42EF582E4344EF583ECF074A52EF55F
+:102EC00082E4344EF583E06014EE6405700C74A562
+:102ED0002EF582E4344EF583E4F00E809722E4FF71
+:102EE000904EE6F0FEFDA3F0A3F0EF900681936014
+:102EF0007BEF93FD131313541FFEED5407FDF8747D
+:102F000001088002C333D8FCFDEE2478FBE4348052
+:102F10008B82F583E0FCEDF4FBEC5BF0EE2470F5C6
+:102F200082E43480F583E04DF0EE2474F582E434DD
+:102F300080F583E05BF090811CE0F4FC74BC2FF51D
+:102F400082E4344DF583ECF0EE2478FBE434808B9E
+:102F500082F583E04DF0EE2470FBE434808B82F543
+:102F600083E0FCEDF4FBEC5BF00FC1EAE4FFEF90D3
+:102F7000068193607BEF93FD131313541FFEED54F2
+:102F800007FDF87401088002C333D8FCFDEE2478F5
+:102F9000FBE434808B82F583E0FCEDF4FBEC5BF02A
+:102FA000EE2470F582E43480F583E04DF0EE247475
+:102FB000F582E43480F583E05BF090811CE0F4FC62
+:102FC00074A82FF582E4344DF583ECF0EE2478FB01
+:102FD000E434808B82F583E04DF0EE2470FBE43422
+:102FE000808B82F583E0FCEDF4FBEC5BF00FE16E8F
+:102FF000E4FFEF90068193604074BC2FF582E434C7
+:103000004DF583E0FE74A82FF582E4344DF583E09E
+:103010006E602374BC2FF582E4344DF583C083C009
+:1030200082E0FE74A82FF582E4344DF583E0FDEED6
+:103030005DD082D083F00F80B922908091740DF022
+:10304000A304F0A3F0A3F0A3F0A314F022120E2621
+:103050001182904CEB7401F0904CE5740AF0E4900E
+:103060004CF0F0904D0574FFF09044FCE0904DD092
+:10307000F09044FDE0904DD1F09044FEE0904DD2B0
+:10308000F022904CD37405F0E4A3F0904D06741434
+:10309000F0904C907433F0E4FFEFC3940474809488
+:1030A000805014EF25E024D6F582E4344CF5837487
+:1030B00062F0A3F00F80E2904C91E0FEA3E0FFC32A
+:1030C000904C94E09FFD904C93E09EFCE41202062D
+:1030D0007BAE7A477961783F1200FBC004C005C01F
+:1030E00006C007904C91E0FCA3E0FDE4120206D07C
+:1030F00003D002D001D00012000A12023F904CFA15
+:10310000EEF0A3EFF0904C91E0FEA3E0FFC3904CF3
+:1031100094E09FFD904C93E09EFCE4120206743311
+:10312000FBFAF9783F1200FBC004C005C006C007D7
+:10313000904C91E0FCA3E0FDE4120206D003D00223
+:10314000D001D00012000A12023F904CDEEEF0A334
+:10315000EFF0904C91E0FEA3E0FFC3904C94E09F11
+:10316000FD904C93E09EFCE41202067B857AEB799D
+:1031700011783F1200FBC004C005C006C007904C88
+:1031800091E0FCA3E0FDE4120206D003D002D001DE
+:10319000D00012000A12023F904CE0EEF0A3EFF0D4
+:1031A00022904EFAEDF09000011203CF904EFBF00A
+:1031B00022904CEAE0600214F0904CEFE0600214C0
+:1031C000F0904CF8E0600B14F0E07006904CF47452
+:1031D00006F0904CE5E06020904CEEE06006E49054
+:1031E0004CE5F022904CE5E014F01217B0904CE55D
+:1031F000E0704A1217C88045904CE9E0703F904C4F
+:10320000EEE07039904CE2E0603314F0E0FFC394DC
+:1032100004748094805016EF30E109D2017F1412BB
+:1032200011B28010C2017F141211B28007C2017F57
+:10323000141211B2904CE2E07003740AF0904DDC6D
+:10324000E07036904DDDE06401702E904CE3F0A309
+:10325000F0904DDDF0904E4CE0600D7B017A4E79A0
+:103260004C7D03120EDA8011904800E0600B7B0168
+:103270007A4879007D09120EDA904DD4E06011E0B1
+:1032800014F0E0700B904D3DE070057F1B12149D13
+:10329000904DE6E06014E014F0E0700E904CC7E052
+:1032A00064047006904213740CF022904EFCEEF011
+:1032B000A3EFF0A905904B9EE0FEA3E0FFAD01193E
+:1032C000ED602F0FEFAC0670010E14F5828C83E0D9
+:1032D000FD904EFCE475F00112042485F082F58324
+:1032E000EDF0AD07AC06BC4BD4BD9AD17E4B7F361A
+:1032F00080CB904B9EEEF0A3EFF0227A0C794B90AE
+:103300004EEC7401F0A3740CF0A3744BF0904BA03E
+:10331000E0FEA3E0FF904B9EE06E7003A3E06F70B1
+:103320000281AA7E0C7F4B7D0351AB904EECE0FBFB
+:10333000A3E0FAA3E0F91203B6B4022B904EEDE439
+:1033400075F00212040E904EECE0FBA3E0FAA3E04D
+:10335000F91203B6FF904E68E0A3E0FAA3E0F5820D
+:103360008A831205DD81AA904EECE0FBA3E0FAA36C
+:10337000E0F91203B664047059904EED75F0011235
+:10338000040E7E0C7F4E904EECE0FBA3E0FAA3E02F
+:10339000F91203B614FD51AB904EECE0FBA3E0FA3A
+:1033A000A3E02401F9E43AFAC002C001904EECE037
+:1033B000A3E0FAA3E0F91203B6FD7C00904E6BE0A7
+:1033C000A3E0FAA3E0F5828A83D001D0021205DDE2
+:1033D00081AA904EECE0FBA3E0FAA3E0F91203B659
+:1033E00064057059904EED75F00112040E7E0C7F4D
+:1033F0004E904EECE0FBA3E0FAA3E0F91203B61402
+:10340000FD51AB904EECE0FBA3E0FAA3E02401F900
+:10341000E43AFAC002C001904EECE0A3E0FAA3E067
+:10342000F91203B6FD7C00904E74E0A3E0FAA3E02D
+:10343000F5828A83D001D0021205DD806D904EECBA
+:10344000E0FBA3E0FAA3E0F91203B664037059901D
+:103450004EED75F00112040E7E0C7F4E904EECE0A6
+:10346000FBA3E0FAA3E0F91203B614FD51AB904EB2
+:10347000ECE0FBA3E0FAA3E02401F9E43AFAC0028D
+:10348000C001904EECE0A3E0FAA3E0F91203B6FD10
+:103490007C00904E77E0A3E0FAA3E0F5828A83D027
+:1034A00001D0021205DD800280FE904BA5E0FEA354
+:1034B000E0FF904C5EE06E7003A3E06F6022904EE0
+:1034C0006EE0FBA3E0FAA3E0F94A60371205D99059
+:1034D0004BA5E0FFA3E0904C5ECFF0A3EFF080CAD5
+:1034E000904C8DE0FFA3E06F6019904E71E0FBA35C
+:1034F000E0FAA3E0F94A600B1205D9904C8DE0A3E5
+:10350000F080DD22900BE77403F0ED6003120FC230
+:1035100022900BE77406F0020FC2900BE77404F0E0
+:10352000020FC2900BE77405F0020FC2900446E050
+:10353000FF22900B7F7401F0E4900B7EF0229082CA
+:10354000807401F022904EF2EBF0A3EAF0A3E9F0D0
+:10355000ED1DAE0470011C4E6017904EF2E0FBA30F
+:10356000E475F001120424A9F0FA74FF1203FC8040
+:10357000DF22EFF4603AEF5407FEEF131313540306
+:10358000FF24A3F582E43400F583C083C082E0FD0C
+:103590007401A806088002C333D8FCF4FC5DD08215
+:1035A000D083F074A72FF582E43400F583E05CF05B
+:1035B00022904F0AEFF07B017A807974121FAC924F
+:1035C00009904F0AE0FFA209B392010211B2E4FF91
+:1035D000EFFD7C002478FBEC34808B82F583E0FEE9
+:1035E000ED2470FDEC34808D82F583E04EF4FEEF27
+:1035F000247CFDEC34808D82F583EEF00FEFB40473
+:02360000CF22D7
+:00000001FF
Index: c51/output/fwram.rom
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/fwram.rom	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/fwram.rom	(working copy)
@@ -0,0 +1,13826 @@
+02
+05
+df
+02
+02
+ab
+e8
+64
+80
+f8
+e9
+33
+e8
+33
+60
+11
+04
+60
+f0
+ed
+33
+ec
+33
+70
+09
+e8
+fc
+e9
+fd
+ea
+fe
+eb
+ff
+22
+04
+60
+de
+d3
+eb
+9f
+ea
+9e
+e9
+9d
+e8
+c2
+e7
+8c
+f0
+c2
+f7
+95
+f0
+40
+0c
+e8
+cc
+f8
+e9
+cd
+f9
+ea
+ce
+fa
+eb
+cf
+fb
+12
+02
+76
+85
+d0
+f0
+58
+04
+70
+03
+20
+d5
+b3
+e8
+04
+70
+07
+50
+02
+b2
+d5
+02
+02
+b5
+92
+d5
+ec
+04
+60
+f7
+e4
+cc
+c0
+e0
+c3
+98
+f8
+60
+3b
+94
+18
+60
+08
+40
+0d
+d0
+e0
+fb
+02
+02
+8d
+e4
+fb
+fa
+c9
+fc
+80
+28
+e8
+30
+e4
+06
+e4
+c9
+fb
+e4
+ca
+fc
+e8
+30
+e3
+05
+e4
+c9
+ca
+cb
+fc
+e8
+54
+07
+60
+10
+f8
+c3
+e9
+13
+f9
+ea
+13
+fa
+eb
+13
+fb
+ec
+13
+fc
+d8
+f1
+30
+f5
+2f
+c3
+e4
+9c
+fc
+ef
+9b
+ff
+ee
+9a
+fe
+ed
+99
+fd
+d0
+e0
+fb
+ef
+4e
+4d
+4c
+70
+12
+22
+db
+03
+02
+02
+b2
+ec
+2c
+fc
+ef
+33
+ff
+ee
+33
+fe
+ed
+33
+fd
+ed
+30
+e7
+eb
+02
+02
+8d
+ef
+2b
+ff
+ee
+3a
+fe
+ed
+39
+fd
+d0
+e0
+fb
+50
+13
+0b
+bb
+00
+03
+02
+02
+b5
+ed
+13
+fd
+ee
+13
+fe
+ef
+13
+ff
+ec
+13
+fc
+02
+02
+8d
+ec
+4d
+60
+11
+e8
+49
+70
+17
+ed
+33
+ec
+33
+04
+60
+0d
+e4
+fc
+ff
+fe
+fd
+22
+e9
+33
+e8
+33
+04
+70
+f8
+02
+02
+ab
+12
+02
+76
+58
+04
+60
+09
+e4
+cc
+24
+81
+50
+06
+28
+50
+09
+02
+02
+b5
+28
+40
+03
+02
+02
+b2
+c0
+e0
+eb
+4a
+70
+44
+b9
+80
+06
+d0
+e0
+fb
+02
+02
+a1
+ef
+4e
+70
+1c
+bd
+80
+08
+eb
+ff
+ea
+fe
+e9
+fd
+80
+eb
+e9
+8d
+f0
+a4
+fe
+e5
+f0
+02
+01
+e4
+e9
+cd
+f9
+ea
+fe
+eb
+ff
+ef
+89
+f0
+a4
+fc
+e5
+f0
+ce
+89
+f0
+a4
+2e
+ff
+e4
+35
+f0
+cd
+89
+f0
+a4
+2d
+fe
+e4
+35
+f0
+80
+67
+ef
+4e
+70
+05
+bd
+80
+d7
+80
+c3
+ef
+8b
+f0
+a4
+ac
+f0
+ee
+8b
+f0
+a4
+2c
+fc
+e4
+35
+f0
+f8
+ef
+8a
+f0
+a4
+2c
+e5
+f0
+38
+fc
+e4
+33
+cb
+8d
+f0
+a4
+2c
+fc
+e5
+f0
+3b
+f8
+ee
+8a
+f0
+a4
+2c
+fc
+e5
+f0
+38
+f8
+e4
+33
+cf
+89
+f0
+a4
+2c
+fc
+e5
+f0
+38
+cf
+34
+00
+ce
+89
+f0
+a4
+2f
+ff
+e5
+f0
+3e
+fe
+e4
+33
+c9
+8d
+f0
+a4
+2e
+fe
+e5
+f0
+39
+cd
+8a
+f0
+a4
+2f
+ff
+e5
+f0
+3e
+fe
+e4
+3d
+fd
+33
+d0
+e0
+fb
+50
+07
+0b
+bb
+00
+0f
+02
+02
+b5
+ec
+2c
+fc
+ef
+33
+ff
+ee
+33
+fe
+ed
+33
+fd
+02
+02
+8d
+75
+f0
+20
+80
+0e
+75
+f0
+10
+80
+05
+75
+f0
+08
+7d
+00
+7e
+00
+7f
+00
+33
+92
+d5
+30
+d5
+03
+12
+05
+57
+ec
+33
+40
+10
+ef
+33
+ff
+ee
+33
+fe
+ed
+33
+fd
+ec
+33
+fc
+d5
+f0
+ed
+22
+e5
+f0
+24
+7e
+a2
+d5
+13
+cc
+92
+e7
+cd
+ce
+ff
+22
+ed
+d2
+e7
+cd
+33
+ec
+33
+92
+d5
+24
+81
+40
+06
+e4
+ff
+fe
+fd
+fc
+22
+fc
+e4
+cf
+ce
+cd
+cc
+24
+e0
+50
+11
+74
+ff
+80
+ed
+c3
+cc
+13
+cc
+cd
+13
+cd
+ce
+13
+ce
+cf
+13
+cf
+04
+70
+f0
+30
+d5
+de
+02
+05
+57
+e9
+d2
+e7
+c9
+33
+e8
+33
+f8
+92
+d5
+ed
+d2
+e7
+cd
+33
+ec
+33
+fc
+50
+02
+b2
+d5
+22
+ec
+30
+e7
+10
+0f
+bf
+00
+0c
+0e
+be
+00
+08
+0d
+bd
+00
+04
+0b
+eb
+60
+14
+a2
+d5
+eb
+13
+fc
+ed
+92
+e7
+fd
+22
+74
+ff
+fc
+fd
+fe
+ff
+22
+e4
+80
+f8
+a2
+d5
+74
+ff
+13
+fc
+7d
+80
+e4
+80
+ef
+e7
+09
+f6
+08
+df
+fa
+80
+46
+e7
+09
+f2
+08
+df
+fa
+80
+3e
+88
+82
+8c
+83
+e7
+09
+f0
+a3
+df
+fa
+80
+32
+e3
+09
+f6
+08
+df
+fa
+80
+78
+e3
+09
+f2
+08
+df
+fa
+80
+70
+88
+82
+8c
+83
+e3
+09
+f0
+a3
+df
+fa
+80
+64
+89
+82
+8a
+83
+e0
+a3
+f6
+08
+df
+fa
+80
+58
+89
+82
+8a
+83
+e0
+a3
+f2
+08
+df
+fa
+80
+4c
+80
+d2
+80
+fa
+80
+c6
+80
+d4
+80
+69
+80
+f2
+80
+33
+80
+10
+80
+a6
+80
+ea
+80
+9a
+80
+a8
+80
+da
+80
+e2
+80
+ca
+80
+33
+89
+82
+8a
+83
+ec
+fa
+e4
+93
+a3
+c8
+c5
+82
+c8
+cc
+c5
+83
+cc
+f0
+a3
+c8
+c5
+82
+c8
+cc
+c5
+83
+cc
+df
+e9
+de
+e7
+80
+0d
+89
+82
+8a
+83
+e4
+93
+a3
+f6
+08
+df
+f9
+ec
+fa
+a9
+f0
+ed
+fb
+22
+89
+82
+8a
+83
+ec
+fa
+e0
+a3
+c8
+c5
+82
+c8
+cc
+c5
+83
+cc
+f0
+a3
+c8
+c5
+82
+c8
+cc
+c5
+83
+cc
+df
+ea
+de
+e8
+80
+db
+89
+82
+8a
+83
+e4
+93
+a3
+f2
+08
+df
+f9
+80
+cc
+88
+f0
+ef
+60
+01
+0e
+4e
+60
+c3
+88
+f0
+ed
+24
+02
+b4
+04
+00
+50
+b9
+f5
+82
+eb
+24
+02
+b4
+04
+00
+50
+af
+23
+23
+45
+82
+23
+90
+03
+10
+73
+bb
+01
+06
+89
+82
+8a
+83
+e0
+22
+50
+02
+e7
+22
+bb
+fe
+02
+e3
+22
+89
+82
+8a
+83
+e4
+93
+22
+bb
+01
+0c
+e5
+82
+29
+f5
+82
+e5
+83
+3a
+f5
+83
+e0
+22
+50
+06
+e9
+25
+82
+f8
+e6
+22
+bb
+fe
+06
+e9
+25
+82
+f8
+e2
+22
+e5
+82
+29
+f5
+82
+e5
+83
+3a
+f5
+83
+e4
+93
+22
+bb
+01
+06
+89
+82
+8a
+83
+f0
+22
+50
+02
+f7
+22
+bb
+fe
+01
+f3
+22
+c5
+f0
+f8
+a3
+e0
+28
+f0
+c5
+f0
+f8
+e5
+82
+15
+82
+70
+02
+15
+83
+e0
+38
+f0
+22
+a3
+f8
+e0
+c5
+f0
+25
+f0
+f0
+e5
+82
+15
+82
+70
+02
+15
+83
+e0
+c8
+38
+f0
+e8
+22
+e8
+8f
+f0
+a4
+cc
+8b
+f0
+a4
+2c
+fc
+e9
+8e
+f0
+a4
+2c
+fc
+8a
+f0
+ed
+a4
+2c
+fc
+ea
+8e
+f0
+a4
+cd
+a8
+f0
+8b
+f0
+a4
+2d
+cc
+38
+25
+f0
+fd
+e9
+8f
+f0
+a4
+2c
+cd
+35
+f0
+fc
+eb
+8e
+f0
+a4
+fe
+a9
+f0
+eb
+8f
+f0
+a4
+cf
+c5
+f0
+2e
+cd
+39
+fe
+e4
+3c
+fc
+ea
+a4
+2d
+ce
+35
+f0
+fd
+e4
+3c
+fc
+22
+75
+f0
+08
+75
+82
+00
+ef
+2f
+ff
+ee
+33
+fe
+cd
+33
+cd
+cc
+33
+cc
+c5
+82
+33
+c5
+82
+9b
+ed
+9a
+ec
+99
+e5
+82
+98
+40
+0c
+f5
+82
+ee
+9b
+fe
+ed
+9a
+fd
+ec
+99
+fc
+0f
+d5
+f0
+d6
+e4
+ce
+fb
+e4
+cd
+fa
+e4
+cc
+f9
+a8
+82
+22
+b8
+00
+c1
+b9
+00
+59
+ba
+00
+2d
+ec
+8b
+f0
+84
+cf
+ce
+cd
+fc
+e5
+f0
+cb
+f9
+78
+18
+ef
+2f
+ff
+ee
+33
+fe
+ed
+33
+fd
+ec
+33
+fc
+eb
+33
+fb
+10
+d7
+03
+99
+40
+04
+eb
+99
+fb
+0f
+d8
+e5
+e4
+f9
+fa
+22
+78
+18
+ef
+2f
+ff
+ee
+33
+fe
+ed
+33
+fd
+ec
+33
+fc
+c9
+33
+c9
+10
+d7
+05
+9b
+e9
+9a
+40
+07
+ec
+9b
+fc
+e9
+9a
+f9
+0f
+d8
+e0
+e4
+c9
+fa
+e4
+cc
+fb
+22
+75
+f0
+10
+ef
+2f
+ff
+ee
+33
+fe
+ed
+33
+fd
+cc
+33
+cc
+c8
+33
+c8
+10
+d7
+07
+9b
+ec
+9a
+e8
+99
+40
+0a
+ed
+9b
+fd
+ec
+9a
+fc
+e8
+99
+f8
+0f
+d5
+f0
+da
+e4
+cd
+fb
+e4
+cc
+fa
+e4
+c8
+f9
+22
+c3
+e4
+9f
+ff
+e4
+9e
+fe
+e4
+9d
+fd
+e4
+9c
+fc
+22
+eb
+9f
+f5
+f0
+ea
+9e
+42
+f0
+e9
+9d
+42
+f0
+e8
+9c
+45
+f0
+22
+ec
+f0
+a3
+ed
+f0
+a3
+ee
+f0
+a3
+ef
+f0
+22
+a8
+82
+85
+83
+f0
+d0
+83
+d0
+82
+12
+05
+99
+12
+05
+99
+12
+05
+99
+12
+05
+99
+e4
+73
+e4
+93
+a3
+c5
+83
+c5
+f0
+c5
+83
+c8
+c5
+82
+c8
+f0
+a3
+c5
+83
+c5
+f0
+c5
+83
+c8
+c5
+82
+c8
+22
+d0
+83
+d0
+82
+f8
+e4
+93
+70
+12
+74
+01
+93
+70
+0d
+a3
+a3
+93
+f8
+74
+01
+93
+f5
+82
+88
+83
+e4
+73
+74
+02
+93
+68
+60
+ef
+a3
+a3
+a3
+80
+df
+8a
+83
+89
+82
+e4
+73
+78
+7f
+e4
+f6
+d8
+fd
+75
+81
+cf
+02
+06
+26
+02
+1f
+eb
+e4
+93
+a3
+f8
+e4
+93
+a3
+40
+03
+f6
+80
+01
+f2
+08
+df
+f4
+80
+29
+e4
+93
+a3
+f8
+54
+07
+24
+0c
+c8
+c3
+33
+c4
+54
+0f
+44
+20
+c8
+83
+40
+04
+f4
+56
+80
+01
+46
+f6
+df
+e4
+80
+0b
+01
+02
+04
+08
+10
+20
+40
+80
+90
+06
+6b
+e4
+7e
+01
+93
+60
+bc
+a3
+ff
+54
+3f
+30
+e5
+09
+54
+1f
+fe
+e4
+93
+a3
+60
+01
+0e
+cf
+54
+c0
+25
+e0
+60
+a8
+40
+b8
+e4
+93
+a3
+fa
+e4
+93
+a3
+f8
+e4
+93
+a3
+c8
+c5
+82
+c8
+ca
+c5
+83
+ca
+f0
+a3
+c8
+c5
+82
+c8
+ca
+c5
+83
+ca
+df
+e9
+de
+e7
+80
+be
+52
+4e
+56
+ff
+14
+c8
+00
+00
+00
+ff
+22
+9f
+ff
+31
+b1
+00
+00
+00
+ff
+31
+a1
+00
+0a
+1c
+15
+16
+17
+18
+19
+1a
+0c
+09
+0b
+0f
+10
+11
+1b
+0e
+08
+0d
+00
+00
+00
+3e
+e0
+00
+e4
+de
+00
+66
+47
+1e
+35
+8b
+1d
+29
+04
+2b
+14
+1f
+3a
+8a
+1b
+64
+16
+39
+1a
+20
+3b
+88
+06
+3d
+07
+3c
+08
+21
+22
+05
+19
+0a
+09
+17
+15
+24
+23
+11
+10
+0b
+0d
+1c
+18
+25
+2e
+87
+36
+3f
+0e
+30
+0c
+26
+41
+65
+37
+00
+0f
+40
+12
+27
+2d
+38
+32
+34
+33
+2f
+13
+48
+b0
+e6
+00
+e2
+7f
+00
+46
+43
+42
+45
+28
+44
+31
+2a
+89
+66
+4c
+51
+53
+2c
+59
+5c
+5f
+de
+49
+4f
+54
+62
+5a
+5d
+60
+4e
+4b
+56
+55
+63
+5b
+5e
+61
+4d
+4a
+50
+f2
+52
+58
+85
+57
+7c
+da
+ea
+e9
+ef
+e5
+e1
+df
+00
+f8
+d4
+d2
+d3
+d1
+e3
+7b
+90
+d6
+7d
+f3
+00
+e7
+d0
+91
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+00
+01
+01
+00
+90
+4e
+fe
+ef
+f0
+90
+4c
+f0
+e0
+70
+02
+e1
+fd
+14
+f0
+e4
+90
+4d
+e5
+f0
+90
+4e
+55
+f0
+90
+4e
+fe
+e0
+ff
+75
+f0
+1f
+a4
+24
+ee
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+64
+01
+70
+70
+ef
+75
+f0
+1f
+a4
+24
+ef
+f9
+74
+4d
+35
+f0
+fa
+7b
+01
+7e
+42
+7f
+74
+90
+4e
+c4
+74
+06
+f0
+12
+08
+78
+90
+4e
+fe
+e0
+75
+f0
+1f
+a4
+24
+f5
+f9
+74
+4d
+35
+f0
+fa
+7b
+01
+7e
+44
+7f
+7b
+90
+4e
+c4
+74
+10
+f0
+12
+08
+78
+90
+4e
+fe
+e0
+75
+f0
+1f
+a4
+24
+05
+f9
+74
+4e
+35
+f0
+fa
+7b
+01
+7e
+44
+7f
+f9
+90
+4e
+c4
+74
+06
+f0
+12
+08
+78
+7f
+2b
+12
+14
+9d
+90
+4d
+e5
+74
+01
+f0
+e4
+90
+4c
+f0
+f0
+90
+44
+8b
+04
+f0
+22
+90
+4e
+55
+74
+01
+f0
+90
+44
+f9
+74
+0f
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+90
+4d
+d3
+74
+01
+f0
+7f
+2b
+12
+14
+9d
+90
+42
+5e
+74
+01
+f0
+22
+90
+4e
+ff
+ed
+f0
+ef
+64
+01
+70
+6f
+e0
+ff
+75
+f0
+1f
+a4
+24
+ee
+f5
+82
+e4
+34
+4d
+f5
+83
+74
+01
+f0
+ef
+75
+f0
+1f
+a4
+24
+ef
+f5
+82
+e4
+34
+4d
+af
+82
+fe
+7b
+01
+7a
+03
+79
+d0
+90
+4e
+c4
+74
+06
+f0
+11
+78
+90
+4e
+ff
+e0
+75
+f0
+1f
+a4
+24
+f5
+f5
+82
+e4
+34
+4d
+af
+82
+fe
+7b
+01
+7a
+44
+79
+7b
+90
+4e
+c4
+74
+10
+f0
+11
+78
+90
+4e
+ff
+e0
+75
+f0
+1f
+a4
+24
+05
+f5
+82
+e4
+34
+4e
+af
+82
+fe
+7b
+01
+7a
+44
+79
+f9
+90
+4e
+c4
+74
+06
+f0
+11
+78
+22
+90
+4e
+bf
+ee
+f0
+a3
+ef
+f0
+a3
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+90
+4e
+c4
+e0
+ff
+14
+f0
+ef
+60
+27
+90
+4e
+c1
+e0
+fb
+a3
+e4
+75
+f0
+01
+12
+04
+24
+a9
+f0
+fa
+12
+03
+b6
+ff
+90
+4e
+bf
+e4
+75
+f0
+01
+12
+04
+24
+85
+f0
+82
+f5
+83
+ef
+f0
+80
+cf
+22
+90
+4e
+c5
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+e4
+a3
+f0
+a3
+f0
+90
+4d
+e2
+f0
+90
+4e
+c9
+f0
+90
+4e
+c9
+e0
+ff
+c3
+94
+05
+74
+80
+94
+80
+50
+2c
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+7e
+00
+e9
+2f
+f9
+ee
+3a
+fa
+12
+03
+b6
+64
+7f
+70
+05
+90
+4d
+e2
+04
+f0
+90
+4e
+c9
+e0
+04
+f0
+80
+c6
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+26
+fb
+ef
+60
+02
+61
+dc
+90
+4e
+c5
+e0
+a3
+e0
+fa
+a3
+e0
+4a
+70
+02
+61
+dc
+90
+4d
+7d
+e0
+60
+08
+e4
+f0
+90
+4d
+46
+74
+03
+f0
+90
+4c
+c7
+e0
+64
+04
+70
+06
+90
+42
+13
+74
+03
+f0
+90
+4d
+e6
+74
+0a
+f0
+e4
+90
+4c
+e3
+f0
+a3
+f0
+90
+4c
+d5
+e0
+64
+01
+70
+11
+90
+4d
+40
+f0
+a3
+74
+48
+f0
+a3
+74
+12
+f0
+e4
+a3
+f0
+80
+10
+e4
+90
+4d
+40
+f0
+a3
+74
+48
+f0
+a3
+74
+5d
+f0
+e4
+a3
+f0
+7b
+01
+7a
+48
+79
+00
+7d
+09
+7c
+00
+b1
+fa
+7b
+01
+7a
+4e
+79
+4c
+7d
+09
+7c
+00
+b1
+fa
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+90
+00
+01
+12
+03
+cf
+ff
+7e
+00
+64
+0e
+70
+0a
+90
+00
+02
+12
+03
+cf
+64
+29
+60
+10
+ef
+64
+29
+4e
+70
+36
+90
+00
+02
+12
+03
+cf
+64
+0e
+70
+2c
+90
+4b
+eb
+74
+20
+f0
+a3
+74
+15
+f0
+a3
+74
+10
+f0
+a3
+74
+05
+f0
+90
+4c
+c5
+e0
+64
+01
+60
+09
+90
+4c
+ce
+e0
+44
+10
+f0
+80
+10
+90
+4c
+ce
+e0
+54
+ef
+f0
+80
+07
+90
+4c
+ce
+e0
+54
+ef
+f0
+90
+4c
+b6
+74
+01
+f0
+90
+4c
+f4
+e0
+ff
+64
+01
+70
+02
+61
+dc
+ef
+64
+04
+70
+02
+61
+dc
+ef
+64
+02
+70
+02
+61
+dc
+90
+4c
+c5
+e0
+64
+03
+70
+4a
+90
+4e
+c9
+f0
+90
+4e
+c9
+e0
+ff
+c3
+94
+05
+74
+80
+94
+80
+50
+38
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+7e
+00
+e9
+2f
+f9
+ee
+3a
+fa
+12
+03
+b6
+ff
+64
+39
+60
+0a
+ef
+64
+53
+60
+05
+ef
+64
+47
+70
+06
+90
+4d
+46
+74
+03
+f0
+90
+4e
+c9
+e0
+04
+f0
+80
+ba
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+71
+dd
+90
+4e
+4b
+e0
+64
+01
+70
+11
+74
+02
+f0
+90
+4e
+4c
+f0
+7b
+01
+7a
+4e
+79
+4c
+7d
+03
+c1
+da
+90
+4e
+4b
+e0
+64
+04
+70
+13
+74
+02
+f0
+90
+4e
+4c
+74
+06
+f0
+7b
+01
+7a
+4e
+79
+4c
+7d
+03
+c1
+da
+90
+4e
+4b
+e0
+64
+03
+60
+0b
+e0
+64
+02
+70
+2f
+90
+4d
+e4
+e0
+70
+29
+e4
+90
+4e
+4b
+f0
+90
+4d
+ed
+f0
+90
+4d
+e9
+e0
+60
+0a
+e4
+f0
+90
+4e
+4c
+74
+06
+f0
+80
+06
+90
+4e
+4c
+74
+02
+f0
+7b
+01
+7a
+4e
+79
+4c
+7d
+03
+c1
+da
+90
+4d
+e4
+e0
+70
+16
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+7d
+06
+7c
+00
+b1
+fa
+90
+48
+00
+74
+01
+f0
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+90
+48
+01
+f0
+90
+4c
+c5
+e0
+64
+03
+70
+0a
+90
+4d
+46
+e0
+90
+48
+02
+f0
+80
+05
+e4
+90
+48
+02
+f0
+e4
+90
+4d
+df
+f0
+90
+4e
+55
+e0
+70
+75
+90
+00
+01
+12
+03
+cf
+64
+7f
+70
+15
+7e
+48
+7f
+03
+e9
+24
+02
+f9
+e4
+3a
+fa
+90
+4e
+c4
+74
+05
+f0
+11
+78
+80
+1c
+7e
+48
+7f
+03
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+90
+4e
+c4
+74
+06
+f0
+11
+78
+90
+4e
+c9
+74
+03
+f0
+90
+4e
+c9
+e0
+ff
+c3
+94
+09
+74
+80
+94
+80
+50
+42
+74
+00
+2f
+f5
+82
+e4
+34
+48
+f5
+83
+e0
+64
+7f
+70
+0f
+90
+4e
+c9
+e0
+24
+00
+f5
+82
+e4
+34
+48
+f5
+83
+e4
+f0
+90
+4e
+c9
+e0
+04
+f0
+80
+cc
+7e
+48
+7f
+03
+90
+4e
+c5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+90
+4e
+c4
+74
+06
+f0
+11
+78
+7b
+01
+7a
+48
+79
+00
+7d
+09
+d1
+da
+22
+90
+4e
+d4
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+e4
+a3
+f0
+f0
+90
+4e
+d7
+e0
+ff
+c3
+94
+06
+74
+80
+94
+80
+40
+02
+a1
+de
+90
+4e
+d4
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+7e
+00
+e9
+2f
+f9
+ee
+3a
+fa
+12
+03
+b6
+ff
+54
+f0
+64
+f0
+60
+09
+ef
+54
+d0
+64
+d0
+60
+02
+a1
+d6
+12
+03
+b6
+f9
+fb
+7a
+00
+64
+f1
+70
+08
+7f
+83
+7e
+01
+b1
+df
+a1
+aa
+eb
+64
+f2
+4a
+70
+07
+7f
+cd
+fe
+b1
+df
+a1
+aa
+e9
+fb
+7a
+00
+64
+f3
+70
+07
+7f
+b7
+fe
+b1
+df
+a1
+aa
+eb
+64
+f4
+4a
+70
+07
+7f
+b6
+fe
+b1
+df
+a1
+aa
+e9
+fb
+7a
+00
+64
+f5
+70
+07
+7f
+b5
+fe
+b1
+df
+a1
+aa
+eb
+64
+f6
+4a
+70
+07
+7f
+ea
+fe
+b1
+df
+a1
+aa
+e9
+fb
+7a
+00
+64
+f7
+70
+07
+7f
+e9
+fe
+b1
+df
+a1
+aa
+eb
+64
+f8
+4a
+70
+07
+7f
+e2
+fe
+b1
+df
+a1
+aa
+e9
+fb
+7a
+00
+64
+f9
+70
+08
+7f
+94
+7e
+01
+b1
+df
+a1
+aa
+eb
+64
+fa
+4a
+70
+08
+7f
+8a
+7e
+01
+b1
+df
+a1
+aa
+e9
+fb
+7a
+00
+64
+fb
+70
+08
+7f
+92
+7e
+01
+b1
+df
+a1
+aa
+eb
+64
+d0
+4a
+70
+08
+7f
+2a
+7e
+02
+b1
+df
+a1
+aa
+e9
+fb
+7a
+00
+64
+d1
+70
+08
+7f
+25
+7e
+02
+b1
+df
+a1
+aa
+eb
+64
+d3
+4a
+70
+08
+7f
+26
+7e
+02
+b1
+df
+a1
+aa
+e9
+fb
+7a
+00
+64
+d2
+70
+08
+7f
+24
+7e
+02
+b1
+df
+a1
+aa
+eb
+64
+d4
+4a
+70
+08
+7f
+27
+7e
+02
+b1
+df
+a1
+aa
+e9
+fb
+7a
+00
+64
+d5
+70
+08
+7f
+21
+7e
+02
+b1
+df
+a1
+aa
+eb
+64
+d6
+4a
+70
+08
+7f
+23
+7e
+02
+b1
+df
+80
+79
+e9
+fb
+7a
+00
+64
+d7
+70
+07
+7f
+70
+fe
+b1
+df
+80
+6a
+eb
+64
+d8
+4a
+70
+07
+7f
+6f
+fe
+b1
+df
+80
+5d
+e9
+fb
+7a
+00
+64
+d9
+70
+07
+7f
+b8
+fe
+b1
+df
+80
+4e
+eb
+64
+da
+4a
+70
+07
+7f
+30
+fe
+b1
+df
+80
+41
+e9
+fb
+7a
+00
+64
+db
+70
+08
+7f
+06
+7e
+03
+b1
+df
+80
+31
+eb
+64
+dc
+4a
+70
+08
+7f
+07
+7e
+03
+b1
+df
+80
+23
+e9
+fd
+7c
+00
+64
+dd
+70
+06
+7f
+01
+d1
+bf
+80
+15
+ed
+64
+de
+4c
+70
+06
+7f
+02
+d1
+bf
+80
+09
+e9
+64
+df
+70
+04
+7f
+04
+d1
+bf
+90
+4e
+4b
+e0
+64
+02
+70
+24
+90
+4e
+d4
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+a3
+e0
+7e
+00
+29
+f9
+ee
+3a
+fa
+12
+03
+b6
+90
+4d
+ed
+f0
+e4
+12
+03
+fc
+90
+4e
+d7
+e0
+04
+f0
+61
+ec
+22
+ad
+07
+ac
+06
+90
+4e
+4b
+e0
+64
+02
+60
+0e
+74
+01
+f0
+90
+4e
+4c
+04
+f0
+ef
+a3
+f0
+ee
+a3
+f0
+22
+90
+4e
+ef
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+ed
+1d
+ae
+04
+70
+01
+1c
+4e
+60
+16
+90
+4e
+ef
+e0
+fb
+a3
+e4
+75
+f0
+01
+12
+04
+24
+a9
+f0
+fa
+e4
+12
+03
+fc
+80
+e0
+22
+7b
+01
+7a
+4c
+79
+bf
+7d
+48
+7c
+00
+b1
+fa
+7b
+01
+7a
+4d
+79
+93
+7d
+14
+7c
+00
+b1
+fa
+7b
+01
+7a
+4d
+79
+a8
+7d
+14
+7c
+00
+b1
+fa
+7b
+01
+7a
+4d
+79
+bc
+7d
+14
+7c
+00
+b1
+fa
+7b
+01
+7a
+48
+79
+00
+7d
+09
+7c
+00
+b1
+fa
+7b
+01
+7a
+4e
+79
+4c
+7d
+09
+7c
+00
+b1
+fa
+e4
+90
+4d
+e6
+f0
+90
+4d
+ec
+f0
+90
+4d
+eb
+f0
+90
+4d
+dd
+f0
+90
+4d
+d5
+f0
+90
+4d
+e5
+f0
+90
+4d
+e3
+f0
+90
+4e
+4b
+f0
+90
+4d
+dc
+f0
+90
+4d
+df
+f0
+90
+4d
+e2
+f0
+90
+4d
+ea
+f0
+90
+4d
+d8
+f0
+90
+4d
+e7
+f0
+90
+4d
+ed
+f0
+90
+4c
+b7
+74
+f0
+f0
+90
+4d
+e0
+f0
+e4
+90
+4d
+38
+f0
+90
+4d
+d4
+f0
+22
+90
+4e
+4b
+e0
+64
+02
+60
+12
+74
+04
+f0
+90
+4d
+e9
+74
+01
+f0
+90
+4e
+4c
+74
+06
+f0
+a3
+ef
+f0
+22
+90
+4e
+7a
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+a3
+ed
+f0
+e4
+ff
+90
+4e
+7d
+e0
+fe
+ef
+c3
+9e
+50
+23
+90
+4e
+7a
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+8f
+82
+75
+83
+00
+12
+03
+cf
+fe
+74
+7e
+2f
+f5
+82
+e4
+34
+4e
+f5
+83
+ee
+f0
+0f
+80
+d3
+12
+19
+22
+ef
+70
+02
+e1
+c1
+90
+4c
+eb
+e0
+60
+02
+e1
+c1
+90
+4c
+c7
+e0
+ff
+64
+04
+60
+0b
+ef
+64
+03
+70
+1f
+90
+4d
+d3
+e0
+60
+19
+90
+4e
+7e
+e0
+64
+06
+70
+03
+74
+03
+f0
+7b
+01
+7a
+4e
+79
+7e
+90
+4e
+7d
+e0
+fd
+12
+35
+23
+90
+4c
+c5
+e0
+64
+03
+70
+65
+90
+4e
+7e
+e0
+64
+01
+70
+23
+74
+04
+f0
+a3
+e0
+70
+14
+90
+4e
+81
+e0
+70
+0e
+a3
+e0
+70
+0a
+a3
+e0
+70
+06
+90
+4d
+dd
+f0
+80
+34
+90
+4d
+dd
+74
+01
+f0
+80
+2c
+90
+4e
+7e
+e0
+64
+02
+70
+19
+74
+05
+f0
+a3
+e0
+70
+0a
+a3
+e0
+70
+06
+90
+4d
+dd
+f0
+80
+13
+90
+4d
+dd
+74
+01
+f0
+80
+0b
+90
+4e
+7e
+e0
+64
+03
+70
+03
+74
+07
+f0
+7b
+01
+7a
+4e
+79
+7e
+90
+4e
+7d
+e0
+fd
+12
+35
+11
+22
+90
+4f
+07
+ed
+f0
+e0
+fd
+90
+0b
+e8
+f0
+7e
+0b
+7f
+e9
+90
+4e
+c4
+ed
+f0
+11
+78
+7b
+01
+7a
+0b
+79
+e7
+90
+4f
+07
+e0
+24
+02
+fd
+90
+4e
+b9
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+a3
+ed
+f0
+90
+4b
+9c
+e0
+ff
+a3
+e0
+90
+4e
+bd
+cf
+f0
+a3
+ef
+f0
+90
+4b
+9a
+e0
+fe
+a3
+e0
+ff
+90
+4b
+9c
+e0
+fc
+a3
+e0
+fd
+7b
+64
+11
+79
+90
+4e
+bc
+e0
+fe
+ef
+c3
+9e
+40
+e2
+90
+4e
+bc
+e0
+ff
+14
+f0
+ef
+60
+3f
+90
+4e
+b9
+e0
+fb
+a3
+e4
+75
+f0
+01
+12
+04
+24
+a9
+f0
+fa
+12
+03
+b6
+ff
+90
+4e
+bd
+e4
+75
+f0
+01
+12
+04
+24
+85
+f0
+82
+f5
+83
+ef
+f0
+90
+4e
+bd
+e0
+fe
+a3
+e0
+ff
+be
+4b
+c6
+bf
+36
+c3
+90
+4e
+bd
+74
+4a
+f0
+a3
+74
+a0
+f0
+80
+b7
+90
+4e
+bd
+e0
+ff
+a3
+e0
+90
+4b
+9c
+cf
+f0
+a3
+ef
+f0
+22
+90
+4e
+d8
+ee
+f0
+a3
+ef
+f0
+90
+4e
+da
+ec
+f0
+a3
+ed
+f0
+90
+4e
+da
+e0
+fe
+a3
+e0
+ff
+d3
+90
+4e
+d9
+e0
+9f
+90
+4e
+d8
+e0
+9e
+40
+16
+90
+4e
+da
+e0
+fe
+a3
+e0
+ff
+90
+4e
+d9
+e0
+9f
+ff
+90
+4e
+d8
+e0
+9e
+fe
+80
+1e
+90
+4e
+d8
+e0
+fe
+a3
+e0
+ff
+c3
+90
+4e
+db
+e0
+9f
+ff
+90
+4e
+da
+e0
+9e
+fe
+ad
+03
+c3
+eb
+9f
+ff
+e4
+9e
+fe
+22
+90
+4c
+c7
+e0
+64
+04
+60
+08
+90
+4c
+c5
+e0
+64
+03
+70
+03
+7f
+01
+22
+7f
+00
+22
+90
+4d
+eb
+e0
+64
+02
+60
+02
+21
+b1
+90
+4c
+e9
+e0
+60
+3a
+90
+4c
+cc
+e0
+64
+01
+60
+1e
+90
+4c
+c3
+e0
+64
+01
+70
+07
+7f
+1f
+12
+35
+b1
+80
+2e
+90
+4c
+c3
+e0
+64
+02
+70
+26
+7f
+1e
+12
+35
+b1
+80
+1f
+c2
+01
+7f
+1f
+31
+b2
+c2
+01
+7f
+1e
+31
+b2
+c2
+01
+7f
+14
+31
+b2
+80
+0b
+90
+4c
+ee
+e0
+60
+05
+7f
+14
+12
+35
+b1
+11
+d3
+ef
+60
+6e
+90
+4c
+e5
+e0
+70
+68
+a3
+e0
+60
+16
+14
+f0
+d2
+01
+7f
+ff
+31
+b2
+90
+4c
+e6
+e0
+70
+0e
+c2
+01
+7f
+ff
+31
+b2
+80
+06
+c2
+01
+7f
+ff
+31
+b2
+90
+4c
+e7
+e0
+60
+16
+14
+f0
+d2
+01
+7f
+1d
+31
+b2
+90
+4c
+e7
+e0
+70
+0e
+c2
+01
+7f
+1d
+31
+b2
+80
+06
+c2
+01
+7f
+1d
+31
+b2
+90
+4c
+e8
+e0
+60
+20
+14
+f0
+90
+4c
+e5
+e0
+70
+18
+90
+4c
+e2
+e0
+70
+12
+d2
+01
+7f
+14
+31
+b2
+90
+4c
+e8
+e0
+70
+06
+c2
+01
+7f
+14
+31
+b2
+22
+ef
+f4
+60
+0d
+7b
+01
+7a
+80
+79
+74
+a2
+01
+92
+00
+12
+18
+75
+22
+90
+4d
+eb
+e0
+64
+02
+60
+02
+41
+c5
+90
+4c
+e9
+e0
+60
+02
+41
+bf
+90
+4c
+ee
+e0
+60
+02
+41
+bf
+90
+4c
+d5
+e0
+64
+02
+70
+04
+f1
+8f
+80
+2f
+90
+4c
+d5
+e0
+64
+01
+70
+14
+90
+4c
+f7
+e0
+70
+21
+90
+4c
+e2
+74
+0a
+f0
+90
+4c
+f7
+74
+01
+f0
+80
+13
+90
+4c
+f7
+e0
+64
+01
+70
+0b
+f0
+90
+4c
+e2
+f0
+c2
+01
+7f
+14
+31
+b2
+11
+d3
+ef
+70
+02
+41
+b9
+90
+4c
+e5
+e0
+60
+02
+41
+b9
+90
+4d
+e0
+e0
+ff
+90
+4c
+b7
+e0
+6f
+70
+02
+41
+c5
+e0
+30
+e0
+0e
+90
+4c
+e6
+74
+14
+f0
+d2
+01
+7f
+ff
+31
+b2
+80
+0b
+c2
+01
+7f
+ff
+31
+b2
+e4
+90
+4c
+e6
+f0
+90
+4c
+b7
+e0
+30
+e1
+0e
+90
+4c
+e7
+74
+14
+f0
+d2
+01
+7f
+1d
+31
+b2
+80
+0b
+c2
+01
+7f
+1d
+31
+b2
+e4
+90
+4c
+e7
+f0
+90
+4c
+b7
+e0
+30
+e2
+1a
+90
+4c
+e8
+74
+14
+f0
+90
+4c
+e5
+e0
+70
+25
+90
+4c
+e2
+e0
+70
+1f
+d2
+01
+7f
+14
+31
+b2
+80
+17
+90
+4c
+e5
+e0
+70
+0c
+90
+4c
+e2
+e0
+70
+06
+c2
+01
+7f
+14
+31
+b2
+e4
+90
+4c
+e8
+f0
+e4
+90
+4d
+46
+f0
+90
+4c
+b7
+e0
+90
+4d
+e0
+f0
+22
+c2
+01
+7f
+ff
+21
+b2
+c2
+01
+7f
+ff
+31
+b2
+22
+90
+4f
+01
+ef
+f0
+14
+b4
+0d
+00
+40
+02
+81
+97
+90
+12
+e1
+75
+f0
+03
+a4
+c5
+83
+25
+f0
+c5
+83
+73
+02
+13
+08
+02
+13
+08
+02
+13
+08
+02
+14
+97
+02
+13
+4c
+02
+13
+8e
+02
+13
+97
+02
+13
+e4
+02
+13
+e4
+02
+14
+4c
+02
+14
+97
+02
+14
+97
+02
+13
+48
+90
+4c
+c5
+e0
+ff
+64
+03
+60
+05
+ef
+64
+02
+70
+0d
+7f
+22
+91
+9d
+90
+4f
+01
+e0
+90
+4c
+ed
+f0
+22
+90
+4f
+01
+e0
+14
+90
+4d
+d6
+f0
+90
+42
+13
+74
+05
+f0
+90
+4c
+f0
+f0
+7f
+04
+91
+9d
+7f
+0a
+f1
+98
+7f
+2a
+91
+9d
+e4
+90
+4c
+ed
+f0
+22
+7f
+0e
+81
+9d
+e4
+90
+4c
+f0
+f0
+12
+19
+c1
+ef
+70
+0c
+12
+19
+ae
+ef
+70
+06
+12
+1f
+ed
+ef
+60
+0f
+90
+4f
+01
+e0
+90
+4c
+ed
+f0
+90
+4d
+ec
+74
+03
+f0
+22
+f1
+e0
+e4
+90
+4d
+d4
+f0
+90
+4d
+d3
+f0
+90
+4e
+55
+f0
+12
+22
+1c
+7f
+0d
+91
+9d
+e4
+90
+4c
+ed
+f0
+22
+12
+19
+c1
+e4
+90
+4c
+ed
+f0
+22
+7b
+01
+7a
+4d
+79
+ee
+7d
+5d
+7c
+00
+12
+35
+45
+90
+4c
+c0
+74
+ff
+f0
+a3
+f0
+7f
+c8
+f1
+98
+c2
+01
+7f
+ff
+31
+b2
+7b
+01
+7a
+4d
+79
+ee
+7d
+5d
+7c
+00
+7f
+60
+7e
+7f
+12
+1c
+84
+7b
+01
+7a
+4c
+79
+c0
+7d
+01
+7c
+00
+7f
+bd
+7e
+7f
+12
+1c
+84
+d2
+01
+7f
+ff
+31
+b2
+e4
+90
+4c
+ed
+f0
+22
+e4
+90
+4c
+f0
+f0
+12
+19
+ae
+ef
+60
+09
+90
+4f
+01
+e0
+90
+4c
+ed
+f0
+22
+7b
+01
+7a
+4c
+79
+00
+7d
+04
+7c
+00
+7f
+52
+7e
+7f
+12
+20
+ca
+7f
+0a
+f1
+98
+e4
+90
+4e
+55
+f0
+90
+4c
+00
+e0
+f4
+70
+21
+a3
+e0
+f4
+70
+1c
+a3
+e0
+f4
+70
+17
+a3
+e0
+f4
+70
+12
+90
+4c
+00
+74
+0f
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+90
+4e
+55
+74
+01
+f0
+7f
+21
+91
+9d
+90
+4c
+c5
+74
+02
+f0
+e4
+a3
+f0
+90
+4c
+ed
+f0
+22
+e4
+90
+4c
+f0
+f0
+12
+19
+c1
+ef
+70
+06
+12
+19
+ae
+ef
+60
+09
+90
+4f
+01
+e0
+90
+4c
+ed
+f0
+22
+90
+4c
+c5
+e0
+64
+01
+60
+23
+e4
+90
+4e
+55
+f0
+7f
+23
+91
+9d
+90
+4c
+c5
+74
+01
+f0
+e4
+a3
+f0
+90
+4c
+ee
+74
+28
+f0
+c2
+01
+7f
+14
+31
+b2
+e4
+90
+4c
+e9
+f0
+e4
+90
+4c
+ed
+f0
+22
+e4
+90
+4c
+ed
+f0
+22
+90
+4e
+dc
+ef
+f0
+78
+dd
+7c
+4e
+7d
+01
+7b
+ff
+7a
+07
+79
+34
+7e
+00
+7f
+03
+12
+03
+90
+90
+4e
+dc
+e0
+90
+4e
+df
+f0
+7b
+01
+7a
+4e
+79
+dd
+7d
+03
+02
+0f
+e5
+90
+4f
+06
+ef
+f0
+12
+05
+b3
+16
+7b
+14
+17
+4a
+15
+15
+71
+27
+17
+11
+29
+14
+fe
+2f
+15
+65
+30
+15
+ca
+31
+16
+3f
+32
+14
+fe
+33
+16
+ec
+34
+17
+2b
+35
+15
+c2
+37
+15
+71
+39
+15
+ca
+3c
+00
+00
+17
+8e
+f1
+ea
+12
+30
+4d
+7b
+01
+7a
+4c
+79
+c0
+7d
+01
+7c
+00
+7f
+bd
+7e
+7f
+12
+20
+ca
+90
+4c
+c0
+e0
+d3
+94
+03
+74
+80
+94
+80
+40
+02
+e4
+f0
+90
+4c
+c0
+e0
+90
+4c
+c3
+f0
+f1
+b0
+7f
+0a
+f1
+98
+7b
+01
+7a
+4c
+79
+f2
+7d
+02
+7c
+00
+7f
+be
+7e
+7f
+12
+20
+ca
+90
+4c
+f2
+e0
+f4
+70
+19
+a3
+e0
+f4
+70
+14
+90
+4c
+93
+e0
+a3
+e0
+90
+4c
+f2
+f0
+90
+4c
+91
+e0
+a3
+e0
+90
+4c
+f3
+f0
+02
+20
+04
+12
+30
+3a
+12
+18
+f4
+e4
+90
+4c
+fc
+f0
+22
+90
+4c
+c3
+e0
+d3
+94
+00
+74
+80
+94
+80
+50
+02
+e1
+8e
+e0
+94
+04
+74
+80
+94
+80
+40
+02
+e1
+8e
+e0
+75
+f0
+1f
+a4
+24
+cf
+f9
+74
+4d
+35
+f0
+fa
+7b
+01
+7d
+1f
+7c
+00
+12
+35
+45
+7f
+c8
+f1
+98
+c2
+01
+7f
+ff
+31
+b2
+7b
+01
+7a
+4d
+79
+ee
+7d
+5d
+7c
+00
+7f
+60
+7e
+7f
+12
+1c
+84
+d2
+01
+7f
+ff
+21
+b2
+90
+4d
+d6
+e0
+ff
+02
+07
+37
+90
+4c
+c5
+74
+03
+f0
+e4
+a3
+f0
+f1
+e0
+e4
+90
+4c
+ee
+f0
+90
+4c
+eb
+f0
+90
+4c
+c0
+74
+fe
+f0
+90
+4c
+c3
+f0
+90
+4d
+46
+74
+03
+f0
+90
+4d
+e6
+74
+0a
+f0
+90
+4f
+06
+e0
+64
+31
+70
+3a
+90
+4d
+e7
+f0
+90
+4e
+55
+f0
+90
+4c
+c1
+f0
+90
+4c
+e5
+74
+0a
+f0
+90
+4b
+eb
+e0
+64
+0f
+70
+14
+a3
+e0
+64
+0f
+70
+0e
+a3
+e0
+64
+0f
+70
+08
+a3
+e0
+64
+0f
+70
+02
+e1
+8e
+90
+4c
+bf
+74
+02
+f0
+12
+1b
+ea
+02
+1d
+33
+90
+4c
+e5
+e0
+60
+02
+e1
+8e
+22
+e4
+90
+4c
+c5
+f0
+a3
+f0
+90
+4c
+e3
+f0
+a3
+f0
+90
+4c
+eb
+04
+f0
+90
+4c
+ed
+e0
+60
+09
+f1
+e0
+90
+4c
+ed
+e0
+ff
+41
+c6
+90
+4c
+ec
+e0
+64
+01
+70
+03
+f0
+e1
+8f
+90
+4c
+f0
+e0
+70
+02
+e1
+8e
+90
+4d
+d6
+e0
+ff
+02
+07
+37
+90
+4c
+c7
+74
+03
+f0
+a3
+74
+01
+f0
+e4
+a3
+f0
+a3
+f0
+7f
+0e
+91
+9d
+7f
+02
+91
+9d
+90
+4c
+e9
+e0
+60
+34
+e4
+90
+4d
+e7
+f0
+90
+4c
+c1
+f0
+90
+4c
+c3
+e0
+75
+f0
+1f
+a4
+24
+ec
+f5
+82
+e4
+34
+4d
+f5
+83
+e4
+f0
+90
+4d
+e7
+e0
+ff
+90
+4c
+c3
+e0
+75
+f0
+1f
+a4
+24
+ed
+f5
+82
+e4
+34
+4d
+f5
+83
+ef
+f0
+90
+4d
+e5
+e0
+70
+06
+90
+4d
+d4
+74
+14
+f0
+90
+4c
+e5
+e0
+70
+02
+f1
+c8
+e4
+90
+4c
+e9
+f0
+90
+4c
+e3
+f0
+a3
+f0
+22
+90
+4c
+c7
+74
+04
+f0
+e4
+a3
+f0
+f1
+e0
+e4
+90
+4c
+eb
+f0
+90
+4d
+db
+74
+0a
+f0
+90
+4c
+c3
+e0
+90
+4c
+c0
+f0
+90
+4c
+bf
+74
+03
+f0
+22
+90
+4c
+c3
+e0
+14
+fd
+7f
+01
+12
+07
+fe
+90
+4c
+c3
+e0
+90
+4c
+c0
+f0
+90
+4c
+bf
+74
+03
+f0
+22
+90
+4d
+39
+12
+05
+82
+00
+00
+00
+00
+e4
+90
+4d
+d7
+f0
+90
+4d
+de
+04
+f0
+90
+4c
+c8
+04
+f0
+90
+4c
+c7
+04
+f0
+22
+90
+4c
+c7
+e0
+90
+4c
+cb
+f0
+e4
+90
+4c
+c7
+f0
+a3
+f0
+90
+4c
+eb
+04
+f0
+e4
+90
+4d
+3d
+f0
+90
+4c
+ec
+e0
+64
+01
+70
+03
+f0
+80
+21
+90
+4c
+ed
+e0
+60
+03
+ff
+41
+c6
+90
+4c
+f0
+e0
+60
+08
+90
+4d
+d6
+e0
+ff
+02
+07
+37
+f1
+8f
+e4
+90
+4c
+e3
+f0
+a3
+f0
+22
+e4
+90
+4d
+38
+f0
+7f
+19
+81
+9d
+ef
+d3
+94
+00
+40
+11
+e4
+fd
+fc
+0d
+bd
+00
+01
+0c
+bc
+04
+f8
+bd
+a6
+f5
+1f
+80
+e9
+22
+d2
+01
+7f
+1d
+31
+b2
+d2
+01
+7f
+1f
+31
+b2
+d2
+01
+7f
+1e
+31
+b2
+d2
+01
+7f
+14
+21
+b2
+c2
+01
+7f
+1f
+31
+b2
+c2
+01
+7f
+1e
+31
+b2
+c2
+01
+7f
+14
+31
+b2
+c2
+01
+7f
+1d
+21
+b2
+e4
+90
+4c
+f0
+f0
+90
+4d
+e5
+f0
+22
+12
+30
+3a
+12
+18
+f4
+c2
+06
+7f
+1d
+12
+18
+08
+c2
+06
+7f
+1f
+12
+18
+08
+c2
+06
+7f
+1e
+11
+08
+c2
+06
+7f
+14
+ac
+07
+ec
+f4
+60
+15
+af
+04
+d2
+04
+11
+35
+af
+04
+a2
+06
+92
+01
+12
+11
+b2
+af
+04
+c2
+02
+11
+24
+22
+ef
+f4
+60
+0c
+7b
+01
+7a
+80
+79
+78
+a2
+02
+92
+00
+11
+75
+22
+ef
+f4
+60
+0c
+7b
+01
+7a
+80
+79
+70
+a2
+04
+92
+00
+11
+75
+22
+ac
+07
+ec
+f4
+60
+17
+af
+04
+a2
+05
+92
+03
+11
+64
+af
+04
+a2
+05
+b3
+92
+02
+11
+24
+af
+04
+c2
+04
+11
+35
+22
+ef
+f4
+60
+0c
+7b
+01
+7a
+80
+79
+7c
+a2
+03
+92
+00
+11
+75
+22
+90
+4e
+f5
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+e4
+fe
+fd
+ef
+54
+07
+fe
+ef
+13
+13
+13
+54
+03
+fd
+30
+00
+22
+90
+4e
+f5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+2d
+f9
+e4
+3a
+fa
+12
+03
+b6
+ff
+74
+01
+a8
+06
+08
+80
+02
+c3
+33
+d8
+fc
+4f
+02
+03
+fc
+90
+4e
+f5
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+2d
+f9
+e4
+3a
+fa
+12
+03
+b6
+ff
+74
+01
+a8
+06
+08
+80
+02
+c3
+33
+d8
+fc
+f4
+5f
+02
+03
+fc
+e4
+90
+4f
+04
+f0
+f0
+90
+4f
+04
+e0
+90
+06
+81
+93
+ff
+60
+0c
+c2
+05
+11
+46
+90
+4f
+04
+e0
+04
+f0
+80
+e9
+22
+90
+80
+80
+e4
+f0
+a3
+f0
+a3
+f0
+31
+01
+80
+d5
+e4
+90
+4f
+03
+f0
+f0
+90
+4f
+03
+e0
+ff
+c3
+94
+08
+74
+80
+94
+80
+50
+0c
+c2
+05
+11
+46
+90
+4f
+03
+e0
+04
+f0
+80
+e6
+22
+e4
+90
+4f
+00
+f0
+90
+4c
+c8
+e0
+64
+02
+70
+06
+90
+4f
+00
+e0
+ff
+22
+90
+47
+f5
+e0
+30
+e3
+06
+90
+4f
+00
+e0
+ff
+22
+90
+4c
+ee
+e0
+60
+06
+90
+4f
+00
+e0
+ff
+22
+90
+4c
+c7
+e0
+70
+4a
+90
+4c
+c5
+e0
+64
+03
+60
+42
+90
+4c
+ef
+e0
+70
+46
+74
+0a
+f0
+a3
+e0
+70
+3f
+90
+4d
+eb
+e0
+64
+02
+70
+37
+90
+4c
+c3
+e0
+ff
+7e
+00
+c3
+94
+01
+74
+80
+94
+80
+40
+10
+d3
+ef
+94
+03
+74
+80
+94
+80
+50
+06
+e0
+12
+12
+c6
+80
+17
+7f
+09
+12
+12
+c6
+90
+4f
+00
+74
+01
+f0
+80
+0a
+e4
+90
+4c
+eb
+f0
+90
+4f
+00
+04
+f0
+90
+4f
+00
+e0
+ff
+22
+90
+4c
+c7
+e0
+64
+02
+70
+08
+7f
+0e
+12
+14
+9d
+7f
+01
+22
+7f
+00
+22
+90
+4c
+c7
+e0
+ff
+64
+04
+60
+05
+ef
+64
+03
+70
+08
+7f
+11
+12
+14
+9d
+7f
+01
+22
+90
+4c
+c5
+e0
+ff
+64
+03
+60
+05
+ef
+64
+02
+70
+08
+7f
+22
+12
+14
+9d
+7f
+01
+22
+7f
+00
+22
+90
+4c
+ce
+e0
+30
+e1
+46
+90
+4c
+d0
+e0
+c3
+94
+fa
+74
+80
+94
+80
+50
+03
+e0
+04
+f0
+90
+4c
+d0
+e0
+64
+b4
+70
+3b
+90
+4d
+e3
+e0
+04
+f0
+e0
+d3
+94
+02
+74
+80
+94
+80
+50
+07
+e4
+90
+4c
+d0
+f0
+80
+24
+90
+4d
+e3
+e0
+64
+03
+70
+1c
+90
+4d
+dc
+04
+f0
+e4
+90
+4c
+d0
+f0
+12
+17
+8f
+80
+0d
+e4
+90
+4d
+e3
+f0
+90
+4d
+dc
+f0
+90
+4c
+d0
+f0
+90
+4c
+ce
+e0
+30
+e4
+3e
+90
+4c
+ea
+74
+0a
+f0
+90
+4c
+d1
+e0
+c3
+94
+fa
+74
+80
+94
+80
+50
+03
+e0
+04
+f0
+90
+4c
+d1
+e0
+64
+06
+70
+4a
+90
+4c
+c3
+e0
+60
+04
+64
+fe
+70
+40
+e4
+90
+4c
+cd
+f0
+31
+c1
+7f
+0a
+12
+17
+98
+7f
+0a
+12
+12
+c6
+12
+17
+f0
+80
+2a
+90
+4c
+cd
+e0
+60
+1f
+e4
+f0
+7f
+0d
+12
+12
+c6
+90
+4c
+eb
+74
+01
+f0
+90
+4c
+c3
+e0
+90
+4c
+c0
+f0
+90
+4c
+bf
+74
+01
+f0
+71
+ea
+b1
+33
+e4
+90
+4c
+d1
+f0
+90
+4c
+ce
+e0
+30
+e3
+4d
+90
+4c
+ea
+74
+0a
+f0
+90
+4c
+d2
+e0
+c3
+94
+fa
+74
+80
+94
+80
+50
+03
+e0
+04
+f0
+90
+4c
+d2
+e0
+64
+06
+70
+65
+90
+4c
+e9
+74
+f0
+f0
+e4
+90
+4c
+ee
+f0
+7f
+05
+12
+12
+c6
+12
+17
+f0
+e4
+90
+4c
+cc
+f0
+90
+4c
+eb
+04
+f0
+90
+4c
+c0
+e0
+90
+4c
+c4
+f0
+90
+4c
+c3
+e0
+90
+4c
+c0
+f0
+80
+36
+90
+4c
+cc
+e0
+60
+2b
+e4
+f0
+90
+4c
+c3
+e0
+ff
+90
+4c
+c0
+e0
+6f
+60
+1d
+90
+4c
+eb
+74
+01
+f0
+12
+17
+f0
+90
+4c
+c3
+e0
+90
+4c
+c0
+f0
+90
+4c
+bf
+74
+01
+f0
+31
+c1
+71
+ea
+b1
+33
+e4
+90
+4c
+d2
+f0
+90
+4c
+ce
+e0
+20
+e5
+02
+61
+e4
+a3
+e0
+c3
+94
+fa
+74
+80
+94
+80
+50
+03
+e0
+04
+f0
+90
+4c
+cf
+e0
+64
+06
+60
+02
+61
+e9
+90
+4d
+e8
+e0
+64
+14
+70
+08
+90
+4c
+c1
+74
+02
+f0
+80
+21
+90
+4d
+e8
+e0
+64
+12
+70
+07
+90
+4c
+c1
+04
+f0
+80
+12
+90
+4d
+e8
+e0
+64
+1a
+60
+05
+e0
+64
+08
+70
+05
+e4
+90
+4c
+c1
+f0
+90
+4c
+e5
+74
+0a
+f0
+90
+4c
+c3
+e0
+ff
+7e
+00
+60
+04
+64
+fe
+70
+07
+90
+4c
+bf
+74
+02
+f0
+22
+d3
+ef
+94
+03
+ee
+64
+80
+94
+80
+50
+2f
+c3
+ef
+94
+01
+ee
+64
+80
+94
+80
+40
+24
+90
+4c
+c1
+e0
+ff
+90
+4c
+c3
+e0
+75
+f0
+1f
+a4
+24
+ec
+f5
+82
+e4
+34
+4d
+f5
+83
+ef
+f0
+90
+4c
+bf
+74
+03
+f0
+22
+e4
+90
+4c
+cf
+f0
+22
+90
+4c
+bf
+e0
+70
+02
+81
+83
+64
+01
+60
+05
+7f
+c8
+12
+17
+98
+c2
+01
+7f
+ff
+12
+11
+b2
+90
+4c
+bf
+e0
+64
+02
+70
+31
+7b
+01
+7a
+4c
+79
+00
+7d
+04
+fc
+7f
+52
+7e
+7f
+91
+84
+7b
+01
+7a
+4c
+79
+c1
+7d
+01
+7c
+00
+7f
+57
+7e
+7f
+91
+84
+7b
+01
+7a
+4d
+79
+e7
+7d
+01
+7c
+00
+7f
+56
+7e
+7f
+91
+84
+80
+17
+90
+4c
+bf
+e0
+64
+03
+70
+0f
+7b
+01
+7a
+4d
+79
+ee
+7d
+5d
+fc
+7f
+60
+7e
+7f
+91
+84
+7b
+01
+7a
+4c
+79
+c0
+7d
+01
+7c
+00
+7f
+bd
+7e
+7f
+91
+84
+7b
+01
+7a
+4c
+79
+f2
+7d
+02
+7c
+00
+7f
+be
+7e
+7f
+91
+84
+d2
+01
+7f
+ff
+12
+11
+b2
+7f
+0a
+12
+17
+98
+e4
+90
+4c
+bf
+f0
+22
+90
+4e
+93
+ee
+f0
+a3
+ef
+f0
+a3
+ec
+f0
+a3
+ed
+f0
+a3
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+90
+4e
+95
+e0
+70
+02
+a3
+e0
+70
+02
+a1
+32
+90
+4e
+93
+e0
+fe
+a3
+e0
+ff
+44
+0f
+24
+01
+fd
+e4
+3e
+fc
+c3
+ed
+9f
+ff
+ec
+9e
+fe
+90
+4e
+9a
+f0
+a3
+ef
+f0
+90
+4e
+95
+e0
+fc
+a3
+e0
+fd
+d3
+9f
+ec
+9e
+40
+0a
+90
+4e
+9a
+e0
+fe
+a3
+e0
+ff
+80
+04
+ae
+04
+af
+05
+90
+4e
+9a
+ee
+f0
+fc
+a3
+ef
+f0
+fd
+c3
+90
+4e
+96
+e0
+9d
+f0
+90
+4e
+95
+e0
+9c
+f0
+90
+4e
+93
+e0
+fe
+a3
+e0
+ff
+90
+4e
+97
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+21
+82
+7f
+0a
+12
+17
+98
+90
+4e
+9a
+e0
+fe
+a3
+e0
+ff
+90
+4e
+98
+ee
+8f
+f0
+12
+04
+0e
+90
+4e
+94
+e0
+2f
+f0
+90
+4e
+93
+e0
+3e
+f0
+81
+9b
+22
+90
+80
+10
+74
+01
+f0
+80
+fe
+22
+f1
+93
+12
+32
+fb
+d1
+d0
+71
+ea
+12
+11
+c4
+90
+4d
+7d
+e0
+60
+03
+12
+24
+33
+90
+0b
+7e
+e0
+14
+60
+0d
+24
+fe
+70
+e2
+b1
+8b
+12
+17
+f0
+d1
+c2
+80
+fe
+90
+4c
+ea
+e0
+70
+12
+90
+4c
+ec
+e0
+70
+0c
+90
+4c
+e5
+e0
+70
+06
+90
+4c
+f8
+e0
+60
+05
+12
+35
+32
+80
+bc
+b1
+8b
+d1
+c2
+80
+b6
+80
+b4
+22
+e4
+ff
+90
+4f
+05
+f0
+fe
+fd
+ef
+90
+06
+81
+93
+60
+48
+ef
+93
+fd
+13
+13
+13
+54
+1f
+fe
+ed
+54
+07
+fd
+f8
+74
+01
+08
+80
+02
+c3
+33
+d8
+fc
+fd
+ee
+24
+78
+fb
+e4
+34
+80
+8b
+82
+f5
+83
+e0
+fc
+ed
+f4
+fb
+ec
+5b
+f0
+ee
+24
+70
+f5
+82
+e4
+34
+80
+f5
+83
+e0
+4d
+f0
+ee
+24
+74
+f5
+82
+e4
+34
+80
+f5
+83
+e0
+5b
+f0
+0f
+80
+b1
+12
+35
+ce
+90
+81
+1c
+e0
+90
+4f
+05
+f0
+90
+4d
+dc
+e0
+60
+20
+e4
+ff
+d1
+23
+7f
+01
+d1
+23
+7f
+02
+d1
+23
+7f
+03
+d1
+23
+7f
+04
+d1
+23
+7f
+05
+d1
+23
+7f
+06
+d1
+23
+7f
+07
+80
+10
+90
+4f
+05
+e0
+ff
+90
+00
+a3
+f0
+ef
+f4
+90
+00
+a7
+f0
+22
+90
+4f
+09
+ef
+f0
+f1
+a6
+92
+08
+90
+4f
+09
+e0
+ff
+a2
+08
+b3
+92
+07
+ef
+f4
+70
+02
+c1
+c1
+ef
+54
+07
+fe
+ef
+13
+13
+13
+54
+03
+ff
+30
+07
+43
+24
+a3
+f5
+82
+e4
+34
+00
+f5
+83
+c0
+83
+c0
+82
+e0
+fd
+74
+01
+a8
+06
+08
+80
+02
+c3
+33
+d8
+fc
+f4
+5d
+d0
+82
+d0
+83
+f0
+74
+a7
+2f
+f5
+82
+e4
+34
+00
+f5
+83
+c0
+83
+c0
+82
+e0
+ff
+74
+01
+a8
+06
+08
+80
+02
+c3
+33
+d8
+fc
+4f
+d0
+82
+d0
+83
+f0
+22
+74
+a3
+2f
+f5
+82
+e4
+34
+00
+f5
+83
+c0
+83
+c0
+82
+e0
+fd
+74
+01
+a8
+06
+08
+80
+02
+c3
+33
+d8
+fc
+fc
+4d
+d0
+82
+d0
+83
+f0
+74
+a7
+2f
+f5
+82
+e4
+34
+00
+f5
+83
+e0
+ff
+ec
+f4
+fe
+ef
+5e
+f0
+22
+e4
+90
+0b
+7f
+f0
+90
+0b
+7e
+f0
+7f
+01
+02
+17
+98
+90
+4c
+f4
+e0
+ff
+60
+09
+64
+03
+60
+05
+ef
+64
+05
+70
+03
+02
+26
+af
+90
+4c
+f4
+e0
+64
+01
+70
+0e
+a3
+e0
+ff
+e4
+fd
+f1
+57
+90
+4c
+f4
+74
+02
+f0
+22
+90
+4c
+f4
+e0
+64
+02
+70
+0b
+74
+03
+f0
+a3
+e0
+ff
+a3
+e0
+fd
+80
+4b
+90
+4c
+f4
+e0
+64
+04
+70
+26
+90
+4c
+f6
+f0
+90
+4c
+f5
+e0
+ff
+e4
+fd
+f1
+57
+e4
+90
+4c
+f5
+f0
+90
+4c
+f8
+e0
+70
+07
+90
+4c
+f4
+74
+06
+f0
+22
+90
+4c
+f4
+74
+05
+f0
+22
+90
+4c
+f4
+e0
+64
+06
+70
+14
+90
+4c
+f6
+f0
+90
+4c
+f5
+f0
+a3
+e0
+fd
+e4
+ff
+f1
+57
+e4
+90
+4c
+f4
+f0
+22
+90
+4e
+f8
+ef
+f0
+a3
+ed
+f0
+7b
+01
+7a
+48
+79
+00
+7d
+09
+7c
+00
+12
+0d
+fa
+90
+48
+00
+74
+01
+f0
+a3
+e0
+ff
+90
+4e
+f8
+e0
+fe
+ef
+4e
+90
+48
+01
+f0
+90
+4e
+f9
+e0
+90
+48
+03
+f0
+7b
+01
+7a
+48
+79
+00
+7d
+09
+02
+0e
+da
+7b
+01
+7a
+4e
+79
+56
+78
+68
+7c
+4e
+7d
+01
+7e
+00
+7f
+12
+02
+03
+90
+7b
+01
+7a
+81
+79
+1c
+ad
+07
+e4
+90
+4f
+08
+f0
+fe
+ef
+54
+07
+f0
+ef
+13
+13
+13
+54
+03
+fe
+f5
+82
+75
+83
+00
+12
+03
+cf
+fd
+33
+95
+e0
+fc
+90
+4f
+08
+e0
+ff
+74
+01
+7e
+00
+a8
+07
+08
+80
+05
+c3
+33
+ce
+33
+ce
+d8
+f9
+ff
+ee
+5c
+fe
+ef
+5d
+4e
+24
+ff
+22
+a1
+3c
+90
+4c
+c0
+e0
+ff
+64
+fe
+60
+03
+ef
+70
+08
+7f
+22
+12
+14
+9d
+7f
+01
+22
+7f
+00
+22
+90
+4d
+eb
+74
+02
+f0
+7b
+01
+7a
+4d
+79
+ee
+7d
+5d
+7c
+00
+7f
+60
+7e
+7f
+11
+ca
+7f
+0a
+12
+17
+98
+7b
+01
+7a
+4c
+79
+00
+7d
+04
+7c
+00
+7f
+52
+7e
+7f
+11
+ca
+7f
+0a
+12
+17
+98
+7b
+01
+7a
+4d
+79
+e7
+7d
+01
+7c
+00
+7f
+56
+7e
+7f
+11
+ca
+7f
+0a
+12
+17
+98
+7b
+01
+7a
+4c
+79
+c1
+7d
+01
+7c
+00
+7f
+57
+7e
+7f
+11
+ca
+7f
+0a
+12
+17
+98
+90
+4c
+c3
+e0
+ff
+7e
+00
+d3
+94
+03
+74
+80
+94
+80
+50
+38
+c3
+ef
+94
+01
+74
+80
+94
+80
+40
+2e
+e0
+75
+f0
+1f
+a4
+24
+ec
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+90
+4c
+c1
+f0
+90
+4c
+c3
+e0
+75
+f0
+1f
+a4
+24
+ed
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+90
+4d
+e7
+f0
+12
+12
+c6
+80
+05
+7f
+08
+12
+12
+c6
+90
+4d
+e7
+e0
+d3
+94
+01
+74
+80
+94
+80
+40
+02
+e4
+f0
+90
+4c
+c1
+e0
+d3
+94
+02
+74
+80
+94
+80
+40
+02
+e4
+f0
+22
+90
+4e
+cf
+ec
+f0
+a3
+ed
+f0
+a3
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+90
+80
+98
+74
+04
+f0
+a3
+e4
+f0
+90
+0c
+af
+74
+a0
+f0
+a3
+ee
+f0
+a3
+ef
+f0
+90
+0c
+b2
+74
+a1
+f0
+7a
+0c
+79
+af
+7e
+0c
+7f
+af
+74
+af
+fc
+74
+0c
+ff
+ec
+fe
+ef
+90
+80
+9a
+ee
+f0
+a3
+ef
+f0
+90
+4e
+cf
+e0
+fc
+a3
+e0
+fa
+ec
+ff
+ea
+fe
+ef
+90
+80
+9e
+ee
+f0
+a3
+ef
+f0
+7a
+0b
+79
+83
+7e
+0b
+7f
+83
+74
+83
+fc
+74
+0b
+ff
+ec
+fe
+ef
+90
+80
+9c
+ee
+f0
+a3
+ef
+f0
+90
+80
+90
+74
+02
+f0
+90
+80
+9c
+a3
+e0
+20
+e7
+07
+90
+80
+90
+e0
+44
+01
+f0
+90
+80
+06
+e0
+44
+04
+f0
+31
+7a
+90
+4e
+d1
+e0
+a3
+e0
+fa
+a3
+e0
+ae
+02
+ff
+7b
+01
+7a
+0b
+79
+83
+90
+4e
+cf
+e0
+a3
+e0
+90
+4e
+c4
+f0
+02
+08
+78
+90
+81
+2c
+e0
+30
+e5
+f9
+22
+90
+4e
+b2
+ee
+f0
+a3
+ef
+f0
+90
+4e
+b6
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+90
+4e
+b4
+ec
+f0
+a3
+ed
+f0
+a3
+e0
+f9
+a3
+e0
+fa
+a3
+e0
+90
+4e
+9f
+c9
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+a3
+ec
+f0
+a3
+ed
+f0
+7b
+01
+7a
+0b
+79
+86
+91
+62
+90
+0b
+83
+74
+a0
+f0
+90
+4e
+b2
+e0
+ff
+a3
+e0
+90
+0b
+84
+cf
+f0
+a3
+ef
+f0
+90
+4e
+b5
+e0
+24
+03
+fd
+90
+4e
+b4
+e0
+34
+00
+fc
+ed
+fa
+ec
+ff
+ea
+fe
+ef
+90
+80
+98
+ee
+f0
+a3
+ef
+f0
+7a
+0b
+79
+83
+7e
+0b
+7f
+83
+74
+83
+fc
+74
+0b
+ff
+ec
+fe
+ef
+a3
+ee
+f0
+a3
+ef
+f0
+90
+80
+9e
+e4
+f0
+a3
+f0
+90
+80
+90
+04
+f0
+90
+80
+06
+e0
+44
+04
+f0
+21
+7a
+7b
+01
+7a
+4c
+79
+f2
+7d
+02
+7c
+00
+7f
+be
+7e
+7f
+11
+ca
+90
+4c
+f2
+e0
+04
+f0
+a3
+e0
+04
+f0
+90
+4c
+f2
+e0
+90
+44
+fa
+f0
+90
+4c
+f3
+e0
+90
+44
+fb
+f0
+90
+4d
+d0
+e0
+90
+44
+fc
+f0
+90
+4d
+d1
+e0
+90
+44
+fd
+f0
+90
+4d
+d2
+e0
+90
+44
+fe
+f0
+22
+90
+4d
+ec
+e0
+60
+39
+e0
+14
+f0
+e0
+70
+33
+90
+4c
+ed
+e0
+64
+05
+70
+2b
+90
+47
+f5
+e0
+20
+e3
+24
+e4
+90
+4d
+d4
+f0
+90
+4c
+e9
+74
+f0
+f0
+e4
+90
+4c
+ee
+f0
+90
+4e
+55
+f0
+90
+4d
+d3
+f0
+51
+1c
+7f
+0d
+12
+14
+9d
+e4
+90
+4c
+ed
+f0
+22
+12
+10
+e9
+90
+4c
+e4
+e0
+04
+f0
+70
+06
+90
+4c
+e3
+e0
+04
+f0
+71
+02
+71
+34
+12
+19
+f0
+51
+5f
+90
+4c
+e9
+e0
+60
+24
+e4
+90
+4c
+e3
+f0
+a3
+f0
+90
+4c
+e9
+e0
+14
+f0
+e0
+70
+14
+90
+4c
+c4
+e0
+90
+4c
+c3
+f0
+90
+4c
+c0
+f0
+7f
+0d
+12
+12
+c6
+12
+17
+8f
+90
+4c
+ee
+e0
+60
+18
+e4
+90
+4c
+e3
+f0
+a3
+f0
+90
+4c
+ee
+e0
+14
+f0
+e0
+70
+08
+7f
+0a
+12
+17
+98
+12
+17
+8f
+22
+e4
+ff
+24
+bc
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+70
+12
+90
+4d
+06
+e0
+60
+0c
+14
+f0
+e0
+70
+05
+90
+4c
+d5
+f0
+22
+71
+23
+22
+90
+4c
+d3
+e0
+60
+0a
+14
+f0
+e0
+70
+05
+74
+05
+f0
+91
+a6
+22
+90
+4d
+db
+e0
+60
+0f
+e0
+14
+f0
+e0
+70
+09
+90
+41
+31
+04
+f0
+90
+4d
+da
+f0
+90
+4c
+c7
+e0
+ff
+64
+04
+70
+53
+ef
+64
+04
+70
+34
+90
+4d
+da
+e0
+70
+10
+90
+4c
+e3
+e0
+fe
+a3
+e0
+ff
+4e
+60
+23
+ef
+54
+1f
+70
+1e
+e4
+90
+4d
+da
+f0
+90
+4e
+4c
+74
+04
+f0
+90
+4c
+f9
+e0
+90
+4e
+4d
+f0
+7b
+01
+7a
+4e
+79
+4c
+7d
+02
+12
+0e
+da
+90
+4c
+e3
+e0
+64
+38
+70
+04
+a3
+e0
+64
+40
+60
+02
+81
+32
+12
+19
+c1
+90
+4c
+ec
+74
+01
+f0
+22
+90
+4c
+c5
+e0
+64
+03
+70
+4d
+90
+4c
+e3
+e0
+fe
+a3
+e0
+ff
+64
+0a
+4e
+70
+08
+90
+4d
+46
+e0
+60
+02
+e4
+f0
+ef
+54
+1f
+64
+10
+70
+20
+7b
+01
+7a
+48
+79
+00
+7d
+09
+fc
+12
+0d
+fa
+e4
+90
+4e
+4b
+f0
+90
+48
+00
+04
+f0
+fb
+7a
+48
+79
+00
+7d
+09
+12
+0e
+da
+c3
+90
+4c
+e4
+e0
+94
+b0
+90
+4c
+e3
+e0
+94
+04
+40
+3a
+80
+39
+90
+4c
+c5
+e0
+64
+01
+70
+11
+c3
+90
+4c
+e4
+e0
+94
+78
+90
+4c
+e3
+e0
+94
+00
+40
+21
+80
+20
+c3
+90
+4c
+e4
+e0
+94
+14
+90
+4c
+e3
+e0
+94
+00
+40
+10
+90
+4d
+e5
+e0
+60
+07
+e4
+f0
+7f
+0e
+12
+14
+9d
+12
+17
+8f
+22
+12
+17
+f0
+90
+4b
+ef
+74
+ff
+f0
+90
+4c
+fc
+74
+01
+f0
+e4
+90
+4c
+e6
+f0
+a3
+f0
+a3
+f0
+90
+4c
+b7
+74
+f0
+f0
+90
+4d
+e0
+f0
+90
+4d
+40
+74
+ff
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+22
+90
+4e
+9c
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+90
+4e
+a2
+74
+ff
+f5
+f0
+12
+04
+24
+45
+f0
+60
+2a
+90
+4e
+9f
+e0
+fb
+a3
+e4
+75
+f0
+01
+12
+04
+24
+a9
+f0
+fa
+12
+03
+b6
+ff
+90
+4e
+9c
+e0
+fb
+a3
+e4
+75
+f0
+01
+12
+04
+24
+a9
+f0
+fa
+ef
+12
+03
+fc
+80
+c8
+22
+90
+4e
+cb
+12
+05
+82
+00
+00
+00
+00
+90
+4c
+95
+e0
+70
+02
+a3
+e0
+70
+02
+c1
+70
+90
+4c
+95
+e0
+fe
+a3
+e0
+ff
+90
+4c
+d4
+e0
+fd
+04
+f0
+ed
+25
+e0
+24
+d6
+f5
+82
+e4
+34
+4c
+f5
+83
+ee
+f0
+a3
+ef
+f0
+90
+4c
+d4
+e0
+c3
+94
+04
+74
+80
+94
+80
+40
+02
+e4
+f0
+e4
+90
+4e
+ca
+f0
+90
+4e
+ca
+e0
+c3
+94
+04
+74
+80
+94
+80
+50
+3d
+a3
+e0
+f8
+a3
+e0
+f9
+a3
+e0
+fa
+a3
+e0
+fb
+90
+4e
+ca
+e0
+25
+e0
+24
+d6
+f5
+82
+e4
+34
+4c
+f5
+83
+e0
+fe
+a3
+e0
+ff
+e4
+fc
+fd
+eb
+2f
+ff
+ea
+3e
+fe
+ed
+39
+fd
+ec
+38
+fc
+90
+4e
+cb
+12
+05
+76
+90
+4e
+ca
+e0
+04
+f0
+80
+b6
+90
+4e
+cb
+e0
+fc
+a3
+e0
+fd
+a3
+e0
+fe
+a3
+e0
+ff
+e4
+7b
+04
+fa
+f9
+f8
+12
+04
+c5
+90
+4e
+cb
+12
+05
+76
+90
+4c
+e0
+e0
+fe
+a3
+e0
+ff
+e4
+fc
+fd
+90
+4e
+cb
+e0
+f8
+a3
+e0
+f9
+a3
+e0
+fa
+a3
+e0
+fb
+d3
+12
+05
+65
+50
+07
+e4
+90
+4c
+f9
+f0
+a1
+ff
+90
+4c
+fa
+e0
+fe
+a3
+e0
+ff
+e4
+fc
+fd
+90
+4e
+cb
+e0
+f8
+a3
+e0
+f9
+a3
+e0
+fa
+a3
+e0
+fb
+c3
+12
+05
+65
+40
+08
+90
+4c
+f9
+74
+64
+f0
+80
+5b
+90
+4c
+e0
+e0
+fe
+a3
+e0
+ff
+fb
+aa
+06
+e4
+90
+4e
+cb
+e0
+fc
+a3
+e0
+fd
+a3
+e0
+fe
+a3
+e0
+c3
+9b
+ff
+ee
+9a
+fe
+ed
+94
+00
+fd
+ec
+94
+00
+fc
+e4
+7b
+64
+fa
+f9
+f8
+12
+04
+3a
+c0
+06
+c0
+07
+90
+4c
+e0
+e0
+fe
+a3
+e0
+ff
+c3
+90
+4c
+fb
+e0
+9f
+ff
+90
+4c
+fa
+e0
+9e
+fe
+ab
+07
+fa
+e4
+f9
+f8
+d0
+07
+d0
+06
+12
+04
+c5
+90
+4c
+f9
+ef
+f0
+90
+4c
+e0
+e0
+fe
+a3
+e0
+ff
+c3
+90
+4c
+d7
+e0
+9f
+90
+4c
+d6
+e0
+9e
+50
+07
+90
+4c
+d5
+74
+02
+f0
+22
+90
+4c
+de
+e0
+fe
+a3
+e0
+ff
+e4
+fc
+fd
+90
+4e
+cb
+e0
+f8
+a3
+e0
+f9
+a3
+e0
+fa
+a3
+e0
+fb
+c3
+12
+05
+65
+50
+1c
+90
+4c
+d5
+74
+01
+f0
+90
+4c
+fc
+e0
+70
+2a
+90
+4d
+40
+f0
+a3
+74
+48
+f0
+a3
+74
+12
+f0
+e4
+a3
+f0
+22
+e4
+90
+4c
+d5
+f0
+90
+4c
+fc
+e0
+70
+0f
+90
+4d
+40
+f0
+a3
+74
+48
+f0
+a3
+74
+5d
+f0
+e4
+a3
+f0
+22
+90
+4d
+46
+e0
+60
+37
+90
+4d
+dd
+e0
+70
+31
+90
+4c
+c5
+e0
+64
+03
+70
+29
+7b
+01
+7a
+48
+79
+00
+7d
+09
+fc
+12
+0d
+fa
+e4
+90
+4e
+4b
+f0
+90
+48
+00
+04
+f0
+90
+4d
+46
+e0
+90
+48
+02
+f0
+7b
+01
+7a
+48
+79
+00
+7d
+09
+12
+0e
+da
+22
+90
+4e
+e0
+e4
+f0
+a3
+f0
+a3
+f0
+d1
+e3
+50
+26
+12
+2a
+cb
+90
+4e
+e0
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+4a
+70
+07
+90
+4c
+b6
+04
+f0
+80
+9d
+90
+4e
+e0
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+08
+bb
+22
+90
+4b
+9c
+e0
+fe
+a3
+e0
+ff
+90
+4b
+9a
+e0
+b5
+06
+07
+a3
+e0
+b5
+07
+02
+d3
+22
+c3
+22
+90
+4e
+e3
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+e4
+fd
+fc
+90
+4d
+e2
+e0
+64
+01
+60
+02
+e1
+ae
+7c
+05
+af
+04
+1c
+ef
+70
+03
+02
+28
+5d
+90
+4e
+e3
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+ec
+7e
+00
+29
+f9
+ee
+3a
+fa
+12
+03
+b6
+fd
+64
+13
+70
+36
+90
+4c
+ea
+74
+0a
+f0
+90
+4c
+ce
+e0
+44
+08
+f0
+54
+ef
+f0
+ed
+24
+ee
+ff
+90
+4c
+c3
+e0
+b5
+07
+08
+90
+4c
+c5
+e0
+64
+03
+70
+10
+90
+4c
+c3
+ef
+f0
+90
+4c
+cc
+74
+01
+f0
+e4
+90
+4c
+e5
+f0
+7f
+01
+22
+90
+4c
+ce
+e0
+54
+e7
+f0
+ed
+ff
+64
+14
+60
+0f
+ef
+64
+1a
+60
+0a
+ef
+64
+12
+60
+05
+ef
+64
+08
+70
+15
+90
+4c
+ea
+74
+0a
+f0
+90
+4d
+e8
+ed
+f0
+90
+4c
+ce
+e0
+44
+20
+f0
+7f
+01
+22
+90
+4c
+ce
+e0
+54
+df
+f0
+e1
+15
+90
+4e
+e3
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+90
+00
+01
+12
+03
+cf
+fd
+7c
+00
+64
+ef
+70
+2c
+90
+4c
+ea
+74
+0a
+f0
+90
+4c
+ce
+e0
+54
+f7
+f0
+44
+10
+f0
+90
+4c
+c3
+e0
+60
+13
+64
+fe
+60
+0f
+90
+4c
+cd
+74
+01
+f0
+e4
+90
+4c
+c3
+f0
+90
+4c
+e5
+f0
+7f
+01
+22
+ed
+64
+e9
+4c
+60
+15
+90
+4e
+e3
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+90
+00
+01
+12
+03
+cf
+64
+ea
+70
+46
+90
+4c
+ea
+74
+0a
+f0
+90
+4c
+ce
+e0
+44
+08
+f0
+54
+ef
+f0
+90
+4e
+e3
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+90
+00
+01
+12
+03
+cf
+24
+18
+ff
+90
+4c
+c3
+e0
+b5
+07
+08
+90
+4c
+c5
+e0
+64
+03
+70
+10
+90
+4c
+c3
+ef
+f0
+90
+4c
+cc
+74
+01
+f0
+e4
+90
+4c
+e5
+f0
+7f
+01
+22
+90
+4c
+ce
+e0
+54
+e7
+f0
+54
+df
+f0
+7f
+00
+22
+90
+4c
+f5
+ed
+f0
+a3
+eb
+f0
+ef
+30
+e0
+13
+90
+4c
+f4
+e0
+64
+03
+70
+04
+74
+02
+f0
+22
+90
+4c
+f4
+74
+01
+f0
+22
+90
+4c
+f4
+74
+04
+f0
+22
+ae
+05
+ac
+07
+e4
+90
+4f
+02
+f0
+ec
+30
+e0
+05
+e4
+90
+4c
+f8
+f0
+90
+4f
+02
+ee
+f0
+90
+4c
+c1
+e0
+ff
+60
+38
+ee
+fb
+7a
+00
+64
+e6
+70
+08
+90
+4f
+02
+74
+e7
+f0
+80
+28
+eb
+64
+e4
+4a
+70
+08
+90
+4f
+02
+74
+e6
+f0
+80
+1a
+eb
+64
+e3
+4a
+70
+08
+90
+4f
+02
+74
+e2
+f0
+80
+0c
+eb
+64
+e2
+4a
+70
+06
+90
+4f
+02
+74
+e3
+f0
+ef
+70
+12
+ee
+64
+da
+70
+0d
+af
+04
+7b
+0f
+7d
+08
+11
+60
+e4
+90
+4f
+02
+f0
+90
+4d
+e2
+e0
+64
+01
+60
+02
+21
+ab
+ee
+fb
+7a
+00
+64
+4a
+70
+08
+90
+4f
+02
+74
+46
+f0
+21
+ab
+eb
+64
+4d
+4a
+70
+08
+90
+4f
+02
+74
+48
+f0
+21
+ab
+eb
+64
+51
+4a
+70
+08
+90
+4f
+02
+74
+d7
+f0
+21
+ab
+eb
+64
+28
+4a
+70
+08
+90
+4f
+02
+74
+47
+f0
+80
+76
+eb
+64
+2a
+4a
+70
+08
+90
+4f
+02
+74
+da
+f0
+80
+68
+eb
+64
+29
+4a
+70
+62
+ec
+30
+e0
+59
+90
+4d
+e7
+e0
+60
+04
+e4
+f0
+80
+06
+90
+4d
+e7
+74
+01
+f0
+90
+4c
+c3
+e0
+fb
+7a
+00
+60
+04
+64
+fe
+70
+08
+90
+4c
+bf
+74
+02
+f0
+80
+34
+d3
+eb
+94
+03
+ea
+64
+80
+94
+80
+50
+29
+c3
+eb
+94
+01
+ea
+64
+80
+94
+80
+40
+1e
+90
+4d
+e7
+e0
+ff
+90
+4c
+c3
+e0
+75
+f0
+1f
+a4
+24
+ed
+f5
+82
+e4
+34
+4d
+f5
+83
+ef
+f0
+90
+4c
+bf
+74
+03
+f0
+e4
+90
+4f
+02
+f0
+90
+4e
+55
+e0
+60
+02
+41
+c5
+90
+4d
+e2
+e0
+70
+06
+90
+4d
+e7
+e0
+60
+14
+90
+4d
+e2
+e0
+64
+01
+60
+02
+41
+c5
+90
+4d
+e7
+e0
+64
+01
+60
+02
+41
+c5
+ee
+24
+c6
+b4
+0c
+00
+40
+02
+41
+c5
+90
+29
+eb
+75
+f0
+03
+a4
+c5
+83
+25
+f0
+c5
+83
+73
+02
+2a
+0f
+02
+2a
+17
+02
+2a
+1f
+02
+2a
+27
+02
+2a
+72
+02
+2a
+8f
+02
+2a
+97
+02
+2a
+9f
+02
+2a
+a7
+02
+2a
+af
+02
+2a
+b7
+02
+2a
+bf
+90
+4f
+02
+74
+d7
+f0
+41
+c5
+90
+4f
+02
+74
+d8
+f0
+41
+c5
+90
+4f
+02
+74
+d6
+f0
+41
+c5
+90
+4c
+c1
+e0
+fe
+70
+14
+af
+04
+7b
+2b
+7d
+04
+11
+60
+ec
+30
+e0
+31
+90
+4c
+f8
+74
+0a
+f0
+80
+29
+ee
+64
+01
+70
+0a
+af
+04
+7b
+52
+7d
+01
+11
+60
+80
+1a
+90
+4c
+c1
+e0
+64
+02
+70
+12
+af
+04
+7b
+2b
+7d
+08
+11
+60
+ec
+30
+e0
+06
+90
+4c
+f8
+74
+0a
+f0
+e4
+90
+4f
+02
+f0
+80
+53
+90
+4c
+c1
+e0
+70
+08
+90
+4f
+02
+74
+d2
+f0
+80
+45
+af
+04
+7b
+50
+7d
+08
+11
+60
+e4
+90
+4f
+02
+f0
+80
+36
+90
+4f
+02
+74
+d5
+f0
+80
+2e
+90
+4f
+02
+74
+f4
+f0
+80
+26
+90
+4f
+02
+74
+f2
+f0
+80
+1e
+90
+4f
+02
+74
+f5
+f0
+80
+16
+90
+4f
+02
+74
+f8
+f0
+80
+0e
+90
+4f
+02
+74
+f6
+f0
+80
+06
+90
+4f
+02
+74
+f7
+f0
+90
+4f
+02
+e0
+ff
+22
+e4
+90
+4e
+88
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+d1
+de
+7a
+4d
+79
+a8
+90
+4e
+ae
+74
+01
+f0
+a3
+74
+4d
+f0
+a3
+74
+a8
+f0
+a3
+74
+14
+f0
+7b
+01
+7a
+4d
+79
+bc
+b1
+6b
+ef
+60
+1c
+7b
+01
+7a
+4d
+79
+bc
+7d
+14
+b1
+3b
+ef
+70
+0f
+90
+4c
+ce
+e0
+44
+02
+f0
+90
+4d
+06
+74
+14
+f0
+80
+0c
+90
+4c
+ce
+e0
+54
+fd
+f0
+e4
+90
+4c
+d0
+f0
+e4
+90
+4e
+88
+f0
+90
+4e
+88
+e0
+ff
+90
+06
+81
+93
+70
+02
+81
+09
+74
+bc
+2f
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+90
+4e
+8b
+f0
+e0
+ff
+b1
+2d
+90
+4e
+92
+ef
+f0
+c3
+94
+02
+74
+80
+94
+80
+50
+02
+61
+f2
+e4
+90
+4e
+89
+f0
+90
+4e
+89
+e0
+ff
+c3
+94
+08
+74
+80
+94
+80
+50
+7b
+7e
+00
+74
+01
+a8
+07
+08
+80
+05
+c3
+33
+ce
+33
+ce
+d8
+f9
+ff
+90
+4e
+8b
+e0
+fd
+e4
+ef
+5d
+60
+58
+e4
+90
+4e
+8a
+f0
+90
+4e
+8a
+e0
+ff
+90
+06
+81
+93
+60
+48
+90
+4e
+88
+e0
+fe
+ef
+6e
+60
+37
+90
+4e
+8a
+e0
+24
+bc
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+fd
+7c
+00
+90
+4e
+89
+e0
+ff
+7e
+00
+74
+01
+a8
+07
+08
+80
+05
+c3
+33
+ce
+33
+ce
+d8
+f9
+ff
+ee
+5c
+fe
+ef
+5d
+4e
+60
+08
+90
+4e
+91
+74
+01
+f0
+80
+08
+90
+4e
+8a
+e0
+04
+f0
+80
+ad
+90
+4e
+89
+e0
+04
+f0
+61
+69
+90
+4e
+8b
+e0
+ff
+60
+08
+b1
+2d
+90
+4e
+8f
+e0
+2f
+f0
+90
+4e
+88
+e0
+04
+f0
+61
+34
+90
+4e
+8f
+e0
+90
+4d
+e4
+f0
+e4
+90
+4e
+88
+f0
+90
+4e
+88
+e0
+fb
+90
+06
+81
+93
+70
+02
+81
+fe
+90
+4e
+88
+e0
+fe
+24
+93
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+fd
+74
+bc
+2e
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+6d
+90
+4e
+8b
+f0
+74
+bc
+2b
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+90
+4e
+8e
+f0
+90
+4e
+8b
+e0
+70
+02
+81
+f6
+90
+4e
+91
+e0
+60
+07
+7b
+00
+7a
+00
+79
+00
+22
+90
+4e
+88
+e0
+ff
+24
+bc
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+fe
+74
+93
+2f
+f5
+82
+e4
+34
+4d
+f5
+83
+ee
+f0
+e4
+90
+4e
+89
+f0
+90
+4e
+89
+e0
+ff
+c3
+94
+08
+74
+80
+94
+80
+50
+5a
+90
+4e
+8b
+e0
+30
+e0
+3b
+90
+4e
+88
+e0
+fe
+33
+33
+33
+54
+f8
+fe
+ef
+4e
+90
+4e
+8d
+f0
+a3
+e0
+ff
+90
+4e
+8d
+e0
+90
+06
+96
+93
+fd
+11
+86
+90
+4e
+90
+ef
+f0
+90
+4e
+8e
+e0
+30
+e0
+09
+90
+4e
+90
+e0
+ff
+b1
+b5
+80
+07
+90
+4e
+90
+e0
+ff
+d1
+1d
+90
+4e
+8b
+e0
+ff
+c3
+13
+f0
+90
+4e
+8e
+e0
+ff
+c3
+13
+f0
+90
+4e
+89
+e0
+04
+f0
+80
+98
+90
+4e
+8c
+74
+01
+f0
+90
+4e
+88
+e0
+04
+f0
+81
+16
+90
+4e
+4b
+e0
+64
+03
+70
+0b
+90
+4d
+df
+e0
+64
+01
+70
+03
+74
+02
+f0
+90
+4e
+8c
+e0
+70
+08
+90
+4d
+df
+e0
+64
+02
+70
+07
+7b
+01
+7a
+4e
+79
+a4
+22
+7b
+00
+7a
+00
+79
+00
+22
+e4
+fe
+ef
+60
+06
+14
+5f
+ff
+0e
+80
+f7
+af
+06
+22
+90
+4e
+e9
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+e4
+ff
+ef
+c3
+9d
+50
+1b
+90
+4e
+e9
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+8f
+82
+75
+83
+00
+12
+03
+cf
+60
+03
+7f
+00
+22
+0f
+80
+e0
+7f
+01
+22
+90
+4e
+ab
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+e4
+ff
+90
+4e
+b1
+e0
+fe
+ef
+c3
+9e
+50
+30
+90
+4e
+ae
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+8f
+82
+75
+83
+00
+12
+03
+cf
+fe
+90
+4e
+ab
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+8f
+82
+75
+83
+00
+12
+03
+cf
+6e
+60
+03
+7f
+00
+22
+0f
+80
+c6
+7f
+01
+22
+e4
+fe
+ef
+fd
+7c
+00
+c3
+94
+e0
+74
+80
+94
+80
+40
+23
+d3
+ed
+94
+e7
+74
+80
+94
+80
+50
+19
+90
+4e
+a4
+e0
+fe
+ef
+54
+07
+ff
+f8
+74
+01
+08
+80
+02
+c3
+33
+d8
+fc
+4e
+90
+4e
+a4
+f0
+22
+e4
+fe
+ee
+c3
+94
+06
+74
+80
+94
+80
+50
+29
+74
+a5
+2e
+f5
+82
+e4
+34
+4e
+f5
+83
+e0
+fd
+6f
+60
+1a
+ed
+70
+14
+90
+4d
+ed
+e0
+6f
+60
+10
+74
+a5
+2e
+f5
+82
+e4
+34
+4e
+f5
+83
+ef
+f0
+22
+0e
+80
+cd
+22
+e4
+fe
+fd
+ef
+54
+f0
+64
+f0
+60
+07
+ef
+54
+d0
+64
+d0
+70
+0d
+90
+4e
+4b
+e0
+64
+02
+70
+0b
+74
+03
+f0
+80
+06
+90
+4d
+df
+74
+01
+f0
+ef
+fb
+7a
+00
+c3
+94
+e0
+74
+80
+94
+80
+40
+24
+d3
+eb
+94
+e7
+74
+80
+94
+80
+50
+1a
+90
+4e
+a4
+e0
+fe
+ef
+54
+07
+ff
+f8
+74
+01
+08
+80
+02
+c3
+33
+d8
+fc
+f4
+5e
+90
+4e
+a4
+f0
+22
+e4
+fe
+ee
+c3
+94
+06
+74
+80
+94
+80
+50
+5f
+ed
+70
+23
+74
+a5
+2e
+f5
+82
+e4
+34
+4e
+f5
+83
+e0
+6f
+70
+4b
+ee
+64
+05
+70
+0c
+74
+a5
+2e
+f5
+82
+e4
+34
+4e
+f5
+83
+e4
+f0
+7d
+01
+80
+36
+74
+a5
+2e
+f5
+82
+e4
+34
+4e
+f5
+83
+e0
+fc
+74
+a4
+2e
+f5
+82
+e4
+34
+4e
+f5
+83
+ec
+f0
+74
+a5
+2e
+f5
+82
+e4
+34
+4e
+f5
+83
+e0
+60
+14
+ee
+64
+05
+70
+0c
+74
+a5
+2e
+f5
+82
+e4
+34
+4e
+f5
+83
+e4
+f0
+0e
+80
+97
+22
+e4
+ff
+90
+4e
+e6
+f0
+fe
+fd
+a3
+f0
+a3
+f0
+ef
+90
+06
+81
+93
+60
+7b
+ef
+93
+fd
+13
+13
+13
+54
+1f
+fe
+ed
+54
+07
+fd
+f8
+74
+01
+08
+80
+02
+c3
+33
+d8
+fc
+fd
+ee
+24
+78
+fb
+e4
+34
+80
+8b
+82
+f5
+83
+e0
+fc
+ed
+f4
+fb
+ec
+5b
+f0
+ee
+24
+70
+f5
+82
+e4
+34
+80
+f5
+83
+e0
+4d
+f0
+ee
+24
+74
+f5
+82
+e4
+34
+80
+f5
+83
+e0
+5b
+f0
+90
+81
+1c
+e0
+f4
+fc
+74
+bc
+2f
+f5
+82
+e4
+34
+4d
+f5
+83
+ec
+f0
+ee
+24
+78
+fb
+e4
+34
+80
+8b
+82
+f5
+83
+e0
+4d
+f0
+ee
+24
+70
+fb
+e4
+34
+80
+8b
+82
+f5
+83
+e0
+fc
+ed
+f4
+fb
+ec
+5b
+f0
+0f
+c1
+ea
+e4
+ff
+ef
+90
+06
+81
+93
+60
+7b
+ef
+93
+fd
+13
+13
+13
+54
+1f
+fe
+ed
+54
+07
+fd
+f8
+74
+01
+08
+80
+02
+c3
+33
+d8
+fc
+fd
+ee
+24
+78
+fb
+e4
+34
+80
+8b
+82
+f5
+83
+e0
+fc
+ed
+f4
+fb
+ec
+5b
+f0
+ee
+24
+70
+f5
+82
+e4
+34
+80
+f5
+83
+e0
+4d
+f0
+ee
+24
+74
+f5
+82
+e4
+34
+80
+f5
+83
+e0
+5b
+f0
+90
+81
+1c
+e0
+f4
+fc
+74
+a8
+2f
+f5
+82
+e4
+34
+4d
+f5
+83
+ec
+f0
+ee
+24
+78
+fb
+e4
+34
+80
+8b
+82
+f5
+83
+e0
+4d
+f0
+ee
+24
+70
+fb
+e4
+34
+80
+8b
+82
+f5
+83
+e0
+fc
+ed
+f4
+fb
+ec
+5b
+f0
+0f
+e1
+6e
+e4
+ff
+ef
+90
+06
+81
+93
+60
+40
+74
+bc
+2f
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+fe
+74
+a8
+2f
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+6e
+60
+23
+74
+bc
+2f
+f5
+82
+e4
+34
+4d
+f5
+83
+c0
+83
+c0
+82
+e0
+fe
+74
+a8
+2f
+f5
+82
+e4
+34
+4d
+f5
+83
+e0
+fd
+ee
+5d
+d0
+82
+d0
+83
+f0
+0f
+80
+b9
+22
+90
+80
+91
+74
+0d
+f0
+a3
+04
+f0
+a3
+f0
+a3
+f0
+a3
+f0
+a3
+14
+f0
+22
+12
+0e
+26
+11
+82
+90
+4c
+eb
+74
+01
+f0
+90
+4c
+e5
+74
+0a
+f0
+e4
+90
+4c
+f0
+f0
+90
+4d
+05
+74
+ff
+f0
+90
+44
+fc
+e0
+90
+4d
+d0
+f0
+90
+44
+fd
+e0
+90
+4d
+d1
+f0
+90
+44
+fe
+e0
+90
+4d
+d2
+f0
+22
+90
+4c
+d3
+74
+05
+f0
+e4
+a3
+f0
+90
+4d
+06
+74
+14
+f0
+90
+4c
+90
+74
+33
+f0
+e4
+ff
+ef
+c3
+94
+04
+74
+80
+94
+80
+50
+14
+ef
+25
+e0
+24
+d6
+f5
+82
+e4
+34
+4c
+f5
+83
+74
+62
+f0
+a3
+f0
+0f
+80
+e2
+90
+4c
+91
+e0
+fe
+a3
+e0
+ff
+c3
+90
+4c
+94
+e0
+9f
+fd
+90
+4c
+93
+e0
+9e
+fc
+e4
+12
+02
+06
+7b
+ae
+7a
+47
+79
+61
+78
+3f
+12
+00
+fb
+c0
+04
+c0
+05
+c0
+06
+c0
+07
+90
+4c
+91
+e0
+fc
+a3
+e0
+fd
+e4
+12
+02
+06
+d0
+03
+d0
+02
+d0
+01
+d0
+00
+12
+00
+0a
+12
+02
+3f
+90
+4c
+fa
+ee
+f0
+a3
+ef
+f0
+90
+4c
+91
+e0
+fe
+a3
+e0
+ff
+c3
+90
+4c
+94
+e0
+9f
+fd
+90
+4c
+93
+e0
+9e
+fc
+e4
+12
+02
+06
+74
+33
+fb
+fa
+f9
+78
+3f
+12
+00
+fb
+c0
+04
+c0
+05
+c0
+06
+c0
+07
+90
+4c
+91
+e0
+fc
+a3
+e0
+fd
+e4
+12
+02
+06
+d0
+03
+d0
+02
+d0
+01
+d0
+00
+12
+00
+0a
+12
+02
+3f
+90
+4c
+de
+ee
+f0
+a3
+ef
+f0
+90
+4c
+91
+e0
+fe
+a3
+e0
+ff
+c3
+90
+4c
+94
+e0
+9f
+fd
+90
+4c
+93
+e0
+9e
+fc
+e4
+12
+02
+06
+7b
+85
+7a
+eb
+79
+11
+78
+3f
+12
+00
+fb
+c0
+04
+c0
+05
+c0
+06
+c0
+07
+90
+4c
+91
+e0
+fc
+a3
+e0
+fd
+e4
+12
+02
+06
+d0
+03
+d0
+02
+d0
+01
+d0
+00
+12
+00
+0a
+12
+02
+3f
+90
+4c
+e0
+ee
+f0
+a3
+ef
+f0
+22
+90
+4e
+fa
+ed
+f0
+90
+00
+01
+12
+03
+cf
+90
+4e
+fb
+f0
+22
+90
+4c
+ea
+e0
+60
+02
+14
+f0
+90
+4c
+ef
+e0
+60
+02
+14
+f0
+90
+4c
+f8
+e0
+60
+0b
+14
+f0
+e0
+70
+06
+90
+4c
+f4
+74
+06
+f0
+90
+4c
+e5
+e0
+60
+20
+90
+4c
+ee
+e0
+60
+06
+e4
+90
+4c
+e5
+f0
+22
+90
+4c
+e5
+e0
+14
+f0
+12
+17
+b0
+90
+4c
+e5
+e0
+70
+4a
+12
+17
+c8
+80
+45
+90
+4c
+e9
+e0
+70
+3f
+90
+4c
+ee
+e0
+70
+39
+90
+4c
+e2
+e0
+60
+33
+14
+f0
+e0
+ff
+c3
+94
+04
+74
+80
+94
+80
+50
+16
+ef
+30
+e1
+09
+d2
+01
+7f
+14
+12
+11
+b2
+80
+10
+c2
+01
+7f
+14
+12
+11
+b2
+80
+07
+c2
+01
+7f
+14
+12
+11
+b2
+90
+4c
+e2
+e0
+70
+03
+74
+0a
+f0
+90
+4d
+dc
+e0
+70
+36
+90
+4d
+dd
+e0
+64
+01
+70
+2e
+90
+4c
+e3
+f0
+a3
+f0
+90
+4d
+dd
+f0
+90
+4e
+4c
+e0
+60
+0d
+7b
+01
+7a
+4e
+79
+4c
+7d
+03
+12
+0e
+da
+80
+11
+90
+48
+00
+e0
+60
+0b
+7b
+01
+7a
+48
+79
+00
+7d
+09
+12
+0e
+da
+90
+4d
+d4
+e0
+60
+11
+e0
+14
+f0
+e0
+70
+0b
+90
+4d
+3d
+e0
+70
+05
+7f
+1b
+12
+14
+9d
+90
+4d
+e6
+e0
+60
+14
+e0
+14
+f0
+e0
+70
+0e
+90
+4c
+c7
+e0
+64
+04
+70
+06
+90
+42
+13
+74
+0c
+f0
+22
+90
+4e
+fc
+ee
+f0
+a3
+ef
+f0
+a9
+05
+90
+4b
+9e
+e0
+fe
+a3
+e0
+ff
+ad
+01
+19
+ed
+60
+2f
+0f
+ef
+ac
+06
+70
+01
+0e
+14
+f5
+82
+8c
+83
+e0
+fd
+90
+4e
+fc
+e4
+75
+f0
+01
+12
+04
+24
+85
+f0
+82
+f5
+83
+ed
+f0
+ad
+07
+ac
+06
+bc
+4b
+d4
+bd
+9a
+d1
+7e
+4b
+7f
+36
+80
+cb
+90
+4b
+9e
+ee
+f0
+a3
+ef
+f0
+22
+7a
+0c
+79
+4b
+90
+4e
+ec
+74
+01
+f0
+a3
+74
+0c
+f0
+a3
+74
+4b
+f0
+90
+4b
+a0
+e0
+fe
+a3
+e0
+ff
+90
+4b
+9e
+e0
+6e
+70
+03
+a3
+e0
+6f
+70
+02
+81
+aa
+7e
+0c
+7f
+4b
+7d
+03
+51
+ab
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+b4
+02
+2b
+90
+4e
+ed
+e4
+75
+f0
+02
+12
+04
+0e
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+ff
+90
+4e
+68
+e0
+a3
+e0
+fa
+a3
+e0
+f5
+82
+8a
+83
+12
+05
+dd
+81
+aa
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+64
+04
+70
+59
+90
+4e
+ed
+75
+f0
+01
+12
+04
+0e
+7e
+0c
+7f
+4e
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+14
+fd
+51
+ab
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+c0
+02
+c0
+01
+90
+4e
+ec
+e0
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+fd
+7c
+00
+90
+4e
+6b
+e0
+a3
+e0
+fa
+a3
+e0
+f5
+82
+8a
+83
+d0
+01
+d0
+02
+12
+05
+dd
+81
+aa
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+64
+05
+70
+59
+90
+4e
+ed
+75
+f0
+01
+12
+04
+0e
+7e
+0c
+7f
+4e
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+14
+fd
+51
+ab
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+c0
+02
+c0
+01
+90
+4e
+ec
+e0
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+fd
+7c
+00
+90
+4e
+74
+e0
+a3
+e0
+fa
+a3
+e0
+f5
+82
+8a
+83
+d0
+01
+d0
+02
+12
+05
+dd
+80
+6d
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+64
+03
+70
+59
+90
+4e
+ed
+75
+f0
+01
+12
+04
+0e
+7e
+0c
+7f
+4e
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+14
+fd
+51
+ab
+90
+4e
+ec
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+24
+01
+f9
+e4
+3a
+fa
+c0
+02
+c0
+01
+90
+4e
+ec
+e0
+a3
+e0
+fa
+a3
+e0
+f9
+12
+03
+b6
+fd
+7c
+00
+90
+4e
+77
+e0
+a3
+e0
+fa
+a3
+e0
+f5
+82
+8a
+83
+d0
+01
+d0
+02
+12
+05
+dd
+80
+02
+80
+fe
+90
+4b
+a5
+e0
+fe
+a3
+e0
+ff
+90
+4c
+5e
+e0
+6e
+70
+03
+a3
+e0
+6f
+60
+22
+90
+4e
+6e
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+4a
+60
+37
+12
+05
+d9
+90
+4b
+a5
+e0
+ff
+a3
+e0
+90
+4c
+5e
+cf
+f0
+a3
+ef
+f0
+80
+ca
+90
+4c
+8d
+e0
+ff
+a3
+e0
+6f
+60
+19
+90
+4e
+71
+e0
+fb
+a3
+e0
+fa
+a3
+e0
+f9
+4a
+60
+0b
+12
+05
+d9
+90
+4c
+8d
+e0
+a3
+f0
+80
+dd
+22
+90
+0b
+e7
+74
+03
+f0
+ed
+60
+03
+12
+0f
+c2
+22
+90
+0b
+e7
+74
+06
+f0
+02
+0f
+c2
+90
+0b
+e7
+74
+04
+f0
+02
+0f
+c2
+90
+0b
+e7
+74
+05
+f0
+02
+0f
+c2
+90
+04
+46
+e0
+ff
+22
+90
+0b
+7f
+74
+01
+f0
+e4
+90
+0b
+7e
+f0
+22
+90
+82
+80
+74
+01
+f0
+22
+90
+4e
+f2
+eb
+f0
+a3
+ea
+f0
+a3
+e9
+f0
+ed
+1d
+ae
+04
+70
+01
+1c
+4e
+60
+17
+90
+4e
+f2
+e0
+fb
+a3
+e4
+75
+f0
+01
+12
+04
+24
+a9
+f0
+fa
+74
+ff
+12
+03
+fc
+80
+df
+22
+ef
+f4
+60
+3a
+ef
+54
+07
+fe
+ef
+13
+13
+13
+54
+03
+ff
+24
+a3
+f5
+82
+e4
+34
+00
+f5
+83
+c0
+83
+c0
+82
+e0
+fd
+74
+01
+a8
+06
+08
+80
+02
+c3
+33
+d8
+fc
+f4
+fc
+5d
+d0
+82
+d0
+83
+f0
+74
+a7
+2f
+f5
+82
+e4
+34
+00
+f5
+83
+e0
+5c
+f0
+22
+90
+4f
+0a
+ef
+f0
+7b
+01
+7a
+80
+79
+74
+12
+1f
+ac
+92
+09
+90
+4f
+0a
+e0
+ff
+a2
+09
+b3
+92
+01
+02
+11
+b2
+e4
+ff
+ef
+fd
+7c
+00
+24
+78
+fb
+ec
+34
+80
+8b
+82
+f5
+83
+e0
+fe
+ed
+24
+70
+fd
+ec
+34
+80
+8d
+82
+f5
+83
+e0
+4e
+f4
+fe
+ef
+24
+7c
+fd
+ec
+34
+80
+8d
+82
+f5
+83
+ee
+f0
+0f
+ef
+b4
+04
+cf
+22
Index: c51/output/geneep.exe
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/output/geneep.exe
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/output/otp.dat
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/otp.dat	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/otp.dat	(working copy)
@@ -0,0 +1,12 @@
+00
+02
+aa
+55
+00
+00
+aa
+55
+00
+00
+82
+78
Index: c51/output/ramcode.rom
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/ramcode.rom	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/ramcode.rom	(working copy)
@@ -0,0 +1,1644 @@
+c5128010
+c000002c
+c0010030
+c0018038
+c0028042
+c04801b5
+c049017b
+c04a0181
+c04a816b
+c0580299
+c058812f
+c0590143
+c059815d
+c05b0166
+c05c8137
+20203bf1
+c01902a7
+c01dd3b0
+c01f022d
+c01f8231
+c0250314
+c02582a0
+c02602aa
+c02702b0
+c02b02b7
+c02d02c3
+c03082be
+c03182e3
+c0320308
+c032833e
+c03484a0
+c0350484
+c0358486
+c03704ab
+c037831f
+c0438103
+c046824c
+c0470263
+c0478235
+c05e8243
+c06681bf
+c067810f
+c0680119
+20203bf1
+6810813b
+60008b81
+70800608
+20203003
+20407719
+2055bcf1
+20407813
+6800c7dc
+203a3013
+6800c793
+203a0032
+20203013
+2040009d
+2040008f
+20400047
+2040003d
+20203015
+680947f4
+6800c3d8
+7d3a040b
+600947f4
+20600000
+20403392
+20403407
+20403024
+204004cc
+20203022
+6800c7dc
+203a004b
+6800c793
+207a0000
+204000fe
+20740000
+1ff0fe00
+1fe20c00
+204000df
+6000cba7
+c000805f
+c0030069
+1fe20400
+18c22200
+6800c040
+c300005c
+1a220c00
+c6848000
+18427e00
+c002806b
+20203bf1
+1a220c00
+d8a000f8
+202000d7
+204000df
+204000df
+60008b7d
+20400064
+20207c33
+204000e2
+18c20400
+18508400
+60094b9a
+20600000
+d8a04d57
+202000d7
+18c22200
+6800cba9
+1fe08401
+18410403
+6008cba9
+1feffe07
+d8a04bad
+98a08a00
+1a220c00
+204000df
+18c22200
+1fe0ffff
+1fe27200
+1fe0fe07
+6000cc82
+1a220c00
+204000df
+18c22200
+c0008081
+c0010089
+c001808b
+c002008d
+68014cb8
+e0a10000
+1a220c00
+204000d9
+2040561e
+247a0000
+700b7d1b
+20205620
+68014cba
+20200082
+68014cbc
+20200082
+68014d3e
+20200082
+680a4d4b
+1c427e00
+98467e00
+68094d4f
+9846fc00
+20407efd
+1807fe00
+207a0000
+1c420400
+600a4d4b
+6800cd51
+1fe0fe01
+6000cd51
+20600000
+680a4c59
+1c427e00
+98467e00
+d8400640
+9846fc00
+20407efd
+1807fe00
+207a0000
+1c420400
+600a4c59
+68094ba5
+18508400
+9840fe00
+1ff0fe00
+60014ba5
+1ff0fe00
+1fe17e03
+c1800000
+6800cc8f
+c28000ba
+c28080bc
+da200000
+204000ce
+7089718f
+6800cc90
+60108973
+204000bd
+da200001
+202000ce
+708971bf
+202000bd
+708971af
+68108053
+79207e07
+60108053
+68108973
+1fe1fe30
+60108973
+70890674
+7089067c
+708972aa
+20001388
+68190150
+68108053
+793ffe07
+60108053
+18508400
+60094c95
+20600000
+d8400021
+6800cc90
+98460400
+1a227e00
+79200407
+243a00d5
+793f8407
+d8a08078
+202069f4
+204000df
+1fe27200
+204000db
+20200064
+204000df
+e0a08000
+c20000db
+20600000
+204000e2
+e8c08000
+20600000
+58004b36
+98c67c00
+24628000
+d8c04aa0
+20600000
+df200003
+d8c04ba2
+18c22200
+68014ba0
+1ff0fe00
+1fe20a00
+1a220c00
+e8c08000
+e0a08000
+204000f6
+c20000ee
+18a27e00
+1ff0fe00
+60014ba0
+20600000
+58004b9a
+98a67c00
+24628000
+d8a04b36
+20600000
+68014b9e
+68094ba0
+20200100
+68014b9a
+68094b9c
+98467c00
+2022e9b1
+2020320b
+1c427e00
+60024d47
+6808c7ef
+6800cd4a
+98467c00
+2441010a
+20207c06
+680a4d47
+600a47ec
+600a4c59
+600a4d4b
+20600000
+da2047df
+20407f9f
+207a0000
+1fe22600
+20400115
+20203ea5
+c10c0000
+c00a04bd
+c00a829e
+20203e7d
+60088259
+6800cc8d
+1fe0fe01
+6000cc8d
+68008259
+207a0000
+1fe0ffff
+60008259
+20400123
+2020011d
+6800cc15
+207a0000
+1fe0ffff
+6000cc15
+20600000
+1a627e00
+1fe17ef0
+c1280000
+1a627e00
+207a0000
+6000cba4
+202000e7
+70416e7f
+20403cf3
+6800cc97
+207a0000
+704c9700
+1c427e00
+60024c59
+20600000
+6800c219
+247a0000
+70804206
+58000f0c
+20403da7
+58030d40
+20403bf3
+37d98200
+1e226000
+20403b36
+20001388
+20203d9d
+c6118000
+680147f4
+c284bd1e
+20403cab
+6801c210
+207a0000
+6800c131
+207a0000
+2040527e
+247a0000
+20403dca
+247a0000
+20403b36
+6800c7dc
+203a3d25
+6800c793
+207a0000
+20203d25
+204000fe
+24740000
+204000fb
+24740000
+700b7f01
+700b7e01
+20400162
+202000fe
+20400155
+24740000
+68008b7f
+247a0000
+20203d2d
+68008b7e
+2000000a
+c0800162
+20600000
+20400155
+24740000
+68008b7f
+247a0000
+20203d4f
+2040016d
+20203aaf
+6800c219
+243a0173
+20403d91
+20007530
+20007530
+20007530
+20403b0a
+70804204
+6810896b
+1fe17ecf
+6010896b
+1fe1fe30
+6010896b
+20600000
+60088017
+1840a204
+20203a86
+60088017
+1840a200
+20203ab6
+2040017e
+58000500
+20403bf3
+70890601
+7089003c
+708901e0
+70896d12
+2000000a
+70890201
+7089023d
+2000000a
+708903b7
+2000000a
+7089027d
+6800cbef
+c0ff8199
+6802ca91
+e0a28000
+e8c28000
+e0a28000
+708956df
+204001a4
+708955df
+20600000
+6802ca87
+e0a28000
+e8c28000
+e0a28000
+6800cc7d
+205a01a2
+60108956
+708955d0
+20600000
+580000c2
+20600000
+20000004
+708955d1
+20000004
+708955d2
+20000004
+708955d4
+20000004
+20600000
+708955d4
+20000004
+708955d2
+20000004
+708955d1
+20000004
+708955d0
+708956c0
+20600000
+2030ba6f
+204001ac
+20203a6f
+78347c00
+68120138
+79347e1a
+6012004c
+20403db0
+7000a201
+20600000
+6800c419
+1fe0fe02
+6000c3f9
+700b7e00
+70017706
+20403fa4
+580001be
+6001428a
+58000128
+60014292
+58000234
+60014290
+58000047
+6001428c
+580001b8
+60014288
+58004aa0
+1ff0fe00
+60014b9a
+60014b9c
+20403e0b
+58004b36
+1ff0fe00
+60014b9e
+60014ba0
+6800cc97
+c02d01f0
+203581ee
+68014c91
+1ff0fe00
+60014c91
+68014c93
+1ff0fe00
+60014c93
+204001fb
+680402a0
+243a01e8
+68014ad4
+1ff0fe00
+203a01e8
+60014c93
+204004c9
+704ba42f
+204000e7
+704c9700
+70828003
+20600000
+704ba430
+202001ea
+1ce27e00
+203a023b
+20405b63
+20404d99
+58000000
+60044040
+600147f4
+1c427e00
+60024c59
+704ba433
+202001ea
+2040688a
+580007e0
+da2002a0
+d840000e
+204068d3
+2040688d
+680082a0
+c280bbf1
+680402a2
+207a0000
+6800cc8f
+c280020f
+c280821d
+680102a2
+1ff0fe00
+60014c91
+680102a8
+1ff0fe00
+60014c93
+20600000
+680902a6
+680102ac
+18422400
+1fe22200
+1ff0fe00
+60014c93
+1a227e00
+98462600
+1a63a600
+1a427e00
+9a667e00
+1ff0fe00
+60014c91
+20600000
+680902a4
+680102aa
+18422400
+1fe22200
+98462600
+1a6b2600
+1a427e00
+9a667e00
+1ff0fe00
+60014c91
+1a63a600
+1a227e00
+9a667e00
+1ff0fe00
+60014c93
+20600000
+70001627
+70890f36
+70890b5f
+202053d4
+70890f2e
+70890bff
+202053d9
+20600000
+68014ba0
+60014b9e
+68014b9c
+60014b9a
+700b7e03
+20400162
+704c975a
+20403db8
+68120138
+793ffe0f
+6012004c
+20403db0
+d85fffff
+20203cda
+ea2a8000
+18417eff
+243a0248
+184cfe00
+e2228000
+1a20a204
+ea208000
+247a0000
+20207f9c
+20407c20
+da2047e4
+20407f9f
+1fe20400
+20407c24
+18427e00
+207a0000
+c010825c
+c011025e
+c011855c
+c006826c
+c016026c
+c0158277
+c0150291
+c0097c85
+20207c5a
+704befff
+2020058f
+793f8023
+704befff
+20200547
+700b7d22
+20205620
+6800807c
+203a0268
+204061d9
+6800807c
+243a7c8c
+68008b7d
+c584fc87
+c0088261
+20207c7b
+20403eff
+20407cd5
+70413100
+180a7e00
+6000c4f9
+7043dc05
+58181203
+6001c3e2
+d8400007
+2040027d
+20207cae
+7043dc04
+580000ff
+6001c3e2
+d8400000
+2040027d
+20207cae
+6800c3f9
+9840fe00
+1fe0fe0b
+1fe67c1f
+2421028d
+6000c3d9
+d8a043e5
+18427e00
+245a028a
+6800c3f9
+1fe27200
+d8c043fa
+20207e45
+1fe27200
+d8c04d6b
+20207e45
+6800c3f9
+1fe0fe0b
+6000c3d9
+20600000
+680147f4
+c284bf90
+c283fcd5
+c5118547
+7043d800
+20403f7e
+700b7d37
+20207c27
+20403b36
+20203cdc
+e8c08000
+6000ccb7
+20600000
+704d7e00
+202004c2
+204054bd
+68088017
+20403a82
+20403a87
+78287c00
+d960157c
+2020547f
+70443e01
+70443f00
+2020534e
+204053dd
+204002ad
+202054c1
+20368184
+204053ee
+20203a91
+6800cc60
+600246f9
+6800c4db
+c00082b5
+202054e0
+7044db00
+202054ef
+680083c0
+c4028000
+680103da
+680903e0
+98467e00
+24610000
+2020557e
+680083d7
+c3828000
+68008341
+203a5626
+20205890
+680883d7
+284c0005
+20608000
+68008340
+1fe3fe00
+9842fe00
+c4018000
+793f8405
+79400403
+600883d7
+28400603
+24608000
+6800c440
+c00282d4
+6800cd7e
+c00082d8
+20600000
+680083c0
+79207e04
+600083c0
+20600000
+704d7e00
+dfe00000
+6002446f
+6000c48b
+6002c465
+79207e27
+6002c46a
+680083c0
+793ffe04
+600083c0
+20600000
+6800c440
+c00382fd
+c0078301
+c00302f0
+c00102ed
+c00982eb
+c00582eb
+2020563a
+18000401
+20205892
+5800000a
+600103ef
+20205693
+700b7d12
+20407c33
+18000401
+2034d892
+700b7d34
+20407c27
+6800cc69
+c00102f9
+202002fb
+700b7d46
+20405620
+18000401
+20205892
+6800cc68
+e0a08000
+18000402
+20205892
+18a08bff
+68044c6c
+e0a40000
+e8c40000
+e0a40000
+18000202
+2020588a
+6800c444
+c004d719
+c001030d
+c003d70d
+20205656
+59000302
+6001c4b5
+58000001
+e0a08000
+58010010
+e0a18000
+202056f1
+09800018
+78287c00
+db600664
+1fef7e00
+1ff17e00
+e0a18000
+2023375c
+7836fc00
+68008017
+1fe0a200
+202054af
+e8c18000
+600183f9
+c0290325
+c001033c
+c009032b
+20205907
+704d3801
+680103fa
+c0108329
+202059ed
+d8c00349
+2020029b
+680103fa
+1fe67c21
+20428329
+680103fa
+1fe67c2d
+2042833a
+680103fa
+68094cbc
+18408401
+98467c00
+20228337
+202059ca
+700b7d34
+20407c27
+202059ca
+70413101
+20600000
+700b7d03
+20205620
+6800c444
+c00d8476
+c00e8476
+c008840a
+c00483bc
+c00283aa
+c003835e
+c009d85c
+c001834f
+c0058352
+c006834a
+20205666
+680103fa
+c003834d
+202057d6
+7003fc07
+20205729
+68014c6a
+e0a10000
+2020588a
+680103fa
+c0070355
+202057c6
+6800cc69
+c08057c6
+6800cc7c
+c001d7c6
+18a20400
+704c6901
+18420a00
+7003fc05
+20205729
+2040577b
+20740000
+680944c0
+58001812
+98467c00
+20228377
+5800180f
+98467c00
+20228379
+5800180a
+98467c00
+2022837d
+58001801
+98467c00
+2022837b
+20205754
+6800cc7f
+d8400000
+f9200400
+98417e00
+c0805728
+6800cc7f
+f9207e00
+6000cc7f
+2020037f
+d8e00000
+2020036e
+d8e00001
+2020036e
+d8e00003
+2020036e
+d8e00002
+2020036e
+680144c0
+1fe22200
+680944c4
+18422400
+20400386
+20228391
+20205728
+d8c04504
+e8c10000
+207a0000
+e8c18000
+e8c10000
+9a267c00
+20628000
+18c08dfd
+e8c08000
+98c08c00
+20200387
+18c08df9
+e8c10000
+60014c61
+2040039f
+203a5728
+18c08dfc
+e8c10000
+1fe0ffff
+60014c63
+70444407
+68024c61
+60024445
+18000409
+20205892
+e8c10000
+e8c08000
+98c08c00
+e8c10000
+207a0000
+e8c10000
+9a467c00
+20628000
+e8c08000
+98c08c00
+202003a2
+d9600003
+18007e01
+6000c445
+20405a74
+20405a7d
+203a5746
+242103ba
+78547c00
+e0a10000
+e8c10000
+e0a10000
+196097ff
+2022d746
+e8c08000
+98c08c00
+202003ae
+18c08c02
+202003b7
+680944c0
+58002a00
+98467c00
+202283fc
+58002a50
+98467c00
+20228407
+58002803
+98467c00
+2422d728
+680144bc
+600102a0
+78347c00
+2040044e
+242103d8
+680902a0
+20400456
+c00083d8
+20400452
+242283d6
+78547c00
+204003da
+2040043c
+20400456
+204003e2
+202003d8
+2040043c
+202003c9
+20345728
+20200474
+680102a0
+60014446
+6800cc67
+1fe27200
+2040046b
+d8a04448
+20407e45
+2020046e
+68094c65
+184cfe00
+c08283f4
+20400468
+680102a0
+e0a10000
+2040046e
+58004504
+98408c00
+e8c08000
+18c20400
+1fe27200
+1fe0fe05
+6000c445
+20400468
+18420c00
+20407e45
+2020046e
+20400468
+680102a0
+e0a10000
+68014c65
+e0a10000
+2040046e
+70444507
+20600000
+20405b08
+e8c08000
+1fe27200
+1fe0fe02
+6000c445
+18c08dfb
+e8c10000
+e0a10000
+18c08c03
+20407e45
+2020588a
+d8402a50
+20405b0c
+202003fd
+d9600002
+680144bc
+600102a0
+700d5c00
+78347c00
+2040044e
+24210432
+680902a0
+20400456
+c0008435
+20400452
+2422842e
+68008d5c
+c0008435
+2434041f
+78547c00
+6800cc67
+1fe0fe04
+6000c445
+2040046e
+20200429
+6800cc67
+1fe67c10
+20228435
+6800c445
+1fe67c10
+20228435
+680102a0
+1fe0ffff
+60010d5a
+20400445
+680102a0
+60010d58
+20400440
+196097ff
+20228430
+2040043c
+2020040f
+700d5c01
+2020042e
+680102a0
+60010d5a
+20200439
+680102a0
+1fe0ffff
+60010d5a
+20200439
+20345728
+20400445
+20200474
+680902a0
+18408401
+600902a0
+20600000
+6800cc67
+60008103
+1fe27200
+2040046b
+20207e45
+20400468
+68010d58
+e0a10000
+68010d5a
+e0a10000
+68008103
+1fe27200
+20407e45
+2020046e
+680902a0
+680144be
+98467c00
+20600000
+680144c0
+68094c65
+98467c00
+20600000
+d8c04504
+18422200
+e8c10000
+203a0461
+e8c90000
+60094c65
+9a267c00
+20228463
+e8c08000
+98c08c00
+20200458
+58000001
+20600000
+e8c08000
+6000cc67
+20400471
+58000000
+20600000
+680102b9
+1fe20a00
+20600000
+680102b7
+1fe20c00
+20600000
+18a27e00
+600102b9
+20600000
+18c27e00
+600102b7
+20600000
+20400468
+2020588a
+6800cbab
+1fe08401
+18410403
+6008cbab
+1feffe07
+d8c04bad
+98c08c00
+6800cc82
+1fe0fffb
+1fe27200
+d8a04445
+20407e45
+6808cc82
+20205892
+2040561c
+202058b0
+1a627e00
+c0018496
+c005049a
+c0000491
+c0090498
+c001049d
+1fe67c0d
+202158c0
+6000cc68
+700b7d27
+20205620
+20405924
+68014437
+1fef8404
+60094d4f
+20600000
+704c7c00
+20205938
+700b7d33
+20205620
+704d7e01
+700b7d2b
+20205620
+58000014
+600103ef
+20600000
+6800c43e
+28200601
+202084a4
+202058a7
+6800c43f
+203a04a7
+202058a7
+6800c43e
+793ffe04
+6000c43e
+20600000
+e8c08000
+c00084b2
+c00204b8
+c00484b0
+202058f8
+704c6903
+20205974
+704d3d01
+6000c4ae
+e8c30000
+e0a30000
+700b7d42
+20205620
+204074a8
+202284bb
+20205968
+704c6902
+2020596a
+704c7d00
+20403f86
+20403f7e
+20403fa4
+20203ecc
+70421300
+70448b00
+704c7c00
+704c6900
+704c7f00
+704c7d00
+20203ed0
+58000000
+60024ba9
+20600000
+c6918000
+68024d40
+60024d72
+204004f2
+243404e5
+704c150a
+20400513
+6800cbef
+c1ff8000
+704c3d02
+6800cd45
+247a0000
+20400155
+24740000
+68008b7f
+247a0000
+20403cab
+6801c210
+207a0000
+6800c131
+207a0000
+6801cd7a
+20407e8a
+600a41fc
+20203cda
+20400155
+24740000
+68008b7f
+247a0000
+20403cab
+6801c210
+207a0000
+6800c131
+207a0000
+6800cc15
+243a04e1
+68024d72
+202004e2
+6800cbef
+c0ff8565
+204004f9
+20540510
+205405d4
+704be601
+20600000
+78547c00
+704be202
+6800cd57
+c0020503
+c0028506
+c003850c
+c0030509
+6800cd45
+245a34df
+20600000
+704d5700
+704be10a
+2020050e
+704d5703
+704be104
+2020050e
+704d5702
+704be103
+2020050e
+704be201
+704be108
+704be700
+202034df
+6804cd57
+60048cd5
+20600000
+704be800
+d9600d00
+34730200
+2040053a
+24378523
+2040054a
+6800cbe0
+1fe0fe01
+6000cbe0
+704d4500
+6800cbef
+c0ff8539
+20400535
+704be700
+704be600
+20600000
+704d4501
+6800cbe7
+1fe0fe01
+6000cbe7
+6800cbef
+c0ff8545
+6800cbe7
+c07f8547
+6800cbe7
+d8400010
+98467c00
+202105f3
+6800cbe8
+1fe0fe01
+6000cbe8
+2000000a
+c0838514
+202005f3
+58000000
+60048cd5
+6004cd57
+20600000
+2020057f
+7857fc00
+2040064b
+18002a00
+68024c00
+98001200
+68088017
+20403a82
+20403a87
+2040060b
+20578645
+20600000
+704d4500
+20600000
+704d4500
+700b7d32
+20207c27
+204005b4
+68008cb3
+c1810000
+6800cbdf
+207a0000
+98007200
+d8c00cb5
+d8a00d17
+20407e45
+68008cb4
+2fe1f008
+24608000
+68008cb5
+c07f855a
+6000ccb7
+20600000
+704d7d01
+20600000
+79200023
+20400561
+2040051f
+704bef01
+20600000
+704be000
+704be94e
+68024beb
+202005c6
+20400561
+6800cbe6
+c000b4df
+6800cbef
+c000856d
+c0010570
+c0018573
+20203bf1
+704bef11
+700d37aa
+20200575
+704bef12
+700d3755
+20200575
+704bef13
+700d3722
+700d3802
+68024c06
+60020d39
+700d3d00
+da200d37
+d8400007
+204005af
+204005d4
+204004f7
+202034df
+6800cbef
+c17f8000
+c0088585
+c0090587
+c0098589
+20600000
+704bef02
+2020051f
+704bef03
+2020051f
+704befff
+700b7d31
+20407c27
+68020d19
+204005c6
+2020051f
+79200023
+204005c7
+204005f3
+6800cbef
+c1ff8000
+204005a1
+58000000
+60014c04
+20403cab
+200007d0
+6800cc04
+c07f8547
+2040053a
+243785aa
+20400535
+79200023
+700b7d3c
+20207c27
+700d37ff
+6800cbe2
+60008d38
+68024c06
+60020d39
+d8400006
+da200d37
+204005af
+202005d4
+68014c04
+1fe0fe01
+60014c04
+204005f3
+20200597
+6008cbe1
+18427200
+d8a00cd5
+1a220c00
+20207e45
+68008cb4
+1fe97e00
+6000cbdf
+1fe0fe01
+d8c00cb4
+98c08c00
+e8c18000
+6001cc0b
+20600000
+6808cc3c
+58004c2b
+98408a00
+1a227e00
+e0a08000
+18408401
+18410407
+6008cc3c
+20600000
+60024c00
+da200000
+df200004
+d8c04c00
+e8c08000
+9a20a200
+c20005ca
+1a227e00
+60014c16
+6800cc16
+6808cc17
+9840fe00
+6000cc18
+20600000
+6800cbe1
+1fe0fe02
+6000cbe3
+6800cbe2
+60008cf5
+6800cbe1
+1fe9fe00
+6808cbe0
+18410403
+18438400
+9841fe00
+6808cc0a
+9840fe00
+e0a08000
+6800cbef
+c0ff85e6
+6800cbe2
+e0a08000
+6800cbe1
+98007200
+6800cbe2
+c00085f1
+d8c00cd5
+20407e45
+68008cd5
+c00185ef
+20600000
+700cd502
+20600000
+d8c00cd6
+20207e45
+6808cbea
+204005f9
+18408401
+18410403
+6008cbea
+20600000
+6800cc00
+1fe17e03
+1fefa204
+58004bf0
+9a20fe00
+98408c00
+e8c08000
+6000cbe9
+20600000
+7844fc00
+7843fc00
+58555555
+98001e00
+6800cbe9
+1fed8400
+79200401
+18431c00
+20600000
+20400602
+7826fc00
+7830fc00
+78507c00
+78287c00
+68014be4
+98003600
+37c18400
+242c0645
+7846fc00
+7825fc00
+7823fc00
+7824fc00
+09800008
+19897e00
+6000cc19
+6808cc18
+98467c00
+24228645
+09800008
+19897e00
+60008cb3
+68008cb3
+6808cbe2
+a8400e00
+24208645
+09800008
+19897e00
+e0a08000
+1fe97e00
+1fe1721f
+2022862f
+09800008
+19897e00
+e0a08000
+c200062b
+18a22200
+09800008
+19897e00
+6000cc2a
+1a220a00
+09800018
+78287c00
+db600664
+1fef7e00
+1ff17e00
+e0a18000
+7845fc00
+20230645
+7837fc00
+68008017
+1fe0a200
+20403ab6
+7846fc00
+20403a7a
+6800cc2a
+1fe22200
+202005bd
+784dfc00
+7845fc00
+2020375c
+20403a7a
+6808cbe9
+20203a91
+204053d2
+68024c00
+98001200
+20400602
+20400648
+79202a00
+782efc00
+78307c00
+7850fc00
+19317e00
+1fecfe00
+1ff1fe00
+08008628
+784efc00
+782dfc00
+7823fc00
+7824fc00
+6800cc18
+08008608
+6800cbe3
+98007200
+d8c00cf5
+e8c08000
+08008608
+c2000661
+78247c00
+08008618
+78447c00
+37d38200
+20000064
+784efc00
+784dfc00
+20203a7a
Index: c51/output/sched.rom
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/sched.rom	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/output/sched.rom	(working copy)
@@ -0,0 +1,465 @@
+4000:
+2d   #mem_patch00
+00   #mem_patch01
+00   #mem_patch02
+00   #mem_patch03
+00   #mem_patch04
+00   #mem_patch05
+00   #mem_patch06
+00   #mem_patch07
+00   #mem_patch08
+00   #mem_patch09
+00   #mem_patch0A
+00   #mem_patch0B
+00   #mem_patch0C
+00   #mem_patch0D
+00   #mem_patch0E
+00   #mem_patch0F
+00   #mem_patch10
+00   #mem_patch11
+35   #mem_patch12
+00   #mem_patch13
+00   #mem_patch14
+00   #mem_patch15
+4f   #mem_patch16
+02   #mem_patch17
+00   #mem_patch18
+00   #mem_patch19
+00   #mem_patch1A
+00   #mem_patch1B
+00   #mem_patch1C
+00   #mem_patch1D
+00   #mem_patch1E
+00   #mem_patch1F
+00   #mem_patch20
+00   #mem_patch21
+00   #mem_patch22
+00   #mem_patch23
+00   #mem_patch24
+00   #mem_patch25
+04   #mem_patch26
+c8   #mem_patch27
+00   #mem_patch28
+5c   #mem_patch29
+40   #mem_patch2A
+04   #mem_patch2B
+3a   #mem_patch2C
+ce   #mem_patch2D
+00   #mem_patch2E
+00   #mem_patch2F
+80   #mem_patch30
+e0   #mem_patch31
+00   #mem_patch32
+00   #mem_patch33
+00   #mem_patch34
+00   #mem_patch35
+00   #mem_patch36
+20   #mem_patch37
+00   #mem_patch38
+a0   #mem_patch39
+01   #mem_patch3A
+00   #mem_patch3B
+00   #mem_patch3C
+00   #mem_patch3D
+00   #mem_patch3E
+00   #mem_patch3F
+
+
+4d4f:  20 00		# 20:10ms  30:15ms
+
+4131:01
+4213:40
+4214:03
+41f7:0a
+41f5:10 00
+4133:00
+4cb1:00 00
+
+414a: 40 25 00
+
+4140:36 08 c2 08 66 22    
+4702:
+'BT3.0 Keyboard
+4280:0e 00
+4282:01
+4284:01
+4747:0a
+47dc:00
+47f6:01
+
+4172:01
+
+#bluetootch param init
+07dc:00
+00a2:00
+07dd:00
+0016:27
+
+47fd:ff
+47f7:ff
+
+416e:80
+
+
+4ba2:02 01
+
+
+#attribute list: handle 2bytes, uuid 2bytes, length 1bytes, attribute Nbytes
+4504:
+
+#Primary service: GATT
+01 00 00 28 02 01 18
+#Characteristic: Service changed
+02 00 03 28 01 20
+03 00 05 2a 01 00
+#Client Characteristic Configuration
+04 00 02 29 02 00 00
+
+#Primary Service: GAP
+05 00 00 28 02 00 18 
+#Characteristic: Device Name
+06 00 03 28 01 02 
+07 00 00 2a 
+'BT4.2 Keyboard
+
+#Characteristic: Appearance
+08 00 03 28 01 02 
+09 00 01 2a 02 c1 03 
+#Characteristic: Peripheral Preferred Connection Parameters
+0a 00 03 28 01 02
+0b 00 04 2a 08 06 00 06 00 64 00 2c 01 # interval 6ms, latency 100, timeout 300
+
+#Primary Service: Device Information
+0c 00 00 28 02 0a 18
+#Manufacturer Name
+0d 00 03 28 01 02
+0e 00 29 2a 06 59 69 43 68 69 70			#IOS 13.5.1
+#Characteristic: pnp id
+0f 00 03 28 01 02
+10 00 50 2a 07 02 e8 04 21 70 01 00		# SAMSUNG soft keyboard,setup shortcuts
+
+#Primary service: HID
+11 00 00 28 02 12 18
+#Characteristic:Protocol mode
+12 00 03 28 01 06
+13 00 4e 2a 01 01
+#Characteristic: hid report
+14 00 03 28 01 12   
+15 00 4d 2a 08 00 00 00 00 00 00 00 00	#hid report	led handle write
+16 00 02 29 02 00 00	
+17 00 08 29 02 01 01	#Report ID: 1	Report Type: Input
+#Characteristic:hid report
+18 00 03 28 01 12  
+19 00 4d 2a 05 00 00 00 00 00
+1a 00 02 29 02 00 00
+1b 00 08 29 02 03 01	#Report ID: 3	Report Type: Input
+
+#Characteristic:hid report
+1c 00 03 28 01 12   
+1d 00 4d 2a 02 00 00 	#hid report	led handle write
+1e 00 02 29 02 00 00	
+1f 00 08 29 02 02 01	#Report ID: 2	Report Type: Input
+
+#Characteristic:hid report
+20 00 03 28 01 0e   
+21 00 4d 2a 02 00	00	#hid report	led handle write
+22 00 02 29 02 00 00	
+23 00 08 29 02 01 02	#Report ID: 1	Report Type: Output
+
+#Characteristic:Report map
+24 00 03 28 01 0a
+25 00 4b 2a a0		#length 66+25+60=160=0xa0
+#66
+05 01
+09 06
+a1 01
+85 01
+75 01 
+95 08
+05 07
+19 e0 
+29 e7 
+15 00
+25 01
+81 02
+95 01 
+75 08
+81 03 
+95 05
+75 01
+05 08
+19 01
+29 05  
+91 02 
+95 01  
+75 03  
+91 03
+95 06 
+75 08 
+15 00 
+26 ff 00
+05 07
+19 00
+29 ff 
+81 00
+c0 
+
+#25
+05 0c  		
+09 01  		
+a1 01	
+85 02			
+19 00  		
+2a ff 03 
+15 00 
+26 ff 03		
+95 01  		
+75 10  			
+81 00  		
+c0
+
+#29
+#05 01
+#09 80
+#A1 01
+#85 03
+#15 00
+#25 01
+#75 01
+#95 03
+#19 81
+#29 83
+#81 02
+#95 01
+#75 05
+#81 03
+#C0
+
+#69
+05 01 # Usage Page(Generic Desktop)
+09 02 # Usage(Mouse)
+a1 01 # Collection(Application)
+85 03 # Report ID(3)
+09 01 # Usage(Pointer)
+a1 00 # Collection(Physical)
+05 09 # Usage Page(Buttons)
+19 01 # Usage Minimum(1)
+29 08 # Usage Maximum(8)
+15 00 # Logical Minimum(0)
+25 01 # Logical Maximum(1)
+75 01 # Report Size(1)
+95 08 # Report Count(8)
+81 02 # Input(Data Variable Absolute)
+05 01 # Usage Page(Generic Desktop)
+09 30 # Usage(X)
+09 31 # Usage(Y)
+16 01 80  #Logical Minimum (-32767)
+26 FF 7F #Logical Maximum (32767) 
+75 10 # Report Size(16)
+95 02 # Report Count(2)
+81 06 # Input(Data Variable Relative)
+09 38 # Usage(Wheel)
+15 81 # Logical Minimum(-127)
+25 7f # Logical Maximum(127)
+75 08 # Report Size(8)
+95 01 # Report Count(1)
+81 06 # Input(Data Variable Relative)
+
+05 0c  #USAGE_PAGE(Consumer Devices)
+0a 38 02
+95 01   #REPORT_COUNT (1)	
+81 06  #INPUT (Data,Var,Rel)
+
+c0 # End Collection
+c0 # End Collection
+
+#Characteristic:Hid information
+26 00 03 28 01 02
+27 00 4a 2a 04 11 01 00 01        
+#Characteristic
+28 00 03 28 01 04
+29 00 4c 2a 01 00
+
+#Primary Service: BAS
+2a 00 00 28 02 0f 18 
+#Characteristic: Battery Level
+2b 00 03 28 01 12 
+2c 00 19 2a 01 64 
+#Client Characteristic Configuration
+2d 00 02 29 02 00 00 
+#End of Attribute list
+00 00
+
+
+4c6a:17
+46f9:50
+44c2:14
+44f9:11 46 34 54 77 dd
+
+
+4c7e:00
+4cb8:15 00
+4cba:1d 00
+4cbc:19 00
+4d3e:2c 00
+4c60:50
+
+4c6c:
+0c 00 #Length
+05 00 #CID
+12 b4 
+08 00 
+08 00 #min interval
+08 00 #max interval
+00 00 #latency
+2c 01 #timeout
+
+4419:
+'BT Keyboard
+
+44e4:07 
+44dd:01
+#mem_le_adv_interval_max:00 01
+43d9:1f
+43da:
+#02 01 05 05 02 12 18 0f 18 03 19 c1 03
+02 01 05 03 19 c1 03 03 03 12 18
+4d6b:
+#microsoft swift pair
+06 ff 06 00 03 00 80
+
+43f9:1f
+43fa:
+'\09BT Keyboard
+
+4d53:20 21 12 24		#version data 20211224
+
+4c91:9f 3e
+4c93:cd 4d
+4c8f:04    #01 VINLPM      #02 HVIN      #04 GPIO
+
+#24g init
+4c10:01#tx
+4be2:02        #mouse 1,kb 2
+4c0f:4#max tx retry
+4c0a:00#with ack
+4be4:c0 12     #400us 
+4bf0:00 13 2c 42
+4bf4:06 15 36 48
+4bf8:0f 1a 3a 4c
+4bfc:11 23 31 4d
+4bef:ff
+4beb:20 15 10 05
+4c7d:c2
+0d37:00 00 00 00 00 00 00 00 00 00
+4d40:00 48 5d 00 #10 min
+4d76:ff ff ff ff
+4d7a:e8 fd 00 #00 00 0a
+
+4216:8f 10 ce
+4219:00 0a 0b ef 0f
+41f8:00
+00a3:00 00 00 00 00 00 00 00
+415d:02
+415e:24
+414d:12 00
+414f:00 02
+4151:12 00
+4153:00 02
+415b:20 00
+4157:20 00
+4159:00 20
+415f:80 03
+4161:00 06
+4c98:00 13
+
+429b:30 3f
+42aa:20
+#pointers to tail space of mem_le_att_list
+4f70:
+07 ff #2M_IF
+0a fb
+0b ff 
+
+#agc table
+1a fb
+1b fb
+1c fb
+1d f6
+1e f2
+1f ee
+20 ea
+21 e6
+22 e2
+23 de
+24 da
+25 d6
+26 d2
+27 ce
+28 ca
+29 c6
+2a c2
+2b bd
+2c b9
+2d b5
+2e b1
+2f ad
+30 a9
+31 80
+32 80
+33 80
+34 c0
+35 c1
+36 c2
+37 c3
+38 c4
+39 c5
+3a c6
+3b c7
+3c 06
+3d 07
+3e 46
+3f 85
+40 86
+41 87
+42 c6
+43 c7
+44 d6
+45 d7
+46 e6
+47 f5
+48 00
+49 f8
+4a 7f
+4e ec
+4f 5e
+
+# tx power
+55 d0
+56 c0
+57 4c
+58 6c
+59 50
+
+#dpll
+68 e4
+69 00
+6a 00
+6b 30
+ff
+4163:70 4f
+
+4a91:
+55 d0
+56 c0
+57 4c
+58 6c
+59 50
+
+4a87:
+55 d0
+56 c0
+57 4c
+58 6c
+59 50
+
Index: c51/patch/adc.obj
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/patch/adc.obj
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/patch/bluetooth.obj
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/patch/bluetooth.obj
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/patch/geneep.exe
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/patch/geneep.exe
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/patch/global_variable.obj
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/patch/global_variable.obj
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/patch/gpio.obj
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/patch/gpio.obj
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/patch/iic.obj
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/patch/iic.obj
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/patch/ipc.obj
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/patch/ipc.obj
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/patch/kb.dat
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/patch/kb.dat	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/patch/kb.dat	(working copy)
@@ -0,0 +1,358 @@
+mem_patch00:
+2d   #mem_patch00
+00   #mem_patch01
+00   #mem_patch02
+00   #mem_patch03
+00   #mem_patch04
+00   #mem_patch05
+00   #mem_patch06
+00   #mem_patch07
+00   #mem_patch08
+00   #mem_patch09
+00   #mem_patch0A
+00   #mem_patch0B
+00   #mem_patch0C
+00   #mem_patch0D
+00   #mem_patch0E
+00   #mem_patch0F
+00   #mem_patch10
+00   #mem_patch11
+35   #mem_patch12
+00   #mem_patch13
+00   #mem_patch14
+00   #mem_patch15
+4f   #mem_patch16
+02   #mem_patch17
+00   #mem_patch18
+00   #mem_patch19
+00   #mem_patch1A
+00   #mem_patch1B
+00   #mem_patch1C
+00   #mem_patch1D
+00   #mem_patch1E
+00   #mem_patch1F
+00   #mem_patch20
+00   #mem_patch21
+00   #mem_patch22
+00   #mem_patch23
+00   #mem_patch24
+00   #mem_patch25
+04   #mem_patch26
+c8   #mem_patch27
+00   #mem_patch28
+5c   #mem_patch29
+40   #mem_patch2A
+04   #mem_patch2B
+3a   #mem_patch2C
+ce   #mem_patch2D
+00   #mem_patch2E
+00   #mem_patch2F
+80   #mem_patch30
+e0   #mem_patch31
+00   #mem_patch32
+00   #mem_patch33
+00   #mem_patch34
+00   #mem_patch35
+00   #mem_patch36
+20   #mem_patch37
+00   #mem_patch38
+a0   #mem_patch39
+01   #mem_patch3A
+00   #mem_patch3B
+00   #mem_patch3C
+00   #mem_patch3D
+00   #mem_patch3E
+00   #mem_patch3F
+
+
+mem_customize_timer_setup:  20 00		# 20:10ms  30:15ms
+
+mem_lpm_mode:01
+mem_lpm_mult:40
+mem_lpm_mult_timeout:03
+mem_lpm_overhead:0a
+mem_lpm_interval:10 00
+mem_scan_mode:00
+mem_test:00 00
+
+mem_class: 40 25 00
+
+mem_lap:36 08 c2 08 66 22    
+mem_local_name_length:
+'BT3.0 Keyboard
+mem_sniff_param_interval:0e 00
+mem_sniff_param_attempt:01
+mem_sniff_param_timeout:01
+mem_unsniff2sniff_timer:0a
+mem_ssp_enable:00
+mem_ui_profile_supported:01
+
+mem_eir_enable:01
+
+#bluetootch param init
+mem_sp_flag:00
+mem_lpm_current_mult:00
+mem_master_sp_flag:00
+mem_le_ch_mapped:27
+
+mem_ui_button_gpio:ff
+mem_led_gpio:ff
+
+mem_seqi:80
+
+
+mem_ipc_tx_evt_buff:02 01
+
+
+#attribute list: handle 2bytes, uuid 2bytes, length 1bytes, attribute Nbytes
+mem_le_att_list:
+
+#Primary service: GATT
+01 00 00 28 02 01 18
+#Characteristic: Service changed
+02 00 03 28 01 20
+03 00 05 2a 01 00
+#Client Characteristic Configuration
+04 00 02 29 02 00 00
+
+#Primary Service: GAP
+05 00 00 28 02 00 18 
+#Characteristic: Device Name
+06 00 03 28 01 02 
+07 00 00 2a 
+'BT4.2 Keyboard
+
+#Characteristic: Appearance
+08 00 03 28 01 02 
+09 00 01 2a 02 c1 03 
+#Characteristic: Peripheral Preferred Connection Parameters
+0a 00 03 28 01 02
+0b 00 04 2a 08 06 00 06 00 64 00 2c 01 # interval 6ms, latency 100, timeout 300
+
+#Primary Service: Device Information
+0c 00 00 28 02 0a 18
+#Manufacturer Name
+0d 00 03 28 01 02
+0e 00 29 2a 06 59 69 43 68 69 70			#IOS 13.5.1
+#Characteristic: pnp id
+0f 00 03 28 01 02
+10 00 50 2a 07 02 e8 04 21 70 01 00		# SAMSUNG soft keyboard,setup shortcuts
+
+#Primary service: HID
+11 00 00 28 02 12 18
+#Characteristic:Protocol mode
+12 00 03 28 01 06
+13 00 4e 2a 01 01
+#Characteristic: hid report
+14 00 03 28 01 12   
+15 00 4d 2a 08 00 00 00 00 00 00 00 00	#hid report	led handle write
+16 00 02 29 02 00 00	
+17 00 08 29 02 01 01	#Report ID: 1	Report Type: Input
+#Characteristic:hid report
+18 00 03 28 01 12  
+19 00 4d 2a 05 00 00 00 00 00
+1a 00 02 29 02 00 00
+1b 00 08 29 02 03 01	#Report ID: 3	Report Type: Input
+
+#Characteristic:hid report
+1c 00 03 28 01 12   
+1d 00 4d 2a 02 00 00 	#hid report	led handle write
+1e 00 02 29 02 00 00	
+1f 00 08 29 02 02 01	#Report ID: 2	Report Type: Input
+
+#Characteristic:hid report
+20 00 03 28 01 0e   
+21 00 4d 2a 02 00	00	#hid report	led handle write
+22 00 02 29 02 00 00	
+23 00 08 29 02 01 02	#Report ID: 1	Report Type: Output
+
+#Characteristic:Report map
+24 00 03 28 01 0a
+25 00 4b 2a a0		#length 66+25+60=160=0xa0
+#66
+05 01
+09 06
+a1 01
+85 01
+75 01 
+95 08
+05 07
+19 e0 
+29 e7 
+15 00
+25 01
+81 02
+95 01 
+75 08
+81 03 
+95 05
+75 01
+05 08
+19 01
+29 05  
+91 02 
+95 01  
+75 03  
+91 03
+95 06 
+75 08 
+15 00 
+26 ff 00
+05 07
+19 00
+29 ff 
+81 00
+c0 
+
+#25
+05 0c  		
+09 01  		
+a1 01	
+85 02			
+19 00  		
+2a ff 03 
+15 00 
+26 ff 03		
+95 01  		
+75 10  			
+81 00  		
+c0
+
+#29
+#05 01
+#09 80
+#A1 01
+#85 03
+#15 00
+#25 01
+#75 01
+#95 03
+#19 81
+#29 83
+#81 02
+#95 01
+#75 05
+#81 03
+#C0
+
+#69
+05 01 # Usage Page(Generic Desktop)
+09 02 # Usage(Mouse)
+a1 01 # Collection(Application)
+85 03 # Report ID(3)
+09 01 # Usage(Pointer)
+a1 00 # Collection(Physical)
+05 09 # Usage Page(Buttons)
+19 01 # Usage Minimum(1)
+29 08 # Usage Maximum(8)
+15 00 # Logical Minimum(0)
+25 01 # Logical Maximum(1)
+75 01 # Report Size(1)
+95 08 # Report Count(8)
+81 02 # Input(Data Variable Absolute)
+05 01 # Usage Page(Generic Desktop)
+09 30 # Usage(X)
+09 31 # Usage(Y)
+16 01 80  #Logical Minimum (-32767)
+26 FF 7F #Logical Maximum (32767) 
+75 10 # Report Size(16)
+95 02 # Report Count(2)
+81 06 # Input(Data Variable Relative)
+09 38 # Usage(Wheel)
+15 81 # Logical Minimum(-127)
+25 7f # Logical Maximum(127)
+75 08 # Report Size(8)
+95 01 # Report Count(1)
+81 06 # Input(Data Variable Relative)
+
+05 0c  #USAGE_PAGE(Consumer Devices)
+0a 38 02
+95 01   #REPORT_COUNT (1)	
+81 06  #INPUT (Data,Var,Rel)
+
+c0 # End Collection
+c0 # End Collection
+
+#Characteristic:Hid information
+26 00 03 28 01 02
+27 00 4a 2a 04 11 01 00 01        
+#Characteristic
+28 00 03 28 01 04
+29 00 4c 2a 01 00
+
+#Primary Service: BAS
+2a 00 00 28 02 0f 18 
+#Characteristic: Battery Level
+2b 00 03 28 01 12 
+2c 00 19 2a 01 64 
+#Client Characteristic Configuration
+2d 00 02 29 02 00 00 
+#End of Attribute list
+00 00
+
+
+mem_le_local_mtu:17
+mem_le_transmit_window:50
+mem_le_notify_handle:14
+mem_le_lap:11 46 34 54 77 dd
+
+
+mem_empty_count:00
+mem_att_report1:15 00
+mem_att_report2:1d 00
+mem_att_report3:19 00
+mem_att_report_battery:2c 00
+mem_le_rx_window:50
+
+mem_le_connection_updata_param:
+0c 00 #Length
+05 00 #CID
+12 b4 
+08 00 
+08 00 #min interval
+08 00 #max interval
+00 00 #latency
+2c 01 #timeout
+
+mem_le_name_len:
+'BT Keyboard
+
+mem_le_adv_channel_map:07 
+mem_le_adv_direct_addr_type:01
+#mem_le_adv_interval_max:00 01
+mem_le_adv_data_len:1f
+mem_le_adv_data:
+#02 01 05 05 02 12 18 0f 18 03 19 c1 03
+02 01 05 03 19 c1 03 03 03 12 18
+mem_le_adv_swift_pair:
+#microsoft swift pair
+06 ff 06 00 03 00 80
+
+mem_le_scan_data_len:1f
+mem_le_scan_data:
+'\09BT Keyboard
+
+mem_version_yy_mm_dd:20 21 12 24		#version data 20211224
+
+mem_adc_0v:9f 3e
+mem_adc_3v:cd 4d
+mem_adc_config_flag:04    #01 VINLPM      #02 HVIN      #04 GPIO
+
+#24g init
+mem_24g_mode:01#tx
+mem_24g_data_type:02        #mouse 1,kb 2
+mem_24g_max_retry:4#max tx retry
+mem_24g_no_ack:00#with ack
+mem_24g_rx_window:c0 12     #400us 
+mem_24g_ch_map1:00 13 2c 42
+mem_24g_ch_map2:06 15 36 48
+mem_24g_ch_map3:0f 1a 3a 4c
+mem_24g_ch_map4:11 23 31 4d
+mem_24g_pairing_sm:ff
+mem_24g_paring_addr:20 15 10 05
+mem_pair_state:c2
+mem_24g_common_temp:00 00 00 00 00 00 00 00 00 00
+mem_24g_enter_hibernate:00 48 5d 00 #10 min
+mem_24g_enter_hibernate_max:ff ff ff ff
+mem_24g_short_sleep_counter:e8 fd 00 #00 00 0a
+
Index: c51/patch/kb_keyboard.dat
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/patch/kb_keyboard.dat	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/patch/kb_keyboard.dat	(working copy)
@@ -0,0 +1,499 @@
+mem_patch00:
+2d   #mem_patch00
+00   #mem_patch01
+00   #mem_patch02
+00   #mem_patch03
+00   #mem_patch04
+00   #mem_patch05
+00   #mem_patch06
+00   #mem_patch07
+00   #mem_patch08
+00   #mem_patch09
+00   #mem_patch0A
+00   #mem_patch0B
+00   #mem_patch0C
+00   #mem_patch0D
+00   #mem_patch0E
+00   #mem_patch0F
+00   #mem_patch10
+00   #mem_patch11
+35   #mem_patch12
+00   #mem_patch13
+00   #mem_patch14
+00   #mem_patch15
+4f   #mem_patch16
+02   #mem_patch17
+00   #mem_patch18
+00   #mem_patch19
+00   #mem_patch1A
+00   #mem_patch1B
+00   #mem_patch1C
+00   #mem_patch1D
+00   #mem_patch1E
+00   #mem_patch1F
+00   #mem_patch20
+00   #mem_patch21
+00   #mem_patch22
+00   #mem_patch23
+00   #mem_patch24
+00   #mem_patch25
+04   #mem_patch26
+c8   #mem_patch27
+00   #mem_patch28
+5c   #mem_patch29
+40   #mem_patch2A
+00   #mem_patch2B
+3a   #mem_patch2C
+ce   #mem_patch2D
+00   #mem_patch2E
+00   #mem_patch2F
+80   #mem_patch30
+e0   #mem_patch31
+00   #mem_patch32
+00   #mem_patch33
+00   #mem_patch34
+00   #mem_patch35
+00   #mem_patch36
+20   #mem_patch37
+00   #mem_patch38
+a0   #mem_patch39
+01   #mem_patch3A
+00   #mem_patch3B
+00   #mem_patch3C
+00   #mem_patch3D
+00   #mem_patch3E
+00   #mem_patch3F
+
+
+mem_customize_timer_setup:  20 00		# 20:10ms  30:15ms
+
+mem_lpm_mode:01
+mem_lpm_mult:40
+mem_lpm_mult_timeout:03
+mem_lpm_overhead:0a
+mem_lpm_interval:10 00
+mem_scan_mode:00
+mem_test:00 00
+
+mem_class: 40 25 00
+
+mem_lap:36 08 c2 08 66 22    
+mem_local_name_length:
+'BT3.0 Keyboard
+mem_sniff_param_interval:0e 00
+mem_sniff_param_attempt:01
+mem_sniff_param_timeout:01
+mem_unsniff2sniff_timer:0a
+mem_ssp_enable:00
+mem_ui_profile_supported:01
+
+mem_eir_enable:01
+
+mem_all_uuid_16bits:
+06
+03#Type: Complete list of 16-bit UUIDs
+1100 0001 0210 2411  0012  0100
+
+mem_all_uuid_128bits:00
+
+#keyboard uuid
+mem_kb_uuid_list:
+#uuids
+04 0011 0100 1002 1124
+
+#handle
+00010000
+
+#total length
+360189
+
+#attribute start, first 4 digit is attribute ID
+090000 0a 00010000
+090001 3503 191124
+090004 350d 3506 190100 090011 3503 190011
+090005 3503 191002
+090006 3509 09656e 09006a 090100
+090009 3508 3506 191124 090100
+09000d 350f 350d 3506 190100 090013 3503 190011
+
+#Service Name
+#090100 2517
+#'Apple Wireless Keyboard
+#41 70 70 6c 65 20 57 69 72 65 6c 65 73 73 20 4b 65 79 62 6f 61 72 64
+#Service Name
+090100 253d
+#'Broadcom Bluetooth Wireless  Keyboard                        
+4272 6f61 6463 6f6d 2042 6c75 6574 6f6f 7468 2057 6972 656c 6573 7320 204b 6579 626f 6172 6420 
+2020 2020 2020 2020 2020 2020 2020 2020 2020 2020 2020 20
+
+#Service Description
+090101 2508
+#'Keyboard
+4b6579626f617264
+
+#Provider Name
+#090102 250a
+#'Apple Inc.
+#41 70 70 6c 65 20 49 6e 63 2e
+#Provider Name
+090102 2510
+#'Broadcom Corp.  
+4272 6f61 6463 6f6d 2043 6f72 702e 2020
+
+090200 090100
+090201 090111
+090202 0840
+090203 0821
+090204 2801
+090205 2801
+090206 3578 3576 0822 2572
+
+# hid descriptor
+0501 # Usage Page(Generic Desktop)
+0906 # Usage(Keyboard)
+a101 # Collection(Application)
+8501 # Report ID(1)
+7501 # Report Size(1)
+9508 # Report Count(8)
+0507 # Usage Page(Keyboard/Keypad)
+19e0 # Usage Minimum(224)
+29e7 # Usage Maximum(231)
+1500 # Logical Minimum(0)
+2501 # Logical Maximum(1)
+8102 # Input(Data Variable Absolute) ; Modifier byte
+9501 # Report Count(1)
+7508 # Report Size(8)
+8103 # Input(Constant Variable Absolute) ; 
+9505 # Report Count(5)
+7501 # Report Size(1)
+0508 # Usage Page(LEDs)
+1901 # Usage Minimum(1)
+2905 # Usage Maximum(5)
+9102 # Output(Data Variable Absolute) ; LED report
+9501 # Report Count(1)
+7503 # Report Size(3)
+9103 # Output(Constant Variable Absolute) ; 
+9506 # Report Count(6)
+7508 # Report Size(8)
+1500 # Logical Minimum(0)
+26ff00 # Logical Maximum(255)
+0507 # Usage Page(Keyboard/Keypad)
+1900 # Usage Minimum(0)
+29ff # Usage Maximum(255)
+8100 # Input(Data Array) ; Key arrarys 6 bytes
+c0 # End Collection
+
+05 0c  		
+09 01  		
+a1 01	
+85 02			
+19 00  		
+2a ff 03 
+15 00 
+26 ff 03		
+95 01  		
+75 10  			
+81 00  		
+c0
+
+#23
+05 01	#Usage Page (Generic Desktop),
+09 80	#USAGE (3-D Digitizer)
+a1 01	#Collection (Application),
+85 03	#Report ID (3)
+19 81	#Usage Minimum (), 
+29 88	#Usage Maximum (),
+15 00	#Logical Minimum (0),
+25 01	#Logical Maximum (1),
+95 08	#Report Count (8),
+75 01	#Report Size (1),
+81 06	#Input (Data,Var,Rel)
+#95 01	#Report Count (1),  
+#75 05	#Report Size (5),	
+#81 01	#Input (Const,Ary,Abs)
+c0		#END_COLLECTION
+
+090207 3508 3506 090409 090100
+09020b 090100
+09020c 090c80
+09020d 2800
+09020e 2801
+09020f 090318
+090210 090000
+#attribute end
+
+#uuids for pnpInformation	
+03 1002 1200 0001
+
+#handle
+00010001
+
+#total length 90 bytes
+3600a1
+
+#attribute list
+090000 0a00010001
+090001 3503 191200
+090004 350d 3506 190100 090001 3503 190001
+090006 3509 09656e 09006a 090100
+090009 3508 3506 191200 090100
+090100 252f42726f6164636f6d20426c7565746f6f746820576972656c657373204b6579626f61726420506e5020536572766572
+090101 25084b6579626f617264
+090200 090103
+090201# VendorID
+0904e8
+090202#ProductID
+097021
+090203 090001
+090204 2801
+090205 090002
+
+#attribute end
+00
+
+#Auto reconnection after power on
+
+memui_uuid_table:mem_kb_uuid_list
+#Auto reconnection after power on
+mem_device_option:43
+mem_ptt:0
+mem_features:
+ff
+ff
+8f
+f8	#fe--EDR  F8--BR
+83	#AFHclose 83
+9d
+59
+82
+
+#bluetootch param init
+mem_sp_flag:00
+mem_lpm_current_mult:00
+mem_master_sp_flag:00
+mem_le_ch_mapped:27
+
+mem_ui_button_gpio:ff
+mem_led_gpio:ff
+
+mem_seqi:80
+
+
+mem_ipc_tx_evt_buff:02 01
+
+
+#attribute list: handle 2bytes, uuid 2bytes, length 1bytes, attribute Nbytes
+mem_le_att_list:
+
+#Primary service: GATT
+01 00 00 28 02 01 18
+#Characteristic: Service changed
+02 00 03 28 01 20
+03 00 05 2a 01 00
+#Client Characteristic Configuration
+04 00 02 29 02 00 00
+
+#Primary Service: GAP
+05 00 00 28 02 00 18 
+#Characteristic: Device Name
+06 00 03 28 01 02 
+07 00 00 2a 
+'BT4.2 Keyboard
+
+#Characteristic: Appearance
+08 00 03 28 01 02 
+09 00 01 2a 02 c1 03 
+#Characteristic: Peripheral Preferred Connection Parameters
+0a 00 03 28 01 02
+0b 00 04 2a 08 06 00 06 00 64 00 2c 01 # interval 6ms, latency 100, timeout 300
+
+#Primary Service: Device Information
+0c 00 00 28 02 0a 18
+#Manufacturer Name
+0d 00 03 28 01 02
+0e 00 29 2a 06 59 69 43 68 69 70			#IOS 13.5.1
+#Characteristic: pnp id
+0f 00 03 28 01 02
+10 00 50 2a 07 02 e8 04 21 70 01 00		# SAMSUNG soft keyboard,setup shortcuts
+
+#Primary service: HID
+11 00 00 28 02 12 18
+#Characteristic:Protocol mode
+12 00 03 28 01 06
+13 00 4e 2a 01 01
+#Characteristic: hid report
+14 00 03 28 01 12   
+15 00 4d 2a 08 00 00 00 00 00 00 00 00	#hid report	led handle write
+16 00 02 29 02 00 00	
+17 00 08 29 02 01 01	#Report ID: 1	Report Type: Input
+
+#Characteristic:hid report
+18 00 03 28 01 12  
+19 00 4d 2a 02 00 00
+1a 00 02 29 02 00 00
+1b 00 08 29 02 03 01	#Report ID: 3	Report Type: Input
+
+#Characteristic:hid report
+1c 00 03 28 01 12   
+1d 00 4d 2a 02 00 00 	#hid report	led handle write
+1e 00 02 29 02 00 00	
+1f 00 08 29 02 02 01	#Report ID: 2	Report Type: Input
+
+#Characteristic:hid report
+20 00 03 28 01 0e   
+21 00 4d 2a 02 00	00	#hid report	led handle write
+22 00 02 29 02 00 00	
+23 00 08 29 02 01 02	#Report ID: 1	Report Type: output
+
+#Characteristic:Report map
+24 00 03 28 01 02
+25 00 4b 2a 72
+#66
+05 01
+09 06
+a1 01
+85 01
+75 01 
+95 08
+05 07
+19 e0 
+29 e7 
+15 00
+25 01
+81 02
+95 01 
+75 08
+81 03 
+95 05
+75 01
+05 08
+19 01
+29 05  
+91 02 
+95 01  
+75 03  
+91 03
+95 06 
+75 08 
+15 00 
+26 ff 00
+05 07
+19 00
+29 ff 
+81 00
+c0 
+
+#25
+05 0c  		
+09 01  		
+a1 01	
+85 02			
+19 00  		
+2a ff 03 
+15 00 
+26 ff 03		
+95 01  		
+75 10  			
+81 00  		
+c0
+
+#23
+05 01	#Usage Page (Generic Desktop),
+09 80	#USAGE (3-D Digitizer)
+a1 01	#Collection (Application),
+85 03	#Report ID (3)
+19 81	#Usage Minimum (), 
+29 88	#Usage Maximum (),
+15 00	#Logical Minimum (0),
+25 01	#Logical Maximum (1),
+95 08	#Report Count (8),
+75 01	#Report Size (1),
+81 06	#Input (Data,Var,Rel)
+#95 01	#Report Count (1),  
+#75 05	#Report Size (5),	
+#81 01	#Input (Const,Ary,Abs)
+c0		#END_COLLECTION
+
+#Characteristic:Hid information
+26 00 03 28 01 02
+27 00 4a 2a 04 11 01 00 01        
+#Characteristic
+28 00 03 28 01 04
+29 00 4c 2a 01 00
+
+#Primary Service: BAS
+2a 00 00 28 02 0f 18 
+#Characteristic: Battery Level
+2b 00 03 28 01 12 
+2c 00 19 2a 01 64 
+#Client Characteristic Configuration
+2d 00 02 29 02 00 00 
+#End of Attribute list
+00 00
+
+
+mem_le_local_mtu:17
+mem_le_transmit_window:50
+mem_le_notify_handle:14
+mem_le_lap:11 46 34 54 77 dd
+
+
+mem_empty_count:00
+mem_att_report1:15 00
+mem_att_report2:1d 00
+mem_att_report3:19 00
+mem_att_report_battery:2c 00
+mem_le_rx_window:50
+
+mem_le_connection_updata_param:
+0c 00 #Length
+05 00 #CID
+12 b4 
+08 00 
+08 00 #min interval
+08 00 #max interval
+00 00 #latency
+2c 01 #timeout
+
+mem_le_name_len:
+'BT Keyboard
+
+mem_le_adv_channel_map:07 
+mem_le_adv_direct_addr_type:01
+#mem_le_adv_interval_max:00 01
+mem_le_adv_data_len:1f
+mem_le_adv_data:
+#02 01 05 05 02 12 18 0f 18 03 19 c1 03
+02 01 05 03 19 c1 03 03 03 12 18
+mem_le_adv_swift_pair:
+#microsoft swift pair
+06 ff 06 00 03 00 80
+
+mem_le_scan_data_len:1f
+mem_le_scan_data:
+'\09BT Keyboard
+
+mem_version_yy_mm_dd:20 21 12 24		#version data 20211224
+
+mem_adc_0v:9f 3e
+mem_adc_3v:cd 4d
+mem_adc_config_flag:02    #01 VINLPM      #02 HVIN      #04 GPIO
+
+#24g init
+mem_24g_mode:01#tx
+mem_24g_data_type:02        #mouse 1,kb 2
+mem_24g_max_retry:4#max tx retry
+mem_24g_no_ack:00#with ack
+mem_24g_rx_window:c0 12     #400us 
+mem_24g_ch_map1:00 13 2c 42
+mem_24g_ch_map2:06 15 36 48
+mem_24g_ch_map3:0f 1a 3a 4c
+mem_24g_ch_map4:11 23 31 4d
+mem_24g_pairing_sm:ff
+mem_24g_paring_addr:20 15 10 05
+mem_pair_state:c2
+mem_24g_common_temp:00 00 00 00 00 00 00 00 00 00
+mem_24g_enter_hibernate:00 48 5d 00 #10 min
+mem_24g_enter_hibernate_max:ff ff ff ff
+mem_24g_short_sleep_counter:e8 fd 00 #00 00 0a
+
Index: c51/patch/kb_process.obj
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/patch/kb_process.obj
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/patch/keyboard.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/patch/keyboard.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/patch/keyboard.format	(working copy)
@@ -0,0 +1,357 @@
+
+omemalloc(
+//Keyboard Work Area
+2 mem_kb_state
+6 mem_kb_report_data
+1 mem_kb_keys
+1 mem_kb_rcv_led_data
+4 mem_kb_fast_wake_last
+//Keyboard Config Area
+1 mem_led_cap_gpio
+1 mem_led_num_gpio
+1 mem_led_scl_gpio
+0 mem_kb_map
+630 mem_kb_uuid_list
+
+// patch area
+10 mem_24g_paring_tx_power_param
+10 mem_5db_tx_power_param
+
+//c51
+1 mem_current_event
+1 mem_ipc_lock_rx_data_bt
+1 mem_ipc_lock_rx_data_c51
+1 mem_ipc_lock_tx_data_bt
+1 mem_ipc_lock_tx_data_c51
+
+
+150 mem_ipc_2bt_fifo_head
+0	mem_ipc_2bt_fifo_end
+100 mem_ipc_2C51_fifo_head
+0	mem_ipc_2C51_fifo_end
+2	mem_ipc_2bt_read_index
+2	mem_ipc_2bt_write_index
+2	mem_ipc_2C51_read_index
+2	mem_ipc_2C51_write_index
+
+2 mem_ipc_tx_evt_buff
+1 mem_ipc_tx_evt
+
+2 mem_ipc_bt_timer
+1 mem_ipc_rx_type
+
+0 mem_rfcomm_tx_buff
+
+1 mem_queue_ele_num
+2 mem_queue_write
+2 mem_queue_read
+0 mem_queue_start
+12 mem_uart_packet
+12 mem_data_ele0
+12 mem_data_ele1
+12 mem_data_ele2
+0 mem_queue_end
+2 mem_queue_temp
+
+
+// patch allocated
+1 mem_24g_rxdata_length
+1 mem_24g_pid
+1 mem_24g_datalen
+1 mem_24g_data_type
+1 mem_24g_txlen
+2 mem_24g_rx_window
+1 mem_24g_ensure
+1 mem_24g_get_ack_fail
+1 mem_24g_retry
+1 mem_24g_ch
+1 mem_24g_current_ch_number
+4 mem_24g_paring_addr
+1 mem_24g_pairing_sm
+4 mem_24g_ch_map1
+4 mem_24g_ch_map2
+4 mem_24g_ch_map3
+4 mem_24g_ch_map4
+4 mem_24g_addr
+2 mem_24g_check_dongle_times
+4 mem_24g_device_addr
+1 mem_24g_no_ack
+3 mem_24g_sta_crc
+1 mem_24g_sta_pid
+1 mem_24g_max_retry
+1 mem_24g_mode
+1 mem_24g_hop_pac_retry
+1 mem_24g_idle_timeout
+1 mem_24g_idle_cnt
+1 mem_24g_auto_paring_switch
+1 mem_24g_enter_lpm_timer
+2 mem_24g_syncword
+1 mem_24g_syncword_crc8
+1 mem_24g_get_syncword_crc8
+2 mem_24g_discard_cnt
+2 mem_cb_24g_data
+9 mem_24g_lasttx
+
+1 mem_power_ctrl_pac_succ_cnt
+1 mem_power_ctrl_level
+
+1 mem_rssi_avg_received
+1 mem_rssi_hex_received
+8 mem_rssi_signal_buf
+8 mem_rssi_noise_buf
+1 mem_rssi_noise_index
+1 mem_rssi_signal_index
+
+1 mem_tx_power
+1 mem_tx_power_temp
+3 mem_cnt
+1 mem_last_txlch
+2 mem_last_txlen
+20 mem_last_txdata
+
+//le
+4 mem_ipc_last_check_timer
+1 mem_prepare_write_len
+2 mem_ipc_c51_timer
+1 mem_le_rx_window
+2 mem_le_find_type_value_start_handle
+2 mem_le_find_type_value_end_handle
+2 mem_le_cur_att_type
+1 mem_le_search_len
+1 mem_le_ll_unknown_type
+1 mem_le_pairing_state
+2 mem_le_local_mtu
+16 mem_le_connection_updata_param
+1 mem_ltk_states
+1 mem_pair_state
+1 mem_empty_count
+1 mem_shutter_find_type_value_flag
+
+1 mem_le51_payload_len
+1 mem_le51_cmd
+
+1 mem_le51_tx_length
+1 mem_le51_txbuff_inuse
+9 mem_le51_txbuf
+
+1 mem_ipc_bt_100ms_timer
+1 mem_ipc_c51_100ms_timer
+
+1 mem_adc_config_flag
+1 mem_adc_channel
+2 mem_adc_0v
+2 mem_adc_3v
+2 mem_adc_current_value
+
+1 mem_hibernate_flag
+2 mem_new_supervision_to
+1 mem_kb_wake_timer
+20 mem_kb_last_data
+1 mem_kb_keycount
+1 mem_led_cap_delay_timer
+3 mem_test
+1 mem_seq
+1 mem_recon_index
+1 mem_power_on_flag
+1 mem_caps_num_lock
+2 mem_att_report1
+2 mem_att_report2
+2 mem_att_report3
+
+1 mem_suspend_flag
+120 mem_32asm_data_end
+1 mem_store_ltk_timer
+1 mem_reconnect_continue
+4 mem_le_pin_code
+1 mem_le_send_security_request_flag
+2 mem_att_report_battery
+4 mem_24g_enter_hibernate
+1 mem_24g_txfail_cnt
+1 mem_mouse_retry_flag
+1 mem_24g_led_flag
+4 mem_ui_timer_last_btclk_temp
+4 mem_ui_check_timer_setup
+2 mem_customize_timer_setup
+1 mem_customize_timer
+1 mem_ios_mode_flag
+4 mem_version_yy_mm_dd
+20 mem_24g_txbuf_new
+7 mem_le_adv_swift_pair
+4 mem_24g_enter_hibernate_setup
+4 mem_24g_enter_hibernate_max
+3 mem_24g_short_sleep_counter
+1 mem_pc_sleep_flag
+1 mem_le_pause_enc_flag
+)
+
+//C51 synchronous task
+(
+3 START_C51_CORE
+)
+
+(
+0 ADC_CONFIG_VINLPM
+1 ADC_CONFIG_HVIN
+2 ADC_CONFIG_GPIO
+)
+
+(
+0 P24G_PAIRING_REQ_HEAD
+1 P24G_PAIRING_COMPLETE_HEAD
+)
+
+(
+0 ENSURE_OFF_24G
+1 ENSURE_ON_24G
+0x4e G24_PAIR_CH
+)
+
+(
+7 RSSI_BUF_LEN_SIGNAL
+255 RSSI_BUF_LEN_NOISE
+0x50 RSSI_THRESH_NOISE
+
+0x77 RSSI_DIS_MIN_24G
+0x82 RSSI_DIS_MAX_24G
+
+0x75 RSSI_DIS_MIN_BLE
+0x80 RSSI_DIS_MAX_BLE
+)
+
+(//bluetooth tx power
+0 TX_POWER_0DB
+1 TX_POWER_3DB
+2 TX_POWER_5DB
+3 TX_POWER_f3DB
+4 TX_POWER_f5DB
+)
+
+/* 24g */
+(
+6 dlen_24g
+14 plen_24g
+90 blen_tx_24g
+106 blen_rx_24g
+42 blen_txack_24g
+58 blen_rxack_24g
+7 retry_24g
+0xaaf08e acc_24g
+0x15c4 crc_data_3byte
+0xbb81 crc_data_6byte
+0x4160 crc_ack
+41390 crc_ack_4byte
+)
+
+(
+1 NO_ACK_24g
+0 with_ack_24g
+)
+
+(
+0 disable_24g
+1 tx_24g
+2 rx_24g
+
+0 bit_ack_24g
+)
+
+
+//mem_24g_data_type
+(
+0x07 bits_data
+//0-2 data type
+3 bit_abort
+4 bit_hop
+5 bit_sync
+//6-7 channel offset
+)
+
+// ble
+(
+0 FLAG_LE_PAIRING_NULL
+1 FLAG_LE_PAIRING_START
+2 FLAG_LE_PAIRING_AFTER_AUTH
+3 FLAG_LE_PAIRING_END
+)
+
+(
+0 PAIR_UNKNOWN
+1 PAIR_ING
+2 PAIR_DONE
+)
+
+(
+0 DEFAULT_STATES
+1 IPHONE_LOST_LTK
+2 MODULE_LOST_LTK
+3 LTK_NOT_LOST
+)
+
+(
+3 QUEUE_ELE_COUNT
+12 QUEUE_ELE_LENGTH
+)
+
+
+8 KB_KSCAN_ROW 
+7 KB_KSCAN_ROW_1
+20 KB_KSCAN_COL
+19 KB_KSCAN_COL_1
+
+/* ks_ctrl */
+(
+0x01 KB_KSCAN_CTRL_ENABLE					
+0x02 KB_KSCAN_CTRL_FREEZE					
+0x04 KB_KSCAN_CTRL_GHOST					
+0x08 KB_KSCAN_CTRL_INT						
+0x10 KB_KSCAN_CTRL_CLKON					
+0x20 KB_KSCAN_CTRL_FIFO_CLR				
+                  
+0 KB_KSCAN_STAT_EMPTY
+1 KB_KSCAN_STAT_FULL 					
+2 KB_KSCAN_STAT_OVERFLOW				
+6 KB_KSCAN_STAT_GHOST 
+
+0 KB_KSCAN_KEY_EVENT_STAT
+0 KB_KSCAN_KEY_PRESS	
+1 KB_KSCAN_KEY_RELEASE
+
+)
+
+
+/* special key codes */
+(
+0x1d KB_KCODE_1_M1
+0x27 KB_KCODE_0
+0x28 KB_KCODE_ENTER
+0x2a KB_KCODE_BKSP
+)
+
+(
+0x01 HID_REPORTID_1
+0x02 HID_REPORTID_2
+0x03 HID_REPORTID_3
+0x04 HID_REPORTID_4
+)
+
+(
+/*DATA OUTPUT report id = 1*/
+0 KB_NUM_LOCK_SELECTED
+1 KB_CAPS_LOCK_SELECTED
+2 KB_SCROLL_LOCK_SELECTED
+)
+
+(
+0x1f  KB_UI_BUTTON_GPIO
+)
+
+(
+0x0007 HANDLE_UUID_CHRCTR_DEVICE_NAME
+0x000e HANDLE_UUID_CHRCTR_MANUFACTURER_NAME
+0x0010 HANDLE_UUID_PNP_ID
+0x0021 HANDLE_UUID_CHRCTR_REPORT_ID1_OUTPUT
+0x002c HANDLE_UUID_BATTERY_LEVEL
+0x002d HANDLE_UUID_END
+)
+
+
Index: c51/patch/keyscan.obj
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/patch/keyscan.obj
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/patch/led.obj
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/patch/led.obj
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/patch/memmap.format
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/patch/memmap.format	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/patch/memmap.format	(working copy)
@@ -0,0 +1,1124 @@
+0x0000 mem_le_adv_transmit
+0x0001 mem_le_adv_waitcnt
+0x0002 mem_le_adv_rcv
+0x0003 mem_le_req_rcv
+0x0004 mem_le_scanrsp_rcv
+0x0005 mem_le_conn_rcv
+0x0006 mem_inquiryscan_waitcnt
+0x0007 mem_inquiryscan_rcvcnt
+0x0008 mem_pagescan_waitcnt
+0x0009 mem_pagescan_rcvcnt
+0x000a mem_pagescan_rcvfhscnt
+0x000b mem_slave_rcvcnt
+0x000c mem_page_transmit
+0x000d mem_page_rcv
+0x000e mem_page_rcv_fhs
+0x000f mem_master_rcvcnt
+0x0010 mem_fhs_wait_counter
+0x0011 mem_newconnto_counter
+0x0012 mem_inquiry_transmit
+0x0013 mem_inquiry_rcv
+0x0014 mem_fw_ver
+0x0015 mem_current_context
+0x0016 mem_le_ch_mapped
+0x0017 mem_last_freq
+0x0018 mem_rssi
+0x0019 mem_rx_type
+0x001a mem_rx_hec_err
+0x001c mem_rx_crc_err
+0x001e mem_context_ptr
+0x0020 mem_display
+0x0028 mem_bcd
+0x0030 mem_state
+0x0031 mem_mode
+0x0032 mem_tsniff
+0x0034 mem_sniff_anchor
+0x0038 mem_clk_offset
+0x003e mem_rx_window
+0x0040 mem_plap
+0x0043 mem_puap
+0x0044 mem_pnap
+0x0046 mem_conn_handle
+0x0047 mem_arq
+0x0048 mem_lmp_to_send
+0x0049 mem_lmi_opcode
+0x004a mem_lmo_reason
+0x004b mem_op
+0x004c mem_state_map
+0x004d mem_supervision_timer
+0x0051 mem_supervision_to
+0x0053 mem_name_offset
+0x0054 mem_key_size
+0x0055 mem_conn_sm
+0x0056 mem_aco
+0x0062 mem_kc
+0x0072 mem_conn_timer
+0x0073 mem_sniff_attempt
+0x0074 mem_sniff_timeout
+0x0075 mem_dsniff
+0x0077 mem_amaddr
+0x0078 mem_lmo_opcode1
+0x0079 mem_lmi_opcode1
+0x007a mem_lmo_reason1
+0x007b mem_lmo_tid1
+0x007c mem_lmo_opcode2
+0x007d mem_lmi_opcode2
+0x007e mem_lmo_reason2
+0x007f mem_lmo_tid2
+0x0080 mem_hci_version
+0x0083 mem_acl_pktlen
+0x0085 mem_sco_pktlen
+0x0086 mem_acl_pktcnt
+0x0088 mem_sco_pktcnt
+0x008a mem_current_sniff_attempt
+0x008b mem_current_sniff_timeout
+0x008c mem_nfreq_index_inq
+0x008d mem_nfreq_index_page
+0x008e mem_ninqy_index
+0x008f mem_fhs_misc
+0x0090 mem_tx_lch
+0x0091 mem_tx_len
+0x0093 mem_subsniff_instant
+0x0097 mem_subsniff_rate
+0x0098 mem_subsniff_tcmax
+0x009a mem_subsniff_tsniff
+0x009b mem_lpm_adjust
+0x009c mem_sync_clke
+0x00a2 mem_lpm_current_mult
+0x00a3 mem_gpio_wakeup_low
+0x00a7 mem_gpio_wakeup_high
+0x00ab mem_air_mode
+0x00ac mem_sco_asso_handle
+0x00ad mem_sco_handle
+0x00af mem_esco_desco
+0x00b0 mem_esco_type
+0x00b1 mem_neogotiation_state
+0x00b2 mem_saved_amaddr
+0x00b3 mem_esco_arq
+0x00b4 mem_esco_saved_arq
+0x00b5 mem_sco_obuf
+0x00d3 mem_sco_ibuf
+0x00f1 mem_sco_poll
+0x00f2 mem_npage_index
+0x00f3 mem_page_mode
+0x00f4 mem_page_clk
+0x00f8 mem_tst_pktcnt_sync
+0x00fa mem_tst_pktcnt_hec
+0x00fc mem_tst_pktcnt_crc
+0x00fe mem_tst_pktcnt_dmh
+0x0100 mem_tmp_buffer_head
+0x0103 mem_tmp_buffer
+0x0153 mem_tester_emulate
+0x0154 mem_temp_payload
+0x0154 test_mode_scenario
+0x0155 test_mode_hopping_mode
+0x0156 test_mode_tx_freq
+0x0157 test_mode_rx_freq
+0x0158 test_mode_power_mode
+0x0159 test_mode_poll_period
+0x015a test_mode_packet_type
+0x015b test_mode_data_length
+0x015d mem_test_mode_old_debug_config
+0x015e mem_tester_cnt
+0x015f mem_temp_am_addr
+0x0160 mem_temp_arq
+0x0161 mem_pdatatemp
+0x0169 mem_len
+0x016b mem_clkn_bt
+0x016f mem_clke_bt
+0x0173 mem_dpll_clkn
+0x0177 mem_connection_options
+0x0178 mem_nameres_cnt
+0x0179 mem_txptr
+0x017b mem_slot_offset
+0x017d extm_fhs_misc
+0x017e extm_newconn_am_addr
+0x017f extm_class
+0x0182 extm_lap
+0x0185 extm_uap
+0x0186 extm_nap
+0x0189 mem_debug_config
+0x018a mem_lch_code
+0x018b mem_fhs_am_addr
+0x018c mem_dpll_error
+0x018e mem_bdaddr_list_buff
+0x01b2 mem_select_list_item
+0x01b3 mem_temp_reconn_record
+0x01b3 mem_record_bt_mode
+0x01b4 mem_temp_lap
+0x01ba mem_list_item_ptr
+0x01bc mem_eir
+0x0220 mem_ucode_status
+0x0221 mem_otp_ucode_flag
+0x0223 mem_spid_tbuf/* spid buf: 03 addr[23:16] addr[15:8] addr[7:0] */
+0x0224 mem_iicd_tbuf/* iicd buf: iic_adr addr[15:8] addr[7:0] iic_adr */
+0x0224 mem_addr_hi
+0x0225 mem_addr_mi
+0x0226 mem_addr_lo
+0x0227 mem_iicd_addr
+0x0228 mem_spid_rbuf
+0x022c mem_ucode_buf
+0x022e mem_ucode_len
+0x0230 mem_sched_addr
+0x0232 mem_ucode_ptr
+0x0234 mem_ucode_keybuf
+0x0244 mem_check_plap_temp
+0x0256 mem_sensor_id
+0x0257 mem_reconnect_flag
+0x0258 mem_switch_fail_master_count
+0x0259 mem_app_evt_timer_count
+0x025a mem_dongle_count
+0x025b mem_le_addr_slave1
+0x0261 mem_le_addr_slave2
+0x0267 mem_le_peer_state
+0x0268 mem_app_peer_addr
+0x026e mem_dongle_peers
+0x026f mem_dongle_pairing_cnt
+0x0270 mem_dongle_signature
+0x0272 mem_h5rx_ackcnt
+0x0273 mem_check_err_acl_cont
+0x0274 mem_rp_packets
+0x0275 mem_packet_type
+0x0277 mem_hci_sniff_conn_handle
+0x0279 mem_hci_sniff_max_interval
+0x027b mem_hci_sniff_min_interval
+0x027d mem_hci_sniff_attempt
+0x027f mem_hci_sniff_timeout
+0x0281 mem_voice_setting
+0x0283 mem_retransmission_effort
+0x0284 mem_sco_ptype
+0x0286 mem_extm_uap_restore
+0x0289 mem_h5rx_rptr
+0x028b mem_h5rx_ack
+0x028c mem_h5tx_ack
+0x028d mem_h5tx_rptr
+0x028f mem_h5tx_wptr
+0x0291 mem_h5tx_free
+0x0293 mem_h5rx_tmp
+0x0294 mem_h5tx_seq
+0x0295 mem_hci_acl_queue_wptr
+0x0297 mem_hci_acl_queue_rptr
+0x0299 mem_hci_acl_queue_end
+0x029b mem_hci_acl_queue_wcnt
+0x029c mem_hci_acl_cnt
+0x029d mem_hci_acl_tx_trigger_wptr//tx via uart
+0x029f mem_ucode_id_local
+0x02a0 mem_temp//8 bytes
+0x02a8 mem_timeup// 4 bytes
+0x02ac mem_rega//4 bytes
+0x02b0 mem_regb//4 bytes
+0x02b4 mem_regc//3 bytes
+0x02b7 mem_contr//2 bytes
+0x02b9 mem_contw//2 bytes
+0x02bb mem_ucode_id_remote
+0x02bc mem_check_sum
+0x02bd mem_ucode_temp
+0x02be mem_ucode_temp1
+0x02bf mem_lock_in_enc//boolean
+0x02c0 mem_hci_disconn_reason
+0x02c1 mem_hci_curr_len
+0x02c2 mem_hci_curr_target
+0x02c4 mem_l2cap_mem_start
+0x02c4 mem_l2cap_rxbuff1_len
+0x02c6 mem_l2cap_rxbuff2_len
+0x02c8 mem_l2cap_rxbuff_new
+0x02ca mem_l2cap_rxbuff_inuse
+0x02cb mem_l2cap_payload_ptr
+0x02cd mem_l2cap_rx_pkt_length
+0x02cf mem_l2cap_rx_cid
+0x02d1 mem_l2cap_rx_done
+0x02d2 mem_l2cap_signal_tx_buff_ptr
+0x02d4 mem_l2cap_signal_tx_payload_ptr
+0x02d6 mem_l2cap_signal_tx_length
+0x02d8 mem_sdp_tx_buff_ptr
+0x02da mem_sdp_tx_payload_ptr
+0x02dc mem_sdp_tx_pkt_length
+0x02de mem_rfcomm_tx_buff_ptr
+0x02e0 mem_rfcomm_tx_payload_ptr
+0x02e2 mem_rfcomm_tx_pkt_length
+0x02e4 memL2CAP_T1
+0x02e6 mem_CONTROL_tasks
+0x02e7 mem_send_config_req
+0x02e8 mem_config_identifier
+0x02e9 mem_config_req_dest_CID
+0x02eb mem_rfcomm_malloc_fail_flag
+0x02ec mem_message_to_uppersm
+0x02ed mem_upper_sm_remote_page
+0x02ee mem_upper_sm_reconn
+0x02ef mem_upper_sm_ss
+0x02f0 mem_tx_malloc_log
+0x0330 mem_l2cap_mem_end
+0x0330 mem_scid
+0x0332 mem_cmd_length
+0x0334 mem_tt2
+0x0336 mem_tt3
+0x0338 mem_id
+0x033a mem_psm
+0x033c mem_l2cap_sdpres_delay_time
+0x0340 mem_le_rxbuf
+0x0378 mem_le_mic
+0x037c mem_le_peer_mic
+0x0380 mem_le_skdm
+0x0388 mem_le_skds
+0x0390 mem_le_peer_ltk
+0x03a0 mem_le_my_ltk
+0x03b0 mem_le_mrand
+0x03c0 mem_le_state
+0x03c1 mem_le_mode
+0x03c2 mem_le_tsniff
+0x03c4 mem_le_anchor
+0x03c8 mem_le_clk_offset
+0x03ce mem_le_receive_window
+0x03d0 mem_le_plap
+0x03d6 mem_le_conn_handle
+0x03d7 mem_le_arq
+0x03d8 mem_le_ch
+0x03d9 mem_le_hop
+0x03da mem_le_event_count
+0x03dc mem_le_supervision_timer
+0x03e0 mem_le_instant
+0x03e2 mem_le_channels
+0x03e3 mem_le_conn_sm
+0x03e4 mem_le_op
+0x03e5 mem_le_access
+0x03e9 mem_le_crcinit
+0x03ec mem_le_window_size
+0x03ed mem_le_slave_latency
+0x03ef mem_le_superto
+0x03f1 mem_le_channel_map
+0x03f6 mem_le_no_using
+0x03f8 mem_le_peer_sca
+0x03f9 mem_le_att_opcode
+0x03fa mem_le_att_handle
+0x03fc mem_le_err_code
+0x03fd mem_le_sk
+0x040d mem_le_testtype
+0x040e mem_le_test_sync
+0x0410 mem_le_test_pcnt
+0x0412 mem_le_rxon_ts
+0x0418 mem_le_rx_ll_opcode
+0x0419 mem_le_notify_attr_start
+0x041b mem_le_notify_len
+0x041c mem_cmd_le_create_conn
+0x041d mem_le_adv_temp
+0x0431 mem_24g_id
+0x0432 mem_lmo_header_length
+0x0433 mem_lmo_header_opcode
+0x0434 mem_lmo_payload
+0x0445 mem_lmi_accepted_opcode
+0x0446 mem_disconn_reason_send
+0x0447 mem_tx_fixed_freq
+0x0448 mem_rx_fixed_freq
+0x0449 mem_ext_features_page
+0x044a mem_lmpext_ssp_enable
+0x044c mem_remote_sppcap
+0x044d mem_lmp_conn_state
+0x044e mem_soft_timer
+0x0450 mem_pincode_state
+0x0451 mem_sres_tid
+0x0452 mem_accptsco_tid
+0x0453 mem_auth_enable
+0x0454 mem_wait_encryption
+0x0455 mem_sniff_payload
+0x0465 mem_aurand_send_delay_time
+0x0469 mem_module_temp_len
+0x046b mem_init_cnt
+0x046d mem_prcp_data
+0x0481 mem_prcp
+0x0482 mem_prcp_tx_len
+0x0483 rx_buf_data_ptr
+0x0485 memRemoteRPNBitRate
+0x0486 memRemotePRNDataBits
+0x0487 memRemotePRNStopBit
+0x0488 memRemotePRNParity
+0x0489 memRemotePRNFlowControl
+0x048a memRemotePRNXon
+0x048b memRemotePRNXoff
+0x048c mem_mod2div_temp
+0x048f mem_contw_temp
+0x0491 mem_attrib_list
+0x0493 mem_current_adss
+0x0494 mem_current_channel
+0x0495 mem_current_frame_type
+0x0496 mem_current_fcs
+0x0497 mem_current_length
+0x0499 mem_rfcomm_uih_payload_ptr
+0x049b mem_uih_cmd_type
+0x049c mem_uih_length
+0x049e mem_param_payload_ptr
+0x04a0 mem_ms_param
+0x04a1 mem_pn_credit_flow_type_info
+0x04a2 mem_pn_priority
+0x04a3 mem_pn_acknowledg_timer
+0x04a4 mem_pn_max_retrans
+0x04a5 mem_rfcomm_send_adss
+0x04a6 mem_rfcomm_send_frame_type
+0x04a7 mem_rfcomm_send_fcs
+0x04a8 mem_rfcomm_send_offset
+0x04a9 mem_sdp_mem_start
+0x04a9 mem_uuid_search_pat
+0x04ad mem_sdp_continue_byte
+0x04af mem_sdp_pduid
+0x04b0 mem_sdp_transactionid
+0x04b2 mem_sdp_attribute_maxbyte
+0x04b4 mem_sdp_record_maxcnt
+0x04b6 mem_sdp_error_code
+0x04be mem_sdp_record_handle
+0x04c2 mem_sdp_search_failed
+0x04c3 mem_sdp_LACAP_found
+0x04c4 mem_sdp_RFCOMM_found
+0x04c5 mem_handle_list
+0x04dd mem_handle_humber
+0x04de mem_sdp_mem_end
+0x04de mem_rxbuf
+0x04ef mem_random_number
+0x04ff mem_round_key
+0x050f mem_kinit
+0x051f mem_input_store
+0x052f mem_x
+0x053f mem_y
+0x054e mem_y15
+0x054f mem_pin_length
+0x0550 mem_pin
+0x0560 mem_key_store
+0x0571 mem_key_store_end
+0x0572 memp_ar_key
+0x0574 memp_ar_input
+0x0576 mem_ar_hround
+0x0580 mem_ec_infinite
+0x0581 mem_ec_loopc
+0x0582 memdat
+0x0582 mem_ax
+0x059a mem_ay
+0x05b2 mem_az
+0x05ca mem_bx
+0x05e2 mem_by
+0x05fa mem_bz
+0x0612 mem_cx
+0x062a mem_cy
+0x0641 mem_cy5
+0x0642 mem_cz
+0x065a mem_k
+0x0672 mem_align
+0x0682 mem_tmp1
+0x0682 memahbak
+0x069a mem_tmp5
+0x06a2 memahsave
+0x06b2 mem_tmp2
+0x06c2 memahsave_end
+0x06c2 mem_addr_padding
+0x06c3 mem_addr_value/* 12 bytes     */ 
+0x06ca mem_tmp3
+0x06ca mem_t1
+0x06cf mem_addr_value_end
+0x06d2 mem_addr_iocap_end
+0x06e2 mem_tmp0
+0x06e2 mem_t0
+0x06ea mem_tmp0a
+0x06fa mem_t2
+0x0712 mem_t3
+0x072a mem_t7
+0x0742 mem_p
+0x075a mem_a
+0x0772 mem_b
+0x078a mem_gx
+0x07a2 mem_gy
+0x07ba memh0
+0x07da mem_sp_state_start
+0x07da mem_sp_state
+0x07db mem_master_sp_state
+0x07dc mem_sp_flag
+0x07dd mem_master_sp_flag
+0x07de mem_sp_calc
+0x07df mem_sp_dh_ready
+0x07e0 mem_sp_localsm
+0x07e1 mem_pairing_auth
+0x07e2 mem_sp_flag_start
+0x07e2 mem_sp_local_key_send_count
+0x07e3 mem_sp_remote_key_recv_count
+0x07e4 mem_sp_remote_key_invalid
+0x07e5 mem_sp_dhkey_invalid
+0x07e6 mem_sp_iocap_local
+0x07e9 mem_sp_iocap_remote
+0x07ec mem_sp_gkey
+0x07f0 mem_sp_pubkey_remote
+0x07f0 mem_sp_pubkey_remote_x
+0x0808 mem_sp_pubkey_remote_x_end
+0x0808 mem_sp_pubkey_remote_y
+0x0820 mem_sp_dhkey
+0x0838 mem_sp_dhkey_end
+0x0838 mem_sp_random_local
+0x0848 mem_sp_random_local_end
+0x0848 mem_sp_random_remote
+0x0858 mem_sp_random_remote_end
+0x0858 memresult
+0x0858 mem_sp_calc_result
+0x0858 memh
+0x085c memg
+0x0860 memf
+0x0864 meme
+0x0868 mem_sp_calc_result_high
+0x0868 memd
+0x086c memc
+0x0870 memb
+0x0874 mema
+0x0878 mem_sp_check_result
+0x0888 mem_sp_confirm_remote
+0x0898 mem_sp_prarm_stack
+0x08a8 mem_UI_data_txbuff_length
+0x08aa mem_ipc_skip_continue_proc
+0x08ab mem_ui_timer_temp//length 4
+0x08ab mem_ipc_rega_temp
+0x08af mem_usb_status
+0x08b0 mem_usb_fifo_empty
+0x08b1 mem_usb_read_len
+0x08b2 mem_usb_rxbuf
+0x08f2 mem_usb_cnt
+0x08f4 mem_usb_tx_enable
+0x08f5 mem_usb_tx_count
+0x08f6 mem_usb_set_protocol_count
+0x08f7 mem_usb_desc
+0x08f8 mem_usb_state
+0x08f9 mem_usb_idle_cnt
+0x08fb mem_usb_idle_timeout
+0x08fd mem_usb_trig_timeout
+0x08ff mem_usb_setup
+0x08ff mem_usb_setup_bmRequestType
+0x0900 mem_usb_setup_bRequest
+0x0901 mem_usb_setup_bValue
+0x0902 mem_usb_setup_bValueH
+0x0903 mem_usb_setup_wIndex
+0x0905 mem_usb_setup_bLength
+0x0906 mem_usb_setup_bLengthH
+0x0907 mem_usb0_setup
+0x090f mem_bufptr
+0x0911 mem_remain
+0x0912 mem_devicedesc
+0x0926 mem_hidreportdesc_kb
+0x09ee mem_hidreportdesc_m
+0x0ab6 mem_confdesc
+0x0b1a mem_string0
+0x0b1f mem_string1
+0x0b3d mem_string2
+0x0b5b mem_string3
+0x0b79 mem_hold_contr
+0x0b7b mem_hold_contw
+0x0b7d mem_fifo_temp
+0x0b7e mem_c51_flag
+0x0b7f mem_c51_lpm_lock
+0x0b80 mem_c51_wait_lpm
+0x0b81 mem_wakup_from_power_flag
+0x0b82 mem_lmp_bb_disconnect_reason
+0x0b83 mem_c51_eeprom_buf
+0x0be7 mem_c51_ipc_txbuf
+0x0c4b mem_c51_ipc_rxbuf
+0x0caf mem_c51_iicd_buf
+0x0cb3 mem_24g_rxbuf
+0x0cd5 mem_24g_txbuf
+0x0cf5 mem_24g_txpayload
+0x0d17 mem_24g_rxpayload
+0x0d37 mem_24g_common_temp
+0x0d57 mem_packet_length_temp
+0x0d58 mem_le_cur_handle_start
+0x0d5a mem_le_cur_handle_end
+0x0d5c mem_le_search_res
+0x4000 mem_patch00
+0x4001 mem_patch01
+0x4002 mem_patch02
+0x4003 mem_patch03
+0x4004 mem_patch04
+0x4005 mem_patch05
+0x4006 mem_patch06
+0x4007 mem_patch07
+0x4008 mem_patch08
+0x4009 mem_patch09
+0x400a mem_patch0a
+0x400b mem_patch0b
+0x400c mem_patch0c
+0x400d mem_patch0d
+0x400e mem_patch0e
+0x400f mem_patch0f
+0x4010 mem_patch10
+0x4011 mem_patch11
+0x4012 mem_patch12
+0x4013 mem_patch13
+0x4014 mem_patch14
+0x4015 mem_patch15
+0x4016 mem_patch16
+0x4017 mem_patch17
+0x4018 mem_patch18
+0x4019 mem_patch19
+0x401a mem_patch1a
+0x401b mem_patch1b
+0x401c mem_patch1c
+0x401d mem_patch1d
+0x401e mem_patch1e
+0x401f mem_patch1f
+0x4020 mem_patch20
+0x4021 mem_patch21
+0x4022 mem_patch22
+0x4023 mem_patch23
+0x4024 mem_patch24
+0x4025 mem_patch25
+0x4026 mem_patch26
+0x4027 mem_patch27
+0x4028 mem_patch28
+0x4029 mem_patch29
+0x402a mem_patch2a
+0x402b mem_patch2b
+0x402c mem_patch2c
+0x402d mem_patch2d
+0x402e mem_patch2e
+0x402f mem_patch2f
+0x4030 mem_patch30
+0x4031 mem_patch31
+0x4032 mem_patch32
+0x4033 mem_patch33
+0x4034 mem_patch34
+0x4035 mem_patch35
+0x4036 mem_patch36
+0x4037 mem_patch37
+0x4038 mem_patch38
+0x4039 mem_patch39
+0x403a mem_patch3a
+0x403b mem_patch3b
+0x403c mem_patch3c
+0x403d mem_patch3d
+0x403e mem_patch3e
+0x403f mem_patch3f
+0x4040 mem_context
+0x4130 mem_current_amaddr
+0x4131 mem_lpm_mode
+0x4132 mem_device_option
+0x4133 mem_scan_mode
+0x4134 mem_last_clkn
+0x4138 mem_features
+0x4140 mem_lap
+0x4143 mem_uap
+0x4144 mem_nap
+0x4146 mem_npage
+0x4147 mem_glap
+0x414a mem_class
+0x414d mem_iscan_window
+0x414f mem_iscan_interval
+0x4151 mem_pscan_window
+0x4153 mem_pscan_interval
+0x4155 mem_page_interval
+0x4157 mem_page_window
+0x4159 mem_page_to
+0x415b mem_inq_window
+0x415d mem_fcomp_mul
+0x415e mem_fcomp_div
+0x415f mem_rx_window_init
+0x4161 mem_rx_window_sniff
+0x4163 mem_rf_init_ptr
+0x4165 mem_last_type
+0x4166 mem_last_type_esco
+0x4167 mem_last_type_saved
+0x4168 mem_retransmission_cnt
+0x416a mem_next_btclk
+0x416e mem_seqi
+0x416f mem_rf_rccal
+0x4170 mem_handle_num
+0x4171 mem_max_slot
+0x4172 mem_eir_enable
+0x4173 mem_afh_instant
+0x4177 mem_afh_error_total
+0x4179 mem_afh_cfg
+0x417a mem_afh_new_mod
+0x417b mem_afh_map_lo
+0x4180 mem_afh_map_hi
+0x4185 mem_afh_used
+0x4186 mem_afh_index
+0x4188 mem_afh_map_new
+0x4193 mem_afh_map
+0x41e3 mem_afh_timer
+0x41e7 mem_afh_classify_channel_map
+0x41f1 mem_chip_functions
+0x41f3 mem_lpm_wake_lock
+0x41f5 mem_lpm_interval
+0x41f7 mem_lpm_overhead
+0x41f8 mem_lpm_hibernate_switch
+0x41f9 mem_esco_addr
+0x41fa mem_sniff_unint_lost
+0x41fb mem_ptt
+0x41fc mem_sleep_counter//should be 0x41fc in REVC
+0x4200 mem_sleep_counter_all
+0x4204 mem_sleep_clkn
+0x420a mem_sniff_rcv
+0x420d mem_sniff_lost
+0x4210 mem_clks_per_lpo
+0x4213 mem_lpm_mult
+0x4214 mem_lpm_mult_timeout
+0x4215 mem_lpm_mult_cnt
+0x4216 mem_lpm_config
+0x4219 mem_lpm_xtalcnt
+0x421a mem_lpm_buckcnt
+0x421b mem_lpm_ldocnt
+0x421c mem_lpm_isogate
+0x421d mem_lpm_isogate_final
+0x421e mem_saved_gpio// should be 0x421e in REVC
+0x422e mem_saved_gsel
+0x4231 mem_saved_mark
+0x4239 mem_saved_spidctrl
+0x423a mem_patch_ptr
+0x423c mem_patch_len
+0x423e mem_timers
+0x425e mem_link_key_exists
+0x425f mem_link_key_eeprom_head
+0x4262 mem_link_key
+0x4272 mem_hci_cmd
+0x4273 mem_hci_conn_handle
+0x4274 mem_hci_plap
+0x4277 mem_hci_puap
+0x4278 mem_hci_pnap
+0x427a mem_uartd_rxitems_got_data
+0x427b mem_uartd_rxitems_threshold
+0x427c mem_uartd_rx_timeout
+0x427e mem_app_state
+0x427f mem_app_handshake_flag
+0x4280 mem_sniff_param_interval
+0x4282 mem_sniff_param_attempt
+0x4284 mem_sniff_param_timeout
+0x4286 mem_cb_check_wakelock
+0x4288 mem_cb_before_hibernate
+0x428a mem_cb_before_lpm
+0x428c mem_cb_le_process
+0x428e mem_cb_bt_process
+0x4290 mem_cb_idle_process
+0x4292 mem_cb_bb_event_process
+0x4294 mem_cb_discovry_timeout
+0x4296 mem_cb_att_write
+0x4298 mem_cb_update_notify_value
+0x429a mem_device_nums
+0x429b mem_eeprom_base
+0x429d mem_unsniff2sniff_timer_count
+0x429e mem_wake_up_delay_timer
+0x429f mem_app_connection_options
+0x42a0 mem_app_disconn_reason
+0x42a2 mem_app_disconn_reason_flag
+0x42a4 mem_at_using_flag
+0x42a5 mem_lpm_delay_after_sniff
+0x42a9 mem_xrecord_mode
+0x42aa mem_eeprom_block_size
+0x42ac mem_baud
+0x42ae mem_hci_lt_rx_state
+0x42af mem_l2cap_xmem_start
+0x42af mem_l2cap_tx_multi_offset//0 means single packet
+0x42b1 mem_sdp_remote_cid
+0x42b3 mem_rfcomm_remote_cid
+0x42b5 mem_hid_ctrl_remote_cid
+0x42b7 mem_hid_int_remote_cid
+0x42b9 mem_sdp_state
+0x42ba mem_rfcomm_state
+0x42bb mem_hid_control_state
+0x42bc mem_hid_interrupt_state
+0x42bd mem_spp_state
+0x42be mem_ML2CAP_comm_id
+0x42bf mem_used_map
+0x42c0 mem_tx_fifo0
+0x42c0 mem_tx_fifo0_map
+0x42c1 mem_tx_fifo0_ptr
+0x42c3 mem_tx_fifo1
+0x42c3 mem_tx_fifo1_map
+0x42c4 mem_tx_fifo1_ptr
+0x42c6 mem_tx_fifo2
+0x42c6 mem_tx_fifo2_map
+0x42c7 mem_tx_fifo2_ptr
+0x42c9 mem_tx_fifo3
+0x42c9 mem_tx_fifo3_map
+0x42ca mem_tx_fifo3_ptr
+0x42cc mem_tx_fifo_end
+0x42cc mem_l2cap_lpm_txbuf
+0x43cc mem_l2cap_flow_ctrl_flag
+0x43cd mem_l2cap_pending_item
+0x43ce mem_l2cap_xmem_end
+0x43ce mem_le_dsniff
+0x43d0 mem_le_conn_interval
+0x43d2 mem_le_scan_enable
+0x43d3 mem_le_scan_interval
+0x43d5 mem_le_scan_window
+0x43d7 mem_le_adv_led
+0x43d8 mem_le_adv_enable
+0x43d9 mem_le_adv_data_len
+0x43da mem_le_adv_data
+0x43f9 mem_le_scan_data_len
+0x43fa mem_le_scan_data
+0x4419 mem_le_name_len
+0x441a mem_le_name
+0x442e mem_le_led_on_time
+0x442f mem_le_new_map
+0x4434 mem_le_new_param
+0x4434 mem_le_new_window
+0x4435 mem_le_new_offset
+0x4437 mem_le_new_interval
+0x4439 mem_le_new_latency
+0x443b mem_le_new_timeout
+0x443d mem_le_temp
+0x443e mem_le_txheader
+0x443f mem_le_txlen
+0x4440 mem_le_txpayload
+0x4442 mem_le_txcid
+0x4444 mem_le_l2cap
+0x4445 mem_le_l2cap_response
+0x4446 mem_le_txbdy
+0x4465 mem_le_pcnt_tx
+0x446a mem_le_pcnt_rx
+0x446f mem_le_last_mic
+0x4473 mem_le_ivm
+0x4477 mem_le_ivs
+0x447b mem_le_ltk
+0x448b mem_ltk_exists
+0x448c mem_le_rconfirm
+0x449c mem_le_srand
+0x44ac mem_le_iat
+0x44ad mem_le_rat
+0x44ae mem_le_preq
+0x44b5 mem_le_pres
+0x44bc mem_le_search_handle_start
+0x44be mem_le_search_handle_end
+0x44c0 mem_le_att_offset
+0x44c0 mem_le_search_att_type
+0x44c2 mem_le_notify_handle
+0x44c4 mem_le_uuid
+0x44c6 mem_le_handle_data_len
+0x44c7 mem_le_handle_data
+0x44d7 mem_le_adv_param
+0x44d7 mem_le_adv_interval_min
+0x44d9 mem_le_adv_interval_max
+0x44db mem_le_adv_type
+0x44dc mem_le_adv_own_addr_type
+0x44dd mem_le_adv_direct_addr_type
+0x44de mem_le_adv_direct_addr
+0x44e4 mem_le_adv_channel_map
+0x44e5 mem_le_adv_filter_policy
+0x44e6 mem_le_conn_param
+0x44e6 mem_le_conn_peer_addr_type
+0x44e7 mem_le_conn_peer_addr
+0x44ed mem_le_conn_own_addr_type
+0x44ee mem_le_conn_interval_min
+0x44f0 mem_le_conn_interval_max
+0x44f2 mem_le_conn_latency
+0x44f4 mem_le_conn_superto
+0x44f6 mem_le_scan_params
+0x44f6 mem_le_scan_type
+0x44f7 mem_le_scan_own_addr_type
+0x44f8 mem_le_scan_filter_policy
+0x44f9 mem_le_lap
+0x44fc mem_le_uap
+0x44fd mem_le_nap
+0x44ff mem_le_xtype_fifo
+0x4504 mem_le_att_list
+0x46f8 mem_le_switch_send_data
+0x46f9 mem_le_transmit_window
+0x46fd mem_lmp_version
+0x4700 mem_lmp_subversion
+0x4702 mem_local_name_length
+0x4703 mem_local_name
+0x4706 mem_local_name2
+0x4746 mem_local_name_end
+0x4747 mem_unsniff2sniff_timer
+0x4748 mem_switch_flag
+0x4749 mem_eeprom_ota_base_addr/*the start- writing addr in eeprom  */
+0x474b mem_pn_dlci
+0x474c mem_pn_max_frame_size
+0x474e memFCStemp1
+0x474f memFCStemp2
+0x4750 memFCStemp3
+0x4751 mem_rfcomm_initiator
+0x4752 mem_remote_spp_channel
+0x4753 mem_HIUfcs_SPP
+0x4754 mem_HIUfcs_SPP_WCredits
+0x4755 mem_rfcomm_send_more_pkt
+0x4756 mem_remote_credits
+0x4757 mem_credit_given
+0x4758 mem_ms_channel
+0x4759 memui_uuid_table
+0x475b mem_all_uuid_16bits
+0x4771 mem_all_uuid_128bits
+0x4793 mem_sp_local_key_invalid
+0x4794 mem_sp_private_key
+0x47ac mem_sp_pubkey_local
+0x47ac mem_sp_pubkey_local_x
+0x47c4 mem_sp_pubkey_local_x_end
+0x47c4 mem_sp_pubkey_local_y
+0x47dc mem_ssp_enable
+0x47dd mem_ipc_lock_bt
+0x47de mem_ipc_lock_c51
+0x47df mem_ipc_fifo_bt2c51
+0x47e4 mem_ipc_fifo_c512bt
+0x47e9 mem_led_switch
+0x47ea mem_ui_button_timer
+0x47eb mem_ui_button_last_state
+0x47ec mem_ui_timer_last_btclk
+0x47f0 mem_discovery_timeout_timer_count
+0x47f2 mem_hid_handshake_timer_count
+0x47f3 memui_reconnect_mode
+0x47f4 mem_ui_state_map
+0x47f6 mem_ui_profile_supported
+0x47f7 mem_led_gpio
+0x47f8 mem_led_dark_time
+0x47fa mem_led_light_time
+0x47fc mem_ui_button_timeout
+0x47fd mem_ui_button_gpio
+0x47fe mem_discovery_timeout
+0x4800 mem_ir_ptr
+0x4802 mem_ir_type
+0x4803 mem_ir_cmd
+0x4804 mem_ir_play_count
+0x4805 mem_ir_report_len
+0x4807 mem_ir_pulse_zero
+0x4808 mem_ir_pulse_one
+0x4809 mem_ir_pulses
+0x4825 mem_ir_sequence_len
+0x4826 mem_ir_sequence
+0x4800 mem_acl_credits
+0x4802 mem_allow_switch
+0x4803 mem_hci_acl_queue_start/*param_acl_pktcnt+2 byte*/
+0x4807 mem_hci_wake_clk
+0x4800 mem_kb_state
+0x4802 mem_kb_report_data
+0x4808 mem_kb_keys
+0x4809 mem_kb_rcv_led_data
+0x480a mem_kb_fast_wake_last
+0x480e mem_led_cap_gpio
+0x480f mem_led_num_gpio
+0x4810 mem_led_scl_gpio
+0x4811 mem_kb_map
+0x4811 mem_kb_uuid_list
+0x4a87 mem_24g_paring_tx_power_param
+0x4a91 mem_5db_tx_power_param
+0x4a9b mem_current_event
+0x4a9c mem_ipc_lock_rx_data_bt
+0x4a9d mem_ipc_lock_rx_data_c51
+0x4a9e mem_ipc_lock_tx_data_bt
+0x4a9f mem_ipc_lock_tx_data_c51
+0x4aa0 mem_ipc_2bt_fifo_head
+0x4b36 mem_ipc_2bt_fifo_end
+0x4b36 mem_ipc_2C51_fifo_head
+0x4b9a mem_ipc_2C51_fifo_end
+0x4b9a mem_ipc_2bt_read_index
+0x4b9c mem_ipc_2bt_write_index
+0x4b9e mem_ipc_2C51_read_index
+0x4ba0 mem_ipc_2C51_write_index
+0x4ba2 mem_ipc_tx_evt_buff
+0x4ba4 mem_ipc_tx_evt
+0x4ba5 mem_ipc_bt_timer
+0x4ba7 mem_ipc_rx_type
+0x4ba8 mem_rfcomm_tx_buff
+0x4ba8 mem_queue_ele_num
+0x4ba9 mem_queue_write
+0x4bab mem_queue_read
+0x4bad mem_queue_start
+0x4bad mem_uart_packet
+0x4bb9 mem_data_ele0
+0x4bc5 mem_data_ele1
+0x4bd1 mem_data_ele2
+0x4bdd mem_queue_end
+0x4bdd mem_queue_temp
+0x4bdf mem_24g_rxdata_length
+0x4be0 mem_24g_pid
+0x4be1 mem_24g_datalen
+0x4be2 mem_24g_data_type
+0x4be3 mem_24g_txlen
+0x4be4 mem_24g_rx_window
+0x4be6 mem_24g_ensure
+0x4be7 mem_24g_get_ack_fail
+0x4be8 mem_24g_retry
+0x4be9 mem_24g_ch
+0x4bea mem_24g_current_ch_number
+0x4beb mem_24g_paring_addr
+0x4bef mem_24g_pairing_sm
+0x4bf0 mem_24g_ch_map1
+0x4bf4 mem_24g_ch_map2
+0x4bf8 mem_24g_ch_map3
+0x4bfc mem_24g_ch_map4
+0x4c00 mem_24g_addr
+0x4c04 mem_24g_check_dongle_times
+0x4c06 mem_24g_device_addr
+0x4c0a mem_24g_no_ack
+0x4c0b mem_24g_sta_crc
+0x4c0e mem_24g_sta_pid
+0x4c0f mem_24g_max_retry
+0x4c10 mem_24g_mode
+0x4c11 mem_24g_hop_pac_retry
+0x4c12 mem_24g_idle_timeout
+0x4c13 mem_24g_idle_cnt
+0x4c14 mem_24g_auto_paring_switch
+0x4c15 mem_24g_enter_lpm_timer
+0x4c16 mem_24g_syncword
+0x4c18 mem_24g_syncword_crc8
+0x4c19 mem_24g_get_syncword_crc8
+0x4c1a mem_24g_discard_cnt
+0x4c1c mem_cb_24g_data
+0x4c1e mem_24g_lasttx
+0x4c27 mem_power_ctrl_pac_succ_cnt
+0x4c28 mem_power_ctrl_level
+0x4c29 mem_rssi_avg_received
+0x4c2a mem_rssi_hex_received
+0x4c2b mem_rssi_signal_buf
+0x4c33 mem_rssi_noise_buf
+0x4c3b mem_rssi_noise_index
+0x4c3c mem_rssi_signal_index
+0x4c3d mem_tx_power
+0x4c3e mem_tx_power_temp
+0x4c3f mem_cnt
+0x4c42 mem_last_txlch
+0x4c43 mem_last_txlen
+0x4c45 mem_last_txdata
+0x4c59 mem_ipc_last_check_timer
+0x4c5d mem_prepare_write_len
+0x4c5e mem_ipc_c51_timer
+0x4c60 mem_le_rx_window
+0x4c61 mem_le_find_type_value_start_handle
+0x4c63 mem_le_find_type_value_end_handle
+0x4c65 mem_le_cur_att_type
+0x4c67 mem_le_search_len
+0x4c68 mem_le_ll_unknown_type
+0x4c69 mem_le_pairing_state
+0x4c6a mem_le_local_mtu
+0x4c6c mem_le_connection_updata_param
+0x4c7c mem_ltk_states
+0x4c7d mem_pair_state
+0x4c7e mem_empty_count
+0x4c7f mem_shutter_find_type_value_flag
+0x4c80 mem_le51_payload_len
+0x4c81 mem_le51_cmd
+0x4c82 mem_le51_tx_length
+0x4c83 mem_le51_txbuff_inuse
+0x4c84 mem_le51_txbuf
+0x4c8d mem_ipc_bt_100ms_timer
+0x4c8e mem_ipc_c51_100ms_timer
+0x4c8f mem_adc_config_flag
+0x4c90 mem_adc_channel
+0x4c91 mem_adc_0v
+0x4c93 mem_adc_3v
+0x4c95 mem_adc_current_value
+0x4c97 mem_hibernate_flag
+0x4c98 mem_new_supervision_to
+0x4c9a mem_kb_wake_timer
+0x4c9b mem_kb_last_data
+0x4caf mem_kb_keycount
+0x4cb0 mem_led_cap_delay_timer
+0x4cb1 mem_test
+0x4cb4 mem_seq
+0x4cb5 mem_recon_index
+0x4cb6 mem_power_on_flag
+0x4cb7 mem_caps_num_lock
+0x4cb8 mem_att_report1
+0x4cba mem_att_report2
+0x4cbc mem_att_report3
+0x4cbe mem_suspend_flag
+0x4cbf mem_32asm_data_end
+0x4d37 mem_store_ltk_timer
+0x4d38 mem_reconnect_continue
+0x4d39 mem_le_pin_code
+0x4d3d mem_le_send_security_request_flag
+0x4d3e mem_att_report_battery
+0x4d40 mem_24g_enter_hibernate
+0x4d44 mem_24g_txfail_cnt
+0x4d45 mem_mouse_retry_flag
+0x4d46 mem_24g_led_flag
+0x4d47 mem_ui_timer_last_btclk_temp
+0x4d4b mem_ui_check_timer_setup
+0x4d4f mem_customize_timer_setup
+0x4d51 mem_customize_timer
+0x4d52 mem_ios_mode_flag
+0x4d53 mem_version_yy_mm_dd
+0x4d57 mem_24g_txbuf_new
+0x4d6b mem_le_adv_swift_pair
+0x4d72 mem_24g_enter_hibernate_setup
+0x4d76 mem_24g_enter_hibernate_max
+0x4d7a mem_24g_short_sleep_counter
+0x4d7d mem_pc_sleep_flag
+0x4d7e mem_le_pause_enc_flag
+0x4800 mem_at_gpio
+0x4801 mem_module_wake_up_gpio
+0x4802 mem_module_state_gpio
+0x4803 mem_module_connect_state_gpio
+0x4804 mem_module_version
+0x480a mem_last_uart_clock
+0x480e mem_current_packet_length
+0x4810 mem_module_prepare_tx_len
+0x4812 mem_module_state
+0x4813 mem_module_task
+0x4814 mem_cmode_addr
+0x481a mem_at_scan_time
+0x481c mem_prarm_pswd
+0x4820 mem_prarm_uart
+0x4824 mem_prarm_blename
+0x4827 mem_prarm_name
+0x482b mem_prarm_bleadss
+0x482e mem_prarm_adss
+0x4832 mem_prarm_vers
+0x4836 mem_prarm_class
+0x483b mem_prarm_clrflg
+0x4841 mem_prarm_reconn
+0x4847 mem_prarm_bledis
+0x4849 mem_prarm_dis
+0x484c mem_prarm_stsn
+0x4850 mem_prarm_atp
+0x4853 mem_prarm_list
+0x4857 mem_prarm_role
+0x485b mem_prarm_sniff
+0x4860 mem_prarm_ldev
+0x4864 mem_prarm_rssi
+0x4868 mem_prarm_cdev
+0x486c mem_prarm_bleinqr
+0x486f mem_prarm_inqr
+0x4873 mem_prarm_cmode
+0x4878 mem_prarm_mode
+0x487c mem_prarm_dmstate
+0x4883 mem_prarm_discov
+0x4889 mem_prarm_ota
+0x488c mem_prarm_bleconn
+0x488e mem_prarm_conn
+0x4892 mem_prarm_pageout
+0x4899 mem_prarm_recfail
+0x48a0 mem_module_uuid_list
+0x4800 mem_mouse_x
+0x4802 mem_mouse_y
+0x4804 mem_mouse_z
+0x4805 mem_mouse_key
+0x4806 mem_mouse_z_last
+0x4807 mem_mouse_z_before
+0x4808 mem_mouse_z_now
+0x4809 mem_mouse_z_data
+0x480a mem_mouse_move_flag
+0x480b mem_reconnect_timeout
+0x480c mem_mouse_direct_timeout
+0x480e mem_mouse_no_data_timeout
+0x4810 mem_mouse_blank_data_timeout
+0x4812 mem_mouse_discovery_timer
+0x4814 mem_mouse_direct_timer
+0x4816 mem_mouse_no_data_timer
+0x4818 mem_mouse_blank_data_timer
+0x481a mem_mouse_send_blank_timer
+0x481b mem_mouse_dpi
+0x481c mem_mouse_dpi_button_state
+0x481d mem_mouse_test_cnt
+0x481e mem_le_hibernate_timer
+0x4820 mem_mouse_mode_state
+0x4821 mem_sensor_type
+0x4822 mem_lbutton_gpio
+0x4823 mem_rbutton_gpio
+0x4824 mem_mbutton_gpio
+0x4825 mem_dpi_button_gpio
+0x4826 mem_sensor_data_gpio
+0x4827 mem_whee_a_data_gpio
+0x4828 mem_whee_b_data_gpio
+0x4829 mem_conn_cnt
+0x482a mem_mouse_uuid_list
+0x4800 mem_shutter_send_data
+0x4804 mem_shutter_key_temp
+0x4805 mem_shutter_send_length
+0x4806 mem_shutter_clkn_bt_last
+0x480a mem_shutter_key
+0x480b mem_shutter_flag
+0x480c mem_shutter_cable_unplug_conut
+0x480d mem_shutter_hid_disconn_count
+0x480e mem_shutter_1key_send_sm
+0x480f mem_shutter_iphonekey_gpio
+0x4810 mem_shutter_androidkey_gpio
+0x4811 mem_shutter_key_number
+0x4812 mem_shutter_uuid_list
Index: c51/patch/ram.obj
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/patch/ram.obj
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/patch/ramcode.rom
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/patch/ramcode.rom	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/patch/ramcode.rom	(working copy)
@@ -0,0 +1,1644 @@
+c5128010
+c000002c
+c0010030
+c0018038
+c0028042
+c04801b5
+c049017b
+c04a0181
+c04a816b
+c0580299
+c058812f
+c0590143
+c059815d
+c05b0166
+c05c8137
+20203bf1
+c01902a7
+c01dd3b0
+c01f022d
+c01f8231
+c0250314
+c02582a0
+c02602aa
+c02702b0
+c02b02b7
+c02d02c3
+c03082be
+c03182e3
+c0320308
+c032833e
+c03484a0
+c0350484
+c0358486
+c03704ab
+c037831f
+c0438103
+c046824c
+c0470263
+c0478235
+c05e8243
+c06681bf
+c067810f
+c0680119
+20203bf1
+6810813b
+60008b81
+70800608
+20203003
+20407719
+2055bcf1
+20407813
+6800c7dc
+203a3013
+6800c793
+203a0032
+20203013
+2040009d
+2040008f
+20400047
+2040003d
+20203015
+680947f4
+6800c3d8
+7d3a040b
+600947f4
+20600000
+20403392
+20403407
+20403024
+204004cc
+20203022
+6800c7dc
+203a004b
+6800c793
+207a0000
+204000fe
+20740000
+1ff0fe00
+1fe20c00
+204000df
+6000cba7
+c000805f
+c0030069
+1fe20400
+18c22200
+6800c040
+c300005c
+1a220c00
+c6848000
+18427e00
+c002806b
+20203bf1
+1a220c00
+d8a000f8
+202000d7
+204000df
+204000df
+60008b7d
+20400064
+20207c33
+204000e2
+18c20400
+18508400
+60094b9a
+20600000
+d8a04d57
+202000d7
+18c22200
+6800cba9
+1fe08401
+18410403
+6008cba9
+1feffe07
+d8a04bad
+98a08a00
+1a220c00
+204000df
+18c22200
+1fe0ffff
+1fe27200
+1fe0fe07
+6000cc82
+1a220c00
+204000df
+18c22200
+c0008081
+c0010089
+c001808b
+c002008d
+68014cb8
+e0a10000
+1a220c00
+204000d9
+2040561e
+247a0000
+700b7d1b
+20205620
+68014cba
+20200082
+68014cbc
+20200082
+68014d3e
+20200082
+680a4d4b
+1c427e00
+98467e00
+68094d4f
+9846fc00
+20407efd
+1807fe00
+207a0000
+1c420400
+600a4d4b
+6800cd51
+1fe0fe01
+6000cd51
+20600000
+680a4c59
+1c427e00
+98467e00
+d8400640
+9846fc00
+20407efd
+1807fe00
+207a0000
+1c420400
+600a4c59
+68094ba5
+18508400
+9840fe00
+1ff0fe00
+60014ba5
+1ff0fe00
+1fe17e03
+c1800000
+6800cc8f
+c28000ba
+c28080bc
+da200000
+204000ce
+7089718f
+6800cc90
+60108973
+204000bd
+da200001
+202000ce
+708971bf
+202000bd
+708971af
+68108053
+79207e07
+60108053
+68108973
+1fe1fe30
+60108973
+70890674
+7089067c
+708972aa
+20001388
+68190150
+68108053
+793ffe07
+60108053
+18508400
+60094c95
+20600000
+d8400021
+6800cc90
+98460400
+1a227e00
+79200407
+243a00d5
+793f8407
+d8a08078
+202069f4
+204000df
+1fe27200
+204000db
+20200064
+204000df
+e0a08000
+c20000db
+20600000
+204000e2
+e8c08000
+20600000
+58004b36
+98c67c00
+24628000
+d8c04aa0
+20600000
+df200003
+d8c04ba2
+18c22200
+68014ba0
+1ff0fe00
+1fe20a00
+1a220c00
+e8c08000
+e0a08000
+204000f6
+c20000ee
+18a27e00
+1ff0fe00
+60014ba0
+20600000
+58004b9a
+98a67c00
+24628000
+d8a04b36
+20600000
+68014b9e
+68094ba0
+20200100
+68014b9a
+68094b9c
+98467c00
+2022e9b1
+2020320b
+1c427e00
+60024d47
+6808c7ef
+6800cd4a
+98467c00
+2441010a
+20207c06
+680a4d47
+600a47ec
+600a4c59
+600a4d4b
+20600000
+da2047df
+20407f9f
+207a0000
+1fe22600
+20400115
+20203ea5
+c10c0000
+c00a04bd
+c00a829e
+20203e7d
+60088259
+6800cc8d
+1fe0fe01
+6000cc8d
+68008259
+207a0000
+1fe0ffff
+60008259
+20400123
+2020011d
+6800cc15
+207a0000
+1fe0ffff
+6000cc15
+20600000
+1a627e00
+1fe17ef0
+c1280000
+1a627e00
+207a0000
+6000cba4
+202000e7
+70416e7f
+20403cf3
+6800cc97
+207a0000
+704c9700
+1c427e00
+60024c59
+20600000
+6800c219
+247a0000
+70804206
+58000f0c
+20403da7
+58030d40
+20403bf3
+37d98200
+1e226000
+20403b36
+20001388
+20203d9d
+c6118000
+680147f4
+c284bd1e
+20403cab
+6801c210
+207a0000
+6800c131
+207a0000
+2040527e
+247a0000
+20403dca
+247a0000
+20403b36
+6800c7dc
+203a3d25
+6800c793
+207a0000
+20203d25
+204000fe
+24740000
+204000fb
+24740000
+700b7f01
+700b7e01
+20400162
+202000fe
+20400155
+24740000
+68008b7f
+247a0000
+20203d2d
+68008b7e
+2000000a
+c0800162
+20600000
+20400155
+24740000
+68008b7f
+247a0000
+20203d4f
+2040016d
+20203aaf
+6800c219
+243a0173
+20403d91
+20007530
+20007530
+20007530
+20403b0a
+70804204
+6810896b
+1fe17ecf
+6010896b
+1fe1fe30
+6010896b
+20600000
+60088017
+1840a204
+20203a86
+60088017
+1840a200
+20203ab6
+2040017e
+58000500
+20403bf3
+70890601
+7089003c
+708901e0
+70896d12
+2000000a
+70890201
+7089023d
+2000000a
+708903b7
+2000000a
+7089027d
+6800cbef
+c0ff8199
+6802ca91
+e0a28000
+e8c28000
+e0a28000
+708956df
+204001a4
+708955df
+20600000
+6802ca87
+e0a28000
+e8c28000
+e0a28000
+6800cc7d
+205a01a2
+60108956
+708955d0
+20600000
+580000c2
+20600000
+20000004
+708955d1
+20000004
+708955d2
+20000004
+708955d4
+20000004
+20600000
+708955d4
+20000004
+708955d2
+20000004
+708955d1
+20000004
+708955d0
+708956c0
+20600000
+2030ba6f
+204001ac
+20203a6f
+78347c00
+68120138
+79347e1a
+6012004c
+20403db0
+7000a201
+20600000
+6800c419
+1fe0fe02
+6000c3f9
+700b7e00
+70017706
+20403fa4
+580001be
+6001428a
+58000128
+60014292
+58000234
+60014290
+58000047
+6001428c
+580001b8
+60014288
+58004aa0
+1ff0fe00
+60014b9a
+60014b9c
+20403e0b
+58004b36
+1ff0fe00
+60014b9e
+60014ba0
+6800cc97
+c02d01f0
+203581ee
+68014c91
+1ff0fe00
+60014c91
+68014c93
+1ff0fe00
+60014c93
+204001fb
+680402a0
+243a01e8
+68014ad4
+1ff0fe00
+203a01e8
+60014c93
+204004c9
+704ba42f
+204000e7
+704c9700
+70828003
+20600000
+704ba430
+202001ea
+1ce27e00
+203a023b
+20405b63
+20404d99
+58000000
+60044040
+600147f4
+1c427e00
+60024c59
+704ba433
+202001ea
+2040688a
+580007e0
+da2002a0
+d840000e
+204068d3
+2040688d
+680082a0
+c280bbf1
+680402a2
+207a0000
+6800cc8f
+c280020f
+c280821d
+680102a2
+1ff0fe00
+60014c91
+680102a8
+1ff0fe00
+60014c93
+20600000
+680902a6
+680102ac
+18422400
+1fe22200
+1ff0fe00
+60014c93
+1a227e00
+98462600
+1a63a600
+1a427e00
+9a667e00
+1ff0fe00
+60014c91
+20600000
+680902a4
+680102aa
+18422400
+1fe22200
+98462600
+1a6b2600
+1a427e00
+9a667e00
+1ff0fe00
+60014c91
+1a63a600
+1a227e00
+9a667e00
+1ff0fe00
+60014c93
+20600000
+70001627
+70890f36
+70890b5f
+202053d4
+70890f2e
+70890bff
+202053d9
+20600000
+68014ba0
+60014b9e
+68014b9c
+60014b9a
+700b7e03
+20400162
+704c975a
+20403db8
+68120138
+793ffe0f
+6012004c
+20403db0
+d85fffff
+20203cda
+ea2a8000
+18417eff
+243a0248
+184cfe00
+e2228000
+1a20a204
+ea208000
+247a0000
+20207f9c
+20407c20
+da2047e4
+20407f9f
+1fe20400
+20407c24
+18427e00
+207a0000
+c010825c
+c011025e
+c011855c
+c006826c
+c016026c
+c0158277
+c0150291
+c0097c85
+20207c5a
+704befff
+2020058f
+793f8023
+704befff
+20200547
+700b7d22
+20205620
+6800807c
+203a0268
+204061d9
+6800807c
+243a7c8c
+68008b7d
+c584fc87
+c0088261
+20207c7b
+20403eff
+20407cd5
+70413100
+180a7e00
+6000c4f9
+7043dc05
+58181203
+6001c3e2
+d8400007
+2040027d
+20207cae
+7043dc04
+580000ff
+6001c3e2
+d8400000
+2040027d
+20207cae
+6800c3f9
+9840fe00
+1fe0fe0b
+1fe67c1f
+2421028d
+6000c3d9
+d8a043e5
+18427e00
+245a028a
+6800c3f9
+1fe27200
+d8c043fa
+20207e45
+1fe27200
+d8c04d6b
+20207e45
+6800c3f9
+1fe0fe0b
+6000c3d9
+20600000
+680147f4
+c284bf90
+c283fcd5
+c5118547
+7043d800
+20403f7e
+700b7d37
+20207c27
+20403b36
+20203cdc
+e8c08000
+6000ccb7
+20600000
+704d7e00
+202004c2
+204054bd
+68088017
+20403a82
+20403a87
+78287c00
+d960157c
+2020547f
+70443e01
+70443f00
+2020534e
+204053dd
+204002ad
+202054c1
+20368184
+204053ee
+20203a91
+6800cc60
+600246f9
+6800c4db
+c00082b5
+202054e0
+7044db00
+202054ef
+680083c0
+c4028000
+680103da
+680903e0
+98467e00
+24610000
+2020557e
+680083d7
+c3828000
+68008341
+203a5626
+20205890
+680883d7
+284c0005
+20608000
+68008340
+1fe3fe00
+9842fe00
+c4018000
+793f8405
+79400403
+600883d7
+28400603
+24608000
+6800c440
+c00282d4
+6800cd7e
+c00082d8
+20600000
+680083c0
+79207e04
+600083c0
+20600000
+704d7e00
+dfe00000
+6002446f
+6000c48b
+6002c465
+79207e27
+6002c46a
+680083c0
+793ffe04
+600083c0
+20600000
+6800c440
+c00382fd
+c0078301
+c00302f0
+c00102ed
+c00982eb
+c00582eb
+2020563a
+18000401
+20205892
+5800000a
+600103ef
+20205693
+700b7d12
+20407c33
+18000401
+2034d892
+700b7d34
+20407c27
+6800cc69
+c00102f9
+202002fb
+700b7d46
+20405620
+18000401
+20205892
+6800cc68
+e0a08000
+18000402
+20205892
+18a08bff
+68044c6c
+e0a40000
+e8c40000
+e0a40000
+18000202
+2020588a
+6800c444
+c004d719
+c001030d
+c003d70d
+20205656
+59000302
+6001c4b5
+58000001
+e0a08000
+58010010
+e0a18000
+202056f1
+09800018
+78287c00
+db600664
+1fef7e00
+1ff17e00
+e0a18000
+2023375c
+7836fc00
+68008017
+1fe0a200
+202054af
+e8c18000
+600183f9
+c0290325
+c001033c
+c009032b
+20205907
+704d3801
+680103fa
+c0108329
+202059ed
+d8c00349
+2020029b
+680103fa
+1fe67c21
+20428329
+680103fa
+1fe67c2d
+2042833a
+680103fa
+68094cbc
+18408401
+98467c00
+20228337
+202059ca
+700b7d34
+20407c27
+202059ca
+70413101
+20600000
+700b7d03
+20205620
+6800c444
+c00d8476
+c00e8476
+c008840a
+c00483bc
+c00283aa
+c003835e
+c009d85c
+c001834f
+c0058352
+c006834a
+20205666
+680103fa
+c003834d
+202057d6
+7003fc07
+20205729
+68014c6a
+e0a10000
+2020588a
+680103fa
+c0070355
+202057c6
+6800cc69
+c08057c6
+6800cc7c
+c001d7c6
+18a20400
+704c6901
+18420a00
+7003fc05
+20205729
+2040577b
+20740000
+680944c0
+58001812
+98467c00
+20228377
+5800180f
+98467c00
+20228379
+5800180a
+98467c00
+2022837d
+58001801
+98467c00
+2022837b
+20205754
+6800cc7f
+d8400000
+f9200400
+98417e00
+c0805728
+6800cc7f
+f9207e00
+6000cc7f
+2020037f
+d8e00000
+2020036e
+d8e00001
+2020036e
+d8e00003
+2020036e
+d8e00002
+2020036e
+680144c0
+1fe22200
+680944c4
+18422400
+20400386
+20228391
+20205728
+d8c04504
+e8c10000
+207a0000
+e8c18000
+e8c10000
+9a267c00
+20628000
+18c08dfd
+e8c08000
+98c08c00
+20200387
+18c08df9
+e8c10000
+60014c61
+2040039f
+203a5728
+18c08dfc
+e8c10000
+1fe0ffff
+60014c63
+70444407
+68024c61
+60024445
+18000409
+20205892
+e8c10000
+e8c08000
+98c08c00
+e8c10000
+207a0000
+e8c10000
+9a467c00
+20628000
+e8c08000
+98c08c00
+202003a2
+d9600003
+18007e01
+6000c445
+20405a74
+20405a7d
+203a5746
+242103ba
+78547c00
+e0a10000
+e8c10000
+e0a10000
+196097ff
+2022d746
+e8c08000
+98c08c00
+202003ae
+18c08c02
+202003b7
+680944c0
+58002a00
+98467c00
+202283fc
+58002a50
+98467c00
+20228407
+58002803
+98467c00
+2422d728
+680144bc
+600102a0
+78347c00
+2040044e
+242103d8
+680902a0
+20400456
+c00083d8
+20400452
+242283d6
+78547c00
+204003da
+2040043c
+20400456
+204003e2
+202003d8
+2040043c
+202003c9
+20345728
+20200474
+680102a0
+60014446
+6800cc67
+1fe27200
+2040046b
+d8a04448
+20407e45
+2020046e
+68094c65
+184cfe00
+c08283f4
+20400468
+680102a0
+e0a10000
+2040046e
+58004504
+98408c00
+e8c08000
+18c20400
+1fe27200
+1fe0fe05
+6000c445
+20400468
+18420c00
+20407e45
+2020046e
+20400468
+680102a0
+e0a10000
+68014c65
+e0a10000
+2040046e
+70444507
+20600000
+20405b08
+e8c08000
+1fe27200
+1fe0fe02
+6000c445
+18c08dfb
+e8c10000
+e0a10000
+18c08c03
+20407e45
+2020588a
+d8402a50
+20405b0c
+202003fd
+d9600002
+680144bc
+600102a0
+700d5c00
+78347c00
+2040044e
+24210432
+680902a0
+20400456
+c0008435
+20400452
+2422842e
+68008d5c
+c0008435
+2434041f
+78547c00
+6800cc67
+1fe0fe04
+6000c445
+2040046e
+20200429
+6800cc67
+1fe67c10
+20228435
+6800c445
+1fe67c10
+20228435
+680102a0
+1fe0ffff
+60010d5a
+20400445
+680102a0
+60010d58
+20400440
+196097ff
+20228430
+2040043c
+2020040f
+700d5c01
+2020042e
+680102a0
+60010d5a
+20200439
+680102a0
+1fe0ffff
+60010d5a
+20200439
+20345728
+20400445
+20200474
+680902a0
+18408401
+600902a0
+20600000
+6800cc67
+60008103
+1fe27200
+2040046b
+20207e45
+20400468
+68010d58
+e0a10000
+68010d5a
+e0a10000
+68008103
+1fe27200
+20407e45
+2020046e
+680902a0
+680144be
+98467c00
+20600000
+680144c0
+68094c65
+98467c00
+20600000
+d8c04504
+18422200
+e8c10000
+203a0461
+e8c90000
+60094c65
+9a267c00
+20228463
+e8c08000
+98c08c00
+20200458
+58000001
+20600000
+e8c08000
+6000cc67
+20400471
+58000000
+20600000
+680102b9
+1fe20a00
+20600000
+680102b7
+1fe20c00
+20600000
+18a27e00
+600102b9
+20600000
+18c27e00
+600102b7
+20600000
+20400468
+2020588a
+6800cbab
+1fe08401
+18410403
+6008cbab
+1feffe07
+d8c04bad
+98c08c00
+6800cc82
+1fe0fffb
+1fe27200
+d8a04445
+20407e45
+6808cc82
+20205892
+2040561c
+202058b0
+1a627e00
+c0018496
+c005049a
+c0000491
+c0090498
+c001049d
+1fe67c0d
+202158c0
+6000cc68
+700b7d27
+20205620
+20405924
+68014437
+1fef8404
+60094d4f
+20600000
+704c7c00
+20205938
+700b7d33
+20205620
+704d7e01
+700b7d2b
+20205620
+58000014
+600103ef
+20600000
+6800c43e
+28200601
+202084a4
+202058a7
+6800c43f
+203a04a7
+202058a7
+6800c43e
+793ffe04
+6000c43e
+20600000
+e8c08000
+c00084b2
+c00204b8
+c00484b0
+202058f8
+704c6903
+20205974
+704d3d01
+6000c4ae
+e8c30000
+e0a30000
+700b7d42
+20205620
+204074a8
+202284bb
+20205968
+704c6902
+2020596a
+704c7d00
+20403f86
+20403f7e
+20403fa4
+20203ecc
+70421300
+70448b00
+704c7c00
+704c6900
+704c7f00
+704c7d00
+20203ed0
+58000000
+60024ba9
+20600000
+c6918000
+68024d40
+60024d72
+204004f2
+243404e5
+704c150a
+20400513
+6800cbef
+c1ff8000
+704c3d02
+6800cd45
+247a0000
+20400155
+24740000
+68008b7f
+247a0000
+20403cab
+6801c210
+207a0000
+6800c131
+207a0000
+6801cd7a
+20407e8a
+600a41fc
+20203cda
+20400155
+24740000
+68008b7f
+247a0000
+20403cab
+6801c210
+207a0000
+6800c131
+207a0000
+6800cc15
+243a04e1
+68024d72
+202004e2
+6800cbef
+c0ff8565
+204004f9
+20540510
+205405d4
+704be601
+20600000
+78547c00
+704be202
+6800cd57
+c0020503
+c0028506
+c003850c
+c0030509
+6800cd45
+245a34df
+20600000
+704d5700
+704be10a
+2020050e
+704d5703
+704be104
+2020050e
+704d5702
+704be103
+2020050e
+704be201
+704be108
+704be700
+202034df
+6804cd57
+60048cd5
+20600000
+704be800
+d9600d00
+34730200
+2040053a
+24378523
+2040054a
+6800cbe0
+1fe0fe01
+6000cbe0
+704d4500
+6800cbef
+c0ff8539
+20400535
+704be700
+704be600
+20600000
+704d4501
+6800cbe7
+1fe0fe01
+6000cbe7
+6800cbef
+c0ff8545
+6800cbe7
+c07f8547
+6800cbe7
+d8400010
+98467c00
+202105f3
+6800cbe8
+1fe0fe01
+6000cbe8
+2000000a
+c0838514
+202005f3
+58000000
+60048cd5
+6004cd57
+20600000
+2020057f
+7857fc00
+2040064b
+18002a00
+68024c00
+98001200
+68088017
+20403a82
+20403a87
+2040060b
+20578645
+20600000
+704d4500
+20600000
+704d4500
+700b7d32
+20207c27
+204005b4
+68008cb3
+c1810000
+6800cbdf
+207a0000
+98007200
+d8c00cb5
+d8a00d17
+20407e45
+68008cb4
+2fe1f008
+24608000
+68008cb5
+c07f855a
+6000ccb7
+20600000
+704d7d01
+20600000
+79200023
+20400561
+2040051f
+704bef01
+20600000
+704be000
+704be94e
+68024beb
+202005c6
+20400561
+6800cbe6
+c000b4df
+6800cbef
+c000856d
+c0010570
+c0018573
+20203bf1
+704bef11
+700d37aa
+20200575
+704bef12
+700d3755
+20200575
+704bef13
+700d3722
+700d3802
+68024c06
+60020d39
+700d3d00
+da200d37
+d8400007
+204005af
+204005d4
+204004f7
+202034df
+6800cbef
+c17f8000
+c0088585
+c0090587
+c0098589
+20600000
+704bef02
+2020051f
+704bef03
+2020051f
+704befff
+700b7d31
+20407c27
+68020d19
+204005c6
+2020051f
+79200023
+204005c7
+204005f3
+6800cbef
+c1ff8000
+204005a1
+58000000
+60014c04
+20403cab
+200007d0
+6800cc04
+c07f8547
+2040053a
+243785aa
+20400535
+79200023
+700b7d3c
+20207c27
+700d37ff
+6800cbe2
+60008d38
+68024c06
+60020d39
+d8400006
+da200d37
+204005af
+202005d4
+68014c04
+1fe0fe01
+60014c04
+204005f3
+20200597
+6008cbe1
+18427200
+d8a00cd5
+1a220c00
+20207e45
+68008cb4
+1fe97e00
+6000cbdf
+1fe0fe01
+d8c00cb4
+98c08c00
+e8c18000
+6001cc0b
+20600000
+6808cc3c
+58004c2b
+98408a00
+1a227e00
+e0a08000
+18408401
+18410407
+6008cc3c
+20600000
+60024c00
+da200000
+df200004
+d8c04c00
+e8c08000
+9a20a200
+c20005ca
+1a227e00
+60014c16
+6800cc16
+6808cc17
+9840fe00
+6000cc18
+20600000
+6800cbe1
+1fe0fe02
+6000cbe3
+6800cbe2
+60008cf5
+6800cbe1
+1fe9fe00
+6808cbe0
+18410403
+18438400
+9841fe00
+6808cc0a
+9840fe00
+e0a08000
+6800cbef
+c0ff85e6
+6800cbe2
+e0a08000
+6800cbe1
+98007200
+6800cbe2
+c00085f1
+d8c00cd5
+20407e45
+68008cd5
+c00185ef
+20600000
+700cd502
+20600000
+d8c00cd6
+20207e45
+6808cbea
+204005f9
+18408401
+18410403
+6008cbea
+20600000
+6800cc00
+1fe17e03
+1fefa204
+58004bf0
+9a20fe00
+98408c00
+e8c08000
+6000cbe9
+20600000
+7844fc00
+7843fc00
+58555555
+98001e00
+6800cbe9
+1fed8400
+79200401
+18431c00
+20600000
+20400602
+7826fc00
+7830fc00
+78507c00
+78287c00
+68014be4
+98003600
+37c18400
+242c0645
+7846fc00
+7825fc00
+7823fc00
+7824fc00
+09800008
+19897e00
+6000cc19
+6808cc18
+98467c00
+24228645
+09800008
+19897e00
+60008cb3
+68008cb3
+6808cbe2
+a8400e00
+24208645
+09800008
+19897e00
+e0a08000
+1fe97e00
+1fe1721f
+2022862f
+09800008
+19897e00
+e0a08000
+c200062b
+18a22200
+09800008
+19897e00
+6000cc2a
+1a220a00
+09800018
+78287c00
+db600664
+1fef7e00
+1ff17e00
+e0a18000
+7845fc00
+20230645
+7837fc00
+68008017
+1fe0a200
+20403ab6
+7846fc00
+20403a7a
+6800cc2a
+1fe22200
+202005bd
+784dfc00
+7845fc00
+2020375c
+20403a7a
+6808cbe9
+20203a91
+204053d2
+68024c00
+98001200
+20400602
+20400648
+79202a00
+782efc00
+78307c00
+7850fc00
+19317e00
+1fecfe00
+1ff1fe00
+08008628
+784efc00
+782dfc00
+7823fc00
+7824fc00
+6800cc18
+08008608
+6800cbe3
+98007200
+d8c00cf5
+e8c08000
+08008608
+c2000661
+78247c00
+08008618
+78447c00
+37d38200
+20000064
+784efc00
+784dfc00
+20203a7a
Index: c51/patch/rf.dat
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/patch/rf.dat	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/patch/rf.dat	(working copy)
@@ -0,0 +1,107 @@
+mem_lpm_config:8f 10 ce
+mem_lpm_xtalcnt:00 0a 0b ef 0f
+mem_lpm_hibernate_switch:00
+mem_gpio_wakeup_low:00 00 00 00 00 00 00 00
+mem_fcomp_mul:02
+mem_fcomp_div:24
+mem_iscan_window:12 00
+mem_iscan_interval:00 02
+mem_pscan_window:12 00
+mem_pscan_interval:00 02
+mem_inq_window:20 00
+mem_page_window:20 00
+mem_page_to:00 20
+mem_rx_window_init:80 03
+mem_rx_window_sniff:00 06
+mem_new_supervision_to:00 13
+
+mem_eeprom_base:30 3f
+mem_eeprom_block_size:20
+#pointers to tail space of mem_le_att_list
+4f70:
+07 ff #2M_IF
+0a fb
+0b ff 
+
+#agc table
+1a fb
+1b fb
+1c fb
+1d f6
+1e f2
+1f ee
+20 ea
+21 e6
+22 e2
+23 de
+24 da
+25 d6
+26 d2
+27 ce
+28 ca
+29 c6
+2a c2
+2b bd
+2c b9
+2d b5
+2e b1
+2f ad
+30 a9
+31 80
+32 80
+33 80
+34 c0
+35 c1
+36 c2
+37 c3
+38 c4
+39 c5
+3a c6
+3b c7
+3c 06
+3d 07
+3e 46
+3f 85
+40 86
+41 87
+42 c6
+43 c7
+44 d6
+45 d7
+46 e6
+47 f5
+48 00
+49 f8
+4a 7f
+4e ec
+4f 5e
+
+# tx power
+55 d0
+56 c0
+57 4c
+58 6c
+59 50
+
+#dpll
+68 e4
+69 00
+6a 00
+6b 30
+ff
+mem_rf_init_ptr:70 4f
+
+mem_5db_tx_power_param:
+55 d0
+56 c0
+57 4c
+58 6c
+59 50
+
+mem_24g_paring_tx_power_param:
+55 d0
+56 c0
+57 4c
+58 6c
+59 50
+
Index: c51/patch/sch.rom
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/patch/sch.rom	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/patch/sch.rom	(working copy)
@@ -0,0 +1,465 @@
+mem_patch00:
+2d   #mem_patch00
+00   #mem_patch01
+00   #mem_patch02
+00   #mem_patch03
+00   #mem_patch04
+00   #mem_patch05
+00   #mem_patch06
+00   #mem_patch07
+00   #mem_patch08
+00   #mem_patch09
+00   #mem_patch0A
+00   #mem_patch0B
+00   #mem_patch0C
+00   #mem_patch0D
+00   #mem_patch0E
+00   #mem_patch0F
+00   #mem_patch10
+00   #mem_patch11
+35   #mem_patch12
+00   #mem_patch13
+00   #mem_patch14
+00   #mem_patch15
+4f   #mem_patch16
+02   #mem_patch17
+00   #mem_patch18
+00   #mem_patch19
+00   #mem_patch1A
+00   #mem_patch1B
+00   #mem_patch1C
+00   #mem_patch1D
+00   #mem_patch1E
+00   #mem_patch1F
+00   #mem_patch20
+00   #mem_patch21
+00   #mem_patch22
+00   #mem_patch23
+00   #mem_patch24
+00   #mem_patch25
+04   #mem_patch26
+c8   #mem_patch27
+00   #mem_patch28
+5c   #mem_patch29
+40   #mem_patch2A
+04   #mem_patch2B
+3a   #mem_patch2C
+ce   #mem_patch2D
+00   #mem_patch2E
+00   #mem_patch2F
+80   #mem_patch30
+e0   #mem_patch31
+00   #mem_patch32
+00   #mem_patch33
+00   #mem_patch34
+00   #mem_patch35
+00   #mem_patch36
+20   #mem_patch37
+00   #mem_patch38
+a0   #mem_patch39
+01   #mem_patch3A
+00   #mem_patch3B
+00   #mem_patch3C
+00   #mem_patch3D
+00   #mem_patch3E
+00   #mem_patch3F
+
+
+mem_customize_timer_setup:  20 00		# 20:10ms  30:15ms
+
+mem_lpm_mode:01
+mem_lpm_mult:40
+mem_lpm_mult_timeout:03
+mem_lpm_overhead:0a
+mem_lpm_interval:10 00
+mem_scan_mode:00
+mem_test:00 00
+
+mem_class: 40 25 00
+
+mem_lap:36 08 c2 08 66 22    
+mem_local_name_length:
+'BT3.0 Keyboard
+mem_sniff_param_interval:0e 00
+mem_sniff_param_attempt:01
+mem_sniff_param_timeout:01
+mem_unsniff2sniff_timer:0a
+mem_ssp_enable:00
+mem_ui_profile_supported:01
+
+mem_eir_enable:01
+
+#bluetootch param init
+mem_sp_flag:00
+mem_lpm_current_mult:00
+mem_master_sp_flag:00
+mem_le_ch_mapped:27
+
+mem_ui_button_gpio:ff
+mem_led_gpio:ff
+
+mem_seqi:80
+
+
+mem_ipc_tx_evt_buff:02 01
+
+
+#attribute list: handle 2bytes, uuid 2bytes, length 1bytes, attribute Nbytes
+mem_le_att_list:
+
+#Primary service: GATT
+01 00 00 28 02 01 18
+#Characteristic: Service changed
+02 00 03 28 01 20
+03 00 05 2a 01 00
+#Client Characteristic Configuration
+04 00 02 29 02 00 00
+
+#Primary Service: GAP
+05 00 00 28 02 00 18 
+#Characteristic: Device Name
+06 00 03 28 01 02 
+07 00 00 2a 
+'BT4.2 Keyboard
+
+#Characteristic: Appearance
+08 00 03 28 01 02 
+09 00 01 2a 02 c1 03 
+#Characteristic: Peripheral Preferred Connection Parameters
+0a 00 03 28 01 02
+0b 00 04 2a 08 06 00 06 00 64 00 2c 01 # interval 6ms, latency 100, timeout 300
+
+#Primary Service: Device Information
+0c 00 00 28 02 0a 18
+#Manufacturer Name
+0d 00 03 28 01 02
+0e 00 29 2a 06 59 69 43 68 69 70			#IOS 13.5.1
+#Characteristic: pnp id
+0f 00 03 28 01 02
+10 00 50 2a 07 02 e8 04 21 70 01 00		# SAMSUNG soft keyboard,setup shortcuts
+
+#Primary service: HID
+11 00 00 28 02 12 18
+#Characteristic:Protocol mode
+12 00 03 28 01 06
+13 00 4e 2a 01 01
+#Characteristic: hid report
+14 00 03 28 01 12   
+15 00 4d 2a 08 00 00 00 00 00 00 00 00	#hid report	led handle write
+16 00 02 29 02 00 00	
+17 00 08 29 02 01 01	#Report ID: 1	Report Type: Input
+#Characteristic:hid report
+18 00 03 28 01 12  
+19 00 4d 2a 05 00 00 00 00 00
+1a 00 02 29 02 00 00
+1b 00 08 29 02 03 01	#Report ID: 3	Report Type: Input
+
+#Characteristic:hid report
+1c 00 03 28 01 12   
+1d 00 4d 2a 02 00 00 	#hid report	led handle write
+1e 00 02 29 02 00 00	
+1f 00 08 29 02 02 01	#Report ID: 2	Report Type: Input
+
+#Characteristic:hid report
+20 00 03 28 01 0e   
+21 00 4d 2a 02 00	00	#hid report	led handle write
+22 00 02 29 02 00 00	
+23 00 08 29 02 01 02	#Report ID: 1	Report Type: Output
+
+#Characteristic:Report map
+24 00 03 28 01 0a
+25 00 4b 2a a0		#length 66+25+60=160=0xa0
+#66
+05 01
+09 06
+a1 01
+85 01
+75 01 
+95 08
+05 07
+19 e0 
+29 e7 
+15 00
+25 01
+81 02
+95 01 
+75 08
+81 03 
+95 05
+75 01
+05 08
+19 01
+29 05  
+91 02 
+95 01  
+75 03  
+91 03
+95 06 
+75 08 
+15 00 
+26 ff 00
+05 07
+19 00
+29 ff 
+81 00
+c0 
+
+#25
+05 0c  		
+09 01  		
+a1 01	
+85 02			
+19 00  		
+2a ff 03 
+15 00 
+26 ff 03		
+95 01  		
+75 10  			
+81 00  		
+c0
+
+#29
+#05 01
+#09 80
+#A1 01
+#85 03
+#15 00
+#25 01
+#75 01
+#95 03
+#19 81
+#29 83
+#81 02
+#95 01
+#75 05
+#81 03
+#C0
+
+#69
+05 01 # Usage Page(Generic Desktop)
+09 02 # Usage(Mouse)
+a1 01 # Collection(Application)
+85 03 # Report ID(3)
+09 01 # Usage(Pointer)
+a1 00 # Collection(Physical)
+05 09 # Usage Page(Buttons)
+19 01 # Usage Minimum(1)
+29 08 # Usage Maximum(8)
+15 00 # Logical Minimum(0)
+25 01 # Logical Maximum(1)
+75 01 # Report Size(1)
+95 08 # Report Count(8)
+81 02 # Input(Data Variable Absolute)
+05 01 # Usage Page(Generic Desktop)
+09 30 # Usage(X)
+09 31 # Usage(Y)
+16 01 80  #Logical Minimum (-32767)
+26 FF 7F #Logical Maximum (32767) 
+75 10 # Report Size(16)
+95 02 # Report Count(2)
+81 06 # Input(Data Variable Relative)
+09 38 # Usage(Wheel)
+15 81 # Logical Minimum(-127)
+25 7f # Logical Maximum(127)
+75 08 # Report Size(8)
+95 01 # Report Count(1)
+81 06 # Input(Data Variable Relative)
+
+05 0c  #USAGE_PAGE(Consumer Devices)
+0a 38 02
+95 01   #REPORT_COUNT (1)	
+81 06  #INPUT (Data,Var,Rel)
+
+c0 # End Collection
+c0 # End Collection
+
+#Characteristic:Hid information
+26 00 03 28 01 02
+27 00 4a 2a 04 11 01 00 01        
+#Characteristic
+28 00 03 28 01 04
+29 00 4c 2a 01 00
+
+#Primary Service: BAS
+2a 00 00 28 02 0f 18 
+#Characteristic: Battery Level
+2b 00 03 28 01 12 
+2c 00 19 2a 01 64 
+#Client Characteristic Configuration
+2d 00 02 29 02 00 00 
+#End of Attribute list
+00 00
+
+
+mem_le_local_mtu:17
+mem_le_transmit_window:50
+mem_le_notify_handle:14
+mem_le_lap:11 46 34 54 77 dd
+
+
+mem_empty_count:00
+mem_att_report1:15 00
+mem_att_report2:1d 00
+mem_att_report3:19 00
+mem_att_report_battery:2c 00
+mem_le_rx_window:50
+
+mem_le_connection_updata_param:
+0c 00 #Length
+05 00 #CID
+12 b4 
+08 00 
+08 00 #min interval
+08 00 #max interval
+00 00 #latency
+2c 01 #timeout
+
+mem_le_name_len:
+'BT Keyboard
+
+mem_le_adv_channel_map:07 
+mem_le_adv_direct_addr_type:01
+#mem_le_adv_interval_max:00 01
+mem_le_adv_data_len:1f
+mem_le_adv_data:
+#02 01 05 05 02 12 18 0f 18 03 19 c1 03
+02 01 05 03 19 c1 03 03 03 12 18
+mem_le_adv_swift_pair:
+#microsoft swift pair
+06 ff 06 00 03 00 80
+
+mem_le_scan_data_len:1f
+mem_le_scan_data:
+'\09BT Keyboard
+
+mem_version_yy_mm_dd:20 21 12 24		#version data 20211224
+
+mem_adc_0v:9f 3e
+mem_adc_3v:cd 4d
+mem_adc_config_flag:04    #01 VINLPM      #02 HVIN      #04 GPIO
+
+#24g init
+mem_24g_mode:01#tx
+mem_24g_data_type:02        #mouse 1,kb 2
+mem_24g_max_retry:4#max tx retry
+mem_24g_no_ack:00#with ack
+mem_24g_rx_window:c0 12     #400us 
+mem_24g_ch_map1:00 13 2c 42
+mem_24g_ch_map2:06 15 36 48
+mem_24g_ch_map3:0f 1a 3a 4c
+mem_24g_ch_map4:11 23 31 4d
+mem_24g_pairing_sm:ff
+mem_24g_paring_addr:20 15 10 05
+mem_pair_state:c2
+mem_24g_common_temp:00 00 00 00 00 00 00 00 00 00
+mem_24g_enter_hibernate:00 48 5d 00 #10 min
+mem_24g_enter_hibernate_max:ff ff ff ff
+mem_24g_short_sleep_counter:e8 fd 00 #00 00 0a
+
+mem_lpm_config:8f 10 ce
+mem_lpm_xtalcnt:00 0a 0b ef 0f
+mem_lpm_hibernate_switch:00
+mem_gpio_wakeup_low:00 00 00 00 00 00 00 00
+mem_fcomp_mul:02
+mem_fcomp_div:24
+mem_iscan_window:12 00
+mem_iscan_interval:00 02
+mem_pscan_window:12 00
+mem_pscan_interval:00 02
+mem_inq_window:20 00
+mem_page_window:20 00
+mem_page_to:00 20
+mem_rx_window_init:80 03
+mem_rx_window_sniff:00 06
+mem_new_supervision_to:00 13
+
+mem_eeprom_base:30 3f
+mem_eeprom_block_size:20
+#pointers to tail space of mem_le_att_list
+4f70:
+07 ff #2M_IF
+0a fb
+0b ff 
+
+#agc table
+1a fb
+1b fb
+1c fb
+1d f6
+1e f2
+1f ee
+20 ea
+21 e6
+22 e2
+23 de
+24 da
+25 d6
+26 d2
+27 ce
+28 ca
+29 c6
+2a c2
+2b bd
+2c b9
+2d b5
+2e b1
+2f ad
+30 a9
+31 80
+32 80
+33 80
+34 c0
+35 c1
+36 c2
+37 c3
+38 c4
+39 c5
+3a c6
+3b c7
+3c 06
+3d 07
+3e 46
+3f 85
+40 86
+41 87
+42 c6
+43 c7
+44 d6
+45 d7
+46 e6
+47 f5
+48 00
+49 f8
+4a 7f
+4e ec
+4f 5e
+
+# tx power
+55 d0
+56 c0
+57 4c
+58 6c
+59 50
+
+#dpll
+68 e4
+69 00
+6a 00
+6b 30
+ff
+mem_rf_init_ptr:70 4f
+
+mem_5db_tx_power_param:
+55 d0
+56 c0
+57 4c
+58 6c
+59 50
+
+mem_24g_paring_tx_power_param:
+55 d0
+56 c0
+57 4c
+58 6c
+59 50
+
Index: c51/patch/sched.rom
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/patch/sched.rom	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/patch/sched.rom	(working copy)
@@ -0,0 +1,465 @@
+mem_patch00:
+2d   #mem_patch00
+00   #mem_patch01
+00   #mem_patch02
+00   #mem_patch03
+00   #mem_patch04
+00   #mem_patch05
+00   #mem_patch06
+00   #mem_patch07
+00   #mem_patch08
+00   #mem_patch09
+00   #mem_patch0A
+00   #mem_patch0B
+00   #mem_patch0C
+00   #mem_patch0D
+00   #mem_patch0E
+00   #mem_patch0F
+00   #mem_patch10
+00   #mem_patch11
+35   #mem_patch12
+00   #mem_patch13
+00   #mem_patch14
+00   #mem_patch15
+4f   #mem_patch16
+02   #mem_patch17
+00   #mem_patch18
+00   #mem_patch19
+00   #mem_patch1A
+00   #mem_patch1B
+00   #mem_patch1C
+00   #mem_patch1D
+00   #mem_patch1E
+00   #mem_patch1F
+00   #mem_patch20
+00   #mem_patch21
+00   #mem_patch22
+00   #mem_patch23
+00   #mem_patch24
+00   #mem_patch25
+04   #mem_patch26
+c8   #mem_patch27
+00   #mem_patch28
+5c   #mem_patch29
+40   #mem_patch2A
+04   #mem_patch2B
+3a   #mem_patch2C
+ce   #mem_patch2D
+00   #mem_patch2E
+00   #mem_patch2F
+80   #mem_patch30
+e0   #mem_patch31
+00   #mem_patch32
+00   #mem_patch33
+00   #mem_patch34
+00   #mem_patch35
+00   #mem_patch36
+20   #mem_patch37
+00   #mem_patch38
+a0   #mem_patch39
+01   #mem_patch3A
+00   #mem_patch3B
+00   #mem_patch3C
+00   #mem_patch3D
+00   #mem_patch3E
+00   #mem_patch3F
+
+
+mem_customize_timer_setup:  20 00		# 20:10ms  30:15ms
+
+mem_lpm_mode:01
+mem_lpm_mult:40
+mem_lpm_mult_timeout:03
+mem_lpm_overhead:0a
+mem_lpm_interval:10 00
+mem_scan_mode:00
+mem_test:00 00
+
+mem_class: 40 25 00
+
+mem_lap:36 08 c2 08 66 22    
+mem_local_name_length:
+'BT3.0 Keyboard
+mem_sniff_param_interval:0e 00
+mem_sniff_param_attempt:01
+mem_sniff_param_timeout:01
+mem_unsniff2sniff_timer:0a
+mem_ssp_enable:00
+mem_ui_profile_supported:01
+
+mem_eir_enable:01
+
+#bluetootch param init
+mem_sp_flag:00
+mem_lpm_current_mult:00
+mem_master_sp_flag:00
+mem_le_ch_mapped:27
+
+mem_ui_button_gpio:ff
+mem_led_gpio:ff
+
+mem_seqi:80
+
+
+mem_ipc_tx_evt_buff:02 01
+
+
+#attribute list: handle 2bytes, uuid 2bytes, length 1bytes, attribute Nbytes
+mem_le_att_list:
+
+#Primary service: GATT
+01 00 00 28 02 01 18
+#Characteristic: Service changed
+02 00 03 28 01 20
+03 00 05 2a 01 00
+#Client Characteristic Configuration
+04 00 02 29 02 00 00
+
+#Primary Service: GAP
+05 00 00 28 02 00 18 
+#Characteristic: Device Name
+06 00 03 28 01 02 
+07 00 00 2a 
+'BT4.2 Keyboard
+
+#Characteristic: Appearance
+08 00 03 28 01 02 
+09 00 01 2a 02 c1 03 
+#Characteristic: Peripheral Preferred Connection Parameters
+0a 00 03 28 01 02
+0b 00 04 2a 08 06 00 06 00 64 00 2c 01 # interval 6ms, latency 100, timeout 300
+
+#Primary Service: Device Information
+0c 00 00 28 02 0a 18
+#Manufacturer Name
+0d 00 03 28 01 02
+0e 00 29 2a 06 59 69 43 68 69 70			#IOS 13.5.1
+#Characteristic: pnp id
+0f 00 03 28 01 02
+10 00 50 2a 07 02 e8 04 21 70 01 00		# SAMSUNG soft keyboard,setup shortcuts
+
+#Primary service: HID
+11 00 00 28 02 12 18
+#Characteristic:Protocol mode
+12 00 03 28 01 06
+13 00 4e 2a 01 01
+#Characteristic: hid report
+14 00 03 28 01 12   
+15 00 4d 2a 08 00 00 00 00 00 00 00 00	#hid report	led handle write
+16 00 02 29 02 00 00	
+17 00 08 29 02 01 01	#Report ID: 1	Report Type: Input
+#Characteristic:hid report
+18 00 03 28 01 12  
+19 00 4d 2a 05 00 00 00 00 00
+1a 00 02 29 02 00 00
+1b 00 08 29 02 03 01	#Report ID: 3	Report Type: Input
+
+#Characteristic:hid report
+1c 00 03 28 01 12   
+1d 00 4d 2a 02 00 00 	#hid report	led handle write
+1e 00 02 29 02 00 00	
+1f 00 08 29 02 02 01	#Report ID: 2	Report Type: Input
+
+#Characteristic:hid report
+20 00 03 28 01 0e   
+21 00 4d 2a 02 00	00	#hid report	led handle write
+22 00 02 29 02 00 00	
+23 00 08 29 02 01 02	#Report ID: 1	Report Type: Output
+
+#Characteristic:Report map
+24 00 03 28 01 0a
+25 00 4b 2a a0		#length 66+25+60=160=0xa0
+#66
+05 01
+09 06
+a1 01
+85 01
+75 01 
+95 08
+05 07
+19 e0 
+29 e7 
+15 00
+25 01
+81 02
+95 01 
+75 08
+81 03 
+95 05
+75 01
+05 08
+19 01
+29 05  
+91 02 
+95 01  
+75 03  
+91 03
+95 06 
+75 08 
+15 00 
+26 ff 00
+05 07
+19 00
+29 ff 
+81 00
+c0 
+
+#25
+05 0c  		
+09 01  		
+a1 01	
+85 02			
+19 00  		
+2a ff 03 
+15 00 
+26 ff 03		
+95 01  		
+75 10  			
+81 00  		
+c0
+
+#29
+#05 01
+#09 80
+#A1 01
+#85 03
+#15 00
+#25 01
+#75 01
+#95 03
+#19 81
+#29 83
+#81 02
+#95 01
+#75 05
+#81 03
+#C0
+
+#69
+05 01 # Usage Page(Generic Desktop)
+09 02 # Usage(Mouse)
+a1 01 # Collection(Application)
+85 03 # Report ID(3)
+09 01 # Usage(Pointer)
+a1 00 # Collection(Physical)
+05 09 # Usage Page(Buttons)
+19 01 # Usage Minimum(1)
+29 08 # Usage Maximum(8)
+15 00 # Logical Minimum(0)
+25 01 # Logical Maximum(1)
+75 01 # Report Size(1)
+95 08 # Report Count(8)
+81 02 # Input(Data Variable Absolute)
+05 01 # Usage Page(Generic Desktop)
+09 30 # Usage(X)
+09 31 # Usage(Y)
+16 01 80  #Logical Minimum (-32767)
+26 FF 7F #Logical Maximum (32767) 
+75 10 # Report Size(16)
+95 02 # Report Count(2)
+81 06 # Input(Data Variable Relative)
+09 38 # Usage(Wheel)
+15 81 # Logical Minimum(-127)
+25 7f # Logical Maximum(127)
+75 08 # Report Size(8)
+95 01 # Report Count(1)
+81 06 # Input(Data Variable Relative)
+
+05 0c  #USAGE_PAGE(Consumer Devices)
+0a 38 02
+95 01   #REPORT_COUNT (1)	
+81 06  #INPUT (Data,Var,Rel)
+
+c0 # End Collection
+c0 # End Collection
+
+#Characteristic:Hid information
+26 00 03 28 01 02
+27 00 4a 2a 04 11 01 00 01        
+#Characteristic
+28 00 03 28 01 04
+29 00 4c 2a 01 00
+
+#Primary Service: BAS
+2a 00 00 28 02 0f 18 
+#Characteristic: Battery Level
+2b 00 03 28 01 12 
+2c 00 19 2a 01 64 
+#Client Characteristic Configuration
+2d 00 02 29 02 00 00 
+#End of Attribute list
+00 00
+
+
+mem_le_local_mtu:17
+mem_le_transmit_window:50
+mem_le_notify_handle:14
+mem_le_lap:11 46 34 54 77 dd
+
+
+mem_empty_count:00
+mem_att_report1:15 00
+mem_att_report2:1d 00
+mem_att_report3:19 00
+mem_att_report_battery:2c 00
+mem_le_rx_window:50
+
+mem_le_connection_updata_param:
+0c 00 #Length
+05 00 #CID
+12 b4 
+08 00 
+08 00 #min interval
+08 00 #max interval
+00 00 #latency
+2c 01 #timeout
+
+mem_le_name_len:
+'BT Keyboard
+
+mem_le_adv_channel_map:07 
+mem_le_adv_direct_addr_type:01
+#mem_le_adv_interval_max:00 01
+mem_le_adv_data_len:1f
+mem_le_adv_data:
+#02 01 05 05 02 12 18 0f 18 03 19 c1 03
+02 01 05 03 19 c1 03 03 03 12 18
+mem_le_adv_swift_pair:
+#microsoft swift pair
+06 ff 06 00 03 00 80
+
+mem_le_scan_data_len:1f
+mem_le_scan_data:
+'\09BT Keyboard
+
+mem_version_yy_mm_dd:20 21 12 24		#version data 20211224
+
+mem_adc_0v:9f 3e
+mem_adc_3v:cd 4d
+mem_adc_config_flag:04    #01 VINLPM      #02 HVIN      #04 GPIO
+
+#24g init
+mem_24g_mode:01#tx
+mem_24g_data_type:02        #mouse 1,kb 2
+mem_24g_max_retry:4#max tx retry
+mem_24g_no_ack:00#with ack
+mem_24g_rx_window:c0 12     #400us 
+mem_24g_ch_map1:00 13 2c 42
+mem_24g_ch_map2:06 15 36 48
+mem_24g_ch_map3:0f 1a 3a 4c
+mem_24g_ch_map4:11 23 31 4d
+mem_24g_pairing_sm:ff
+mem_24g_paring_addr:20 15 10 05
+mem_pair_state:c2
+mem_24g_common_temp:00 00 00 00 00 00 00 00 00 00
+mem_24g_enter_hibernate:00 48 5d 00 #10 min
+mem_24g_enter_hibernate_max:ff ff ff ff
+mem_24g_short_sleep_counter:e8 fd 00 #00 00 0a
+
+mem_lpm_config:8f 10 ce
+mem_lpm_xtalcnt:00 0a 0b ef 0f
+mem_lpm_hibernate_switch:00
+mem_gpio_wakeup_low:00 00 00 00 00 00 00 00
+mem_fcomp_mul:02
+mem_fcomp_div:24
+mem_iscan_window:12 00
+mem_iscan_interval:00 02
+mem_pscan_window:12 00
+mem_pscan_interval:00 02
+mem_inq_window:20 00
+mem_page_window:20 00
+mem_page_to:00 20
+mem_rx_window_init:80 03
+mem_rx_window_sniff:00 06
+mem_new_supervision_to:00 13
+
+mem_eeprom_base:30 3f
+mem_eeprom_block_size:20
+#pointers to tail space of mem_le_att_list
+4f70:
+07 ff #2M_IF
+0a fb
+0b ff 
+
+#agc table
+1a fb
+1b fb
+1c fb
+1d f6
+1e f2
+1f ee
+20 ea
+21 e6
+22 e2
+23 de
+24 da
+25 d6
+26 d2
+27 ce
+28 ca
+29 c6
+2a c2
+2b bd
+2c b9
+2d b5
+2e b1
+2f ad
+30 a9
+31 80
+32 80
+33 80
+34 c0
+35 c1
+36 c2
+37 c3
+38 c4
+39 c5
+3a c6
+3b c7
+3c 06
+3d 07
+3e 46
+3f 85
+40 86
+41 87
+42 c6
+43 c7
+44 d6
+45 d7
+46 e6
+47 f5
+48 00
+49 f8
+4a 7f
+4e ec
+4f 5e
+
+# tx power
+55 d0
+56 c0
+57 4c
+58 6c
+59 50
+
+#dpll
+68 e4
+69 00
+6a 00
+6b 30
+ff
+mem_rf_init_ptr:70 4f
+
+mem_5db_tx_power_param:
+55 d0
+56 c0
+57 4c
+58 6c
+59 50
+
+mem_24g_paring_tx_power_param:
+55 d0
+56 c0
+57 4c
+58 6c
+59 50
+
Index: c51/patch/sys.obj
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/patch/sys.obj
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/patch/utilities.obj
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/patch/utilities.obj
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/ram.c
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/ram.c	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/ram.c	(working copy)
@@ -0,0 +1,8 @@
+
+extern void YC_System_Main(void);
+
+
+void main()
+{
+	YC_System_Main();
+}
Index: c51/sys.h
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/sys.h	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/sys.h	(working copy)
@@ -0,0 +1,75 @@
+#ifndef _YC_SYSTEM_H_
+#define _YC_SYSTEM_H_
+#include "common.h"
+
+
+#define STANDBY_TIMER_120MIN				14400		// 500ms*14400 = 120min
+#define PC_SLEEP_STATUS_GET
+
+
+#define STANDBY_TIMER_30MIN				3600		// 500ms*3600 = 30min
+#define STANDBY_TIMER_10MIN				1200		// 500ms*1200 = 10min
+#define RECONNECT_TIMER_5S				10			// 500ms*10 = 5s
+#define RECONNECT_TIMER_10S			20			// 500ms*20 = 10s
+
+#define BT_PAIRING_TIME_OUT_2MIN		240			// 500ms*240 = 2min
+#define BT_PAIRING_TIME_OUT_1MIN		120			// 500ms*120 = 1min
+#define G24_PAIRING_TIME_OUT_20S		40			// 500ms*40 = 20s
+
+#define KB_NUM_CAPS_LED_ON_TIMER    	20			// 500ms*20 = 10s
+
+#define KB_POWERON_LED_ON_TIMER		10			// 100ms*30 = 3s
+
+
+typedef enum c51_ble_state_enum
+{
+	CHANGE_TO_BLE_DISCONNECT =0,
+	CHANGE_TO_BLE_INDIR_ADV = 1,
+	CHANGE_TO_BLE_DIRECT_ADV,
+	CHANGE_TO_BLE_CONNECTING,
+	CHANGE_TO_BLE_CONNECTED,
+}C51_BLE_STATE;
+
+typedef enum c51_br_state_enum{
+	CHANGE_TO_BR_DISCONNECT =0,
+	CHANGE_TO_BR_DISCOVERY = 1,
+	CHANGE_TO_BR_RECONNECT,
+	CHANGE_TO_BR_CONNECTING,
+	CHANGE_TO_BR_CONNECTED,
+}C51_BR_STATE;
+
+typedef enum c51_24g_state_enum{
+	CHANGE_TO_24G_DISCONNECTED =0,
+	CHANGE_TO_24G_PAIRING= 1,
+	CHANGE_TO_24G_CONNECTING,
+	CHANGE_TO_24G_CONNECTED,
+}C51_24G_STATE;
+
+typedef enum c51_ble_connecting_substate_enum
+{
+	CHANGE_TO_BLE_SUB_NONE=0,
+	CHANGE_TO_BLE_SUB_INIT,
+	CHANGE_TO_BLE_SUB_PINCODE,
+	CHANGE_TO_BLE_SUB_PINCODE_OK,
+}C51_BLE_CONNECTING_SUBSTATE;
+
+typedef enum c51_br_connecting_substate_enum
+{
+	CHANGE_TO_BR_SUB_NONE =0,
+	CHANGE_TO_BR_SUB_INIT,
+	CHANGE_TO_BR_SUB_PINCODE,
+	CHANGE_TO_BR_SUB_PINCODE_OK,
+}C51_BR_CONNECTING_SUBSTATE;
+
+typedef enum c51_24g_connecting_substate_enum
+{
+	CHANGE_TO_24G_SUB_NONE=0,
+	CHANGE_TO_24G_SUB_INIT ,
+}C51_24G_CONNECTING_SUBSTATE;
+
+void System_long_sleep();
+void System_Reset_Connect();
+void YC_adc_init();
+
+
+#endif
Index: c51/sys.c
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/sys.c	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/sys.c	(working copy)
@@ -0,0 +1,854 @@
+#include "sys.h"
+#include "gpio.h"
+#include "kbhid.h"
+#include "ipc.h"
+#include "iic.h"
+#include "keyscan.h"
+#include "global_variable.h"
+#include "kb_process.h"
+
+/////////////////////////////////////////////////////////////////
+static void System_clear_mem()
+{
+	xmemclear((byte *)&g_variable,sizeof(G_VARIABLE_MAP));
+	xmemclear(ksSelMapOld,KB_KSCAN_COL_NUM);
+	xmemclear(ksSelMapCheck,KB_KSCAN_COL_NUM);
+	xmemclear(ksSelMapCurr,KB_KSCAN_COL_NUM);
+	xmemclear(hidBuff,9);
+	xmemclear(multikey,9);
+ 
+	delayChgInvTimer = 0;
+	action_timeout = 0;
+
+	power_on_flag = 0;
+	repeat_send_24g = 0;
+	get_24g_led_send = 0;
+	ble_reconnect_flag = 0;
+	press_long_time_flag = 0;
+	mult_key_status = 0;
+	long_press_flag = 0;
+	standard_key_release_flag = 0;
+	fn_flag = 0;
+	fn_flag_last = 0;
+	fn_tx_flag = 0;
+	fn_lock_flag = 0;
+
+	mult_key_value = 0;
+	m_caps_num_lock = 0xf0;
+	m_caps_num_lock_last = 0xf0; 
+	m_reconnect_continue = 0;
+	ble_send_secutiry_request_timer = 0;
+}
+
+static void System_IIC_clk_setup()		// 400KHz
+{
+	REG_IICD_SCL_LOW  =  0x0d;
+   	REG_IICD_SCL_HIGH  =  0x0e;
+   	REG_IICD_START_SETUP  = 0x0e;
+   	REG_IICD_START_HOLD  = 0x0e;
+  	REG_IICD_STOP_SETUP  = 0x0e;
+   	REG_IICD_DATA_SETUP  = 0x0d;
+}
+
+static void System_Hardware_init()
+{
+	System_IIC_clk_setup();
+	KS_Initialize();
+	LED_all_shutdown();
+}
+
+
+void System_Software_init()
+{
+	System_clear_mem();
+	YC_adc_init();
+	g_variable.release_data =1;
+	g_variable.powerOn_timer = KB_POWERON_LED_ON_TIMER;
+//	g_variable.powerOn_first_flag = 1;
+	g_variable.recon_count = 0;
+	g_variable.test_buff = 0xff;
+	le_lap_temp[0] = m_le_lap[3];
+	le_lap_temp[1] = m_le_lap[4];
+	le_lap_temp[2] = m_le_lap[5];
+}
+
+static void System_Hardware_reset()
+{
+	m_reset_reg = 1;
+	while(1);
+}
+
+void System_long_sleep()
+{ 
+	m_reconnect_continue = 0;
+	IPC_TxControlCmd(IPC_CMD_ENTER_HIBERNATE);
+}
+
+void System_G24_long_lpm()
+{
+	LED_all_shutdown();
+	m_24g_pairing_sm = 0xff;
+	g_variable.g24_long_sleep_flag = 1;
+#ifdef PC_SLEEP_STATUS_GET	
+	g_variable.sys_numlockled_on_timer = 0;
+	g_variable.sys_capslockled_on_timer = 0;
+	g_variable.sys_scrolllockled_on_timer = 0;
+	m_caps_num_lock = 0xf0;
+	m_caps_num_lock_last = 0xf0; 
+#endif	
+	m_24g_enter_hibernate[0]	= 0xff;
+	m_24g_enter_hibernate[1]	= 0xff;
+	m_24g_enter_hibernate[2]	= 0xff;
+	m_24g_enter_hibernate[3]	= 0xff;
+}
+
+void System_Reset_Connect()
+{
+	System_Hardware_reset();
+}
+/////////////////////////////////////////////////////////////////
+
+/////////////////////////////////////////////////////////////////
+
+
+/////////////////////////////////////////////////////////////////
+static void kb_cb_Hid(byte *p,byte len) {
+	//p[0] is hid type,always is 1(kb) now
+	byte temp = p[1];
+
+	if (len<2) {
+		return;
+	}
+}
+
+static void kb_cb_event(byte evt)
+{
+
+	switch (evt) 
+	{
+	case IPC_EVT_HIBERNATE_WAKE:
+	case IPC_EVT_RESET:
+		System_Hardware_init();
+		System_Software_init();
+		IIC_Read(EEPROM_RECON_INFO_LAST_DEVICE ,1 ,(byte *)&g_variable.last_device_num);
+		if(g_variable.last_device_num > 3)
+			g_variable.last_device_num = 0;
+		g_variable.current_device_num = g_variable.last_device_num;
+		LED_device_poweron();
+		Delay1ms(10);
+		IIC_Read(EEPROM_RECON_INFO_RAMDON_LE_LAP1 ,2 ,(byte *)&g_variable.ble_ramdon_lap1);
+		if(g_variable.ble_ramdon_lap1 == 0xff && g_variable.ble_ramdon_lap2 == 0xff)
+		{
+			g_variable.ble_ramdon_lap1 = m_adc3vValue;
+			g_variable.ble_ramdon_lap2 = m_adc0vBase;
+		}
+		YC_start_reconnect();
+		break;
+	case IPC_EVT_WAKEUP:
+		System_IIC_clk_setup();
+		KS_Initialize();
+		g_variable.g24_long_sleep_flag = 0;
+		break;
+
+// connection event
+	case IPC_EVT_VIRTUAL_CABLE_UNPLUG:
+	case IPC_EVT_CLEAR_LINKKEY:
+		if ((g_variable.current_device_num > 0) && (g_variable.current_device_num < 4))
+		{
+			xmemclear_ff((byte *)&bd_key_record_list[g_variable.current_device_num-1],sizeof(BD_KEY_RECORD));	
+			Delay1ms(200);
+			GPIO_Setout(EEPROM_WP_GPIO,0);
+			IIC_WriteBlock(EEPROM_RECON_INFO_BASE ,sizeof(BD_KEY_RECORD)*3 , (byte *)bd_key_record_list);		
+			GPIO_Setout(EEPROM_WP_GPIO,1);
+		}
+		break;
+	case IPC_EVT_RECONNECT_STANDY:
+		YC_load_record_list(recon_index);
+		break;		
+		
+// 2.4G event	
+	case IPC_EVT_24G_PAIRING_COMPLETE:
+	case IPC_EVT_24G_ATTEMPT_SUCCESS:
+		g_variable.g24_currentState =  CHANGE_TO_24G_CONNECTED;
+		g_variable.g24_currentSubState = CHANGE_TO_24G_SUB_NONE;
+		YC_clear_reconnect_flag();
+		g_variable.pairing_g24_timeout = 0;
+		g_variable.release_data = 0;
+		g_variable.last_device_num = 0xfe;
+		g_variable.current_device_num = 0xfe;
+		m_24g_led_flag = KB_24G_LED_ACK_TYPE;
+		delayChgInvTimer = 10;
+
+		if(evt == IPC_EVT_24G_PAIRING_COMPLETE)
+		{
+			fn_lock_flag = 0;
+			fast_connect_flag = 0;
+			g_variable.system_mode = OSMODE_WINDOWS;
+			g_variable.powerOn_timer = KB_POWERON_LED_ON_TIMER;
+			if(m_24g_paring_addr[0] != 0x0f || m_24g_paring_addr[1] != 0x0f ||
+				m_24g_paring_addr[2] != 0x0f || m_24g_paring_addr[3] != 0x0f)
+				{
+					g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_G24;
+					YC_update_eeprom_data();
+					System_Hardware_reset();
+				}
+		}
+		else
+		{
+			if(!g_variable.powerOn_timer)
+			;//GPIO_Setout(G24_LED_GPIO,LED_OFF);
+		}
+		break;
+	
+	case IPC_EVT_24G_ATTEMPT_FAIL:	
+		g_variable.g24_currentState =  CHANGE_TO_24G_DISCONNECTED;
+		g_variable.g24_currentSubState = CHANGE_TO_24G_SUB_NONE;
+		g_variable.sleepTimer = 0;
+		g_variable.release_data = 1;
+
+		if (g_variable.key_action != KEY_NONE)
+		{
+			YC_clear_reconnect_flag();
+			YC_key_action_handle(g_variable.key_action);
+			break;
+		}
+
+		if (g_variable.lockLpm == 1)
+		{
+			g_variable.lockLpm =0;
+			System_long_sleep();
+			break;
+		}
+		if (g_variable.recon_count != 0)
+		{
+			YC_load_record_list(recon_index);
+		}
+		break;
+
+
+
+// BT 4.2 event
+	case IPC_EVT_LE_CONNECTED:
+		g_variable.ble_currentState = CHANGE_TO_BLE_CONNECTING;
+		g_variable.ble_currentSubState = CHANGE_TO_BLE_SUB_INIT;
+		g_variable.br_currentState = CHANGE_TO_BR_DISCONNECT;
+		g_variable.br_currentSubState = CHANGE_TO_BR_SUB_NONE;
+		IPC_TxControlCmd(IPC_CMD_STOP_ADV);
+		IPC_TxControlCmd(IPC_CMD_STOP_DISCOVERY);
+		if(g_variable.pairing_timeout)
+		{
+			fn_lock_flag = 0;
+			g_variable.system_mode = OSMODE_WINDOWS;
+			bd_key_record_list[g_variable.current_device_num - 1].system_mode = g_variable.system_mode;
+			bd_key_record_list[g_variable.current_device_num - 1].fn_lock = fn_lock_flag;
+		}
+		if(!ble_reconnect_flag)
+			ble_send_secutiry_request_timer = 20;
+		if(!g_variable.powerOn_timer)
+			LED_device_poweroff();
+		g_variable.pairing_timeout = 0;
+		g_variable.sleepTimer = 0;
+		break;
+	case IPC_EVT_LE_PROTOCOL_CONNECTED:
+	    	g_variable.ble_currentState = CHANGE_TO_BLE_CONNECTED;
+		g_variable.ble_currentSubState = CHANGE_TO_BLE_SUB_NONE;
+		YC_clear_reconnect_flag();
+		g_variable.release_data = 0;
+		le_send_battery_level_delay_count = 10;
+		g_variable.last_device_num = g_variable.current_device_num;
+		g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_BT;
+		break;
+	case IPC_EVT_LE_ENC_INFO:
+		YC_store_record_list(1, g_variable.current_device_num-1);
+		g_variable.last_device_num = g_variable.current_device_num;
+		g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_BT;
+		break;
+
+	case IPC_EVT_LE_PINCODE_REQ:
+		le_pin_code = 0;
+		le_pin_code_len = 0;
+		pinCode_flag = 1;
+		g_variable.ble_currentSubState =  CHANGE_TO_BLE_SUB_PINCODE;
+		g_variable.ble_currentState = CHANGE_TO_BLE_CONNECTING;
+		break;
+		
+	case IPC_EVT_LE_DISCONNECTED:	
+		g_variable.history_state = g_variable.ble_currentState ;
+		g_variable.ble_currentState = CHANGE_TO_BLE_DISCONNECT;
+		g_variable.ble_currentSubState = CHANGE_TO_BLE_SUB_NONE;
+		g_variable.release_data = 1;
+		m_le_send_security_request_flag = 0;
+		if (g_variable.lockLpm == 1)
+		{
+			g_variable.lockLpm =0;
+			System_long_sleep();
+			break;
+		}
+
+		if (g_variable.key_action != KEY_NONE)
+		{
+			YC_key_action_handle(g_variable.key_action);
+			break;
+		}
+
+
+		if (g_variable.recon_count != 0)
+		{
+			YC_load_record_list(recon_index);
+			break;
+		}
+
+		System_long_sleep();		
+		g_variable.sleepTimer = 0;
+		break;
+	}
+}
+
+
+void LED_timer500ms()
+{
+	if (power_on_flag != 2)
+		return;
+	if (g_variable.pairing_timeout != 0) //bt  pairing
+	{
+		if (g_variable.button_reconnect_flag != 1)
+		{
+			if(g_variable.current_device_num == 1)
+				GPIO_FlipOutBit(BT_LED_GPIO);
+			else if(g_variable.current_device_num == 2)
+				GPIO_FlipOutBit(BT2_LED_GPIO);
+		}
+		else
+		{
+			GPIO_Setout(BT_LED_GPIO,LED_OFF);
+			GPIO_Setout(BT2_LED_GPIO,LED_OFF);
+			GPIO_Setout(LOWPOWER_LED_GPIO,LED_OFF);
+		}
+	}
+	else if (g_variable.pairing_g24_timeout != 0)
+	{
+		GPIO_FlipOutBit(LOWPOWER_LED_GPIO);
+	}
+	else
+	{
+		
+	}
+
+	
+	if (YC_check_is_connected()&& !g_variable.powerOn_timer)
+	{
+		if(g_variable.sys_numlockled_on_timer)
+		{
+			g_variable.sys_numlockled_on_timer--;
+			GPIO_Setout(NUM_LOCK_LED_GPIO, LED_ON);
+			if(!g_variable.sys_numlockled_on_timer)
+				GPIO_Setout(NUM_LOCK_LED_GPIO, LED_OFF);
+		}
+		else 
+			GPIO_Setout(NUM_LOCK_LED_GPIO, LED_OFF);
+
+		if(g_variable.sys_capslockled_on_timer)
+		{
+			g_variable.sys_capslockled_on_timer--;
+			GPIO_Setout(CAPS_LED_GPIO, LED_ON);
+			if(!g_variable.sys_capslockled_on_timer)
+				GPIO_Setout(CAPS_LED_GPIO, LED_OFF);
+		}
+		else
+			GPIO_Setout(CAPS_LED_GPIO, LED_OFF);
+
+
+		if(g_variable.sys_scrolllockled_on_timer)
+		{
+			g_variable.sys_scrolllockled_on_timer--;
+			if(!g_variable.powerOn_timer && !g_variable.battery_low_led_flash_interval)
+			{
+				GPIO_Setout(LOWPOWER_LED_GPIO, LED_ON);
+				if(!g_variable.sys_scrolllockled_on_timer)
+					GPIO_Setout(LOWPOWER_LED_GPIO, LED_OFF);
+			}
+		}		
+		
+	}	
+}
+
+void YC_connect_timeout_500ms()
+{
+
+	if(le_send_battery_level_delay_count)
+	{
+		le_send_battery_level_delay_count--;
+		if(!le_send_battery_level_delay_count)
+		{	
+			m_lpm_mode = 1;
+			le_send_battery_level_flag = 1;
+		}
+	}
+	
+//system long sleep timer
+	if (g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTED)
+	{
+		if (g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTED)
+		{
+			if(le_send_battery_level_flag || (g_variable.sleepTimer && !(g_variable.sleepTimer & 0x1f)))		// ble battery level updata each 16 second
+			{
+				le_send_battery_level_flag = 0;
+				multikey[0] = HID_REPORTID_BATTERY;	
+				multikey[1] = g_variable.battery_level_percentage;	
+				IPC_TxHidData(multikey, 2);
+			}
+		}
+		if (g_variable.sleepTimer == STANDBY_TIMER_120MIN) 
+		{
+			YC_disconnect_all_link();
+			g_variable.lockLpm = 1;
+		}
+	}
+	else if(g_variable.g24_currentState == CHANGE_TO_24G_CONNECTED)
+	{
+		if((g_variable.sleepTimer == 10) && m_24g_led_flag)
+		{
+			m_24g_led_flag = 0;
+		}	
+	
+#ifdef PC_SLEEP_STATUS_GET	
+		if((g_variable.sleepTimer & 0x1f) == 0x10)	// search dongle each 8s
+		{
+			xmemclear(hidBuff,9);
+
+			mult_key_status = 0;
+			hidBuff[0] = HID_REPORTID_1;		// standard key send
+			IPC_TxHidData(hidBuff, 9);
+		}
+#endif	
+		if (g_variable.sleepTimer >= STANDBY_TIMER_10MIN)
+		{
+			System_G24_long_lpm();
+		}
+	}
+	else if(g_variable.g24_currentState == CHANGE_TO_24G_PAIRING)
+	{
+		if (g_variable.sleepTimer >= BT_PAIRING_TIME_OUT_1MIN)
+		{
+			System_G24_long_lpm();
+		}
+	}
+	else
+	{
+		if (g_variable.sleepTimer >= RECONNECT_TIMER_10S)
+		{
+			if(ble_reconnect_flag)
+			{
+				ble_reconnect_flag = 0;
+				IPC_TxControlCmd(IPC_CMD_STOP_ADV);
+			}
+			System_long_sleep();
+		}
+	}
+}
+
+
+void YC_wait_disconnect_timer500ms()
+{
+//before discovery/adv,if current state is connected,wait disconnect done
+	if (action_timeout!=0)
+	{
+		action_timeout--;
+		if(action_timeout == 0)
+		{
+			if(g_variable.key_action == KEY_DISCOVERY
+			&& (m_ui_state_map & 0x0008) != 0x0008)
+
+			{
+//				m_lpm_mode = 0;
+				ble_send_secutiry_request_timer = 0;
+				g_variable.pairing_timeout = BT_PAIRING_TIME_OUT_2MIN;
+				g_variable.pairing_g24_timeout = 0;
+				fast_connect_flag = 0;
+				ble_fast_connect_flag = 0;
+				YC_get_ble_ramdon_lap();
+				IPC_TxControlCmd(IPC_CMD_START_ADV);
+				g_variable.key_action = KEY_NONE;
+			}
+		}
+	}
+
+}
+
+
+void YC_pairing_timerout_500ms()
+{
+//pairing timer
+	if (g_variable.pairing_timeout != 0)
+	{
+		g_variable.sleepTimer = 0;
+		g_variable.pairing_timeout--;
+		if (g_variable.pairing_timeout == 0)
+		{
+			g_variable.current_device_num = g_variable.temp_device_num;
+			g_variable.last_device_num = g_variable.current_device_num;
+		
+			YC_key_action_handle(KEY_STOP_DISCOVERY);
+			System_long_sleep();
+		}
+	}
+
+	if (g_variable.pairing_g24_timeout != 0)
+	{
+		g_variable.sleepTimer = 0;
+		g_variable.pairing_g24_timeout--;
+		if (g_variable.pairing_g24_timeout == 0)
+		{
+//			IPC_TxControlCmd(IPC_CMD_STOP_24G);
+			Delay1ms(10);
+			System_long_sleep();
+		}
+	}
+}
+
+void kb_button_press_timer500ms()
+{
+	
+//key status 
+/*
+	if (g_variable.button_flag & KEY_FLAG_BTKEY_PRESS)		//press BT key
+	{
+		if (g_variable.button_timer[0] < 250)
+			g_variable.button_timer[0]++;
+		if (g_variable.button_timer[0] == 2)
+		{
+			YC_key_action_handle(KEY_DISCOVERY);
+		}
+	}
+	else
+		g_variable.button_timer[0] = 0;
+*/		
+	
+	if (g_variable.button_flag & KEY_FLAG_SAME_KEY_PRESS)
+	{
+		if (g_variable.button_timer[1] < 250)
+			g_variable.button_timer[1]++;
+		if (g_variable.button_timer[1] == 180)			// 500ms*180*3 = 4min30s
+		{
+			press_long_time_flag++;
+			if(press_long_time_flag <= 2)
+			{
+				g_variable.button_timer[1] = 0;
+			}
+			else if(press_long_time_flag == 3)
+			{
+				long_press_flag = 1;
+				g_variable.button_timer[1] = 0;
+				System_long_sleep();
+			}
+		}
+	}
+	else
+	{
+		press_long_time_flag = 0;
+		long_press_flag = 0;
+		g_variable.button_timer[1] = 0;
+	}
+
+				
+	if (g_variable.button_flag & KEY_FLAG_FN_24G_DEVICE_BUTTON)		// G24 pairing
+	{
+		g_variable.delay_enter_lpm_timer = 10;
+		if (g_variable.button_timer[2] < 250)
+			g_variable.button_timer[2]++;
+		if (g_variable.button_timer[2] == 6)
+		{
+			if( !g_variable.current_device_num || (g_variable.current_device_num == 0xfe))
+			{
+				g_variable.button_24G_rec_flag = 0;
+				YC_disconnect_all_link();
+				Delay1ms(10);
+				YC_key_action_handle(KEY_PAIRING_24G);
+				LED_all_shutdown();
+
+			}
+		}
+	}
+	else
+	{
+		if(g_variable.button_24G_rec_flag)
+		{
+			g_variable.button_24G_rec_flag = 0;
+			YC_key_action_handle(KEY_STOP_DISCOVERY);
+			g_variable.release_data = 1;
+			g_variable.last_device_num = g_variable.current_device_num;
+			g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_NORMAL;
+			YC_update_eeprom_data();
+			System_Reset_Connect();
+		}
+		g_variable.button_timer[2] = 0;
+	}
+
+	
+	if (g_variable.button_flag & KEY_FLAG_FN_DEVICE_BUTTON)
+	{
+		g_variable.delay_enter_lpm_timer = 10;
+		if (g_variable.button_timer[3] < 250)
+			g_variable.button_timer[3]++;
+		if (g_variable.button_timer[3] == 6)
+		{
+			//do discoverable
+			g_variable.pairing_timeout = BT_PAIRING_TIME_OUT_2MIN;
+			g_variable.pairing_g24_timeout = 0;
+			YC_key_action_handle(KEY_DISCOVERY);
+			LED_all_shutdown();
+			g_variable.button_reconnect_flag = 0;
+			g_variable.release_data = 1;
+			g_variable.temp_device_num = g_variable.last_device_num;
+			g_variable.last_device_num = g_variable.current_device_num;
+		}
+	}
+	else
+	{
+		if (g_variable.button_reconnect_flag)
+		{
+			g_variable.button_reconnect_flag = 0;
+
+			if(g_variable.last_device_num !=g_variable.current_device_num)		//switch device,
+			{
+				g_variable.release_data = 1;
+				LED_all_shutdown();
+				g_variable.last_device_num = g_variable.current_device_num;
+				g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_NORMAL;
+				
+				YC_disconnect_all_link();
+				YC_update_eeprom_data();
+				System_Reset_Connect();
+			}
+		}
+		g_variable.button_timer[3] = 0;
+	}
+		
+
+
+	if (g_variable.button_flag & KEY_FLAG_FN_SYSTEM_MODE_BUTTON)
+	{
+		if (g_variable.button_timer[0] < 250)
+			g_variable.button_timer[0]++;
+		if (g_variable.button_timer[0] == 6)
+		{
+			if(key_value_temp == HID_KEY_Q)
+			{
+				g_variable.system_mode = OSMODE_IOS;
+			}
+			else if(key_value_temp == HID_KEY_O)
+			{
+				g_variable.system_mode = OSMODE_MAC;
+
+			}
+			else if(key_value_temp == HID_KEY_W ||key_value_temp == HID_KEY_E )
+			{
+				g_variable.system_mode = OSMODE_WINDOWS;
+
+			}
+			g_variable.powerOn_timer = 10;
+			if(g_variable.current_device_num == 0 || g_variable.current_device_num == 0xfe)
+			{
+				g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_G24;
+			}
+			else	if (g_variable.current_device_num <= 3 && g_variable.current_device_num >= 1)
+			{
+				bd_key_record_list[g_variable.current_device_num - 1].system_mode = g_variable.system_mode;
+				g_variable.update_eeprom_flag = EEPROM_STORE_TYPE_BT;
+			}
+		}
+	}
+	else
+	{
+		g_variable.button_timer[0] = 0;
+	}		
+
+}
+
+
+
+static void kb_cb_Timer500ms()
+{
+	LED_timer500ms();	
+
+	g_variable.sleepTimer++;
+
+	YC_adc_motion_check_timer500ms();
+	YC_connect_timeout_500ms();
+	kb_button_press_timer500ms();
+	YC_wait_disconnect_timer500ms();
+	YC_pairing_timerout_500ms();
+	
+/*	
+	if(g_variable.ble_currentSubState ==  CHANGE_TO_BLE_SUB_PINCODE)
+	{
+		g_variable.sleepTimer = 0;				//wait macOS enter pincode
+	}
+*/	
+	return;
+}
+
+
+static void kb_cb_Timer100ms()
+{
+
+	if (g_variable.delay_enter_lpm_timer) 
+	{
+		g_variable.delay_enter_lpm_timer --;
+	}
+
+	if(g_variable.recon_delay)
+		g_variable.recon_delay--;
+
+	if(g_variable.one_key_press_wait_release_timer)
+	{
+		g_variable.one_key_press_wait_release_timer--;
+		if(!g_variable.one_key_press_wait_release_timer)
+			g_variable.key_combination_step = CAMBINATION_KEY_NULL;
+	}
+	
+	if (g_variable.powerOn_timer != 0)
+	{	
+		if(g_variable.pairing_g24_timeout)
+		{
+			g_variable.powerOn_timer = 0;
+			return;
+		}
+			
+		g_variable.powerOn_timer--;
+		LED_device_poweron();
+		if (!g_variable.powerOn_timer)
+		{
+			LED_device_poweroff();
+		}
+	}
+	else	if ((g_variable.pairing_timeout == 0) && (g_variable.pairing_g24_timeout == 0))  //  pairing
+	{
+		if(g_variable.battery_low_led_flash_interval)
+		{
+			g_variable.battery_low_led_flash_interval--;
+			if(g_variable.battery_low_led_flash_interval < 4)
+			{
+				if(g_variable.battery_low_led_flash_interval & 0x02)
+				{
+					GPIO_Setout(LOWPOWER_LED_GPIO, LED_ON);
+				}
+				else
+				{
+					GPIO_Setout(LOWPOWER_LED_GPIO, LED_OFF);	
+				}	
+			}
+			else
+				GPIO_Setout(LOWPOWER_LED_GPIO, LED_OFF);
+			if(!g_variable.battery_low_led_flash_interval)
+				g_variable.battery_low_led_flash_interval = LOW_BATTERY_FLASH_INTERVAL;
+		}
+	}
+	
+// The dongle must receive data within 200ms, otherwise it will be forced to lift
+	if(!long_press_flag)
+	{
+		if (repeat_send_24g == 1)
+		{
+			g_variable.sleepTimer = 0;	
+			repeat_send_24g = 0;
+
+			 if (multikey[0] != 0)
+			{
+				IPC_TxHidData(multikey, 3);
+			}
+			else if (hidBuff[0] != 0)
+			{
+
+				IPC_TxHidData(hidBuff,9);
+			}
+		}
+	}
+
+
+// ble delay send secutiry request
+	if(ble_send_secutiry_request_timer)
+	{
+		ble_send_secutiry_request_timer--;
+		if(!ble_send_secutiry_request_timer)
+		{
+			if(!m_le_send_security_request_flag)
+			{
+				IPC_TxControlCmd(IPC_CMD_LE_SMP_SECURITY_REQUEST);
+			}
+		}
+	}
+
+	if (delayChgInvTimer != 0){
+		delayChgInvTimer--;
+		if (delayChgInvTimer == 0)
+		{
+
+			if (g_variable.ble_currentState == CHANGE_TO_BLE_CONNECTED)
+			{
+				kscurrmult = 0x0c;
+			}
+		}
+	}
+}
+
+
+
+static tIPCControlBlock cb = 
+{
+	kb_cb_event,
+	NULL,
+	kb_cb_Timer500ms,
+	kb_cb_Timer100ms,
+	NULL,
+	kb_cb_Hid
+};
+
+static void kb_cb_init()
+{
+	IPC_Initialize(&cb);
+}
+/////////////////////////////////////////////////////////////////
+
+/////////////////////////////////////////////////////////////////
+void YC_System_Main(void)
+{
+
+	kb_cb_init();
+	while(1) {
+		IPC_DealSingleStep();
+		kb_need_keyscan();
+		YC_update_eeprom_data();
+		LED_handle();
+#ifdef PC_SLEEP_STATUS_GET		
+		if(m_pc_sleep_flag)
+		{
+			System_G24_long_lpm();
+		}
+#endif		
+		switch (current_task) {
+		case FIX_ENTER_HIBERNATE:
+			KS_Unistall();
+			//GPIO_SetWakeupByCurrentState(BT_BUTTON_GPIO);
+			LED_all_shutdown();
+			IPC_WaitLpm();	/*<wait enter lpm,do nothing*/
+			while(1);
+			break;
+			
+		case FIX_ENTER_LPM:
+			if (g_variable.delay_enter_lpm_timer ||g_variable.lockLpm ||g_variable.powerOn_timer ||g_variable.one_key_press_wait_release_timer
+			) 
+			{
+				IPC_AbandonLpm();
+				break;
+			}
+			else
+			{
+				KS_Unistall();
+				IPC_WaitLpm();	/*<wait enter lpm,do nothing*/
+				break;
+			}
+		}
+	}
+}
+
Index: c51/type.h
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/type.h	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/type.h	(working copy)
@@ -0,0 +1,25 @@
+#ifndef _YC_DEFINE_H_
+#define _YC_DEFINE_H_
+
+#define PUBLIC 
+#define LOCAL static
+
+typedef unsigned char byte;
+typedef unsigned char idata ibyte;
+typedef volatile unsigned char xdata xbyte;
+typedef volatile unsigned short xdata xword;
+typedef unsigned char xdata * pxbyte;
+typedef unsigned char xdata * data pxdbyte;
+typedef unsigned   short   word;
+typedef unsigned   long    ulong;
+typedef signed     long    s32_t;
+typedef bit bool;
+
+#define true 1
+#define false 0
+#ifndef NULL
+#define NULL (0)
+#endif
+
+#endif
+
Index: c51/util/DeleteNote.pl
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/DeleteNote.pl	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/DeleteNote.pl	(working copy)
@@ -0,0 +1,27 @@
+
+#print "输入注释的标志:";
+
+#chomp ($text = <STDIN>);
+
+#print $text;
+
+###########################
+#该脚本的功能为删除，#为注释的注释代码。
+
+$Sched_path=$ARGV[0];
+
+open(Sched,$Sched_path)||die("Cannot open files\n");
+@sched=<Sched>;
+close(Sched);
+
+foreach $sched(@sched)
+{
+	$sched_begin = $sched;
+	@Sched = split(/[#]+/, $sched);
+	chomp @Sched[0];
+	$sched = @Sched[0]."\n";
+}
+
+open(Sched,">$Sched_path")||die("Cannot open files\n");
+print Sched @sched;
+close(Sched);
Index: c51/util/crc16.exe
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/util/crc16.exe
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/util/crc16.pl
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/crc16.pl	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/crc16.pl	(working copy)
@@ -0,0 +1,27 @@
+$debug = 0;
+$crc = 0xffff;
+$i = 0;
+$offset = 0xffff;
+$source_file = $ARGV[0];
+$offset = $ARGV[1];
+
+open(EEP,"$source_file") or die $!;
+
+while (<EEP>) {    
+	$c = hex();
+
+  if($i >= $offset){
+  	if($debug){printf "%02x\t", $c;}
+  	$crc  = ($crc >> 8) | ($crc << 8);
+		$crc ^= $c & 0xff;
+		$crc ^= ($crc & 0xff) >> 4;
+		$crc ^= $crc << 12;
+		$crc ^= ($crc & 0xff) << 5;
+		$crc &= 0xffff;
+  }
+  $i ++;
+  if($debug){printf "%02x\t", $crc;}
+  printf "%02x\n", $c;
+}
+
+printf "%02x\n%02x\n", (($crc >> 8) & 0xff),($crc & 0xff);
Index: c51/util/eeprom2bin.pl
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/eeprom2bin.pl	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/eeprom2bin.pl	(working copy)
@@ -0,0 +1,15 @@
+
+$source_file = $ARGV[0];
+#$dest_file = $ARGV[1];
+
+
+open(EEP,"$source_file") or die $!;
+open(BINFILE, ">eeprom.bin") or die $!;
+binmode(BINFILE);
+while (<EEP>) {
+	printf BINFILE "%c", hex();
+}
+close(EEP);
+close(BINFILE);
+    
+   
Index: c51/util/eeprom2fulleeprom.exe
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/util/eeprom2fulleeprom.exe
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/util/eeprom2fulleeprom.pl
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/eeprom2fulleeprom.pl	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/eeprom2fulleeprom.pl	(working copy)
@@ -0,0 +1,18 @@
+
+
+
+$source_file = $ARGV[0];
+$eeprom_size = $ARGV[1];
+
+open(EEP,"$source_file") or die("cannot open files");
+for ($i = 1 ;$i<=$eeprom_size*128-2;$i++)
+{
+
+    while (<EEP>) { 
+        $c = hex();
+        printf "%02x\n", $c;
+        $i++;
+    }
+
+	printf "FF\n";
+}
Index: c51/util/hex2mif.exe
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/util/hex2mif.exe
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/util/hex2mif.pl
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/hex2mif.pl	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/hex2mif.pl	(working copy)
@@ -0,0 +1,103 @@
+#!/usr/bin/perl
+# 2005 - David Grant.
+# Take an ihex input from STDIN, and write a .mif file to STDOUT
+# This script could probably be implemented with something like:
+#    $#!@_%^$@%$@%$_!^$@#^@%$#@_%$@^&!%$_!%!%&$*(#^#@%^) 
+# But I perfer the somewhat readable version.
+
+# Flow from within the Nios2 SDK Shell:
+# nios2-elf-as file.asm -o file.o
+# nios2-elf-objcopy file.o --target ihex file.hex
+# cat file.hex | perl hex2mif.pl > file.mif
+
+my @rom = ();
+my @ram = ();
+
+sub conv {
+	my ($in) = @_;
+	$out = substr($in,6,2).substr($in,4,2).substr($in,2,2).substr($in,0,2);
+	return hex $out;
+}
+
+sub writeromfile {
+	my (@buf) = @_;
+	my($x);
+
+	for($x=0; $x<@buf; $x++) {
+		printf ("%02x\n", $buf[$x]);
+	}
+}
+
+sub writebinfile {
+	my (@buf) = @_;
+	my($x);
+
+	for($x=0; $x<@buf; $x++) {
+		for($y=0;$y<8;$y++) {
+			printf ("%d", $buf[$x] & 1<<(7-$y) ? 1 : 0);
+		}
+		printf "\n" if(($x & 3) == 3);
+	}
+}
+
+sub writemiffile {
+	my (@buf) = @_;
+	my($x);
+	print  ("WIDTH=8;\n");
+	print ("DEPTH=".@buf.";\n");
+	print ("CONTENT BEGIN\n");
+	for($x=0; $x<@buf; $x++) {
+		printf ("\t%04x : %02x;\n", $x, $buf[$x]);
+	}
+	print ("END;\n");
+}
+
+if($ARGV[0] eq "ram" || $ARGV[0] eq "rammif")
+{
+	$org = 0x8000;
+	$limit = 0xffff;
+} elsif($ARGV[0] eq "rom" || $ARGV[0] eq "bin" || $ARGV[0] eq "mif" || $ARGV[0] eq "rommif" ) {
+	$org = 0;
+	$limit = 0x7fff;
+} else {
+	$org = 0;
+	$limit = 0xffffff;
+}
+
+
+$org = 0;
+$limit = 0x7fff;
+
+while (<STDIN>) {
+	$l = $_;
+	next if(!/\w/);
+	$count = (hex substr($l, 1, 2));
+	$addr = (hex substr($l, 3, 4));
+	$type = (hex substr($l, 7, 2));
+	last if $type eq 1;
+	if($type == 4) {
+		$org = -(hex substr($l, 9, 4))*0x10000;
+	}
+	if($addr >= $org && $addr <= $limit) 
+	{
+		$addr*=4 if($ARGV[0] eq "bin");
+		$addr -= $org;
+		for($x=0; $x<$count; $x++) {
+			$rom[$addr + $x] = (hex substr($l, 9+2*$x, 2)) ; 
+		}
+	}
+}
+
+if($ARGV[0] eq "rom" || $ARGV[0] eq "ram" || $ARGV[0] eq "mem")
+{
+	writeromfile(@rom);
+}
+elsif($ARGV[0] eq "bin")
+{
+	writebinfile(@rom);
+}
+else
+{
+	writemiffile(@rom);
+}
+
Index: c51/util/memalloc.pl
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/memalloc.pl	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/memalloc.pl	(working copy)
@@ -0,0 +1,74 @@
+#!/usr/bin/perl
+$path="output/bt_format.meta";
+open file, $path;
+@f = <file>;
+close file;
+open file, ">$path";
+$path =~ s/\/.*//;
+open file1, ">output/memmap.format";
+$xaddr = 0x4000;
+$addr = 0;
+if($#ARGV == 1) {
+	$addr = hex($ARGV[0]);
+	$xaddr = hex($ARGV[1]);
+}
+for($i = 0;$i < @f;$i++) { $cmalloc[$i] = (); }
+for($i = 0;$i < @f;$i++) { 
+	$_ = $f[$i];
+	$start = 1 if(/^\s*memalloc\s*\(\s*$/);
+	$start = 2 if(/^\s*xmemalloc\s*\(\s*$/);
+	$start = 3 if(/^\s*omemalloc\s*\(\s*$/);
+	$start = 10 + $1 if(/^\s*cmemalloc\s+([0-9])\s*\(\s*$/);
+	if($start) {
+		if(/^\s*([0-9]+)\s+([a-zA-Z0-9_]+)\s*(.*)$/) {
+			if($start == 1) {
+				$str = sprintf "0x%04x %s%s\n", $addr, $2, $3;
+				$addr += $1;
+				$bstr .= $str;
+				$sstr .= $str;
+			} elsif($start == 2) {
+				$str = sprintf "0x%04x %s%s\n", $xaddr, $2, $3;
+				$xaddr += $1;
+				$xstr .= $str;
+			} else {
+				push @ostr, $_;
+			}
+		}
+		if(/^\s*\)\s*$/) {
+			if(@ostr > 0) {
+				if($start == 3) {
+					push @omalloc,[@ostr];
+				} elsif($start > 9) {
+					$j = $start - 10;
+					push @{$cmalloc[$j]},@ostr;
+				} 
+			}
+			$start = 0;
+			@ostr = ();
+		}
+	} else {
+		$sstr .= $_;
+	}
+}
+for($i = 0;$i <= $#cmalloc;$i++) {
+	push @omalloc,$cmalloc[$i];
+#	for($j = 0;$j <= $#{$cmalloc[$i]};$j++) {		print $cmalloc[$i][$j];	}
+}
+
+$xend = $xaddr;
+for($i = 0;$i <= $#omalloc;$i++) {
+	for($j = 0, $oaddr = $xaddr;$j <= $#{$omalloc[$i]};$j++) {
+		if($omalloc[$i][$j] =~ /^\s*([0-9]+)\s+([a-zA-Z0-9_]+)\s*(.*)$/) {
+			$str = sprintf "0x%04x %s%s\n", $oaddr, $2, $3;
+			$oaddr += $1;
+			$xstr .= $str;
+		}
+	}
+}
+$xend = $oaddr if($oaddr > $xend);
+print file $xstr, $sstr;
+print file1 $bstr, $xstr;
+close file;
+close file1;
+printf "\nLast allocated address is %04x\n", $addr;
+printf "\nLast allocated xmem address is %04x\n", $xend;
\ No newline at end of file
Index: c51/util/mergepatch.pl
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/mergepatch.pl	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/mergepatch.pl	(working copy)
@@ -0,0 +1,44 @@
+#!/usr/bin/perl
+$defs = "";
+$fmt = 0;
+
+
+sub parseif {
+	my($fname) = @_;
+	open file, $fname;
+	@f = <file>;
+	close file;
+	open file, ">$fname";
+	@valid = (1);
+	for($i = 0;$i < @f;$i++) { 
+		$_ = $f[$i];
+		$defs .= $1 . " " if(/^define\s+(\w+)\s*/);
+		if(/^ifdef\s+(\w+)\s*/) {
+			push @valid, ($defs =~ /(^|\s)$1(\s|$)/ ? 1 : 0) & $valid[$#valid];
+		} elsif(/^ifndef\s+(\w+)\s*/) {
+			push @valid, ($defs =~ /(^|\s)$1(\s|$)/ ? 0 : 1) & $valid[$#valid];
+		} elsif(/^else/) {
+			printf "%s\nelse without if at line %d\n", $f[$i - 3], $i if($#valid == 0);
+			$valid[$#valid] = (1 - $valid[$#valid]) & $valid[$#valid - 1];
+		} elsif(/^endif/) {
+			printf "%s\nendif without if at line %d\n", $_, $i if($#valid == 0);
+			pop @valid;
+		} elsif($valid[$#valid]) {
+			if(/^include\s+(.+)\s*/) {
+				open file2, "program/$1";
+				@f2 = <file2>;
+				close file2;
+				splice(@f, $i + 1, 0, @f2);
+			} else {
+				print file $_;
+			}
+		}
+	}
+	close file;
+}
+
+parseif("output/bt_program23.meta");
+$fmt = 1;
+parseif("output/bt_format.meta");
+
+
Index: c51/util/sortsched.pl
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/sortsched.pl	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/sortsched.pl	(working copy)
@@ -0,0 +1,163 @@
+
+
+$Sched_path=$ARGV[0];
+$Sched_test_path=$ARGV[1];
+
+open(Sched,"$Sched_path")||die("Cannot open files1\n");
+@sched=<Sched>;
+@sched[-1] = "";
+close(Sched);
+#open(Sched_test,">ResultsFile.rom")||die("Cannot open files2\n");
+#print Sched_test ("");
+#close (Sched_test);
+#open(Sched_test,">ResultsFile.rom")||die("Cannot open file3s\n");
+open(Sched_test1,">$Sched_test_path")||die("Cannot open files4\n");
+#@Sched_test=<Sched_test>;
+@Data[0]="";
+$Data_num=0;
+@Address_num;
+@OriginalRecord;
+foreach $sched (@sched)
+{
+	if($sched=~/[0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F]:/)
+	{
+		#$lap_flag = 0;
+		#$le_lap_flag = 0;
+		#if($sched=~/40a0:/)
+		#{
+		#	$lap_data = $sched;
+		#	$lap_flag = 1;
+		#}
+		#elsif($sched =~ /44a0:/)
+		#{
+		#	$le_lap_data = $sched;
+		#	$le_lap_flag = 1;
+		#}
+		#else
+		#{
+			$Data_num++;
+			@OriginalRecord[$Data_num]=$sched;
+			@snap_variable=split(/[#\n]/,$sched);
+			@Data[$Data_num]=@snap_variable[0]."\n";
+		#}
+	}
+	else
+	{
+		#if($lap_flag == 1)
+		#{
+		#	$lap_data .= $sched;
+		#}
+		#elsif($le_lap_flag == 1)
+		#{
+		#	$le_lap_data .= $sched;
+		#}
+		#else
+		#{
+			@OriginalRecord[$Data_num].=$sched;
+			@snap_variable=split(/[#\n]/,$sched);
+			@Data[$Data_num].=@snap_variable[0]."\n";
+		#}
+	}
+}
+@sort_Data = sort(@Data);
+@OriginalRecord=sort(@OriginalRecord);
+$PreviousADDR=0;
+$CurrentADDR=0;
+$PreviousData="";
+$CurrentData="";
+$I=0;
+$len_sort_Data=@sort_Data;
+$NextADDR="";
+for($i=0;$i<$len_sort_Data;$i++)
+{
+	$sort_Data=@sort_Data[$i];
+	@snap_variable=split(/:/,$sort_Data);
+	$WData=@snap_variable[1];
+	
+	if($WData =~ /[1-9a-fA-F]/ && hex(@snap_variable[0]) >= 16384){
+	$WADDR=@snap_variable[0];
+	@sort_Data[$i]=@OriginalRecord[$i];
+	@LLL[$i]=0;
+	if($NextADDR eq $WADDR){
+		@snap_variable=split(/[0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F]:/,@OriginalRecord[$i]);
+		@sort_Data[$i]=@snap_variable[1];
+		@LLL[$i]=1;
+	}
+	if(@LLL[$i]==0 && hex($PreviousADDR)+6>hex($WADDR)){
+		$LEN=hex($WADDR) - hex($NextADDR);
+		#print $LEN;
+		for($j=0;$j<$LEN;$j++)
+		{
+			@sort_Data[$i-1].="00 "
+		}
+		@sort_Data[$i-1].="\n";
+		@snap_variable=split(/[0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F]:/,@OriginalRecord[$i]);
+		@sort_Data[$i]=@snap_variable[1];
+		@LLL[$i]=1;
+	}
+	if($PreviousADDR eq $WADDR){
+		@sort_Data[$i-1]="";
+		if(@LLL[$i-1]==1){
+			@snap_variable=split(/[0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F]:/,@OriginalRecord[$i]);
+			@sort_Data[$i]=@snap_variable[1];
+			@LLL[$i]=1;
+		}
+	}
+	else{
+		@DataNum=split(/[0-9a-fA-F][0-9a-fA-F]/,$WData);
+		$DataNum=@DataNum;
+		$PreviousADDR=$WADDR;
+		#@sort_Data[$i].="      ".$DataNum."\n";
+		$NextADDR = &hex_add($WADDR,$DataNum);
+	}
+	}
+	else{
+		if(hex(@snap_variable[0]) >= 16384)
+		{
+			@sort_Data[$i]="";
+		}
+	}
+	#@sort_Data[$i].="      ".$NextADDR."\n";
+	#$sort_Data =~ s/\n//;
+	#$sort_Data.="\n";
+}
+#print Sched_test @OriginalRecord;
+#print Sched_test1 $lap_data;
+#print Sched_test1 $le_lap_data;
+print Sched_test1 @sort_Data;
+#print  $lap_data;
+#print  $le_lap_data;
+#for($i=0;$i<$len_sort_Data;$i++)
+#foreach $sort_Data (@sort_Data)
+#{	
+	#$sort_Data=@sort_Data[$i];
+	#print Sched_test $PreviousData;
+	#@snap_variable=split(/:/,$sort_Data);
+	#$CurrentADDR=@snap_variable[0];
+	#$CurrentData=$sort_Data;
+	#print ($CurrentADDR);
+	#if($CurrentADDR-$PreviousADDR==1)
+	#{
+	#	$CurrentVal=@snap_variable[1];
+	#	@snap_variable=split(/\n/,$PreviousData);
+		
+	#	$PreviousData.=" ".$CurrentVal;
+	#	$CurrentData=$PreviousData;
+	#	@sort_Data[$i]="";
+	#	@sort_Data[$i-1]=$CurrentData;
+		#print ($CurrentData."\n");
+	#}
+	#$PreviousADDR=$CurrentADDR;
+	#$PreviousData=$CurrentData;
+	#print Sched_test $CurrentData;
+#}
+#print Sched_test @sort_Data;
+#close(Sched_test);
+close(Sched_test1);
+
+sub hex_add{
+	my($ADDR,$Len)=@_;
+	$data=hex($ADDR);
+	$data=$data+$Len-1;
+	return(sprintf("%04x",$data));
+}
\ No newline at end of file
Index: c51/util/transform_memmap2btreg.pl
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/transform_memmap2btreg.pl	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/transform_memmap2btreg.pl	(working copy)
@@ -0,0 +1,45 @@
+$memmap_path=$ARGV[0];
+$memblocks_path=$ARGV[1];
+$btreg_path=$ARGV[2];
+open(btreg,">$btreg_path");
+print btreg ("");#reset file
+close(btreg);
+open(memmap,$memmap_path);
+open(memblocks,$memblocks_path);
+open(btreg,">>$btreg_path");
+@text = <memmap>;
+print btreg ("#ifndef _BT_REG_H_\n");
+print btreg ("#define _BT_REG_H_\n");
+foreach $text (@text){
+	@word = split (/[\t ]+/,$text);
+	$reg_addr = @word[0];
+	if ($reg_addr =~ /0x[0-9abcdef]*/){#Is 0x0000~0xffff
+		$word1 = @word[1];
+		@reg_name = split(/\/[\/\*]/,$word1);#delete // or /*  */
+		$reg_name = @reg_name[0];
+		$reg_name =~ s/[\r\n]//;#delete Carriage return
+		
+		printf btreg ("#define\t%-40s\t%s\n",$reg_name,$reg_addr);
+		#print btreg ("#define \t $reg_name \t\t\t $reg_addr \n");
+		#print btreg ("@word[1]\n");
+	}
+}
+@text = <memblocks>;
+foreach $text (@text){
+	@word = split (/[\t ]+/,$text);
+	$reg_addr = @word[0];
+	if ($reg_addr =~ /0x[0-9abcdef]*/){
+		$word1 = @word[1];
+		@reg_name = split(/\/[\/\*]/,$word1);
+		$reg_name = @reg_name[0];
+		$reg_name =~ s/[\r\n]//;
+		printf btreg ("#define\t%-40s\t%s\n",$reg_name,$reg_addr);
+		#print btreg ("#define \t $reg_name \t\t\t\t $reg_addr \n");
+		#print btreg ("@word[1]\n");
+	}
+}
+print btreg ("#endif\n");
+close(memblocks);
+close(memmap);
+close(btreg);
+
Index: c51/util/transform_name2addr.exe
===================================================================
Cannot display: file marked as a binary type.
svn:mime-type = application/octet-stream

Property changes on: c51/util/transform_name2addr.exe
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/octet-stream
\ No newline at end of property
Index: c51/util/transform_name2addr.pl
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/transform_name2addr.pl	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/util/transform_name2addr.pl	(working copy)
@@ -0,0 +1,103 @@
+$Sched_path=$ARGV[0];
+$Sched_test_path=$ARGV[1];
+$Memmap_path=$ARGV[2];
+open(Sched,$Sched_path)||die("Cannot open files\n");
+@sched=<Sched>;
+close(Sched);
+open(Sched_test,">$Sched_test_path");
+print Sched_test ("");
+close(Sched_test);
+open(Sched_test,">$Sched_test_path");
+open(Memmap,$Memmap_path)||die("Cannot open files\n");
+@memmap=<Memmap>;
+close(Memmap);
+$type_add=0;
+$type_exchange=0;
+foreach $sched(@sched)
+{
+	$sched_begin = $sched;
+	@Sched = split(/[#]+/, $sched);
+	$sched = @Sched[0];
+	@Sched[0] = "";
+	if($sched =~ /mem[\w]+/)
+	{
+		@memmap_name = split(/[\W]+/, $sched);
+		foreach $memmap_name(@memmap_name)
+		{
+			if($memmap_name =~ /mem[\w]+/)
+			{
+				$Memmap_name=$memmap_name;
+				$type_add = 0;
+				$type_exchange = 0;
+				if($sched =~ /$Memmap_name[+]/)
+				{
+					$type_add = 1;#修改的类型第一种，加
+					@ADD_Num=split(/[^0-9\+xa-fA-F]/,$sched);
+					foreach $ADD_Num(@ADD_Num)
+					{
+						if($ADD_Num =~ /\+/)
+						{
+							if($ADD_Num =~ /0x/)
+							{
+								@add_num = split(/\+0x/,$ADD_Num);
+								$add_num1 =@add_num[1];
+								$add_num_begin = "0x".$add_num1;
+								$add_num = hex($add_num1);
+							}
+							else
+							{
+								@add_num = split(/\+/,$ADD_Num);
+								$add_num1 =@add_num[1];
+								$add_num_begin = $add_num1;
+								$add_num = int($add_num1);
+							}
+						}#$add_num是匹配出的需要加的数值，字符串形式
+					}
+				}
+				if($sched =~ /[:] *\t*$Memmap_name/)
+				{
+					$type_exchange = 1;#修改的类型第二种，高低位交换
+				}
+				foreach $memmap(@memmap)
+				{
+					if($memmap =~ /$Memmap_name/ && $memmap !~ /$Memmap_name[\w]+/)
+					{
+						@Memmap=split(/[ \t\n]/,$memmap);
+						$memmap_address=@Memmap[0];
+						$memmap_address =~ s/0x//;
+						if($type_add==1)
+						{
+							$memmap_address_D = hex($memmap_address);
+							$memmap_address_D = $memmap_address_D+$add_num;
+							$memmap_address_H = sprintf("%x", $memmap_address_D);
+							$memmap_address = $memmap_address_H;
+							$memmap_address_add_finish = $memmap_address;
+							$sched_begin =~ s/$Memmap_name\+$add_num_begin/$memmap_address/;
+						}
+						if($type_exchange==1)
+						{
+							$memmap_address_High = substr($memmap_address,0,2);
+							$memmap_address_Low = substr($memmap_address,2,2);
+							$memmap_address = $memmap_address_Low." ".$memmap_address_High;
+							if($type_add==0)
+							{
+								$sched_begin =~ s/$Memmap_name/$memmap_address/;
+							}
+							else
+							{
+								$sched_begin =~ s/$memmap_address_add_finish/$memmap_address/;
+							}
+						}
+					}
+				}
+				$sched_begin =~ s/$Memmap_name/$memmap_address/;
+			}
+		}
+		printf Sched_test ("%s",$sched_begin);
+	}
+	else
+	{
+		printf Sched_test ("%s",$sched_begin);
+	}	
+}
+close(Sched_test);
Index: c51/utilities.h
===================================================================
--- /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/utilities.h	(nonexistent)
+++ /branch/mouse_project/LeXiang/Keyboard/KG9025_2mode_3ch/c51/utilities.h	(working copy)
@@ -0,0 +1,24 @@
+#ifndef _YC_UTILITIES_H_
+#define _YC_UTILITIES_H_
+#include "common.h"
+
+#define MAX(a,b) ((a)>(b)?(a):(b))
+
+/*==============Set a breakpoint function
+no input:
+no output
+====================*/
+void YC_Ice_break();
+
+void dmemcpy(byte *dest, byte* src, word len) ;
+
+void xmemcpy(pxbyte dest, byte* src, byte len);
+
+void Delay1ms(byte Time);
+
+void YC_DelayNOP(byte num);
+
+void xmemclear(byte *dest, word len);
+void xmemclear_ff(byte *dest, word len);
+byte compare_str(byte * str1,byte * str2,byte len);
+#endif
