From ee71dadfc582cd81e6ed04cf219eec39df5510d6 Mon Sep 17 00:00:00 2001 From: n2232 Date: Fri, 19 Aug 2011 00:18:58 +0000 Subject: [PATCH] git-svn-id: file:///Volumes/Transfer/gigaleak_20231201/2020-05-23%20-%20ctr.7z%20+%20svn_v1.068.zip/ctr/svn/ctr_mcu@369 013db118-44a6-b54f-8bf7-843cb86687b1 --- tags/2.04/OMakefile | 159 +++ tags/2.04/OMakeroot | 4 + tags/2.04/WDT.c | 2 + tags/2.04/WDT.h | 20 + tags/2.04/accero.c | 270 +++++ tags/2.04/accero.h | 14 + tags/2.04/adc.c | 450 ++++++++ tags/2.04/adc.h | 48 + tags/2.04/batt_params.c | 84 ++ tags/2.04/batt_params.h | 49 + tags/2.04/bsr.hex | 1000 +++++++++++++++++ tags/2.04/bsr.lmf | Bin 0 -> 177376 bytes tags/2.04/bsr_k0r.map | 791 ++++++++++++++ tags/2.04/bsr_mcu.dr | 46 + tags/2.04/bsr_system.h | 67 ++ tags/2.04/config.h | 91 ++ tags/2.04/fsl.h | 362 ++++++ tags/2.04/fsl_user.h | 113 ++ tags/2.04/hal.c | 171 +++ tags/2.04/hal.h | 17 + tags/2.04/hoge.bin | Bin 0 -> 16387 bytes tags/2.04/i2c_ctr.c | 297 +++++ tags/2.04/i2c_ctr.h | 210 ++++ tags/2.04/i2c_mcu.c | 655 +++++++++++ tags/2.04/i2c_mcu.h | 36 + tags/2.04/i2c_twl.c | 231 ++++ tags/2.04/i2c_twl.h | 7 + tags/2.04/i2c_twl_defs.h | 196 ++++ tags/2.04/incs.h | 58 + tags/2.04/incs_loader.h | 47 + tags/2.04/ini_VECT.c | 383 +++++++ tags/2.04/jhl_defs.h | 29 + tags/2.04/led.c | 349 ++++++ tags/2.04/led.h | 146 +++ tags/2.04/led_cam.c | 146 +++ tags/2.04/led_pow.c | 269 +++++ tags/2.04/loader.c | 380 +++++++ tags/2.04/loader.h | 7 + tags/2.04/magic.c | 29 + tags/2.04/magic.h | 24 + tags/2.04/main.c | 89 ++ tags/2.04/nec_s_2_bsrbin2.rb | 82 ++ tags/2.04/pedo_alg_thre_det2.c | 574 ++++++++++ tags/2.04/pedo_lpf_coeff.c | 83 ++ tags/2.04/pedo_lpf_coeff.h | 84 ++ tags/2.04/pedometer.h | 36 + tags/2.04/pm.c | 1388 ++++++++++++++++++++++++ tags/2.04/pm.h | 216 ++++ tags/2.04/pool.h | 24 + tags/2.04/reboot.c | 24 + tags/2.04/reboot.h | 6 + tags/2.04/renge/renge.c | 315 ++++++ tags/2.04/renge/renge.h | 28 + tags/2.04/renge/renge_defs.h | 55 + tags/2.04/renge/renge_task_config.rb | 59 + tags/2.04/renge/renge_task_immediate.h | 25 + tags/2.04/renge/renge_task_intval.h | 37 + tags/2.04/renge/renge_tasks.txt | 11 + tags/2.04/rtc.c | 175 +++ tags/2.04/rtc.h | 21 + tags/2.04/self_flash.c | 608 +++++++++++ tags/2.04/self_flash.h | 9 + tags/2.04/sw.c | 188 ++++ tags/2.04/sw.h | 20 + tags/2.04/task_debug.c | 120 ++ tags/2.04/task_misc.c | 374 +++++++ tags/2.04/task_status.c | 84 ++ tags/2.04/task_sys.c | 638 +++++++++++ tags/2.04/user_define.h | 234 ++++ tags/2.04/voltable.c | 48 + tags/2.04/voltable.h | 57 + tags/2.04/vreg_ctr.c | 576 ++++++++++ tags/2.04/vreg_ctr.h | 299 +++++ tags/2.04/vreg_twl.c | 150 +++ tags/2.04/vreg_twl.h | 127 +++ tags/2.04/yav_mcu_bsr.plg | 196 ++++ tags/2.04/yav_mcu_bsr.pri | 1028 ++++++++++++++++++ tags/2.04/yav_mcu_bsr.prj | 1063 ++++++++++++++++++ tags/2.04/yav_mcu_bsr.prk | 42 + tags/2.04/yav_mcu_bsr.prw | 8 + tags/2.04/yav_mcu_bsr.sdb | 305 ++++++ tags/2.04/ベースからの変更.xls | Bin 0 -> 26624 bytes 82 files changed, 16763 insertions(+) create mode 100644 tags/2.04/OMakefile create mode 100644 tags/2.04/OMakeroot create mode 100644 tags/2.04/WDT.c create mode 100644 tags/2.04/WDT.h create mode 100644 tags/2.04/accero.c create mode 100644 tags/2.04/accero.h create mode 100644 tags/2.04/adc.c create mode 100644 tags/2.04/adc.h create mode 100644 tags/2.04/batt_params.c create mode 100644 tags/2.04/batt_params.h create mode 100644 tags/2.04/bsr.hex create mode 100644 tags/2.04/bsr.lmf create mode 100644 tags/2.04/bsr_k0r.map create mode 100644 tags/2.04/bsr_mcu.dr create mode 100644 tags/2.04/bsr_system.h create mode 100644 tags/2.04/config.h create mode 100644 tags/2.04/fsl.h create mode 100644 tags/2.04/fsl_user.h create mode 100644 tags/2.04/hal.c create mode 100644 tags/2.04/hal.h create mode 100644 tags/2.04/hoge.bin create mode 100644 tags/2.04/i2c_ctr.c create mode 100644 tags/2.04/i2c_ctr.h create mode 100644 tags/2.04/i2c_mcu.c create mode 100644 tags/2.04/i2c_mcu.h create mode 100644 tags/2.04/i2c_twl.c create mode 100644 tags/2.04/i2c_twl.h create mode 100644 tags/2.04/i2c_twl_defs.h create mode 100644 tags/2.04/incs.h create mode 100644 tags/2.04/incs_loader.h create mode 100644 tags/2.04/ini_VECT.c create mode 100644 tags/2.04/jhl_defs.h create mode 100644 tags/2.04/led.c create mode 100644 tags/2.04/led.h create mode 100644 tags/2.04/led_cam.c create mode 100644 tags/2.04/led_pow.c create mode 100644 tags/2.04/loader.c create mode 100644 tags/2.04/loader.h create mode 100644 tags/2.04/magic.c create mode 100644 tags/2.04/magic.h create mode 100644 tags/2.04/main.c create mode 100755 tags/2.04/nec_s_2_bsrbin2.rb create mode 100644 tags/2.04/pedo_alg_thre_det2.c create mode 100644 tags/2.04/pedo_lpf_coeff.c create mode 100644 tags/2.04/pedo_lpf_coeff.h create mode 100644 tags/2.04/pedometer.h create mode 100644 tags/2.04/pm.c create mode 100644 tags/2.04/pm.h create mode 100644 tags/2.04/pool.h create mode 100644 tags/2.04/reboot.c create mode 100644 tags/2.04/reboot.h create mode 100644 tags/2.04/renge/renge.c create mode 100644 tags/2.04/renge/renge.h create mode 100644 tags/2.04/renge/renge_defs.h create mode 100644 tags/2.04/renge/renge_task_config.rb create mode 100644 tags/2.04/renge/renge_task_immediate.h create mode 100644 tags/2.04/renge/renge_task_intval.h create mode 100644 tags/2.04/renge/renge_tasks.txt create mode 100644 tags/2.04/rtc.c create mode 100644 tags/2.04/rtc.h create mode 100644 tags/2.04/self_flash.c create mode 100644 tags/2.04/self_flash.h create mode 100644 tags/2.04/sw.c create mode 100644 tags/2.04/sw.h create mode 100644 tags/2.04/task_debug.c create mode 100644 tags/2.04/task_misc.c create mode 100644 tags/2.04/task_status.c create mode 100644 tags/2.04/task_sys.c create mode 100644 tags/2.04/user_define.h create mode 100644 tags/2.04/voltable.c create mode 100644 tags/2.04/voltable.h create mode 100644 tags/2.04/vreg_ctr.c create mode 100644 tags/2.04/vreg_ctr.h create mode 100644 tags/2.04/vreg_twl.c create mode 100644 tags/2.04/vreg_twl.h create mode 100644 tags/2.04/yav_mcu_bsr.plg create mode 100644 tags/2.04/yav_mcu_bsr.pri create mode 100644 tags/2.04/yav_mcu_bsr.prj create mode 100644 tags/2.04/yav_mcu_bsr.prk create mode 100644 tags/2.04/yav_mcu_bsr.prw create mode 100644 tags/2.04/yav_mcu_bsr.sdb create mode 100644 tags/2.04/ベースからの変更.xls diff --git a/tags/2.04/OMakefile b/tags/2.04/OMakefile new file mode 100644 index 0000000..42baad6 --- /dev/null +++ b/tags/2.04/OMakefile @@ -0,0 +1,159 @@ +############################################################ +# 環境設定 +############################################################ + +# マイコン開発環境のインストール先を環境変数で指定する +NECEL_ROOT = + if $(defined-env NECEL_ROOT) + value $(absname $"$(getenv NECEL_ROOT)") + else + value "C:\Program Files (x86)\NEC Electronics Tools" + +# cygwinのインストール先を環境変数で指定する +CYGWIN_ROOT = + if $(defined-env CYGWIN_ROOT) + value $(absname $"$(getenv CYGWIN_ROOT)") + else + value "C:\cygwin" + +# GCCバージョンを環境変数で指定する +CYGWIN_GCC = + if $(defined-env CYGWIN_GCC) + value $(CYGWIN_ROOT)/bin/$"$(getenv CYGWIN_GCC)" + else + value $(CYGWIN_ROOT)/bin/gcc-4 + +#デバイスファイルは NECEL_ROOT/dev に置くこと +#自己アップデート用ライブラリは CC_LIBS_ROOT/以下に置くこと + +SUBDIR_INTER_ASM = $(dir inter_asm) + +CC_ROOT = $(NECEL_ROOT)/CC78K0R +CC_VER = W2.13 +CC = $(CC_ROOT)/$(CC_VER)/bin/cc78k0r.exe +RA = $(NECEL_ROOT)/RA78K0R/W1.33/bin/ra78k0r.exe +LK = $(NECEL_ROOT)/RA78K0R/W1.33/bin/lk78k0r.exe +OC = $(NECEL_ROOT)/RA78K0R/W1.33/bin/oc78k0r.exe +LCNV = $(NECEL_ROOT)/RA78K0R/W1.33/bin/lc78k0r.exe +DEVFILE_ROOT = $(NECEL_ROOT)/dev + +CC_LIBS_ROOT = $(CC_ROOT)/$(CC_VER)/lib78k0r +CC_INCLUDES_ROOT = $(CC_ROOT)/$(CC_VER)/inc78k0r +S0RM = s0rm.rel + +# セキュリティID +GIVALUE = 1B339499E033F240BFAAh + +# ユーザオプションバイト +GBValue = 7EFBFFh + +DEVICE_NAME = 9F0104 + +FSL_LIB = fsl.lib + +TARGET_NAME = bsr +TARGET_LMF = $(TARGET_NAME).lmf +TARGET_HEX = $(TARGET_NAME).hex + +# ここまで +############################################################ + +############################################################ +# ソースを追加したら編集する箇所 +############################################################ + +SRC_FILES[] = + loader + pm + i2c_ctr + main + magic + WDT + i2c_mcu + i2c_twl + led + rtc + vreg_ctr + vreg_twl + adc + renge\renge + accero + self_flash + sw + task_debug + task_misc + task_sys + pedo_alg_thre_det2 + ini_VECT + task_status + led_cam + led_pow + hal + batt_params + voltable + pedo_lpf_coeff + +INCLUDES[] = + ./ + renge + +# ここまで +############################################################ + +.PHONY: clean BeforeBuild + +AddRel(files) = + file_names = $(addsuffix .rel, $(files)) + return $(file_names) + +# *.cからinter_asm/*.asmを作るための関数 +AsmProgram(files) = + foreach(filename, $(files)) + asm_name = $(addprefix $(SUBDIR_INTER_ASM)/, $(addsuffix .asm, $(basename $(filename)))) + c_name = $(addsuffix .c, $(filename)) + + .SCANNER: $(asm_name): $(c_name) + $(CYGWIN_GCC) -MM -w -I$(CC_INCLUDES_ROOT) $(c_name) | sed 's/$(filename)\.o/$(SUBDIR_INTER_ASM)\/$(filename)\.asm/g' + + $(asm_name): $(c_name) + $(CC) -c$(DEVICE_NAME) -y$(DEVFILE_ROOT) -_msgoff -irenge -i$(CC_INCLUDES_ROOT) -ms -qvjl2w -sa$(SUBDIR_INTER_ASM) -zpb -no $(c_name) + + return $(addsuffix .c, $(files)) + +# inter_asm/*.asm から *.relを作るための関数 +RelProgram(files) = + foreach(filename, $(files)) + rel_name = $(addsuffix .rel, $(basename $(filename))) + asm_name = $(addprefix $(SUBDIR_INTER_ASM)/, $(addsuffix .asm, $(basename $(filename)))) + asm_win_name = $(addprefix $(SUBDIR_INTER_ASM)\\, $(addsuffix .asm, $(basename $(filename)))) + c_name = $(addsuffix .c, $(filename)) + + .SCANNER: $(rel_name): $(asm_win_name) + $(CYGWIN_GCC) -MM -w -I$(CC_INCLUDES_ROOT) $(c_name) | sed 's/\.o/\.rel/g' + + $(rel_name): $(asm_name) + $(RA) -c$(DEVICE_NAME) -y$(DEVFILE_ROOT) -_msgoff $(asm_win_name) + + return $(addsuffix .rel, $(basename $(files))) + +$(TARGET_LMF): $(RelProgram $(SRC_FILES)) $(AsmProgram $(SRC_FILES)) + $(LK) -y$(DEVFILE_ROOT) -_msgoff -o$(TARGET_LMF) $(CC_LIBS_ROOT)/$(S0RM) -gi$(GIVALUE) -pbsr_k0r.map -nkd -gb$(GBValue) -b$(CC_LIBS_ROOT)/$(FSL_LIB) -bcl0rdm.lib -bcl0rm.lib -bcl0rmf.lib -i$(CC_LIBS_ROOT) -dbsr_mcu.dr -s -w0 $(AddRel $(basename $(SRC_FILES))) + +$(TARGET_HEX) : $(TARGET_LMF) + $(OC) -y$(DEVFILE_ROOT) -_msgoff -o.\\$(TARGET_HEX) -nu -ki $(TARGET_LMF) + +BeforeBuild: +# ビルド前に必ず実行したい処理 +# OMakeがタイムスタンプではなくMD5でファイルの状態を管理しているので +# 残念ながら cleanしてからビルドしなおす必要がある + C:\Windows\system32\cmd.exe /c $(CYGWIN_ROOT)\bin\touch magic.c + if $(not $(file-exists $(SUBDIR_INTER_ASM))) + mkdir $(SUBDIR_INTER_ASM) + +hoge.bin: BeforeBuild $(TARGET_HEX) + C:\Windows\system32\cmd.exe /c ruby nec_s_2_bsrbin2.rb $(TARGET_HEX) + +clean: + rm -rf *.prn *.rel $(SUBDIR_INTER_ASM)/*.asm *.omc .omakedb .omakedb.lock + +.DEFAULT: hoge.bin diff --git a/tags/2.04/OMakeroot b/tags/2.04/OMakeroot new file mode 100644 index 0000000..16f4b11 --- /dev/null +++ b/tags/2.04/OMakeroot @@ -0,0 +1,4 @@ +# +# Include the OMakefile in this directory. +# +.SUBDIRS: . diff --git a/tags/2.04/WDT.c b/tags/2.04/WDT.c new file mode 100644 index 0000000..436a51c --- /dev/null +++ b/tags/2.04/WDT.c @@ -0,0 +1,2 @@ +#include "incs_loader.h" + diff --git a/tags/2.04/WDT.h b/tags/2.04/WDT.h new file mode 100644 index 0000000..2e28e9d --- /dev/null +++ b/tags/2.04/WDT.h @@ -0,0 +1,20 @@ +#ifndef _WDT_ +#define _WDT_ + + + +//========================================================= +#define WDT_RESTART_MAGIC 0xAC + + + +//========================================================= +// EHb`hbO^C}̃X^[g +// void WDT_Restart( void ); +#define WDT_Restart() WDTE = WDT_RESTART_MAGIC + +// KlȊOƗOŃZbg +#define mcu_wdt_reset WDTE = 0x0 + + +#endif diff --git a/tags/2.04/accero.c b/tags/2.04/accero.c new file mode 100644 index 0000000..b8108a3 --- /dev/null +++ b/tags/2.04/accero.c @@ -0,0 +1,270 @@ +/* ======================================================== +@xZT֌W +Ef[^XVŃf[^zグ背WX^XVACPUɊ荞 +EtOĂΕJEg +ExZT荞݂^XNo^ĉBiI2C̋Ȃǂ̂Łj + + ======================================================== */ +#ifndef _WIN32 + +#pragma SFR +#pragma NOP +#pragma HALT +#pragma STOP +#pragma ROT +// rorb, rolb, rorw, rolw +#pragma MUL +#pragma BCD + +#endif + +#include "config.h" +#ifndef _WIN32 + +#pragma interrupt INTP23 intp23_ACC_ready RB3 // xZTAf[^ + +#endif + + +#include "incs.h" + +#ifndef _WIN32 +#include +#endif +// ======================================================== +// WX^ +#define ACC_REG_WHOAMI 0x0F +#define ACC_REG_CTRL1 0x20 +#define ACC_REG_CTRL5 0x24 +#define ACC_REG_X 0x28 + +// rbgʒu +#define ACC_bP_PM0 5 +#define ACC_bP_DR0 3 + +// rbgݒl +#define ACC_BITS_PM_PDN 0 +#define ACC_BITS_PM_NORM 1 +#define ACC_BITS_PM_LP0R5 2 +#define ACC_BITS_PM_LP1 3 +#define ACC_BITS_PM_LP2 4 +#define ACC_BITS_PM_LP5 5 +#define ACC_BITS_PM_LP10 6 + +#define ACC_BITS_DR_50Hz 0 +#define ACC_BITS_DR_100Hz 1 +#define ACC_BITS_DR_400Hz 2 +#define ACC_BITS_DR_1000Hz 3 + +#define ACC_BITS_ALL_AXIS_ON 7 + + +#define VREG_BITMASK_ACC_CONF_ACQ ( 1 << 0 ) +#define VREG_BITMASK_ACC_CONF_HOSU ( 1 << 1 ) + + + + +// ======================================================== +task_status tsk_soft_int( ); + + +#define ACC_RAW_DATA_SIZE 6 +/* ======================================================== +@E荞݂mFăf[^zグAWX^ɏo܂ + E{ł΃R[obN֐o^Ă΂ƂȂ̂łA + I2CgpHƂlƎł͂܂łłȂ̂łB + EvƂł + ======================================================== */ +task_status_immed tski_cbk_accero( ) +{ // i^jisro^܂ + static u8 err_count; + u8 acc_dat_buff[ ACC_RAW_DATA_SIZE ]; + + // xZTf[^WX^ւ̔f + if( iic_mcu_read( IIC_SLA_ACCEL, ( ACC_REG_X | 0x80 ), ACC_RAW_DATA_SIZE, acc_dat_buff ) + != ERR_SUCCESS ) + { + err_count ++; + if( err_count < 8 ) + { + // gC + return( ERR_CONTINUE ); + } + else + { + // xZTُɂȂ̂Ŏ~߂ + vreg_ctr[ VREG_C_ACC_CONFIG ] &= ~( VREG_BITMASK_ACC_CONF_HOSU | VREG_BITMASK_ACC_CONF_ACQ ); + tski_acc_hosu_set(); + vreg_ctr[ VREG_C_STATUS_1 ] |= REG_BIT_ACCERO_ERR; + return ( ERR_FINISED ); // ^XN̍폜͕Kv + } + } + else + { + memcpy( &vreg_ctr[VREG_C_ACC_XL], acc_dat_buff, ACC_RAW_DATA_SIZE ); + + err_count = 0; + // 펞pX // + // xXV荞 + if( (( vreg_ctr[VREG_C_ACC_CONFIG] & VREG_BITMASK_ACC_CONF_ACQ ) != 0 ) && + ( system_status.pwr_state == ON ) + ) + { + set_irq( VREG_C_IRQ1, REG_BIT_ACC_DAT_RDY ); + // S~f[^̃Jǂ + if( ACC_VALID ) + { + u8 temp[ACC_RAW_DATA_SIZE]; + iic_mcu_read( IIC_SLA_ACCEL, ( ACC_REG_X | 0x80 ), ACC_RAW_DATA_SIZE, temp ); + } + } + if(( system_status.pwr_state != ON_CHECK ) + &&( system_status.pwr_state != OFF ) +#ifndef _DBG_PEDO_AUTO_ENABLE_ + &&( ( vreg_ctr[VREG_C_ACC_CONFIG] & VREG_BITMASK_ACC_CONF_HOSU ) != 0 ) +#endif + ) + { + pedometer(); // v + } + } + return ( ERR_FINISED ); +} + + + + + +/*======================================================= +@xZT߃ANZX@[h + ========================================================*/ +task_status_immed tski_acc_read( ) +{ + vreg_ctr[VREG_C_ACC_W_BUF] = iic_mcu_read_a_byte( IIC_SLA_ACCEL, vreg_ctr[VREG_C_ACC_R_ADRS] ); +// vreg_ctr[ VREG_C_ACC_R_BUF ] = iic_mcu_read_a_byte( IIC_SLA_ACCEL, vreg_ctr[VREG_C_ACC_R_ADRS] ); + vreg_ctr[VREG_C_IRQ1] |= REG_BIT_ACC_ACK; + if( ( vreg_ctr[VREG_C_IRQ_MASK1] & REG_BIT_ACC_ACK ) == 0 ) + { + IRQ0_ast; + } + return ( ERR_FINISED ); +} + + + +/*========================================================= +@xZT߃ANZX@Cg + ========================================================*/ +task_status_immed tski_acc_write( ) +{ + iic_mcu_write_a_byte( IIC_SLA_ACCEL, vreg_ctr[VREG_C_ACC_W_ADRS], vreg_ctr[VREG_C_ACC_W_BUF] ); + vreg_ctr[VREG_C_IRQ1] |= REG_BIT_ACC_ACK; + if( ( vreg_ctr[VREG_C_IRQ_MASK1] & REG_BIT_ACC_ACK ) == 0 ) + { + IRQ0_ast; + } + return ( ERR_FINISED ); +} + + + +/*========================================================= +@xZT̐ݒ + ========================================================*/ +task_status_immed tski_acc_hosu_set( ) +{ + +// iic_mcu_read_a_byte( IIC_SLA_ACCEL, ACC_REG_WHOAMI ); // X^bNȂ̂œWJc +// if( iic_mcu_result == ERR_NOSLAVE ) + { + u8 dummy; + + if( iic_mcu_read( IIC_SLA_ACCEL, ACC_REG_WHOAMI, 1, &dummy ) == ERR_NOSLAVE ) + { + vreg_ctr[ VREG_C_STATUS_1 ] |= REG_BIT_ACCERO_ERR; + return ( ERR_FINISED ); // Ƃ肠A^XN͍폜ȂĂ͂ȂȂ + // ܂ + }else{ + vreg_ctr[ VREG_C_STATUS_1 ] &= ~REG_BIT_ACCERO_ERR; + } + } + + { + u8 str_send_buf[4]; + + str_send_buf[1] = 0x00; // ctrl2 HPF:normal, filterd, HPF for IRQ : dis/dis, HPF coeff:norm + /* + if( system_status.model == MODEL_TS_BOARD ) + { + // TS Final SoC + str_send_buf[2] = 0x02; // 3 IRQ pol :Active HI, Drive:Pushpull, + } + else + { + // @hA + str_send_buf[2] = 0x10; // 3 IRQ pol :Active HI, Drive:Pushpull, + } + */ + if( system_status.model == MODEL_TS_BOARD ) + { + str_send_buf[2] = bits8(0,0,0,0, 0,0,1,0); // sŝ߁Aƕ + } + else + { + str_send_buf[2] = bits8(0,0,0,1, 0,0,0,0); + } + str_send_buf[3] = 0x80; // ctrl3 block update:enable, MSB first, scale: +-2G(default), selftest: dis + + if( ( vreg_ctr[VREG_C_ACC_CONFIG] & + ( VREG_BITMASK_ACC_CONF_HOSU | VREG_BITMASK_ACC_CONF_ACQ ) ) == 0 ) + { + PMK23 = 1; + // S~ + str_send_buf[0] = + ( ACC_BITS_PM_PDN << ACC_bP_PM0 | 0 << ACC_bP_DR0 | ACC_BITS_ALL_AXIS_ON ); + } + else + { + PMK23 = 0; + // 100Hz 荞 + str_send_buf[0] = + ( ACC_BITS_PM_NORM << ACC_bP_PM0 + | ACC_BITS_DR_100Hz << ACC_bP_DR0 + | ACC_BITS_ALL_AXIS_ON ); + } + iic_mcu_write( IIC_SLA_ACCEL, ( ACC_REG_CTRL1 | 0x80 ), 4, str_send_buf ); + } + + // Jǂ + if( ACC_VALID ) + { + if( system_status.pwr_state == ON ) + { + u8 temp[ACC_RAW_DATA_SIZE]; + iic_mcu_read( IIC_SLA_ACCEL, ( ACC_REG_X | 0x80 ), 6, temp ); + } + } + return ( ERR_FINISED ); +} + + + +/* ======================================================== + xZT荞 + I2CgpȂ̂ŁAǂݏo^XN̓o^ŝ + ======================================================== */ +__interrupt void intp23_ACC_ready( ) +{ + EI(); + if( ( vreg_ctr[VREG_C_ACC_CONFIG] & 0x03 ) != 0x00 ) + { + if( ( system_status.pwr_state == ON ) || ( system_status.pwr_state == SLEEP ) ) + { + if( ACC_VALID ) + { + renge_task_immed_add( tski_cbk_accero ); + } + } + } +} diff --git a/tags/2.04/accero.h b/tags/2.04/accero.h new file mode 100644 index 0000000..20494b9 --- /dev/null +++ b/tags/2.04/accero.h @@ -0,0 +1,14 @@ +#ifndef _accero_ +#define _accero_ + + +#include "jhl_defs.h" +#include "pedometer.h" + + +/////////////////////////////////////////////////////////// +task_status_immed tski_cbk_accero( ); +task_status_immed tski_acc_hosu_set( ); + + +#endif diff --git a/tags/2.04/adc.c b/tags/2.04/adc.c new file mode 100644 index 0000000..80f41b4 --- /dev/null +++ b/tags/2.04/adc.c @@ -0,0 +1,450 @@ +/* ======================================================== + cJZ + nintendo + '09 Apr + ======================================================== */ +#include "incs.h" +#include "adc.h" +#include "pm.h" + +#include "led.h" + +#include "vreg_twl.h" + + +// ===================================================== // +static bit adc_updated; +static bit vol_changed_by_ctr; +bit vol_changed_by_twl; +static u8 vol_old; + +static u8 adc_raw_vol; +static u8 adc_raw_dep; + +u8 vol_polling; +u8 vol_level_twl; + +extern const u8 slider_to_codec[]; + + + +// ===================================================== // +typedef struct filter_work +{ + u8* value_used; + s8 diffs; // KIKAN̕΂ + s8 kikan; + u8 large_diff_count; +}filter_work; + + +static filter_work work_vr_3d = { + &vreg_ctr[ VREG_C_3D ] + // ͕̂slł悵Bconstɂ_ + }; + + +static u8 vol_data_ctr; +static u8 vol_data_ctr_tmp; +static filter_work work_vr_vol = { + &vol_data_ctr_tmp + // ͕̂slł悵Bconstɂ_ + }; + + +// twl 8iKvol̃jAl̋E +/* + twl32 -> 8 e[u + 0`1,`4,`8,`13,`18,`23,`28,31 + */ +static const u8 TWL_VOL_BOUNDARY[] = { + 1, 4, 8, 13, 18, 23, 28, 31 +}; + +// ===================================================== // +extern void nop8(); +static void adc_filter( u8 new_val, filter_work* work ); +static u8 adc_scaling( u8 ); +static void update_twl_vol( u8 sent_index ); + + + +// ===================================================== // +#define INTERVAL_TSK_ADC 15 + + + +/* ======================================================== + ADCݒƁAJn + + ȉ̃s͎ɂőEĎ܂B + EBT_TEMP,_P + EADIN1 + EVOL + + ֌W肻łʂ̂ƂŊǗĂ܂ + EPM_BT_DET,_P BT_chk + ======================================================== */ +void tsk_adc( ) +{ + if( adc_updated ) + { + adc_updated = false; + + // 3D ///////////////////////////////////////// + vreg_ctr[ VREG_C_3D ] = adc_raw_dep; // l + + // Volume ///////////////////////////////////// + { + vreg_ctr[ VREG_C_VOL_ADC_RAW ] = adc_raw_vol; + + adc_filter( adc_scaling( adc_raw_vol ), &work_vr_vol ); // ʂ*work_vr_volwvol_data_ctr ǂ݂ɂ... + vol_data_ctr = vol_data_ctr_tmp / 4; + + if( vol_old != vol_data_ctr ) + { + vol_changed_by_ctr = true; + vol_old = vol_data_ctr; + vol_polling = 3; +// renge_task_immed_add( tski_vol_update ); œo^ + } + } + + // obe /////////////////////////// + /* Ă΂܂ */ + } + + // YꂪƂȂ̂Ń|[O orz + if( vol_polling < 5 ) + { + renge_task_immed_add( tski_vol_update ); + vol_polling = (u8)(200 / SYS_INTERVAL_TICK) + 5; // 5/sec + } + vol_polling --; + + + ADCEN = 1; + ADM = bits8(0,0,0,0, 1,0,1,1); // ZNg[hAAfCLK/6 // + + ADPC = 0x06; // ADC|[g̃ZNg + ADS = ADC_SEL_3D; + nop8(); + ADCS = 1; // ADJnB // ܂Ł@@܂ł1us=8clkȏJ + + ADIF = 0; + ADMK = 0; +} + + + +void vol_reset() +{ + vol_old = vol_data_ctr; + vreg_ctr[ VREG_C_SND_VOL ] = vol_data_ctr; // 64i +} + + +/* ======================================================== +@VolXV܂B + @Ȏɓo^܂B +@@E[U[VolXC_𓮂 +@@EHorizonɋXVwꂽ@icodecZbgj +@@ETWLAvVol +======================================================== */ +task_status_immed tski_vol_update() +{ + static u8 sent_index, sent_index_twl; + static bit last_modifyer_is_twl; // false = ctr + + if( !( system_status.pwr_state == ON ) || + ( system_status.pwr_state == SLEEP )){ + return( ERR_FINISED ); + } + + // ǂ̉ʂɂ́H // + if( vol_changed_by_ctr ) + { + // XC_ + vol_changed_by_ctr = false; + last_modifyer_is_twl = false; + sent_index = vol_data_ctr; + } + else if( vol_changed_by_twl ) + { + // TWLAv + vol_changed_by_twl = false; + last_modifyer_is_twl = true; + if( vreg_twl[ REG_TWL_INT_ADRS_VOL ] == 0 ) + { + sent_index_twl = 0; + } + else + { + sent_index_twl = vreg_twl[ REG_TWL_INT_ADRS_VOL ] *2 +1; + } + sent_index = sent_index_twl; + } + else + { + // force_slider0ɂƂ & ܂Ƃ + // XC_TWL̍ŌɃZbgZbg + if( last_modifyer_is_twl ) + { + sent_index = sent_index_twl; + } + else + { + sent_index = vol_data_ctr; + } + } + + // WX^̍XV // + vreg_ctr[ VREG_C_SND_VOL ] = sent_index; + + // twlXV + update_twl_vol( sent_index ); + + // codecɓ` + /// lł + iic_mcu_write_a_byte_codec( CODEC_REG_VOL, slider_to_codec[ sent_index ] ); + + // set_irq( VREG_C_IRQ0, REG_BIT_VR_SNDVOL_CHANGE ); // 荞ݔp~ + return( ERR_FINISED ); +} + + +static void update_twl_vol( u8 sent_index ) +{ + // XP[O + if( sent_index == 0 ) + { + vreg_twl[ REG_TWL_INT_ADRS_VOL ] = 0; + } + else if( sent_index <= 4 ) + { + vreg_twl[ REG_TWL_INT_ADRS_VOL ] = 2; // P̓~bVOŐ + } + else + { + vreg_twl[ REG_TWL_INT_ADRS_VOL ] = sent_index/2 ; + } + + // 8iK̃xB@荞݂̂ɕKv + { + static u8 vol_twl_old; + + if( vol_twl_old != vreg_twl[ REG_TWL_INT_ADRS_VOL ] ) + { + // 8ixɕϊ + u8 new_level = 31; + u8 i; + + vol_twl_old = vreg_twl[ REG_TWL_INT_ADRS_VOL ]; + + for( i=0; i<=7; i++ ) + { + if( vreg_twl[ REG_TWL_INT_ADRS_VOL ] <= TWL_VOL_BOUNDARY[ i ] ) + { + new_level = i; + break; + } + } + vol_level_twl = new_level; + } + } +} + + + +/* ======================================================== +@OŎ̃`l +@@ʂI~߂ + ======================================================== */ +__interrupt void int_adc( ) +{ + volatile u8 adc_data = ADCRH; + + switch ( ADS ) + { +/* +case ( ADC_SEL_AMB_BRIT ): // ‹邳 + vreg_ctr[ VREG_C_AMBIENT_BRIGHTNESS ] = adc_data; + break; +*/ + + case ( ADC_SEL_3D ): + EI(); + adc_raw_dep = adc_data; + break; + + case ( ADC_SEL_VOL ): + EI(); + if( system_status.model == MODEL_TS_BOARD ) + { + adc_raw_vol = adc_data; + } + else + { + adc_raw_vol = 255 - adc_data; + } + + break; + + case ( ADC_SEL_BATT_TEMP ): + EI(); +#ifdef _ENABLE_HAL_ + if( vreg_ctr[ VREG_C_HAL_OVW_TEMPERATURE ] == 0xFF ) // HAL +#else + if( 1 ) +#endif + { + raw_adc_temperature = adc_data; + } + else + { + raw_adc_temperature = vreg_ctr[ VREG_C_HAL_OVW_TEMPERATURE ]; + } + + if(// (( vreg_ctr[ VREG_C_STATUS_1 ] & REG_BIT_MGIC_ERR ) == 0 ) && + (( system_status.pwr_state == ON ) || + ( system_status.pwr_state == SLEEP ) + ) + ) + { + renge_task_immed_add( tski_BT_temp_update ); + } + break; + +/* Ă΂܂ + case ( ADC_SEL_BATT_DET ): + break; +*/ + } + +// Ƃ܂Ƃȏ肻 + if( ADS < ADC_SEL_BATT_DET ) + { + ADS += 1; // ̃`l + } + else + { + ADCEN = 0; // ~߂Ă܂ + adc_updated = true; + } + ADIF = 0; // ȂƁAÕ`l̃f[^̊ŒɊ荞މ”\ +} + + + +/* ======================================================== + tsk_adcƋ邱ƂlĂ܂B + ======================================================== */ +u8 get_adc( u8 ch ) +{ + u8 temp; + + ADMK = 1; + ADIF = 0; + + ADCEN = 1; + ADM = bits8(0,0,0,0, 1,0,1,1); // ZNg[hAAfCLK/6 ///火 + + ADPC = 0x06; // ADC|[g̃ZNg + ADS = ch; + + nop8(); + + ADCS = 1; // ADJnB /// ܂Ł@ɁA1usȏJ + + ADIF = 0; + while( ADIF == 0 ){;} + temp = ADCRH; + ADCEN = 0; + + ADMK = 0; + return ( temp ); +} + + + + + +/* ======================================================== + VR̉“͈͂lăXP[O + + Volp@g񂷂Ȃ炻̂Ƃǂɂ +======================================================== */ +static u8 adc_scaling( u8 orig_val ) +{ + u16 temp; + + if( orig_val <= vreg_ctr[ VREG_C_VOL_CAL_MIN ] ) + { + return( 0 ); + } + if( orig_val >= vreg_ctr[ VREG_C_VOL_CAL_MAX ] ) + { + return( 255 ); + } + + temp = (u16)(( orig_val - vreg_ctr[ VREG_C_VOL_CAL_MIN ] ) * 256 ) / ( vreg_ctr[ VREG_C_VOL_CAL_MAX ] - vreg_ctr[ VREG_C_VOL_CAL_MIN ] ); + if( temp > 255 ) + { + temp = 255; + } + + return( (u8)( temp & 0xFF ) ); +} + + + + +/* ======================================================== + qXeVX V2 + ľܓIȓ܂ +======================================================== */ +#define KIKAN 16 +static void adc_filter( u8 new_val, filter_work *work ) +{ + if( abs( new_val - *( work -> value_used )) > 2 ) + { + // 傫ꂽ + work -> large_diff_count ++; + if( work -> large_diff_count > 16 ) + { + *( work -> value_used ) = new_val; + work -> diffs = 0; + work -> kikan = KIKAN; + } + } + else + { + work -> large_diff_count = 0; + // ߏ̒lłAԂłς΂Ă炻Ɋ񂹂 + if( *( work -> value_used ) < new_val ) + { + work -> diffs ++; + } + else if( *( work -> value_used ) > new_val ) + { + work -> diffs --; + } + + if( --( work -> kikan ) == 0 ) + { + if( ( work -> diffs ) == KIKAN ) +// if( ( work -> diffs ) > (s8)( KIKAN * 0.8 ) ) + { + *( work -> value_used ) = *( work -> value_used ) + 1; + } + else if( ( work -> diffs ) == ( -1 * KIKAN ) ) +// else if( ( work -> diffs ) < (s8)( -1 * KIKAN * 0.8 ) ) + { + *( work -> value_used ) = *( work -> value_used ) - 1; + } + work -> diffs = 0; + work -> kikan = KIKAN; + } + } +} + diff --git a/tags/2.04/adc.h b/tags/2.04/adc.h new file mode 100644 index 0000000..6f4ad04 --- /dev/null +++ b/tags/2.04/adc.h @@ -0,0 +1,48 @@ +#ifndef __adc__ +#define __adc__ + +#include "jhl_defs.h" + +/////////////////////////////////////// +// ANI2 P22 +#define ADC_SEL_AMB_BRIT 0x02 + +/* +// ANI3 P23 +#define ADC_SEL_GYRO_YAW 0x03 +// ANI4 P24 +#define ADC_SEL_GYRO_PITCH 0x04 +// ANI5 P25 +#define ADC_SEL_GYRO_ROLL 0x05 +*/ + +// ANI6 P26 +#define ADC_SEL_3D 0x06 +// ANI7 P27 +#define ADC_SEL_VOL 0x07 + +// ANI8 P150 +#define ADC_SEL_BATT_TEMP 0x08 +// ANI9 P151 +#define ADC_SEL_BATT_DET 0x09 + + + +/////////////////////////////////////// +#define CODEC_REG_VOL 0x13 + + + +/////////////////////////////////////// +extern u8 vol_polling; +extern u8 vol_level_twl; + + + +/////////////////////////////////////// +u8 get_adc( u8 ch ); +void vol_reset(); + + + +#endif diff --git a/tags/2.04/batt_params.c b/tags/2.04/batt_params.c new file mode 100644 index 0000000..74d87df --- /dev/null +++ b/tags/2.04/batt_params.c @@ -0,0 +1,84 @@ +#include "jhl_defs.h" + +#include "batt_params.h" + +/* ======================================================== + eЃobe[p[^ + ======================================================== */ +const bt_param_ bt_param[ _BT_PARAM_NUM_ ] = +{ + // ctr //////////////////////////////////////////////// + // BT_PARAM_CTR_MAXELL + { + { + 0xAE, 0xF0, 0xB4, 0x30, 0xB7, 0x40, 0xBA, 0x30, + 0xBB, 0x50, 0xBB, 0xB0, 0xBC, 0x50, 0xBD, 0x10, + 0xBD, 0x60, 0xBD, 0xB0, 0xBF, 0xE0, 0xC2, 0xB0, + 0xC4, 0x20, 0xC7, 0xB0, 0xCA, 0xE0, 0xCE, 0x10, + 0x01, 0xF0, 0x14, 0x10, 0x14, 0x20, 0x06, 0x30, + 0x63, 0x90, 0x49, 0x00, 0x6E, 0x00, 0x77, 0x70, + 0x7B, 0x00, 0x19, 0x00, 0x19, 0x00, 0x17, 0xF0, + 0x1C, 0x60, 0x12, 0x00, 0x12, 0x00, 0x12, 0x00 + }, + 2, + { 92, (u8)(-256* 0.79), (u8)(-256* 4.35) }, + 0xD800, + { 0xEA, 0xE8 } + }, + + // BT_PARAM_CTR_PANA + { + { + 0x8C, 0x30, 0x9C, 0x10, 0xA5, 0xE0, 0xB0, 0x40, + 0xB1, 0xC0, 0xB2, 0x00, 0xB2, 0x50, 0xB3, 0x10, + 0xB4, 0x90, 0xB6, 0x20, 0xB8, 0x60, 0xBA, 0x50, + 0xBF, 0xA0, 0xC6, 0xB0, 0xCE, 0x90, 0xD0, 0x20, + 0x00, 0x20, 0x00, 0x20, 0x00, 0x20, 0x00, 0x20, + 0x7B, 0x30, 0x68, 0x60, 0x20, 0x00, 0x17, 0x00, + 0x17, 0x30, 0x12, 0xF0, 0x0D, 0xE0, 0x07, 0xF0, + 0x07, 0x00, 0x09, 0x30, 0x01, 0xC0, 0x01, 0xC0 + }, + 1, + { 171, (u8)(-256* 1.00), (u8)(-256* 2.60) }, + 0xDA20, + { 0x69, 0x67 }, + }, + + // spfl /////////////////////////////////////////////// + // BT_PARAM_SPFL_MAXELL + { + { + 0xA1, 0x20, 0xB7, 0x50, 0xB9, 0xD0, 0xBB, 0x00, + 0xBC, 0x30, 0xBC, 0x60, 0xBC, 0xA0, 0xBD, 0x10, + 0xBD, 0xC0, 0xBE, 0x70, 0xBF, 0xD0, 0xC2, 0xA0, + 0xC4, 0x00, 0xC8, 0x50, 0xCC, 0x80, 0xD0, 0xB0, + 0x01, 0xA0, 0x25, 0x10, 0x18, 0xB0, 0x17, 0xC0, + 0x95, 0x20, 0x6F, 0xE0, 0x7C, 0x60, 0x35, 0x10, + 0x35, 0x00, 0x37, 0xF0, 0x16, 0xF0, 0x1C, 0xA0, + 0x17, 0x30, 0x11, 0xD0, 0x11, 0xF0, 0x11, 0xF0 + }, + 2, + { 94, (u8)(-256* 0.35), (u8)(-256* 3.85) }, + 0xDAB0, + { 0xF5, 0xF3 } + }, + + // BT_PARAM_SPFL_PANA !!dummy!! + { + { + 0x8C, 0x30, 0x9C, 0x10, 0xA5, 0xE0, 0xB0, 0x40, + 0xB1, 0xC0, 0xB2, 0x00, 0xB2, 0x50, 0xB3, 0x10, + 0xB4, 0x90, 0xB6, 0x20, 0xB8, 0x60, 0xBA, 0x50, + 0xBF, 0xA0, 0xC6, 0xB0, 0xCE, 0x90, 0xD0, 0x20, + 0x00, 0x20, 0x00, 0x20, 0x00, 0x20, 0x00, 0x20, + 0x7B, 0x30, 0x68, 0x60, 0x20, 0x00, 0x17, 0x00, + 0x17, 0x30, 0x12, 0xF0, 0x0D, 0xE0, 0x07, 0xF0, + 0x07, 0x00, 0x09, 0x30, 0x01, 0xC0, 0x01, 0xC0 + }, + 1, + { 171, (u8)(-256* 1.00), (u8)(-256* 2.60) }, + 0xDA20, + { 0x69, 0x67 }, + } +}; + diff --git a/tags/2.04/batt_params.h b/tags/2.04/batt_params.h new file mode 100644 index 0000000..343b3f4 --- /dev/null +++ b/tags/2.04/batt_params.h @@ -0,0 +1,49 @@ +#ifndef _bt_params_h_ +#define _bt_params_h_ + +#include "jhl_defs.h" +/* + dr CTR | SPFL | YBS + 0 ID = 0 maxell + 120 1 + 360 2 + 750 @ 3 + 1.3k@ 4 + 2.7k 5 pana + 8.2k@ 6 +*/ + + +typedef enum +{ + BT_PARAM_CTR_MAXELL = 0, + BT_PARAM_CTR_PANA, + BT_PARAM_SPFL_MAXELL, + BT_PARAM_SPFL_PANA, + BT_PARAM_SHRIMP_MAXELL, + BT_PARAM_SHRIMP_PANA, + _BT_PARAM_NUM_ +} BT_TYPE; + +typedef struct +{ + u8 rcomp; + s16 up,down; +} rcomp_; + +typedef struct +{ + u8 hi,low; +} verify_; + +typedef struct +{ + u8 mg_param[64]; + u8 v_scale; + rcomp_ rcomp; + u16 ocv; + verify_ verify; +} bt_param_; + + +#endif diff --git a/tags/2.04/bsr.hex b/tags/2.04/bsr.hex new file mode 100644 index 0000000..39af280 --- /dev/null +++ b/tags/2.04/bsr.hex @@ -0,0 +1,1000 @@ +:02000000720D7F +:04001000DA48DC48A6 +:02001C009B4AFD +:02002400E84AA8 +:02002A00334B56 +:08003400604C034C5C4C714D63 +:02004A00DE488E +:02005A00194942 +:02006200F54C5B +:0400C0007EFBFF04C0 +:0A00C4001B339499E033F240BFAA09 +:1000CE00C7C1FBF8FFCEABACC736F00071F4C6610A +:1000DE00D8710016F98EA89C018C015C10D1DD0A36 +:1000EE007110BEFB710016F9EF0B8C015C80D161B3 +:1000FE00E8710016F98F16F931030EF6B1BBF661F1 +:10010E004900DD05618900EFF5FDD401FD2801FDF3 +:10011E008001FD6402EFAEC0C6D7C7360000674C43 +:10012E0009DE3F318E04F60FC1317B9EFDC411896D +:10013E007267318E04F64F14896142DF03F6EF01C8 +:10014E00E660610667318E124900207267318E04B7 +:10015E00F64F14896142DF03F6EF01E66061068710 +:10016E00EFBC40F84F3A61E88666D161E8FDD706EC +:10017E00C6D751105B0C319E609F18F94018F901DB +:10018E00DF05CD2F05EF03CD2F078F16F95CE39F0B +:10019E0016F951035B04318EE7240000DD1023DDD8 +:1001AE000823DF0E712016F9D7713016F9D771407A +:1001BE0016F9D7717BFACEA010CEA180E5F300CE52 +:1001CE00A408F5AAFFD78F16F9310508CD0003CD87 +:1001DE000307EF03CD030ECE23F88F16F931030B71 +:1001EE00CD0408CD0508F690BFB401CF1105F8F582 +:1001FE0021FFCE22E9CE24F3CE25FACE26FCCE2741 +:10020E005FCE2EFCCF120511CF350002CF3700196D +:10021E00CF530006CBEEFEFFCE3831CE3970CF383D +:10022E00050A308700BF1801BF1A01BF1C01BF1E8F +:10023E0001D7C7C1C1FBF8FFCEABAC8C02D1DD122A +:10024E00616902305C03BBF6614900DDEE61890035 +:10025E00EFF51004C6D7FD3D0AFD6F09FD432FFDD6 +:10026E002338FDC804717AFAFDA223F514F98F160E +:10027E00F93105135003FD522B625C01D161E8CFB9 +:10028E0014F902CFC7FB64FD2330FD874471025F72 +:10029E00712BE7FD2638FDC53861EDEFF6D7D7C7D0 +:1002AE00F616FDC804717BFA31225D0871225D716C +:1002BE007AFAEF0B717AFAA7F647DFE9E2EF01F26D +:1002CE00C6D7C7C1C1FBF8FF17A1C1E0C18C0A7028 +:1002DE00C18C0270FDF8021006D2DF04F437EF0372 +:1002EE00CD37028C01721004C6D7C7C1FBF8FFFDD3 +:1002FE00AD02D2DD03E2EF618B70FD1604D2DD0795 +:10030E0071235D5202EF528C0870FD3104FD7C04A6 +:10031E008B6C0170FD3104300400BF240130174096 +:10032E00BF1C01300400BF22018C0A91DF04F6BF0E +:10033E002A01710BE2CE44FF3182E202EFFAAC0CDD +:10034E00148E449961790C61690A8C0AD1DFDAFD49 +:10035E00A504710BE271235DF2C0C6D7C7C1FBF8CD +:10036E00FFFDAD02D2DD03E2EF25710AE68B70FDD3 +:10037E001604D2DD0771235D5202EF138C0870FD57 +:10038E0031048C0A70FD3104FDA50471235DF2C0A9 +:10039E00C6D7C7C1FBF8FFFDAD02D2DD03E2EF65A4 +:1003AE00710AE6710BE28B70FD1604D2DD07712324 +:1003BE005D5202EF50710BE231125D39C73432FBE0 +:1003CE00AC0C1652048B99A5A792DFF9C63184BDE9 +:1003DE0002EFFA717ABDCEB144CBB432FB8C0A3146 +:1003EE008EBEB8CEBB48714BE1714BE5710ABD8C28 +:1003FE00089E44EF0F710BE68C089E448C0A9D36C6 +:10040E00AC0CBD34F2C0C6D7C716FD5404AF040100 +:10041E00BF0C0117FD3104D2DD06FDA504E2EF018C +:10042E00F2C6D7C716710AE6710BE2669E44318298 +:10043E00E202EFFAF6420401DD09AF0401BF0C013E +:10044E00E2EF01F2C6D7AF2801085CFB08BF280116 +:10045E00FDAC02AF28015CFBBF2801300400BF2AAF +:10046E0001301780BF1C01300400BF2201D7AF241A +:10047E0001086C0408BF2401AF28016C0F086C0B37 +:10048E0008BF2801FDAC02AF2A01085CFB08BF2A99 +:10049E0001FDAC02ED5404300400BF2401F6BF2A66 +:1004AE0001300B0BBF2801FDAC02300B0FBF280132 +:1004BE00FDAC02300F0FBF2801D731345D01D7716B +:1004CE00225D710BBD0000717BBD6A0E03713B2571 +:1004DE00713B23E0FD40027120F000FDAC02F6BF3F +:1004EE0026015024BF1401CB440014300F0FBF2837 +:1004FE000171135D710BE2710AE6FD5404CE44FFE7 +:10050E003182E202EFFAFDA504AF0401BF0C0171C6 +:10051E00235D71325DD731245D02EFFAFD7C0471EB +:10052E003A25713A235A0EFC7128F00071335DD7CB +:10053E00C7880616FDAD02D2DD03E2EF38710AE67A +:10054E0050A4FD1604D2DD0771235D5202EF26176B +:10055E00FD31046770FD3104FD7C0450A4FD3104AF +:10056E005020FD3104D936FBFD3104A036FBFDA52C +:10057E000471235DF2C6D7C72008FBF8FFFDD5082E +:10058E005014C15008FD0708C0CC07048C074C144A +:10059E00DE0C8C07318EFD540A615907EFEECC0745 +:1005AE00048C074C1461C8ED7306CC06008C064C07 +:1005BE000461C8ED5206301AF9BC02F6BBCEABACE4 +:1005CE0031B2D109C73641057184C6DEF3F1C736A3 +:1005DE0041057184C661DC9C05713BD1AC02148F60 +:1005EE0040059971505005617902617900F0E16121 +:1005FE004900DD09C73641057184C6DEC3F1C73631 +:10060E0041057184C661DC0E059C055040C18C0706 +:10061E00318E31AD128C06318E318D03BDD831FF46 +:10062E00BDDADADAADD8FD200DC0D2DD0C5008C12E +:10063E005014FD0708C0FDDD0B8C05D1DF06615996 +:10064E0006EDBB058C07318EFD580AD2DD0C500825 +:10065E00C15014FD0708C0FDDD0B8C05D1DF06610E +:10066E005907EDAF0571605005CC0400CC05008C28 +:10067E00054C09DE2B8C05318E04F61FC1317B9E95 +:10068E00FDC41189728C05318E04F64F14896142B6 +:10069E00DF03F6EF01E6600E049C04615905EFCF0F +:1006AE0041001140F81F3A61E86159048C04D1DF12 +:1006BE0008FDDE0BFDF00CEF0C5008C15014FD07C9 +:1006CE0008C0FDDD0B1008C6D7C72004FBF8FF716C +:1006DE005B21CC0100F6BC02AC02440900DE3EAC4C +:1006EE000204F60F144100118972AC020C501489E9 +:1006FE006142DF03F6EF01E6600E019C01AC0212CF +:10070E0049005072AC0204F67F14896142DF03F691 +:10071E00EF01E6600E019C01617902EFBB40F67FAE +:10072E00FF61F86159018C01D161F8EDD507CC015B +:10073E0000717AFAFDC804711300711B2071030356 +:10074E00710205E0C15003FD412BC05013FD400264 +:10075E00500FC1E0FD412BC0CEABAC6159018C01F5 +:10076E0091DD068C014C03DF03E6EF01F66061FBC1 +:10077E007151018C014C0861F8CC01003132070532 +:10078E00A044FCEF03F544FC4044FC11DC0DF544A1 +:10079E00FCF0C15003FD412BC0EF12E6BC02F66126 +:1007AE004902DDB400000000617902EFF1CE370896 +:1007BE00CBE4FFFFCBE6FFF7CED4FFCF370008F533 +:1007CE00120561FDF5ABFFFDD508D25008C15014DE +:1007DE00FD0708C0D2FDDD0B1004C6D73184BD0263 +:1007EE00EFFA717BBDCBE4FFFFCBE6FFFFCBD4FF6F +:1007FE00FF717ABED7717BBED7C7C1200CFBF8FF45 +:10080E008C0C318E31ADC1317B9DD4C0BC068DD4E4 +:10081E009C088C149C0B8C14318E040C00128C0BC7 +:10082E00318EBDD813FDAF0F61C8EDD008CEABAC85 +:10083E00CC05068C0B318EFD500AD2DD158C0B319A +:10084E008EFD540A6169058C05D1DFE7FD0308E2D0 +:10085E00EF71CC0A008C0A4C04DE54F6BC02301A3E +:10086E00F9BBAC06148C089EFD118972AB1462990B +:10087E00AC06A1BC06617900617902F0E161490222 +:10088E00DFE05040C18C0B318E31AD128C0A318EAF +:10089E00318D03BDD831FFBDDADADAADD8FD200DCA +:1008AE00C0D2DD06FD0308E2EF1961590AEFA68CEE +:1008BE000B318EFD580AD2DD03E2EF0761590BEDC5 +:1008CE002408F2100EC6D7C7717B9D717BFAFDEA24 +:1008DE0007301AF9FD030BFD8E0AC6D7FDD508FDAC +:1008EE00DD0BFD0308F5ABFFF2D7C731746006715F +:1008FE0010CBFBEF047118CBFB8FCBFB7FF4FC7698 +:10090E00D1DD5C8FCBFB9FF4FC4014F903DF226634 +:10091E005C10D1DD1C8FCBFB5C10D1DD0B5080C188 +:10092E005011FD7634C0EF095040C15011FD7634A0 +:10093E00C04014F903DD064014F904DF22665C02A0 +:10094E00D1DD1C8FCBFB5C02D1DD0B5040C15010B2 +:10095E00FD7634C0EF095020C15010FD7634C0C66C +:10096E00D7C78F0EFC768F0FFC77665C80D1DD10BB +:10097E00675C80D1DF05712360EF0B712260EF069B +:10098E00710407712160665C40D1DD10675C40D157 +:10099E00DF05713360EF0B713260EF067114057174 +:1009AE003160665C01D1DD10675C01D1DF057143FA +:1009BE0060EF0B714260EF06713407714160665C47 +:1009CE0002D1DD10675C02D1DF05715360EF1D713E +:1009DE005260EF184017F901DF087104027151607F +:1009EE00EF0AC736100571C4C6715160665C04D13A +:1009FE00DD10675C04D1DF05716360EF0B7162601F +:100A0E00EF06714407716160665C08D1DD10675CAA +:100A1E0008D1DF05717360EF0B717260EF06711410 +:100A2E0007717160665C10D161E8715AD1C6D7F555 +:100A3E000EFCF510FCCF16FCFFCF12FCFFCF13FC03 +:020A4E00FFD7D0 +:100A50005208EF065203EF025206FEE600FE1B00AC +:100A6000DC16089F03088F0408089F040862FE2410 +:100A700000089F0408EEBF00EEBA00C1C514410E85 +:100A800011D9D0FF118FD1FF312E45C4C0D7F2311B +:100A9000A2C401E2D79DE261DD4C09DF12717BFA4D +:100AA000C18F06089F5FFDC0CF060800EE2700310A +:100AB000F2FA04CF0608004C00DF05D50008DD1669 +:100AC00061DD717BFAD50608DD0ACDE31F61CD61DA +:100AD000CDEE160061CDFED40061FFFE9A00FCF859 +:100AE000FF0EFEB20061CDFED5004C09DF0EC18FB6 +:100AF00006086F5FFD9F0608C0EE0400CF060800E1 +:100B0000F8E3D75200EF025202FE3700CF5EFD003D +:100B1000CF060800BF0408C716629F0008410011F5 +:100B20008F1A209B4100118F1B209F0108C6510086 +:100B3000FE62FFEF025205CF060800C1510CFE0A0B +:100B400000C0D7C1511DFE0200C0D761DD717BFA24 +:100B500070CEC0A59EC47CFF9EC4609EC461CDD7EC +:100B600061DD717BFAC18EC45C1BFED6FFCF060827 +:100B700001FED7FFC061CDD731F2FA1AC1AEE4BF92 +:100B800050FDAEE6BF52FDAED4BF54FD30FFFFBEF8 +:100B9000E4BEE6BED4C0D731F2FA11C1AF50FDBEFB +:100BA000E4AF52FDBEE6AF54FDBED4C0D7C1BF56C0 +:100BB000FD13BF58FD15BF5AFD17BF5CFDC0D7AF71 +:100BC00056FDDB58FDEB5AFDFB5CFDD7534B305215 +:100BD0005430324E323030475631323000FFC1503F +:100BE000FEFEAB0061DD717BFACF060800FE0A0055 +:100BF000FEA4FF61CDF8E3EECF00C7FB0408BF50B1 +:100C0000FD8FC0009C05C5C337040600BF52FD35EB +:100C100036420C300000522BFE6600C2C4C630F0D3 +:100C20000BB800300000B8022004AF52FDB800300D +:100C30000F00B802AF50FD61FF520AFE3AFFECF818 +:100C4000FF0E717BFAC1C7FB04088C05C65C80FEF1 +:100C50000200C0D761DD717BFA70CFC0FFA59FC0D5 +:100C6000007CFF9FC000609FC00061CDD7618BFEFC +:100C7000E2FF717BBE410011FB000017CEFC00615A +:100C8000CB089EFDF31161C999A58392DFF7D7FECA +:100C9000B1FED55EFDDF23C1CF0308035109FEF489 +:100CA000FDC0D2DF37FE3800A20408CF0308075189 +:100CB00009FEE1FDD2B20408DF22C7FB040831833C +:100CC00002C6D7C6510AFECCFD624C1FDF06CF5EBE +:100CD000FD01EF04CF5EFD00C0EE5BFEC0EE55FEF1 +:100CE000C7C1FB04088B31196C0161589BC0C6D782 +:100CF000717BFAFE4DFEAF0408040600C1143654A1 +:100D00000C300000522DF3FE77FF8FC000FE2BFE4B +:100D100061CF5C807C8073C0041900CEFC0F61CB76 +:100D2000C55404EF03C55417FE18FEC7360008BBB0 +:100D3000629C0288089C03D1DD334C41DE2F70F1A8 +:100D4000312DB161090033081C000851FF612A41AF +:100D50000E118FD0FF613B118FD1FF6138DC0E8BFC +:100D60005C03DF0964C6C4FE2BFDEECAFDC6C4EEFB +:020D7000C3FDC1 +:100D720061CF5100718C7109FECBF800FEFCC101FC +:100D820000F6BF00F953C0F693935820FEDFF941F5 +:100D92000036824D34FEFCEF05118B99A7A517444E +:100DA200D44DDFF53602F930FEFCEF04CC0000A78B +:100DB20047DFF9410036D44D3420FEEF05118B99FF +:100DC200A7A51744DC4DDFF53628FE305CFEEF04A4 +:100DD200CC0000A747DFF9FCCE0000EFFE61DD7119 +:100DE2007BFABEF0ADD8BEF200AEF661CDD7C361DC +:100DF200DD717BFABEF0ADD8BEF200DBF6FFADDCF2 +:100E0200BEF000AEF6BDD8AEF40312ADDABEF2000B +:100E1200AEF661CD03BDDAC2D7C3F33174D908830C +:100E2200C1F626D8BDD8C031750683C312F623C2D7 +:100E3200FD3D0E93DF0312F623C2D7440000DD26E8 +:100E420061DD717BFACFE80080BEF6F6BEF4BEF239 +:100E5200ADD8BEF0CFE800818FE8003103FAAEF0E2 +:100E6200F5E80061CDD7B1D7C3F33174D90883C196 +:100E7200F626D8BDD8C0317505C312F623C2FD8B44 +:100E82000E93DF0312F623C2D7440000DD2761DD93 +:100E9200717BFACFE80080BEF6F6BEF4BEF2ADD8A2 +:100EA200BEF0CFE800818FE8003103FAAFE000F531 +:100EB200E80061CDD7ADD8D7C3F33174DB0F83C15E +:100EC200F626D8BDD861317026DABDDAC031750D8B +:100ED20083C312F626DCBDDC61317023C2FDF30E42 +:100EE20093DF0CF626D8BDD861317026DABDDAC29E +:100EF200D7C161686BDC6BDDC0DD2F61DD717BFA10 +:100F0200CFE80080BEF4ADDCBEF6ADD8BEF0ADDAFF +:100F1200BEF2CFE800818FE8003103FAAEF0BDD80F +:100F2200AEF2BDDAF5E80061CDD7F6BDD8BDDAD7AD +:100F32008292DD2B61DD717BFACFE80080BEF0F694 +:100F4200BEF2BEF46208BEF6CFE800818FE800313F +:100F520003FAAFE0006072AEF0F5E80061CDD76051 +:100F620072F6B1D706DABDDAADDC06D8BDD861D8E3 +:100F7200A6DAD7D1DD17C1C3DAD89DD8ADDA311CD4 +:100F820061EEB4D8DFF8BDDA13BDD8C2C0D7D1DD67 +:100F92001BC1C3DADA9DDAADD8311E33311E33718B +:100FA200F9B4DADFF4BDD813BDDAC2C0D746D8DD52 +:100FB2000771FF7177D971C0D75BDB9DDB605BDAAC +:100FC2009DDAADDC5BD9085BD808BDD8D7C3C7F3BF +:100FD200728EFDC162314C410036784D1161A072B2 +:070FE200C09EFD62C6C2D7EC +:0A0FF60030393A31343A3135000049 +:0A20000030393A31343A313500002E +:10200A0005214F7B9EC5E9000104080D12171C1F0C +:10201A00080100001F003B005A0078009700B50035 +:10202A00D400F300110130014E01192634445362E1 +:10203A006E777D80807D776E625344342619100A4C +:10204A0008080808080808080A10AEF0B430B740B3 +:10205A00BA30BB50BBB0BC50BD10BD60BDB0BFE014 +:10206A00C2B0C420C7B0CAE0CE1001F014101420C8 +:10207A000630639049006E0077707B0019001900E2 +:10208A0017F01C6012001200120002005C003600F9 +:10209A00A70000D8EAE88C309C10A5E0B040B1C097 +:1020AA00B200B250B310B490B620B860BA50BFA014 +:1020BA00C6B0CE90D02000200020002000207B3027 +:1020CA00686020001700173012F00DE007F00700D3 +:1020DA00093001C001C00100AB000000670020DA2E +:1020EA006967A120B750B9D0BB00BC30BC60BCA0A6 +:1020FA00BD10BDC0BE70BFD0C2A0C400C850CC8045 +:10210A00D0B001A0251018B017C095206FE07C60F0 +:10211A003510350037F016F01CA0173011D011F029 +:10212A0011F002005E00A7002700B0DAF5F38C3048 +:10213A009C10A5E0B040B1C0B200B250B310B49048 +:10214A00B620B860BA50BFA0C6B0CE90D02000204A +:10215A000020002000207B30686020001700173024 +:10216A0012F00DE007F00700093001C001C00100BC +:10217A00AB000000670020DA696700000000000079 +:10218A000000000000000000000000000000000045 +:10219A000000000000000000000000000000000035 +:1021AA000000000000000000000000000000000025 +:1021BA000000000000000000000000000000000015 +:1021CA000000000000000000000000000000000005 +:1021DA0000000000000000000000000000000000F5 +:1021EA0000000000000000000000000000000000E5 +:1021FA0000000000000000000000000000000000D5 +:10220A0000000000000000000000000000000000C4 +:10221A0000007F7E7D7C7A7978777675747271702A +:10222A006F6E6D6C6A6968676665646261605F5E3D +:10223A005D5C5A5958575655535251504F4E4D4B53 +:10224A004A494948474645434241403F3E3D3B3A59 +:10225A00393801020203030200FEFBF7F3F0F0F340 +:10226A00FA041225384D5F6E777A776E5F4D3825FE +:10227A001204FAF3F0F0F3F7FBFE00020303020282 +:02228A00010051 +:10228C008F04F9B004F9D1DF47CF04F91EFD3B23CD +:10229C00FDDD2231325C0D31045C093122600571A7 +:1022AC003304EF03713204FD142331225C057142B7 +:1022BC0002EF03714302D42ADD05B42A71420231C4 +:1022CC004402067140CBFBEF047148CBFBFD10269A +:1022DC00D74A284BDC134A28B9DE0E4005F928DE14 +:1022EC0004A005F9D771335CD74A283EDC054A288F +:1022FC00BDDC0E4006F928DE04A006F9D771325C6D +:10230C00D7F505F9F506F9D73132600E4007F90219 +:10231C00DE04A007F9D771235CD73132040A40C719 +:10232C00FB3CDE0471235CD771225CF507F9D7C73F +:10233C00C1FBF8FF71445C712760DE57712460713A +:10234C00415C312260127130CBFB5002C15011FD47 +:10235C007634C0CD2A32EF3B7138CBFBE0C1501143 +:10236C00FD7634C0F42A17C15002FD292BC0D2DFF0 +:10237C000D8B318E318D080E01081C00BD2CAD2C3F +:10238C0044009BDC05D5C7FBDF095020C15011FD73 +:10239C007634C0C0C6D7C78D2076FDE423FD5D2BF7 +:1023AC00D517F9DD0571035CEF2C664B2061F83114 +:1023BC00545C1A71535CFDC804664C07DD0381DF65 +:1023CC00098F16F9310303FD6D24FD812471025C24 +:1023DC00306425FD7B38C6D7C7716201717201501C +:1023EC0005FD40025008FDF836629D285009FDF8A5 +:1023FC00366276716301711816F94A28F1DC05E52D +:10240C0017F9EF224A2804DE1ACF17F9025008C137 +:10241C00506CFDD002C092DF0DD437DF097110165D +:10242C00F9EF03F517F94017F901DF05710A22EFEF +:10243C0006710B22710302CD20075700674C08DE92 +:10244C001073090A20614EDC05679D20EF0387EFAE +:10245C00EB4A2007DF09D517F961F8CF17F903C646 +:10246C00D7500AFD4002304000C15006FD0C2BC075 +:10247C005096ED4002C72006FBF8FFD517F961E82E +:10248C00ED6025304A57C1503EFD0C2BC0D2DD0704 +:10249C007100CAFBED60257108CAFB17040200C16C +:1024AC005004C1500CC1506CFDF8021006EA30AA61 +:1024BC0048318D12AA48318E616B08616A08C1508F +:1024CC000EFD0C2BC0F690C1500CFD0C2BC0CC019A +:1024DC00008C014C04DE2831245D02EFFA71125D90 +:1024EC00EA308C015010D605C15010C18C01D604B5 +:1024FC004000C1506CFDA0031006615901EFD25091 +:10250C00A5FD4002EA30AA48318D12AA48318E61ED +:10251C006B08616A08C1500EFD0C2BC050A5FD4024 +:10252C00025004C1506CFDD002C0629C01EA308A9A +:10253C004B4E0161C3048A4A4E0117040200C1507C +:10254C0004C1500CC1506CFDA0031006F6C1503EE6 +:10255C00FD0C2BC01006C6D7C78F08F94B2861F8A5 +:10256C00ED0D26400AF928DE06A00AF9ED0D26F538 +:10257C000AF98D289F08F98D285070D612307351A6 +:10258C00230480001231FF318E039F09F99FC6FB93 +:10259C00F68F09F97C804C95DC1C8F09F9318F245E +:1025AC001400EA30BDD8AA44FDDF0D1231FF318E84 +:1025BC0003318F16EF1A8F09F9318F241400EA308A +:1025CC00BDD8AA46FDDF0D1231FF318E03318F16B7 +:1025DC00EA308A427217F3031644000171FE61C897 +:1025EC0036FF001701DE02F61617BD4EC7500CFD64 +:1025FC000C2BC0D2DF078D289F08F9EF047100CA9D +:10260C00FBF2C6D7C72008FBF8FF4017F901DD061F +:10261C004017F902DF1C17040600FD042CD2DF0A58 +:10262C008C069C058C079C04EF4ACC0563CC0400FB +:10263C00EF4217040600FD042CD2DD0F7100CAFB1B +:10264C0071035CCC050071025DEF298C06318E3173 +:10265C008D080E07081C00BBEA308A4072ABFD32B5 +:10266C000FBB8C019C05D1DF08CC0501CC0400EF1D +:10267C00038B9C0417040600FD0F2CD2DD06CC0640 +:10268C00C8CC07008C069FC9FB8C06318E318D0897 +:10269C000E07081C00BD2CAD2C4401A5DC09CC0395 +:1026AC0064F6BF0CF9EF52AD2C220CF94401A0DCFE +:1026BC0009CC031EF6BF0CF9EF3FAD2C44819DDC19 +:1026CC000BCC030A30F401BF0CF9EF2DAD2C4401F7 +:1026DC009BDC0BCC030530F401BF0CF9EF1BAD2CCC +:1026EC00440191DC0BCC030030F401BF0CF9EF0971 +:1026FC0071025D30F401BF0CF93132040C31245CF1 +:10270C0008CC0564CC0400EF0D8C034E05DE078C61 +:10271C00039C05CC04008C059FC7FB8C049FC8FB55 +:10272C00FD912B8F0EF94E05DD2B40C7FB0BDE0602 +:10273C00400EF90BDE1640C7FB06DE06400EF9060E +:10274C00DE0AD5C7FBDF0ED50EF9DD095020C150CE +:10275C0011FD7634C08FC7FB9F0EF9FDCE2B1008F0 +:10276C00C6D7C7D82FC15002FD412BC04018F90164 +:10277C0061F8712010055012FD40028D2F6C08700D +:10278C00C15002FD412BC05003FD40028D2F6C182F +:10279C0070C15002FD412BC05016FD40025003FD8C +:1027AC00522B625C01D1DD107170CBFB5002C15019 +:1027BC0013FD7634C0F2EF01E2C6D7C75004FD52C8 +:1027CC002B625C03D1DD405014FD5E2834CBFB89B9 +:1027DC005C9F998A0C7CFF50FF5C14D1DD228A0C23 +:1027EC007CFF5C147234CFFB89616A997162075665 +:1027FC0000316207058666D1DFF7716307716B27BD +:10280C0034DEFB895CEB99712810055002FD522BCC +:10281C00D2DD354018F901DF05500AFD40028D2F3D +:10282C006C1070C15002FD412BC0E0FD4002D82F4E +:10283C00C15002FD412BC05033FD4002F0C150028B +:10284C00FD412BC07178CBFBE0C15013FD7634C039 +:10285C00C6D7C7C12004FBF8FFCC02005004FD52C0 +:10286C002B629C038C045C20D1DD0E8C036C019CD0 +:10287C00038C026C209C02EF138C045C10D1DD0CD9 +:10288C008C035CFE9C038C026C109C028C045C0818 +:10289C00D1DD0E8C036C029C038C026C089C02EF45 +:1028AC00138C045C04D1DD0C8C035CFD9C038C024A +:1028BC006C049C028C03D1DD05501AFD40028C0384 +:1028CC0070C15004FD412BC08FCBFB5C9F728C03FD +:1028DC00318E316D148C03318E314D616D08616C0C +:1028EC005C606162629FCBFB8FD7FB7CFF50FF5E0D +:1028FC0002D1DD278FD7FB7CFF5E027234CFFB89C0 +:10290C00616A99716207CC01003162070861590153 +:10291C008C01D1DFF4716307716B27F21006C6D7F7 +:10292C00D9BFFBC15006FD412BC0D9C0FBC150071C +:10293C00FD412BC0D7FD2C29F2D7C7711300711B99 +:10294C0020710303710205E0C15003FD412BC050FF +:10295C0013FD4002F0C15005FD412BC0500FC1E0EA +:10296C00FD412BC0500AFD40027103055008FD408B +:10297C0002501FC1E0FD412BC05012FD400250031C +:10298C00FD522B625C01D1DF03E2EF24F0FD522BF0 +:10299C00629D2E3602F9C75008FD292BC05003C189 +:1029AC00FD412BC0710203711A20FDE92AF429F2B2 +:1029BC00C6D75003FD522B625C01D1DD155014FDBE +:1029CC005E28FDC7275014FD4002E0C15003FD41B5 +:1029DC002BC0711300711B207103035014FD4002B6 +:1029EC00F0C1E0FD412BC0F0C15003FD412BC0D71D +:1029FC00C72004FBF8FFCC02008D299C035010C1AA +:102A0C0050A4FDD002C0629D29D437DD04F2EDC67E +:102A1C002A8C037B295C08D1DD0F8D295C08D1DF62 +:102A2C0005CC0210EF03CC02208C037B295C04D173 +:102A3C00DD158D295C04D1DF088C026C049C02EF3F +:102A4C00068C026C089C028FCAFB5CF3728D295CAD +:102A5C000C6162629FCAFB8FD6FB7CFF50FF5E024B +:102A6C009C02D1DD1F34CEFB896E0299716207CCBA +:102A7C000100316207086159018C01D1DFF47163E7 +:102A8C0007716B278D295C40D1DD095002C15012B2 +:102A9C00FD7634C08D295C01D1DD08E0C15012FDFA +:102AAC007634C0717AFA8D295C41D1DD0C5A29BE7D +:102ABC00D829C15010FD3E05C0F21004C6D7FD6EDA +:102ACC0027F2D7FDC727F2D7C78FDEFB7617FD5E3F +:102ADC0028664FDEFBDFF2F5DEFBF2C6D75064FD55 +:102AEC004002FD1A2C6261FB71115CF171145C6186 +:102AFC00DC70C15012FD3E05C0FD1C36CD3D03D728 +:102B0C00C7C1C1FBF8FFAC0ABB17C15002C18C0294 +:102B1C0070C1506CFDA00310061004C6D7C7C1FBD2 +:102B2C00F8FFAC08C15002C18B70C1506CFDF802AB +:102B3C001006C0C6D7C78806166770C1C75084FD7B +:102B4C006A031004C6D7C716C75084FDD002C0C68E +:102B5C00D7C74A2004DE045600EF0256014018F98C +:102B6C0001DF048686EF0A4018F902DF0451046184 +:102B7C000666318F12504CD633514CD6610A045430 +:102B8C0020BD30C6D740C7FB51DC05CF1EFC0FD78C +:102B9C0040C7FB33DC05CF1EFC0BD740C7FB0BDC5F +:102BAC0005CF1EFC07D740C7FB0661D831320405A0 +:102BBC00CF1EFC03D7D5C7FBDD04E51EFCD7F51EE5 +:102BCC00FCD7D514F9DF0471635CD7FD1A2C626154 +:102BDC00FB71715C71145C71775C61C831625C175C +:102BEC0071625C71745C71115CF171745C61DC70AC +:102BFC00C15012FD3E05C0D7C716C75004FD292B86 +:102C0C00C0C6D7C716C75002FD292BC0C6D740C7B0 +:102C1C00FB0BDE02E2D7F2D771000105717850058B +:102C2C00713AD5713BD18F10055CFC9F1005CF54C8 +:102C3C00054AE54205711042057100420571485084 +:102C4C00057130500571205005CF530505CF520545 +:102C5C000A7130510571205105713BD571705005C9 +:102C6C008F11055CFC9F1105F422D771785005710A +:102C7C00080105D77140F00071783002713AE671A5 +:102C8C003BE2713BEA713BEE8F10055CFC9F10053B +:102C9C00CF34024AE552FF711A52710A5271483010 +:102CAC00027130300271203002CF330205CF320274 +:102CBC000A71303102713BE6717030028F11055C84 +:102CCC00FC9F110571603002D7717830027148F0A9 +:102CDC0000D7C788061666614FDD0967614EDE03B3 +:102CEC0096EF01866672C6D7C7161714AA0412A9E6 +:102CFC0043DD29AA0412A923FDDC4DC3AC02FDDC83 +:102D0C004D13C2BDD813FDAF0FDE0C1714AA02125F +:102D1C00AA0403BA04EF051714A9BA04AC041231BF +:102D2C00FF319E03317F087208C6D77100F2003064 +:102D3C004400BFB601300188BF9001300984BF9EAA +:102D4C0001BF9C01BF9A01BF9801BF9601BF9401BE +:102D5C00BF9201F53CFF30FE00BFBE01F6BFBC01C7 +:102D6C00BFB80150EEBFBA01A1BFB201C918FE0035 +:102D7C00F6BE6EBE64BE6A7123047153078F16F9DA +:102D8C00310507F5E5FBCB6CFF0071535D71425DBE +:102D9C00D730EF00BFB401F6BFBA017108F2007171 +:102DAC00230471530771435DD78F9CFBB09CFBD1FF +:102DBC00DF7331D4D106715BD1E59EFBD59EFBDD73 +:102DCC00347140CAFBD99DFBF1E734020023DD06C8 +:102DDC0025DD0325DF05F6BE66EF06D9E4FBF1BE63 +:102DEC0066A09DFB409DFB20DF06F59DFBB09EFB86 +:102DFC00CF9CFB19D7CF9CFB1E7148CAFBD5E6FBB9 +:102E0C00DF04F6BE66D7D9E4FBF14266FFDD16D9C6 +:102E1C00E4FBF112AE6643DE05A266FFEF03B26679 +:102E2C00FFCF9CFB03D7C7161714F6B9AA0412F6EA +:102E3C00231231FF31AE03316FBA02C6D7C7C1FBC3 +:102E4C00F8FF8C085080D612AB1413B9AB14AA043B +:102E5C0012A92312D939FBF133BDD813FD1B0EBABD +:102E6C0002C0C6D731645D01D74014F902DF10F6F9 +:102E7C00BE64BE6EBE6ABFA6FBBFACFBBFB2FB316D +:102E8C00545D1530A2FBFD322E30A8FBFD322E30E6 +:102E9C00AEFBFD322EED242F31745D0F71735D711D +:102EAC0008EAFBF5A0FBF59FFBEF6DD59FFBDF65FB +:102EBC008F38FB9F9FFB40A0FB1FDC1A7100EAFBC5 +:102ECC00403AFBFFDD22A0A1FB8F3AFB4FA1FBDEBA +:102EDC0017F5A0FBEF12D9A0FBF1A1605C1F9FA01E +:102EEC00FB7108EAFBF5A1FBE9A0FB093CFB70C1F7 +:102EFC0030A2FBFD492EC0E9A0FB095CFB70C13080 +:102F0C00A8FBFD492EC0E9A0FB097CFB70C130AECB +:102F1C00FBFD492EC0B09FFB30A2FBFDF42CF3133C +:102F2C00BE6E30A8FBFDF42CF313BE6A30AEFBFD75 +:102F3C00F42CF313BE64D7C736F00071F4DC29719E +:102F4C0070F000CE9D08CE9EC0CE9F80F594FFF50C +:102F5C0093FFF592FFE597FFE596FFE595FFE59862 +:102F6C00FFCE9C7F7100BEFB711BE3712BE3711ACA +:102F7C00E7712BE7717A9D710A9E31929E02EFFAEE +:102F8C00710B9E71035E71135E71235EC6D7C731E0 +:102F9C00025E1E71025E710A9E31929E02EFFA343D +:102FAC00ECFB3692FF52078B99A5A792DFF9710BB8 +:102FBC009EC6D7C788061631125E1571125EC734CD +:102FCC00B4FB3092FF1652078B99A5A792DFF9C676 +:102FDC0066736718B4FBC6D7C771035E31145E1EE7 +:102FEC0071135E710A9E31929E02EFFA3492FF3693 +:102FFC00B4FB52078B99A5A792DFF9710B9E312474 +:10300C005E1371235E717B9E8FF4FB9E9A8FF5FB92 +:10301C009E9B717A9EC6D7CFBFFB5CCFC0FB5FCFA8 +:10302C00E0FB5DCF14FC36CF15FCC9E5EBFBD7C735 +:10303C00CFBCFB12CFBDFB04CFE4FBFFF5E5FBF5EA +:10304C00E6FBF5E7FBF5E8FB5600664C64DE087220 +:10305C003838FB0086EFF3C6D7C788061617F1E79A +:10306C003403002361E3EDAB332361F8ED5631B14A +:10307C002361E3ED60312561F8ED6F31B1240D0072 +:10308C0061D8EDAB33240B0061F8ED90312361F87E +:10309C00EDD7312361F8EDA4312361F8ED6F3324C2 +:1030AC00060061F8ED4032B12561D8ED5C322400A8 +:1030BC000061F8ED69322361F8EDAB332361F8ED73 +:1030CC008933B12361E3ED8C322361F8ED9D32231A +:1030DC0061F8EDAE322361F8ED9D322361F8EDBF5E +:1030EC00322361F8EDD0322361F8EDDF322361F841 +:1030FC00ED01332361F8ED0D332361F8ED19332322 +:10310C0061F8ED22332402002361E3EDAB3324029A +:10311C000061F8ED2B332361F8ED38332561F8EDC0 +:10312C004433B124060061D8EDAB3324000061F8C0 +:10313C00EDAD332561F8ED503324120061F8ED6AE2 +:10314C00332361F8ED5B33EDAD3334BEFB89615F46 +:10315C0099EDB733304129FD7B3866736718BCFB9A +:10316C00EDB73340C1FB6ADF1440C2FB68DF0E676A +:10317C004C6CDF0930AD41FD7B38713AD5679FC38C +:10318C00FBEDB73367D1DD0D30D13CFD7B3834DC42 +:10319C00FB89616F99EDB733675C02D1DD0830CAEA +:1031AC002AFD7B38EF0C675C01D1DD0630CF2AFDA0 +:1031BC007B38675C3CD1DD1030D42AFD7B38675CF2 +:1031CC003C7266736218BCFBEDB73367D1DD625C91 +:1031DC0001D1DD05300800EF01F6609F1BFC675C38 +:1031EC0002D1DD03E6EF01F6341BFC8961689967B7 +:1031FC005C04D1DD04E6A1EF01F6341BFC896168A7 +:10320C0099675C08D1DD05302000EF01F6341BFC1A +:10321C0089616899675C10D1DD05301000EF01F60B +:10322C00341BFC89616899675C20D161E871601B73 +:10323C00FCEDB733D432DF08679FE5FBA432EF0D0A +:10324C004A3205DE08E83267184BFDA432EDB7337D +:10325C00675C0F7266736218BCFBEDB7334A32645D +:10326C00DE1B4A3201DF0667D161F85701E832678D +:10327C001838FBA4324A320561C871725DEDB73360 +:10328C00675C7F70C117F1243000FDBF2FC0EDB714 +:10329C0033675C3F70C117F1243000FDBF2FC0EDC8 +:1032AC00B733675C0770C117F1243000FDBF2FC026 +:1032BC00EDB733675C1F70C117F1243000FDBF2FD1 +:1032CC00C0EDB7336770C117F1243000FDBF2FC0BC +:1032DC00EDB733CEABAC710A9E31929E02EFFAD5AC +:1032EC0092FFDF05710B9EEFED679E99710B9E9F10 +:1032FC00F3FBEDB73371225E675C7F9FF4FBEDB798 +:10330C003371225E675C3F9FF5FBEDB733675C3F23 +:10331C009FF6FBEDB733675C1F9FF7FBEDB73330C0 +:10332C00883AFD7B38679FFCFBEDB73330433AFDA1 +:10333C007B38679FFDFBEF7330653AFD7B38679FE9 +:10334C0000FCEF67675C01D161E8FD8744EF5C4AE4 +:10335C0038C8DE57E83867186AFAA438EF4D679D0D +:10336C0038EF4867318E247000DD0D240200DF3BFE +:10337C0030EA08FD7B38EF3371625FEF2E675C013A +:10338C00D1DD05711202EF03711302675C02D1DD0E +:10339C0005712202EF03712302679FEBFBEF0CEF29 +:1033AC000A664C5BDE05736718BCFBC6D7C716668E +:1033BC004C30DC094C37DE05FD9A2FEF6E664C0263 +:1033CC00DF1F8FBEFB5C03728F1DFC5C03318E31E3 +:1033DC006D08616A08128F1DFC5C80312A6162EFF6 +:1033EC0059664C3DDF0AAE90BF18FCF918FCEF4A49 +:1033FC00664C3EDF05F919FCEF40664C4FDF05FDCE +:10340C00AF44EF36664C61DF08E838096AFA72EFB0 +:10341C0029664C7FDF05FD473DEF1F664C4EDF0BE9 +:10342C0031745F045210EF12F2EF0F664C5BDC0448 +:10343C0052FFEF06667309BCFB72C6D7C788061627 +:10344C0017F1241000240500DC07244C00DD17EFD5 +:10345C0017717BFA17F104BCFB1489617F99717A9F +:10346C00FA71325EEF02A438C6D7C7C1C1FBF8FFB0 +:10347C004014F903DD064014F904DF2F8C027309A4 +:10348C00C4FB5E0AD1DF248C02318E04BCFB148990 +:10349C006E0A99716207CC0100316207086159010B +:1034AC008C01D1DFF4716307716B271004C6D7CF81 +:1034BC001DFC03F51BFCF51FFCF521FCD7C788068A +:1034CC001617F1E734020025DD3D23DD1725DD1C41 +:1034DC0023DD0523DD2BEF3B71625E679F20FCCD66 +:1034EC003D03EF2F675C839F1DFCEF27675C039FF9 +:1034FC001FFC675C034C0261F8711260FDA246EF81 +:10350C0012679F21FCEF0C6791DF08E0C15012FDA0 +:10351C007634C0C6D7C71617F1E7240000DD2A237E +:10352C00DD1E240300DD0724FB00DD24EF25312202 +:10353C006005308000EF01F6086F1EFC7208EF1971 +:10354C008F1BFCF51BFC72EF1071425F5235EF09BB +:10355C00F2EF066673091AFC72C6D7C71617F1E7A5 +:10356C00240000DD38241000DD1C23DD1C23DD309D +:10357C00240E00DD18241100DD1B240F00DD1224A5 +:10358C003000DD15EF1EE2EF1D5202EF195204EF71 +:10359C00155206EF115205EF0D5207EF09F2EF0627 +:1035AC005203EF0252FFC6D7C731445E3771435EF8 +:1035BC008D3C9FC4FB8D3B9FE3FB3604FDC7D83B82 +:1035CC00FD2937618A70618AFD6E37C0D840F131B0 +:1035DC002F609D3F8D3A4B3FDD0A71525E8D3F9DB2 +:1035EC003ACD3D034A3D05DE09302636FD7B38CD0C +:1035FC003D6BB43D7150F000CE300BCF170006CEB2 +:10360C003106FDAC02717A30710BE3710BE7C6D752 +:10361C008D3F9D3A8D3F9FC5FBD74014F903DF06C4 +:10362C004014F904DF02F2D731545E0D71535E7110 +:10363C00735E8D3F9F2AFCEF3831645E2371635EAD +:10364C0071725ED520FCDF05F52BFCEF0B8F20FC97 +:10365C005002D6A1609F2BFC8F2BFC9F2AFCEF11F4 +:10366C0031745E088F2BFC9F2AFCEF058D3F9F2A3F +:10367C00FC8F2AFC9FC5FBD92AFCFD9936E92AFC54 +:10368C00091C2270C15013FD3E05C0F2D7C7C1C141 +:10369C00FBF8FF8C02D1DF05F520FCEF1A8C024CF5 +:1036AC0005DE06CF20FC02EF0E8C02318E1231FEAD +:1036BC0003311F609F20FC8F2CFC4F20FCDD29CC9C +:1036CC00011F8F20FC9F2CFCCC00008B4C08DE14BF +:1036DC008B730912204F20FCDC058B9C01EF0561DC +:1036EC005900EFE78C019D3E1004C6D7C716710A2E +:1036FC00E7710BE37150F000CE300BCF170006666C +:10370C009E31FDAC02717A30710BE33182E302EF32 +:10371C00FA8D1F7158F000710BE772C6D7C7C1C183 +:10372C00FBF8FF8F14FC4E02DC03F2EF318C024FDE +:10373C0015FCDC0452FFEF268C022F14FC70613157 +:10374C00318D128F15FC2F14FC70613133BDD813E1 +:10375C00FD3D0EBB440001DC03F690BB8B721004E4 +:10376C00C6D7C7C1FBF8FFAC0814A91489708B61CC +:10377C0028706131FDDC4D1344030071FEDC23AC79 +:10378C0008148A04819A04AC08148A044C11DC10C5 +:10379C00A9148B99AC0814CA0200AC0814CA031003 +:1037AC00EF72AC0814CA0400AC0814A914894DDEDD +:1037BC000AAC08148A02819A02EF12AC0814A914FC +:1037CC00894D61D308AC08148A02919A02AC081492 +:1037DC008A03919A03D1DF3CAC08148A024C10DFA7 +:1037EC0010A91489318EA112AC0814A9146299EF96 +:1037FC0017AC08148A024CF0DF0EA91489318EB173 +:10380C0012AC0814A9146299AC0814CA0200AC08D2 +:10381C0014CA0310C0C6D7ED6638717BFAC7D44200 +:10382C0061F831045F2E71045F71215F71035FD405 +:10383C0042DD05B442CEABAC717AFA5600664C0A46 +:10384C00DD1272F3311C790AFDCEFC0061CAFDC594 +:10385C003886EFE9717AFAF2C6D7C75600664C0A79 +:10386C00DE0BF0317E12F6782EFC86EFF0C6D7C751 +:10387C00C1C1FBF8FFCC01008C014C0ADE36717B18 +:10388C00FA8C01F0317E042EFC14A96168DF09ACBE +:10389C0002B9717AFAF2EF1D8C01F0317E12792E99 +:1038AC00FC614902DF06717AFAE2EF09717AFA617A +:1038BC005901EFC4E21004C6D7C72004FBF8FFF689 +:1038CC00422EFC61F8EDA739717BFA9C038C034CFA +:1038DC000ADE3C8C03F0317E042EFC14A96168DFF7 +:1038EC0005717AFAEF29717AFA8C0372F3311C792B +:1038FC002EFCCEFC0061CA629C02D1DF0A8C03F064 +:10390C00317E12E6782EFC717BFA615903EFBECC46 +:10391C000200CC01018C02F0317E042EFC14A96152 +:10392C0068DD788C02F0317E12792EFCE743DF657E +:10393C008C014C0ADE5F8C01F0317E12792EFCE793 +:10394C0043DD4D717BFA8C01F0317E042EFC14A901 +:10395C006168DF186169018C01F0317E12F6782EF6 +:10396C00FC8C024E01DCED717AFAEF2F8C01F031F8 +:10397C007E042EFC14A9128C02F0317E33782EFCBE +:10398C008C01F0317E12E6782EFC615902717AFAC4 +:10399C00615901EF9B615902ED213900F21004C607 +:1039AC00D7C7200CFBF8FF17040600C15006C15006 +:1039BC00A8C15030FDF8021006D2DD1DA042FC401B +:1039CC0042FC08DE03E2EF6B34FCFB895CFC99FDE6 +:1039DC00883A7110CAFBF2EF5A300600C117040680 +:1039EC0000C13001FCFDE44D1004F542FC8FFCFBE2 +:1039FC005C01D1DD264014F903DF205010C180FD9D +:103A0C007634C0C736100571D4C6DE0F17C1500608 +:103A1C00C150A8C15030FDF80210064014F901DD68 +:103A2C00114014F905DD0B8FFCFB5C02D161E8FD44 +:103A3C00B241F2100CC6D7D9FDFBC15030FDD002FB +:103A4C00C0629F00FC7130CDFB8FD5FB5C08D1DFD1 +:103A5C0006716307716B27F2D7D900FCC1D9FFFB44 +:103A6C00C15030FD6A0310047130CDFB8FD5FB5C67 +:103A7C0008D1DF06716307716B27F2D7C72006FBED +:103A8C00F8FF17040500C1E0C1500FC15030FDF81C +:103A9C00021006624C02DF077110CAFBF2EF5F7175 +:103AAC0018CAFBCC03004017F901DF05CC0402EF68 +:103ABC0003CC0410CC05808FFCFB5C03D1DF0871B8 +:103ACC007AD5CC0207EF06717BD5CC022F170402F6 +:103ADC0000C15004C150A0C15030FDA0031006C756 +:103AEC0036100571D4C6DE154014F903DF0F17C16B +:103AFC005006C150A8C15030FDF8021006F2100655 +:103B0C00C6D7D514F9DF03F6BD444014F901DD0D19 +:103B1C00D546FCDD04B046FCD7CF46FC038F14F928 +:103B2C00318FE723DD0B24020024030061C8ED363E +:103B3C003C8F16F931233E301B004644DF0AE0C1AE +:103B4C005010FD7634C0EF1D3077014644DF16501F +:103B5C0002C15010FD7634C0F6464ADF088FE0FBF8 +:103B6C005010D6BD4AF6464ADD36B64A464ADF30D4 +:103B7C0071025DEF2B301B004644DF13F6464CDF21 +:103B8C0018E0C15010FD7634C0C94C5307EF0A3011 +:103B9C007701464461F871025DF6464C61E8B64C1B +:103BAC003144600871335FF6BD44EF1431345F0566 +:103BBC00F6BD44EF0BA644F6464461F8C944FFFF3A +:103BCC00315260194A4605DE16A4464A4605DF0FF7 +:103BDC00A4465004C15010FD7634C0EF02F44631B7 +:103BEC005460194A4805DE16A4484A4805DF0FA45C +:103BFC00485008C15010FD7634C0EF02F448D44947 +:103C0C00DD03B449D7316260174A4705DE14A44777 +:103C1C004A4705DF0DA4475010C1FD7634C0EF02B2 +:103C2C00F4474A470661F8CD4925D7C736100571C8 +:103C3C00D4DE0730AD39FD7B38D24014F903DF1DDB +:103C4C003122070630FC29FD7B3831445F0C71436F +:103C5C005F5080C15012FD7634C0FD783CFDA33C12 +:103C6C0031645F0671635FFD8143C6D78F1DFC5CB9 +:103C7C0001D1DD22D549FCDD04B049FCD7CF49FC8C +:103C8C00098D3E4F48FCDD0E8D3E9F48FC5040C1D7 +:103C9C005012FD7634C0D74014F903DD04F6BD1A7A +:103CAC00D7D5E8FBDF08F6461ADD19B61AD7D9E4E2 +:103CBC00FBF1461ADD0ED9E4FB12AD1A43DE03A666 +:103CCC001AD7B61AD7717BFAC78FDCFB76F5DCFBFB +:103CDC00717AFA5C10D161E871525F665C0FD1DDCC +:103CEC0057665C01D1DD05F514F9EF4C665C02D129 +:103CFC00DD11E0C15003FD412BC0711300711B207D +:103D0C00710303665C04D1DD11711300711B20D5A6 +:103D1C001DFC61F8710303FDBB34665C08D161E8DE +:103D2C007103035005FD40027102035003C1FD41B4 +:103D3C002BC0711A20FDE92AF2C6D7C756FF4A32AA +:103D4C001361C8ED213E8F16F9311505300400EFD3 +:103D5C000F8F16F9314505300500EF04D917F9F12D +:103D6C00609F4CFC8D4E9F4DFC71345CE6613012B3 +:103D7C0071045C61DC31196162629F4EFCE54FFCA1 +:103D8C0031140205308000EF01F6C131346005308A +:103D9C004000EF01F6C2616B08616A08C13134045E +:103DAC0005302000EF01F6C2616B08616A08C13171 +:103DBC00240205300800EF01F6C2616B08616A0845 +:103DCC00C131646005300400EF01F6C2616B08611B +:103DDC006A08C131546004E6A1EF01F6C2616B08B8 +:103DEC00616A08C131446003E6EF01F6C2616B08F9 +:103DFC00616A9F50FCF171240461DC9F4AFCF171F3 +:103E0C00540761DC9F4BFCD832F101041EFD14A950 +:103E1C00148976A4326672C6D7C7FD6F098F14F960 +:103E2C00318FE724000061F8ED014023DD1B236195 +:103E3C00F8ED0B3F2361F8ED873F2361F8EDD03FA0 +:103E4C002361F8EDA140EDFE3F4015F901DF303163 +:103E5C0024601FF64644DD05F544FDEF03A044FD48 +:103E6C004044FD65DC0FF6BD44F514F971025FEDBD +:103E7C002641FDA223AD44440A0061D8ED264171D0 +:103E8C00325FFDC80471535CFDA2234017F903DFB8 +:103E9C000971025FF514F9ED2641FD102640C9FBAE +:103EAC009BDE0D3124600971025FF514F9ED26419A +:103EBC00714A277140110571301105713A22715AFE +:103ECC002271501105FD4629D2DD0971025FF514EE +:103EDC00F9ED264171103500CF37001D71401205E8 +:103EEC004015F901DD064015F903DF05F5E5FBEF9B +:103EFC0004CFE5FB03CF14F902FD2C29ED2641FD7F +:103F0C00242CFD802C714A9DFDBB34FD3B30F537D4 +:103F1C00FF712BE0F515F971025FCBE43FEFCBE6B7 +:103F2C00F6F0FDC804713BD47112027123028F1696 +:103F3C00F93105285004FD522B625C03318E315D42 +:103F4C0034CBFB896168995002FD522BD2DD06718E +:103F5C0070CBFBEF047178CBFBFDA223FD372D71E9 +:103F6C000816F9CF14F9038FBEFB5C02D1DD0950A2 +:103F7C0080C15010FD7634C0ED2641FD28413154EE +:103F8C005F2FA450D450DD0831A4E00A31020C0696 +:103F9C00712BE0FD9E4131A4E01731040C13712B01 +:103FAC00E05027C15005FD412BC0CF14F90471021C +:103FBC005FFD93418F16F931250731246003F51409 +:103FCC00F9ED2641FD284131020C14F0C15005FDDC +:103FDC00412BC05005FD4002FD9E41CF14F903FD5D +:103FEC0093418F16F931250731246003F514F9ED4F +:103FFC002641F514F9CFE5FB03F5E6FBF5E8FB717B +:10400C00525DF6426CFF61E8ED2641F6BD4A710344 +:10401C005DF5FCFBFD883AFD9D2DFD772CFDD52C27 +:10402C00714B9D711302712302F5CCFBF5CDFBF5A1 +:10403C00CEFBF5CFFB31245D02EFFACE3708CBE493 +:10404C00BFFFCBE6FFF3CED4FFCF37000971481288 +:10405C0005F6BEE0BEE2BED0716A27FDBE297143F3 +:10406C0007714B27714810057148110571381005FF +:10407C0071381105713302713B22715302715B224D +:10408C007158100571581105CF14F90571325FF68E +:10409C00BD44FD3D0AF515F9F544FD31246004D409 +:1040AC002ADD2371335FE515F9E514F98F16F93123 +:1040BC002568F510FCF50EFC502EFD4002CF15F9CD +:1040CC0003E514F9EF54FD2405FD3B2371730171D5 +:1040DC00320471430271035C71525C31949E02EFA5 +:1040EC00FA712AE7CEA409F5F3003124600261FDD0 +:1040FC00F442FD6F09E5F300CEA40831226006CF2F +:10410C0014F905EF0971335FE515F9E514F9712B15 +:10411C00E78F16F9312503F514F9C6D7D552FCDF14 +:10412C001A310200155003FD522B625C01D1DF07DE +:10413C00F514F971025FD7E552FCD74052FCF0DF61 +:10414C000831040041F552FCD74052FCC8DF0BF596 +:10415C0014F971025FCF52FCF0D73102000A4052C1 +:10416C00FCFFDD22A052FCD7F0C15004FD412BC056 +:10417C008FCBFB5C9F9FCBFB7110DCFB30D13CFDEC +:10418C007B38CF52FCF0D731045D06F514F971027F +:10419C005FD771535FF450717207FDAC02717307F6 +:1041AC00D7FD8505F2D7717BFAC7200CFBF8FF8F82 +:1041BC0002FCF0F901FCF303FDDC4D13BC048F048D +:1041CC00FCF0F903FCF303FDDC4D13BC028F06FC81 +:1041DC00F0F905FCF303FDDC4D13BB717AFAAC046A +:1041EC00BDD8F6BDDAAC04311EBDDCF6BDDEFDF08B +:1041FC000DADD8BDDCADDABDDEAC02BDD8F6BDDA96 +:10420C00AC02311EDADCC3DADEC3BDDCF6BDDEFD8A +:10421C00F00DC0BDDEC0BDDCADDEFD660FADD8BDA2 +:10422C00DCADDABDDEABBDD8F6BDDAAB311EDADC07 +:10423C00C3DADEC3BDDCF6BDDEFDF00DC0BDDEC0F5 +:10424C00BDDCADDEFD660FDADAADD8FD9D45C3C52C +:10425C008FECFC5C3FF0317E046CFC14C2C0B9A046 +:10426C00ECFCF6BC08BC0A9C078C074C2EDD3E8F80 +:10427C00ECFC0E0770F161DC605C3FF0317E127972 +:10428C006CFCBDD8F6BDDA8C0773095C22318FBD8E +:10429C00DC70BDDEFDF00DAC08BDDCAC0AFD660FBC +:1042AC00ADDABC0AADD8BC08615907EFBCAC08BD8F +:1042BC00D8AC0ABDDAC9DC0004F6FDBA0EC9DCFFC5 +:1042CC00FFF6FDBB0FADD8BF66FCAF60FC4266FCD1 +:1042DC00DD12AF62FCBF64FCAF60FCBF62FCAF667A +:1042EC00FCBF60FCAF62FC4264FCDC50AF60FC4283 +:1042FC0062FCDE48AF46FD4260FCDE40404AFD16E3 +:10430C00DC1F404AFDA0DE168F68FC4F4AFDDE0E16 +:10431C00AF60FC226AFC44691061C8FD8143F54A18 +:10432C00FDAF60FC445146DC0BAF60FC241027BF92 +:10433C0048FDEF1130F82ABF48FDEF09404AFDFF58 +:10434C0061E8A04AFDAF64FC4262FCDC1BAF62FC7E +:10435C004260FCDE13AF60FC4248FDDE0BF568FCEE +:10436C00AF60FCBF6AFCEF094068FCFF61E8A06825 +:10437C00FC100CC6D7717BFAC7710A9E31929E0253 +:10438C00EFFA8E949F5AFC8E969F5BFC8E979F5CE7 +:10439C00FC8E989F5DFC8E939F5EFC8E929F5FFCC3 +:1043AC00710B9E717AFA8F5DFCFDCF0F76FD1B456C +:1043BC0013BD56D507FCDF0AD508FCDF05D509FC73 +:1043CC00DD25F6B14656DF11C9563722665C0391DE +:1043DC00DF060A56181A57009617FD3E4613FD596C +:1043EC004431745F02EF6152069292695AFC685430 +:1043FC00FCDFF6AD56BD54F852F3311C791AF94472 +:10440C00FEFFDD44D852F101041AF914A944FFFF50 +:10441C00DF04E6B9EF0BD852F101041AF914A9A183 +:10442C00B9717BFAA007FCD507FCDF1CA008FCD5F2 +:10443C0008FCDF14A009FCD509FCDF0CCF07FCFF3E +:10444C00CF08FCFFCF09FCFFC6717AFAD7C716D884 +:10445C0052F10744A800DC0571725FEF1CF647DDD2 +:10446C0018A4524A52A8DC0571725FEF0CF852F393 +:10447C00311CF6781AF9B7EFE4C6D7C756A896667A +:10448C00F0317E12F6B1781AF966D1DFF1717BFA50 +:10449C00F507FCF508FCF509FCF45271735FC67165 +:1044AC007AFAD7C72004FBF8FFD432DF178D529F5E +:1044BC00EDFC717BFA520692926954FC68EEFCDFBB +:1044CC00F6717AFA4A3206DE0EE83209EEFC9C03EB +:1044DC00A4328C0372EF34F9EDFCF3311C791AF928 +:1044EC00BB310260058B9C03EF128C019C03D5ED54 +:1044FC00FCDF06CFEDFCA7EF03B0EDFC718071077C +:10450C006061DC61FB7101608C03721004C6D7C75B +:10451C002008FBF8FF8F5DFCFDCF0F9C078F5CFC28 +:10452C00FDCF0F9C068F5BFCFDCF0F9C058F5AFCBB +:10453C00FDCF0F9C048F5EFC9C038F5FFC9C028C58 +:10454C0006318E0112791A20BB8C075C03D1DF096E +:10455C008C064C0361C86179008C05318EB1610900 +:10456C0000BB313D120103BB8B0E04708C011C008F +:10457C00BB8F0CFC4E03DC0E8C034F0CFCDC0B8C49 +:10458C00024F0DFCDC04AB12EF03ABB1121008C6EA +:10459C00D7C7C3C12008FBF8FFF661490A61F8616F +:1045AC004908DF07F7340000ED3A46E6BC04F6BCD8 +:1045BC0006AC0ABC02AC08BBAC06614902AC046197 +:1045CC00F8614900DE28AC04BDD8AC06BDDAE1FDCB +:1045DC00750FADDABC06ADD8BC04ABBDD8AC02BD12 +:1045EC00DAE1FD900FADDABC02ADD8BBEFCAAC0678 +:1045FC00BC02AC04BBAC08BDD8AC0ABDDAAC04BD83 +:10460C00DCAC06FDF30EAC04BDDCAC06FD660FE1C4 +:10461C00FD900FADDABC06ADD8BC04AC0661490206 +:10462C00AC0461F8614900DCC5AC0214AB12100C8F +:10463C00C6D7C7C12004FBF8FF8F57FCFDCF0F9CDA +:10464C00034E04DF1CAD544656DE07AD56265412FD +:10465C00EF40F64656DF074654DD03E7EF34F7EF3D +:10466C00318C04318EB1128C03318E43DF1830380B +:10467C002226540656BB8C045C0391DF05AB041850 +:10468C0000BBAB12EF0C8C034E04DE0532A900EF1D +:10469C0001F71006C6D7717BFA31126009F646583D +:1046AC00DD04B658EF7C711360717AFA4014F9048A +:1046BC00DF07715307F424EF69D9E7FBF1E7240016 +:1046CC0000DD0F23DD1A23DD1023DD5323DD27232B +:1046DC00DD38715307F424EF49715207F424EF428B +:1046EC00D424DF07715207E424EF05715307F42437 +:1046FC00C958FA00EF2CD424DF0B715207E424C9FB +:10470C0058FA00EF1DF5E7FBEF18D424DF0B7153BB +:10471C0007E424C958FA00EF09CFE7FB02EF03FDC9 +:10472C002F47D7D91FFCF1E7240000DD0923DD2139 +:10473C0023DD0923EF1B715307F424D7D424DF079F +:10474C00715207E424EF05715307F424C9582D0165 +:10475C00D7715207E424D731425D01D771635DD91B +:10476C00E5FBF1E7240000DD1223DD1923DD112325 +:10477C00DD2623DD3423DD3923DD3FFDEF47EF3D1F +:10478C00FD1048EF38D9E4FBC1AE6CFDDE2CC0F354 +:10479C0013BE6C712304EF25F0C1AE6CFDDE2CC092 +:1047AC00F313BE6C712304EF14F6BE6C712204EF8C +:1047BC000CCB6CFF00712304EF03FD84484014F90B +:1047CC0005DD064014F901DF0671230471635D31C8 +:1047DC00645D0FF6BE64BE6A31220402EF02F690ED +:1047EC00BE6ED7CD2647F45AAE6C317DBFFAFCFDB8 +:1047FC005948D2DF0ED9E4FBC1AE6CFDDE2CC0F300 +:10480C0013BE6CD7FD5948D2DD0DCD2647F45AAEF8 +:10481C006C317DBFFAFCD7E85A0934205080D6BFE2 +:10482C00F6FC22FAFCBDD8304700FD1B0EBFF8FC8D +:10483C0030F6FCFDF42CF313BE6CB426D426DF0C3E +:10484C00CD2647A45A4A5A1F61C8F45AD740C7FB11 +:10485C000BDC05712304F2D740C7FB0661D831226B +:10486C005C11F0C1AE6CFDDE2CC0F313BE6C71227A +:10487C0004EF03FD8448E2D771625DF0C1AE6CFDBC +:10488C00DE2CC0F313BE6CA0FCFC40FCFC40DC3DF9 +:10489C00F5FCFCD9FDFCF1313F044CFD14D9FDFCB9 +:1048AC00F1BDD85008FD6A0E087208E6D2DD04018D +:1048BC0092DFFC896158D1DD05712204EF0371236D +:0E48CC0004A0FDFC40FDFC2061C8F5FDFCD7FA +:1048DA0061FC61FCC1C3C5C7520C929269D4FEC186 +:1048EA00DFF88EFD708EFCC1717AFA4014F903DF8D +:1048FA000630FC29FD7B38C09EFC609EFD34D4FE48 +:10490A005206C0B9A5A592DFF9C6C4C2C061FC614E +:10491A00DF520C929269D4FEC1DFF88EFD708EFCD4 +:10492A00C18F4105775C04D1DD06675C01D1DD509A +:10493A0031345E3671620771335E8FCCFB5FD4FB14 +:10494A00D1DF1B8FCDFB5FD5FBD1DF128FCEFB5F93 +:10495A00D6FBD1DF098FCFFB5FD7FBD1DD0C3162EC +:10496A000702EFFA716307716B27710360FDE42F89 +:10497A00F4227148500571605005717AFAED874A40 +:10498A00675C02D1DD16D422DD124A2202DD0DF463 +:10499A00227148500571605005717AFA717AFA8D60 +:1049AA0022318FE7240000DD0823DD1423DD31EFF7 +:1049BA0050F4327140500571505005E422ED874A97 +:1049CA008F40059F10F9715050058F10F99F12F909 +:1049DA00D910F9FDB933629F11F9CD2202ED874A48 +:1049EA00675C02D1DD18675C10D1DD05CD2203EFCB +:1049FA00107148500571605005F422ED874ACD22A6 +:104A0A00044A2203DF138F11F99F4005D911F9C116 +:104A1A00D910F9FD4834C0EF228F4005768F10F97E +:104A2A0001DC064010F902DE0671605005EF4EC740 +:104A3A00D910F9FD6530C071505005D912F9F12429 +:104A4A002900DD2A240400DD25242200DD2024118A +:104A5A0000DD0C240100DD16241E00DD11EF0C40E0 +:104A6A0010F960DF09CF10F961EF03A010F94A22AB +:104A7A0003DF0AD910F9FDB933629F11F9C09EFC10 +:104A8A00609EFD34D4FE5206C0B9A5A592DFF96135 +:104A9A00FCC1C7717AFA714AE5717BBD51405F0466 +:104AAA0001D1DD06F616A747DFF2300400BF240164 +:104ABA00F6BF2A01300B0BBF2801000000000000DE +:104ACA000000510FBF280100000000000000005044 +:104ADA000FBF2801710AE671235DC6C061FCC1C51A +:104AEA00717AFAD436DD0BEA34899E44A634B43698 +:104AFA00EF33710AE6300400BF2401F6BF2A013001 +:104B0A000B0BBF28010000000000000000510FBF7E +:104B1A0028010000000000000000500FBF280171AA +:104B2A00135D71235DC4C061FC61EF520C929269FE +:104B3A00D4FEC1DFF88EFD708EFCC12006FBF8FFA3 +:104B4A0071503002CEABACCC0400F6BB31B2E210ED +:104B5A00617900F6614900DFF371603002EDED4BD7 +:104B6A008E519C03713BE28C035C02D1DD1E8C03E7 +:104B7A005C08D1DF0971503002CC0400EFCC8C05FF +:104B8A0070FD2135629E50CC0402EFBE8C035C039B +:104B9A00D1DF408E509C02715030028C04D1DF0E5E +:104BAA008C0270FD6735629C05CC0401EF328C04DF +:104BBA004C02DF0671603002EF29CF34025A71606D +:104BCA0030028C0270C18C0570FDC934C0CF34022A +:104BDA004AEF108C035C01D1DD0671603002EF03ED +:104BEA00ED544B1006C09EFC609EFD34D4FE520666 +:104BFA00C0B9A5A592DFF961FCC1C3C5C7520C9221 +:104C0A009269D4FEC1DFF88EFD708EFCC1710A9ED6 +:104C1A0031929E02EFFA8FF6FB4F96FFDF198FF75C +:104C2A00FB4F97FFDF118FF8FB4F98FFDF09500406 +:104C3A00C15011FD7634C0710B9EC09EFC609EFD72 +:104C4A0034D4FE5206C0B9A5A592DFF9C6C4C2C0C3 +:104C5A0061FCA44261FCC1C3C5C7520C929269D4DB +:104C6A00FEC1DFF88EFD708EFCC1C1FBF8FF8D1FFF +:104C7A009C018E31318EE7240600DD0823DD0E23E8 +:104C8A00DD22EF39717AFA8C019D3CEF30717AFAA4 +:104C9A004017F901DF068C019D3BEF2151FF2E01E0 +:104CAA009D3BEF19717AFA8C019D284014F903DDB6 +:104CBA00064014F904DF06306425FD7B384031FFD5 +:104CCA0009DE05A031FFEF077158F00071425E71ED +:104CDA000BE3C0C09EFC609EFD34D4FE5206C0B9F0 +:104CEA00A5A592DFF9C6C4C2C061FC61FF520C924D +:104CFA009269D4FEC1DFF88EFD708EFCC1717AFA1A +:104D0A008FFCFB5C03D1DD194014F903DD06401466 +:104D1A00F904DF0D36100571D4DE0630AD39FD7B9E +:104D2A0038C09EFC609EFD34D4FE5206C0B9A5A5CB +:104D3A0092DFF961FC61FC61FC61FC61FC61FC6170 +:104D4A00FC61FC61FC61FC61FC61FC61FC61FC6171 +:104D5A00FC61FC61FC61FC61FC61FC61FC61FC6161 +:0D4D6A00FC61FC61FC61FC61FC61FC61FC12 +:0A4D780000060C12181E242A303623 +:104D8200C4FB0000000040FE000000000E3BB435F2 +:104D92008C226347B52D702EA246373CF808253E7B +:104DA2004CFC2EFE20FE02F903F94DFC28FE4EFCBF +:104DB2004FFC18F94AFC6CFF1AFF6EFF6AFF64FF92 +:104DC2004BFC66FF50FC0000983AF82AFF0055554C +:024DD200555535 +:084DD400FF0000000000470091 +:104DDC00317503F7332312D714AEF8C716AC06128D +:104DEC00C5AC0416F643DD078B99A7A5B3EFF5C246 +:024DFC00C6D718 +:024FF4000204B5 +:0A4FF60030393A31343A3135000009 +:00000001FF + \ No newline at end of file diff --git a/tags/2.04/bsr.lmf b/tags/2.04/bsr.lmf new file mode 100644 index 0000000000000000000000000000000000000000..155865fb662db274da658b3a345644513cf3fcce GIT binary patch literal 177376 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�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 chip erase command disabled, otherwise enabled */ +/* bit_1 = 0 -> block erase command disabled, otherwise enabled */ +/* bit_2 = 0 -> write command disabled, otherwise enabled */ +/* bit_4 = 0 -> boot-area re-programming disabled, otherwise enabled */ +/* bit_8...bit_15 = 03H -> last block of the boot-area */ +/* other bits = 1 */ +/* Output: - */ +/* Changed: content of the data_buffer */ +/* Returned: fsl_u08, status code */ +/* = 0x00(FSL_OK), normal */ +/* = 0x05(FSL_ERR_PARAMETER), parameter error */ +/*----------------------------------------------------------------------------------------------*/ +extern fsl_u08 FSL_GetSecurityFlags( fsl_u16 * destination_pu16 ); + + +/*----------------------------------------------------------------------------------------------*/ +/* Block type: FSL command function */ +/*----------------------------------------------------------------------------------------------*/ +/* Purpose: read the boot flag i */ +/* Input: destination_pu08 - destination address of the bootflag info */ +/* The format of the boot-flag info is: "unsigned char" */ +/* The value of the boot info is 0x00 for cluster 0 and 0x01 for cluster 1. */ +/* Output: - */ +/* Changed: content of the data_buffer */ +/* Returned: fsl_u08, status code */ +/* = 0x00(FSL_OK), normal */ +/* = 0x05(FSL_ERR_PARAMETER), parameter error */ +/*----------------------------------------------------------------------------------------------*/ +extern fsl_u08 FSL_GetActiveBootCluster( fsl_u08 * destination_pu08 ); + + +/*----------------------------------------------------------------------------------------------*/ +/* Block type: FSL command function */ +/*----------------------------------------------------------------------------------------------*/ +/* Purpose: puts the last address of the specified block into *destination_pu32 */ +/* Input: *destination_pu32 - destination where the last-block-address */ +/* should be stored */ +/* block_u16 - block number of the last address is needed */ +/* Changed: - */ +/* Returned: fsl_u08, status code */ +/* = 0x00(FSL_OK), normal */ +/* = 0x05(FSL_ERR_PARAMETER), parameter error */ +/*----------------------------------------------------------------------------------------------*/ +extern fsl_u08 FSL_GetBlockEndAddr( fsl_u32 * destination_pu32, + fsl_u16 block_u16 ); + + +/*----------------------------------------------------------------------------------------------*/ +/* Block type: FSL command function */ +/*----------------------------------------------------------------------------------------------*/ +/* Purpose: puts the information about the protected flash area into the function parameter */ +/* Input: *start_block_pu16 - destination where the FSW start block should be stored */ +/* *end_block_pu16 - destination where the FSW end block should be stored */ +/* Changed: - */ +/* Returned: fsl_u08, status code */ +/* = 0x00(FSL_OK), normal */ +/* = 0x05(FSL_ERR_PARAMETER), parameter error */ +/*----------------------------------------------------------------------------------------------*/ +extern fsl_u08 FSL_GetFlashShieldWindow( fsl_u16 * start_block_pu16, + fsl_u16 * end_block_pu16 ); + + +/*----------------------------------------------------------------------------------------------*/ +/* Block type: FSL command function */ +/*----------------------------------------------------------------------------------------------*/ +/* Purpose: defines a new Flash-Shield-Window area inside the flash memory */ +/* Input: start_block_u16 - starting block of the Flash-Shield-Window (FSW) */ +/* end_block_u16 - ending block of the flash-Shield-Window (FSW) */ +/* Changed: - */ +/* Returned: fsl_u08, status code */ +/* = 0x00(FSL_OK), normal */ +/* = 0x05(FSL_ERR_PARAMETER), parameter error */ +/* = 0x10(FSL_ERR_PROTECTION), protection error */ +/* = 0x1A(FSL_ERR_ERASE), erase error */ +/* = 0x1B(FSL_ERR_IVERIFY), internal verify error */ +/* = 0x1F(FSL_ERR_INTERRUPTION), write interrupted by user interrupt */ +/*----------------------------------------------------------------------------------------------*/ +extern fsl_u08 FSL_SetFlashShieldWindow( fsl_u16 start_block_u16, + fsl_u16 end_block_u16 ); + + +/*----------------------------------------------------------------------------------------------*/ +/* Block type: FSL command function */ +/*----------------------------------------------------------------------------------------------*/ +/* Purpose: Swapping of bootcluster 0 and 1 */ +/* */ +/* CAUTION !!!! */ +/* After this function the boot cluster are immediately swapped */ +/* Input: - */ +/* Output: - */ +/* Returned: fsl_u08, status code */ +/* = 0x00(FSL_OK), normal */ +/* = 0x05(FSL_ERR_PARAMETER), parameter error */ +/* = 0x10(FSL_ERR_PROTECTION), protection error */ +/* = 0x1A(FSL_ERR_ERASE), erase error */ +/* = 0x1B(FSL_ERR_IVERIFY), internal verify error */ +/* = 0x1F(FSL_ERR_INTERRUPTION), write interrupted by user interrupt */ +/*----------------------------------------------------------------------------------------------*/ +extern fsl_u08 FSL_SwapBootCluster( void ); + + +/*----------------------------------------------------------------------------------------------*/ +/* Block type: FSL command function */ +/*----------------------------------------------------------------------------------------------*/ +/* Purpose: sets specified security flag by dedicated command-function. */ +/* */ +/* There are following security levels: */ +/* a) chip-erase protection (cannot be reset by programmer !!!) */ +/* b) block-erase protection (can be reset by chip-erase on programmer) */ +/* c) write protection (can be reset by chip-erase on programmer) */ +/* d) boot-cluster protection (cannot be reset by programmer !!!) */ +/* */ +/* CAUTION !!!! */ +/* Each security flag can be written by the application only once */ +/* */ +/* Input: - */ +/* Output: - */ +/* Returned: fsl_u08, status code */ +/* = 0x00(FSL_OK), normal */ +/* = 0x05(FSL_ERR_PARAMETER), parameter error */ +/* = 0x10(FSL_ERR_PROTECTION), protection error */ +/* = 0x1A(FSL_ERR_ERASE), erase error */ +/* = 0x1B(FSL_ERR_IVERIFY), internal verify error */ +/* = 0x1F(FSL_ERR_INTERRUPTION), write interrupted by user interrupt */ +/*----------------------------------------------------------------------------------------------*/ +extern fsl_u08 FSL_SetChipEraseProtectFlag( void ); +extern fsl_u08 FSL_SetBlockEraseProtectFlag( void ); +extern fsl_u08 FSL_SetWriteProtectFlag( void ); +extern fsl_u08 FSL_SetBootClusterProtectFlag( void ); + + +/*----------------------------------------------------------------------------------------------*/ +/* Block type: FSL function */ +/*----------------------------------------------------------------------------------------------*/ +/* Purpose: defines the firmware operation method after interrupt service (ISR) execution. */ +/* Input: mode_u08 = 0x00, after RETI the firmware is continuing the interrupted command.*/ +/* = other, after RETI the firmware is interrupted with status 0x1F. */ +/* Changed: - */ +/* Returned: - */ +/*----------------------------------------------------------------------------------------------*/ +extern void FSL_SetInterruptMode( fsl_u08 mode_u08 ); + +#endif diff --git a/tags/2.04/fsl_user.h b/tags/2.04/fsl_user.h new file mode 100644 index 0000000..1018689 --- /dev/null +++ b/tags/2.04/fsl_user.h @@ -0,0 +1,113 @@ +/*==============================================================================================*/ +/* Project = Selfprogramming library for 78K0R/Ix3/Kx3-L Single Voltage SST (MF2) Flash */ +/* Module = fsl_user.h */ +/* Version = V1.01 */ +/* Date = 28.03.2008 11:45:55 */ +/*==============================================================================================*/ +/* COPYRIGHT */ +/*==============================================================================================*/ +/* Copyright (c) 2007 by NEC Electronics (Europe) GmbH, */ +/* a company of the NEC Electronics Corporation */ +/*==============================================================================================*/ +/* Purpose: */ +/* user configurable constant/macros of the selfprogramming library */ +/* */ +/*==============================================================================================*/ +/* */ +/* Warranty Disclaimer */ +/* */ +/* Because the Product(s) is licensed free of charge, there is no warranty of any kind */ +/* whatsoever and expressly disclaimed and excluded by NEC, either expressed or implied, */ +/* including but not limited to those for non-infringement of intellectual property, */ +/* merchantability and/or fitness for the particular purpose. NEC shall not have any obligation */ +/* to maintain, service or provide bug fixes for the supplied Product(s) and/or the Application.*/ +/* */ +/* Each User is solely responsible for determining the appropriateness of using the Product(s) */ +/* and assumes all risks associated with its exercise of rights under this Agreement, */ +/* including, but not limited to the risks and costs of program errors, compliance with */ +/* applicable laws, damage to or loss of data, programs or equipment, and unavailability or */ +/* interruption of operations. */ +/* */ +/* Limitation of Liability */ +/* */ +/* In no event shall NEC be liable to the User for any incidental, consequential, indirect, */ +/* or punitive damage (including but not limited to lost profits) regardless of whether */ +/* such liability is based on breach of contract, tort, strict liability, breach of warranties, */ +/* failure of essential purpose or otherwise and even if advised of the possibility of */ +/* such damages. NEC shall not be liable for any services or products provided by third party */ +/* vendors, developers or consultants identified or referred to the User by NEC in connection */ +/* with the Product(s) and/or the Application. */ +/* */ +/*==============================================================================================*/ +/* Environment: PM plus (V6.30) */ +/* RA78K0(V1.20) */ +/* CC78K0(V2.00) */ +/*==============================================================================================*/ + + +#ifndef __FSL_USER_H_INCLUDED +#define __FSL_USER_H_INCLUDED + + +/*==============================================================================================*/ +/* constant definitions */ +/*==============================================================================================*/ + + +/* specify the CPU frequency in [Hz], only 2MHz....20MHz allowed */ +#define FSL_SYSTEM_FREQUENCY 8000000 + +/* define whether low-voltage mode is used or not */ +/* #define FSL_LOW_VOLTAGE_MODE */ + +/* size of the common data buffer expressed in [bytes] */ +/* the data buffer is used for data-exchange between the firmware and the selflib. */ +//#define FSL_DATA_BUFFER_SIZE 256 +#define FSL_DATA_BUFFER_SIZE 0 + + +/* customizable interrupt controller configuration during selfprogramming period */ +/* Bit --7-------6-------5-------4-------3-------2-------1-------0---------------------- */ +/* MK0L: PMK5 PMK4 PMK3 PMK2 PMK1 PMK0 LVIMK WDTIMK */ +/* MK0H: SREMK0 SRMK0* STMK0* DMAMK1 DMAMK0 SREMK3 SRMK3 STMK3 */ +/* MK1L: TMMK03 TMMK02 TMMK01 TMMK00 IICMK0 SREMK1 SRMK1 STMK1* */ +/* MK1H: TMMK04 SREMK2 SRMK2 STMK2* KRMK RTCIMK RTCMK ADMK */ +/* MK2L: PMK10 PMK9 PMK8 PMK7 PMK6 TMMK07 TMMK06 TMMK05 */ +/* MK2H: 1 1 1 1 1 1 1 PMK11 */ +/*------------------------------------------------------------------------------------------ */ +/* */ +/* Examples: */ +/* ========= */ +/*#define FSL_MK0L_MASK 0xF7 -> allow INTP1 interrupt during selfprogramming */ +/*#define FSL_MK0H_MASK 0xEF -> allow DMA1 interrupt during selfprogramming */ +/*#define FSL_MK1L_MASK 0xBF -> allow TM02 interrupt during selfprogramming */ +/*#define FSL_MK1H_MASK 0xFF -> all interrupts disabled during selfprogramming */ +/*#define FSL_MK2L_MASK 0xF7 -> allow INTP6 interrupt during selfprogramming */ +/*#define FSL_MK2H_MASK 0xFF -> all interrupts disabled during selfprogramming */ +/*------------------------------------------------------------------------------------------ */ +#define FSL_MK0L_MASK 0xFF /* all interrupts disabled during selfprogramming */ +#define FSL_MK0H_MASK 0xFF /* all interrupts disabled during selfprogramming */ +#define FSL_MK1L_MASK 0xFF /* all interrupts disabled during selfprogramming */ +#define FSL_MK1H_MASK 0xFF /* all interrupts disabled during selfprogramming */ +#define FSL_MK2L_MASK 0xFF /* all interrupts disabled during selfprogramming */ +#define FSL_MK2H_MASK 0xFF /* all interrupts disabled during selfprogramming */ + + +/* FLMD0 control bit */ +#ifndef _WIN32 +#define FSL_FLMD0_HIGH {BECTL.7 = 1;} +#define FSL_FLMD0_LOW {BECTL.7 = 0;} +#else +#define FSL_FLMD0_HIGH {BECTL_7 = 1;} +#define FSL_FLMD0_LOW {BECTL_7 = 0;} +#endif + + +/*----------------------------------------------------------------------------------------------*/ +/* switch interrupt backu functionality ON/OFF using #define/#undef */ +/*----------------------------------------------------------------------------------------------*/ +/* #define FSL_INT_BACKUP */ +#undef FSL_INT_BACKUP + + +#endif diff --git a/tags/2.04/hal.c b/tags/2.04/hal.c new file mode 100644 index 0000000..75e1385 --- /dev/null +++ b/tags/2.04/hal.c @@ -0,0 +1,171 @@ +#ifndef _WIN32 +#pragma SFR +#endif + +#include "incs_loader.h" + + +#define WIFI_txLatch PIF21 // dgMpX { led.h Œ` + + +// HALłԂ //////////////////////////////////////// +// ȎȂ琳_ɂr...≽łȂ +bit PM_EXTDC_n; +bit BT_IN_CHG_n; +bit SW_POW_n; +bit SW_HOME_n; +bit SW_WIFI_n; +bit SHELL_OPEN; + +/* +#define REG_BIT_HAL0_PM_EXTDC_n ( 1 << 7 ) +#define REG_BIT_HAL0_BT_IN_CHG_n ( 1 << 6 ) +//#define REG_BIT_HAL0_PM_IRQ_n ( 1 << 5 ) // gȂ +#define REG_BIT_HAL0_WL_TX ( 1 << 4 ) +#define REG_BIT_HAL0_SHELL_OPEN ( 1 << 3 ) +#define REG_BIT_HAL0_SW_WIFI_n ( 1 << 2 ) +#define REG_BIT_HAL0_SW_HOME_n ( 1 << 1 ) +#define REG_BIT_HAL0_SW_POW_n ( 1 << 0 ) + +#define REG_BIT_HAL1_DIPSW_1 ( 1 << 3 ) +#define REG_BIT_HAL1_DIPSW_0 ( 1 << 2 ) +#define REG_BIT_HAL1_HW_DET_1 ( 1 << 1 ) +#define REG_BIT_HAL1_HW_DET_0 ( 1 << 0 ) +*/ + + +// ڂւ +// `^OȂ炱ł(ԃJEg͕) +void hal_update() +{ + u8 temp_conf = vreg_ctr[ VREG_C_HAL_OVW_CONT0 ]; + u8 temp_dat = vreg_ctr[ VREG_C_HAL_OVW_DAT0 ]; + + // A_v^L + if( temp_conf & REG_BIT_HAL0_PM_EXTDC_n ) + { + // O͂Ȃ񂾂傫Ȃ肪 + if(( temp_dat & REG_BIT_HAL0_PM_EXTDC_n ) == 0 ) + { + PM_EXTDC_n = 0; + } + else + { + PM_EXTDC_n = 1; + } + } + else + { + PM_EXTDC_n = PM_EXTDC_n_RAW; + } + + // [dH + if( temp_conf & REG_BIT_HAL0_BT_IN_CHG_n ) + { + if(( temp_dat & REG_BIT_HAL0_BT_IN_CHG_n ) == 0 ) + { + BT_IN_CHG_n = 0; + } + else + { + BT_IN_CHG_n = 1; + } + } + else + { + BT_IN_CHG_n = BT_IN_CHG_n_RAW; + } + + // dt + if( temp_conf & REG_BIT_HAL0_SW_POW_n ) + { + if(( temp_dat & REG_BIT_HAL0_SW_POW_n ) == 0 ) + { + SW_POW_n = 0 ; + } + else + { + SW_POW_n = 1; + } + } + else + { + SW_POW_n = SW_POW_n_RAW; + } + + // Ɩt + if( temp_conf & REG_BIT_HAL0_SW_HOME_n ) + { + if(( temp_dat & REG_BIT_HAL0_SW_HOME_n ) == 0 ) + { + SW_HOME_n = 0; + } + else + { + SW_HOME_n = 1; + } + } + else + { + if( system_status.model == MODEL_TS_BOARD )// ڑ̃|[gႤ + { + SW_HOME_n = SW_HOME_n_TSBOARD_RAW; + } + else + { + SW_HOME_n = SW_HOME_n_JIKKI_RAW; + } + } + + // J + if( temp_conf & REG_BIT_HAL0_SW_WIFI_n ) + { + if(( temp_dat & REG_BIT_HAL0_SW_WIFI_n ) == 0 ) + { + SW_WIFI_n = 0; + } + else + { + SW_WIFI_n = 1; + } + } + else + { + SW_WIFI_n = SW_WIFI_n_RAW; + } + + // + if( temp_conf & REG_BIT_HAL0_SHELL_OPEN ) + { + if(( temp_dat & REG_BIT_HAL0_SHELL_OPEN ) == 0 ) + { + SHELL_OPEN = 0; + } + else + { + SHELL_OPEN = 1; + } + } + else + { + SHELL_OPEN = SHELL_OPEN_RAW; + } + + // dg + if( temp_conf & REG_BIT_HAL0_WL_TX ) + { + WIFI_txLatch = 1; + } + +} + + + +void hal_reset() +{ + vreg_ctr[ VREG_C_HAL_OVW_CONT0 ] = 0; + vreg_ctr[ VREG_C_HAL_OVW_CONT1 ] = 0; + vreg_ctr[ VREG_C_HAL_OVW_TEMPERATURE ] = 0xFF; + vreg_ctr[ VREG_C_HAL_OVW_BT_FUEL ] = 0xFF; + vreg_ctr[ VREG_C_HAL_OVW_BT_VOLTAGE ] = 0xFF; +} diff --git a/tags/2.04/hal.h b/tags/2.04/hal.h new file mode 100644 index 0000000..f08592a --- /dev/null +++ b/tags/2.04/hal.h @@ -0,0 +1,17 @@ +#ifndef _hal_h_ +#define _hal_h_ + + +extern bit PM_EXTDC_n; +extern bit BT_IN_CHG_n; +extern bit SW_POW_n; +extern bit SW_HOME_n; +extern bit SW_WIFI_n; +extern bit SHELL_OPEN; + + +// ======================================================== +void hal_update(); +void hal_reset(); + +#endif diff --git a/tags/2.04/hoge.bin b/tags/2.04/hoge.bin new file mode 100644 index 0000000000000000000000000000000000000000..b18f698e39bfb373b173974b81a01b7475d362bd GIT binary patch literal 16387 zcmeHueOyylw&?jxP69#*2#8iG!EdWMK#^+Ih>RklM&#P60TOD#I*#RFr{8mHXXdrj z8cplW?TjrD?6cG9h+nVpQIoW!y9qn*KnNK)cCC%J2%0BYO0zu$Ym z`^Wpe-xG7r-fOSD_S$QIt-aPdTQ+a49uvOj-^F}S{s`cmf=KGR^3Gf_0=E{Dg_c5Y zG=_fqD7$@RzfR&glYd7z;^yC35Q+iblY zmKfaqhZ@|DTXg4mEvIW15lDyvz>aga>nP($46ZDn7mlTXFHR$Ym*s}o+c<@(5gfM2!RQ~=U1$5MZ& z=vCpkX=wF4+x1r}pl#W$YICpAZH#8?tj^@1DLIJy=(BTZfjm1$4NO_SbS4JZkQ*s> z_qB8k<8=m}G5BJ*)Wo2hGoptHJzluoS+DEdx8uq!taCr(|6|yVIz%&PG4d>_24ZAP zr(sCxWYk%TIZHEvH(bZ?t~h$ge}A|$?d#6;Tb+|{cTSNyrW?ow*STcjmC24^?&L&|2fGm@64~rQog!xN9QrZf_kHxt%!2>upaEMhh7cE*;B|u4tg2(%TWxlU33-|zxlfqBZzSc{v zc5PLwov4zB2%YM@j~bi{vY1QQ@oL1AGE?M(#Ce{)EZBBd$%)i?UdsIsF4;YbK0x-HX0vk6qrU$L&YDc^*Gc5g7;Q51BBI=Jk*|* zAvQ!O7EwF*zW4qfU$Bk+WfL&PJ>S%MH1Eu@4AHJ-cQ^l~voW7r@i%V86;9h^XX^5V zST5=+O4zlv*$vT6SqiU-axrz7!d=mL60mcgR{=-E0#1xDQBju{>2)BN!g);uIf8O{ z8qQcm#sv$gfq;xfgd~#N43OcDQ5m`qr{m04iUH9A($-jJYt%@c84&_A5P`npVfiC* z8>6BkWQ|d=!--gwaI;w@xEoE0s3r{KUTE49Lvr&cbMpHZV1LOhaku|U zl{hk_IY7m{|L%D-1<9^*cq%~=OPN#QaUolTXFWV4qYP6cl|gf(hcPF#ni*Nmv~;K` zySgyJ8*Nv!yX9i7ZM|B!F$}bw?%S^FP+@jeAqD9ol`$oFoCq|+zQ=xePSc*fnC5=j z=Dl@uIA!zH(A@lU4Mc*&MDOLyX4>`~VS5hi{~OxxM)6PH!H=P9XtSvmwap&X+g0$| zMK<-a;iiihFCOfbQ^&NN=cCO`t2qHNEAvry`kYT?Td(SCq!o@I)&4Moy6-T}S}%ForWECrkzHc=%mp-HIl!3Q;nf&DBF5k=vs`$nT96825MVR*{O3rM)pR@{n5fb zyyzGtQ3@o=ZM?q&#{$QR1|m;`c^5Viuy-c_k=Lplh-mX&+jb0IgEtVcZ=0cn3cU24 zA`qC+XbQX(whh_V!(npHHq_Un2HI#ZgB>XzL`7SC)k$HT-k$F^QV z85kO+-kZG2ju(pQ;RI=h%_%h+1ZIy$BMu``+ud?pwX3^^u_x3-*%M%ZqA|TairwAR8!sP@ zg=zOW1D)!iRR}1XVYtUCDVVBH&}cSXlS$^Xz;$RbyS9+>7Q-mOJZ)@HCBSAQ!w4Km zDBs(l+IL(9QxW=uW+UOdgr*%(MAHtos~?zlDuwPi+j_0=d!S!!-EltIHllR#x_t-^g=kyS`GC4pYSa1_C%BmF()Eoz8I;1#lIM?R($4Gvi)RicOyY%pjm%{EM zMo<-z0#T$2UByDagK9gcJ_}> zwYUe^cTeG$-L;o(e4)mthcRq*s2FFN+|s3Dup3h`cHlOJl7*O$?!g#7(Z&N(kBZ^7 zXTO|eJ8L_8BN4Nm4RvF-aOiDJ8VbjRK16^X3<$;`YEPEQP8HK~gTfG@p)cJ<7_du( z=3-r?vI28aOnYLv6JubfaHOQZgI?oPojB9B1`Cyk0h>luTh~N~v{;L~bz zTwXZIr-Bj01qzL0%Z-hpmK*;P0 zRX5oOj@mR>CNlwJ)`V>{U_v`S58LLWDQ(N~#O$9l0e7p-247}NqOBXeg14BXao?| zfno12Q*gRhW~GKkaXbiTTF7V#jp9h17$$_2p>OU#*xNjS9SXn@oV*+I*FgB7r@0?W zntBfnlKO)ehtbHUiznPCZ?R8ZV1CgWn9|$S+rs`-^^24GfZ>F^Am-OT5~bXEa4VS- znO)bh9nFD2^I-D;wAJ5r9edev9b?Jchx+~3(a<0L9yvNfZRb7IrvBH|4qw6|K z^!^$<%$|*{nsTw}B5*kdaXH1)#d{XPli@mkI2QRV{Y&VYe`i7b=#y9nzXn~^fP;{{t)GT&lCj94u$1eH? z;n;;CX>l*@g-c49d*%Yy;@@D3(Uq|rU``7eye)7+*-~S!aRC*Wt^?P zx}{DoZ#&_>=h|(2Xdat2k9`os?xg7ZSHDpA$=4W8F=O;e6DBb@hE2leV;it%vEO3< zfpufIusGa^ufoSo$;w+>zU`Tx?bz|NXSS8E&C8lHPN!vt|7mrH`i~j^Z2H*PXl^`m z+}xyVvNj!YT{>~(RBHQ?&n|W9@csl{LaNI6*c;2SZP+taFJR-~FR6cmRga-R0<&P* z*!vjP`^|N`u}1gar6Z=JEgxbZn*UvQ?2SLA{>A#S*;U_mr1Oo>Q?cQ{7mS;&saO)0 zWYqVMxuot_V;Upg0)N;6(3dK))QeA4?o0i%`J>MpvE#<$*5mcSS4(r1>+=)!r?AuJ zjvb#L!RsgMl8+>{{9EdimtM3!sCy8b+n?A!p+3nN_jz1@Tt9)80#{S9BNzR*{yX_X z8r}bm|6cmnpS}3}bI(5W^iQ9v=Bl3D_LHq!p4ePj@%W~4o3*U8#Ij-iqmQinm$gM} z%&S+eTv4!mdH%AcKU$Kz*tBTjg8B0v%E1YOBnd1eetWCG|JH3vKRIV**|uk%e`Z_R z%ACo1>NWy@D~2$HM&Ou(3Lc??=X}e$sNh6-zCq^G*bK`Uma=HrG%Kh=uoZI|l$>B- z(=0TXOF(uB(LIBwkIjG_n@6ZPlcLe(pAlu<6nDY26`uHlX&-rGOmuLXm#U}1UXp16 z_(Bg|Fs;cGV^S$_6~HqrZa*FLLz2y~#+cMW0xGDXz+eFgr8TvS4}0NSZh>p2#SaC_ zg`Uf^a8s?`N4Rt=x7Y$~>N(>X(M$~Mhi7MG2=lp|GvcLTz~GFeRx=?_p9$yMn4L(& zWnyqRJ(^}6oRx>YRk0$~HpCWN zQns(JEdpGGnAkn&H`<(Jbr!eZPsS$-i0sl(+sSB;x#bR%Kpq3rV7X=V+2 zKg~UcbIFOpf@wEB^p&KbkXA5_@}_hp1p%?uyjA|3XxZZ%(>>Rx;dEd&BmGH1MW3WO zZ5k+xQE41WoK00f0=6;6tJ|*8rrK6{=*rqufqYf?dqJw&rva{QLqL&ibDOomfzgDu znpJW%T#?@DGZF2nD!6zcr0adw$;N_5TFnblA+p9`pNRnDn9sx{ihx>Ft2r8Rg)BPX z82^~h?$X0!x9!J_Z40m)gX#s|03?)vD;3unNDIJw!1u+zlPr_}U#z zaK$vZGLD&I(!zXG)oX*0_G^Q?ra2jSn5(|f8@I19P&+U^8)kQtPEF9+CI%du;EOv7 z|IIT2609RV0sF?-)ceOg**7MF#yS#(lzYmS-dzSP=2j=&A`|m4oD11bXNR#Q+)D%! zlbTkwM}&0Vr&f4?TM!5v+0PVH1R7(w*1$CIO-KSwNv39<_i62_8o1rpP(ncm{TSTf zh1`)cJ{DDnsR@^QjwlhPM{EX6j2fnPBk*CWJ|JhrHrnwTxEeAYG>)p1J8LL~LhLNC zFm(_o7B zeak(j=6*ai%L{e>zL%Q@Oc6ltJpW+CD6OnpU{N>15i+WccEy|tx&C41xo4HVPGJq$ zYE|qo9RwEPuZFZ!meg~6jGf$yLx$LzT0;o&0E7#6w4Jns6riq#01#Y35gws{m|;A) zvm!iM0aAbmJ*Lemz=53v?kFT%bYXW^+ez46f0CfQR@#2T*tS}%w(@c(T=v}}l1eGu zmZvJ|QsOSLAX7}anu*wXe1j3u44`#9jg`k2rjFaOt(Q>OAilULYKNB5a z42!!41U@ONQ+#b3f#%;23L2_`@k4_SP(7O7kOzYY107PbU~dD+VweOQrZ@LaM|PEk zbjyI^W!N@#zzqU`(QtUhr;}h2RIK)jz5%}%ZEWUEAQw4hRykPR;w(401dGiB6Go5f z%M-HCE+ApHA`^Xswh%hLS4p&wZ^~x)P7E*+dT0_}X6|6&VF8m^MP2m?dEmfS_WNdT8cCyAp zcTJRHQ8H6WMxkVsl2oIl%GL{87D6K3u;uX7m5Gwu55Jy-ppW7nv$%&l%2}YF+%p#2 zX|~*w#FbmPrz}eEpSr8}?snjqLURl_hNPmMD2zmTiOcQ*H;3Ug_pF)b=JkLb*`cE? zl2b=_71IS*a%oNnKMa2PfMA4Qs+sOuOVeFNw3aijfjs=?_i$Ba+7X9p#?gamZiO6! z)8NAbOZu}$f}3}hn}3;`{|z_)#%K#!M8TD!FqcxqX^XggKr+HF)kt(@5_DGv0rXjd zn}3z7G7=-SIjfNX>VTKuk12ywVOz~>Ds8L0(EpJlKc)maDdB^UsRjxixpgG_5>pNKWeyv_jCq*rPjDgnmFo@M zsQIO<4tLeyuD5a5?{L>!xa&8#YY*;!IBX1Iu4X*oI*z;kf}3x+KF0UCKEyvw4q<`j zZOxmSw{QlETZcpNpkcp-Zahw|-6S@4)#Gb1nc(j@;+z2(dBFrbEg#J*)5-d8p&U#Uy zuuuHDUer7+R<)wWmd|cMSqsWStHaqBQ5Kqq>=CDk@CIkyif`VAP?XdbRH~#lfom8! zn?2LHs(!4qmg%f(>2&V!|0eAJb=bcreC4;{D{qCb{9E|S@4}rmFL4-npvQm7&HR!} zxd!e{?)h3yTgUFHL$120I*u&m;!8P0DF~D$N+)te>1c7*Kg8@k;Ue|0e-E$$33eY= zUpki4m$qje6ODVqiK7T@727M5kBNW;RM`X|29!tI%GwjoJ|>Rh0x>qdG#(n}UZ`^n zigj;0{9@fZ-1E>zmrJyCwTNY1m&B5;1Sz{~tn}%Xzl-knuH&M2L=_BXL}Wtf^Jp;!7}{5I6f`Dhs#zG{%FAp&WMBO6N(0 zPrrk8JHu8ktgk3s;L{#@!<8%rlO>^`qHv*)4vv!qQ$^uwA1xow z6S6A`Z9e9Dj%Lg4YGHas;Y$Eswm_IvQMk$%#XeO=73l>1fDj9uc&MVVpsLueIWD3z z6*eLmIvtiyV;*&SA;u>ONnmVGx=9@u!JGQhUQpe*j8cKvk1P_3rgfL|Y>u7St~n)^ zLexaMod9t_esLkN(74((P`z2UlZ~8{{O(bX7xls7c z3a+4`)5i*lp|F#6JPAJ zI%i6bnG!;aW1lKzhSRiC(=kH=>KA56^4{#PXGod}X`orhD;oXq6oIHBpqDBMDR!ce z_Nuy4B|?ZnGepmZNOqDH#?>)PTAeEK(>w4<(5Q2k1YVMzV2(=Ixm}}Ag(45Vvj!Jv z+j>m6X2)w6MznNJdkuB;PX8VYha38t{d2P=6d|Aj z*kwTjPh_+^by*oq#mW%K1&pD-_a6dEU>+a~wcdyAhn-Xyoh>Phf=lll z7`G6n{wgpB)otrZp&2g59XM_$?oi;LRdR@xYfF5OgLzTwEgR+T+7f={cRP`6djcXn z5M|VDJFyD)^dTZ9S|*rGxK4vhV(fFy)Hdt^{cylNs0{TFrlG zH5((*ZTx-pxsoYYV!U8G_;Hp5b{uK1{HuAK4vc!j1|w8ZY8i1!{%WO;^5;qpNkj_5 z6lH0r!tH+tx^64s0o`rhShxb;-2!0Yd>lM!J_^+&&>{EX;sISWm_=kTh8PvoffJKB z<5|(sBO-f&YS?z-zJN)s7s3h_x+DJ(O2iDDM9~;T?t!snxM$^Xs;MKrDC3ep6Tx~H zu|IcEa5Q#Mx(<2=;s>TV!#&^AL8!qh{Q|t_jGAQY5iMkr9qHRxrOV&#p<>}d_h&ND zl&5reOwUq@r;aR@++9m0(vbir*lPwp3XX0#1|R|^`(bovGb}WY$Cl>#w7_;G-s3*w zGdKVekqtwE1eO-~7{?_MY|l*vkm0lcQ~)3&vXst@)Q%4Xj6kfjA{Y#O- zI>Hn&xRfo1;(Sz`4=*UrM>hVE;{5LAJb7%nn=Q8{6)dB@3Hz79%Qt5KGMF1m91AfB z5S4A{?DENQ=YcSiZm-&S@F6%!&MOkVk4;mnj1tm!*}Sr7Zb=!6m{H6&^0N=i|MOvX zQyEN&GWq2tZEmEM!1PP&S&n499Avy)((GEeI$z>rb}e+~ODKLusjD15JQZk4arayo zeN13!3P0{oDat(+k}+^i)gMe*;w68d;s!9Rz;=g6eA@33VF^WIRf@_gEV1YKN0i_h z8X`}HLM2uv4g{{4!ba_6N>EH(B-?WzY$p)ZB{ycFco|XQ8xfm2;)UWm&G;jCzg&D-1ghS;**wkyNEE9fu|n$2xQSB}Wpu_oy+1=Sm_Yb$Wd27kUAW1>k4N{es72`c zs`C6?dG0gyg%+8{LdcPkO}9>hxyjT1JXs*?^JG(={J19;W-W{W1o!q$SqyQ&2lMi@ z=uS0dF_%$>V(Gx6^{xRHIRs7s5}+bH-4xTO;yd0kK=TfiE11fe;=t+zzjwSH@_Q{bWq9_gUz%NyF1vLOOVYS?p4FKa}_evgI@&< z;?N;^?gJc?7=+eHq@=@zPJ>p5vieZl(-yPEWpnnMyUjeq?!TmEiD(rxFV`)GToOw~ z$3xCMb=aB=WGG-u{`F$S#bh;zg&dX?5F(-z`bW&p$ma({P`f{X4Rw$V(9Qk2$Q6|Y za<_)T4>x6Tps9c(OZ<`uhlpJJfc(rXxn~x)q86?u&~<-@=szp^J4Jt&81b$tv4}1d zi+C#%i>Tr9^tO$({B^MT)zi#0?d-fP$=3 zPz-}}$4>$N2u|k_BX|A?GF74)Ce5ua8#Hs(YNVHLSG(o^L4!3GHaJBOa1c^|5SMO| zNQXR5IVi}IBU!?sf-F6pZG^3`fokdvG+k_<*ojS^K$BPQA9Jv`$#d{xledA06cOyi zi=LAgy(dQyTAI8qfZ~-aVn=WfD5wYi3rrCQpMFv2gLY_F(UE zaLuTN;{fe#&^BHC)Pqq0`Qw;RJ>hUbZUjDE71Cj=lv^S3`oratYZJ=3%B8~dKdeIOEU^^wvO4SUL58vk4LQj7JRt;dskpOqIgm5=Y zNP9xVIclQV{Tt^7Y4=;sjneMlIxW)f-#JU9-M@C0O1t+s%OtQ_z&JWeB)Kd0X?gsQ z;+xj>s3o7ahk;91k4EAr2aYaX=ZpJv-CPJpCExU^wCj>n9>Ly9k{2$Gm)GaP1)dOW zMXEh}p4cF5E|z?OgX@}#hl-Hao)XLph55YRBG~*>f(ajhKH;OTek4SVLiT+Gywii zt+X0=HYNCH;VX1O_`_Qjikf^BK;V+R32ph+lAn?M8fmbI+g=u-s%ZLPbV}M)@_OKM&(UAHYjh(Q3@?N$|P__LYzFV ze=a4p(XK`csRjb{N!w`%Z$=UAC`_=CU7*Lw#+@-#l^qAixFcFxMS8%=xjI_%M8S=6 z4BRLW=mqk?QN7|WKG~|c<00@{3z6r`8K3&wEDYrC0KI`g#KGQ1;j;!6RHhn7))7?mG^ik6Za7g9 zJB+OmxVs6@C-5o30X>?$!~R{zBZ@4@Rg`bS!Q!Rsyy}DNrWET1Qvjx;dTB9FUK6su zg*!8R%5+qZJhDrC$;ORZ15jhWMP64JV^(j~ z1eQL^Q-69?c#(^@!Z?G*Nx{uvt$HwBc;dn}@OdB`O{{@WF`y5n)*AS!20kZJzMLyU zXt~|#P@_owRk{G-(E$1M(c73X3!qU7RLR~4CTt;Dfvp8h1*Yk`Cc~AXeAOIEUd^= z^jHbFT4IrpWeb}Imn9*h-lGo>-_aXK9F7j>!G zG)vq)J%Jt|#xJ|M@{+p?>Ltkp|2+%*l5|0qZnBH0LOB7YntH((z9j}ca97Xs6u!p? zcI-#NJdK0_c2cTdmQ1pgYCG+hCAUqoNv$V8X)lU~?XEl2>KocESM8QsBa;WrS&^$s zOPyq`le4-*MXHvM-g^&yICbho3sm-fx1wV){R}dhs}xhMnawKA1}`?3S?cHz%euiG zH{NkpEbD=U-q9(ReE|uLqf0Dvi{P$?kOJi4QQ|B((kg#7XE051nZm~~z)|0;1&YZx zu{({|7o-vVn0tx=V;7u=${c45e1d^z1@mAAXM)P`J(B+A`rrj! zQ2r>h+!+@qS|NEsDd=o7w?D*I!*M2xL_-)pAR29 zqygclfh6uxnRE~or$TjvRqd$!abpW=@Pa;gGkrRkNYg2dpPZhC@u|qH8J&(}d}8`U zjE@tdp{~`Z>Cy#la2L=8QDfRWEPj6!VDQ?Z+g!mF_?l~tsfnK&(5PkNPI-wYt3DXC2E1ySw)4{{|`eQp`|t z3e61RyE8)xVdKn30(}xgVSz^W!^=9@_t6KXzFWv8-PgBb_nI2`B<(T;uYmGD5nf;+ z(V$8wqw}!~&x8X;uq>3IrXHK~ht&$iCtg5U}vQ+5S%!$%voO5fE3u750sDd@HX0 zZP*v*7!p_iE({ThU|CQi6hSHZKGDb$+MoNw#8H&Ru1PicZWevns>0y2RzAkSrwI?i z7=eNIVZjIq#m)ntOV!R7?q3t0jo#xT<XRV2vK#D+Cqx}FUSYQX=Zd`!g3p^8{JzE2HpG5=?OVN4aRPo9`Q!bFCA=-XCA=xT zLaGRxB@FxByrCIk>|fwt7?Hx3VeC)IZ!-;gcfz5e_QVF2{*wkOF|dRO2lD&x{kz~l Y(ROc8_&pKg|3CBpt^^3`PSpQ@0#i+E-T(jq literal 0 HcmV?d00001 diff --git a/tags/2.04/i2c_ctr.c b/tags/2.04/i2c_ctr.c new file mode 100644 index 0000000..8899cda --- /dev/null +++ b/tags/2.04/i2c_ctr.c @@ -0,0 +1,297 @@ +/* ======================================================== + SoC VK`l I2CʐM + cJZ.nintendo + '09 Apr + ======================================================== */ + +#include "config.h" + +// TS̓}U{ŃeRAWM͉H}eRŌLjvc + +#ifndef _WIN32 +#pragma interrupt INTIICA1 int_iic_ctr RB1 +#endif + + +#include "incs.h" + +#ifdef _MCU_BSR_ +// #ifdef _MODEL_TS0_ || _MODEL_WM0_ + +// [LOfI2Ct +// TEG͉H}ŃeR +#define ACKD ACKD1 +#define ACKE ACKE1 +#define COI COI1 +#define IICAEN IICA1EN +#define IICRSV IICRSV1 +#define IICA IICA1 +#define IICAIF IICAIF1 +#define IICAMK IICAMK1 +#define IICAPR0 IICAPR11 +#define IICAPR1 IICAPR01 +#define IICCTL0 IICCTL10 +#define IICE IICE1 +#define IICF IICF1 +#define IICS IICS1 +#define IICWH IICWH1 +#define IICWL IICWL1 +#define LREL LREL1 +#define SPD SPD1 +#define SPIE SPIE1 +#define STCEN STCEN1 +#define STD STD1 +#define SVA SVA1 +#define WREL WREL1 +#define WTIM WTIM1 +#define TRC TRC1 +#define SMC SMC1 +#define DFC DFC1 + +#endif + + + +// ============================================== +enum en_IIC_STATE +{ + IIC_IDLE = 0, + IIC_RCV_REG_ADRS, + IIC_TX_OR_RX, + IIC_TX, + IIC_RX +}; + + + +// ============================================== +extern bit irq_readed; // ꂩIRQWX^ǂ܂ꂽ + +u8 iic_burst_state; +static enum en_IIC_STATE state = IIC_IDLE; + +#define bit_iics_spd (i2c_stat & (1<<0)) +#define bit_iics_std (i2c_stat & (1<<1)) +#define bit_iics_ackd (i2c_stat & (1<<2)) +#define bit_iics_trc (i2c_stat & (1<<3)) +#define bit_iics_coi (i2c_stat & (1<<4)) + +// ============================================== +__interrupt void int_iic_ctr( ) +{ + static u8 reg_adrs; + static u8 tx_buf; + u8 rx_buf; + static u8 adrs_access_from; // o[XgANZX̎Ɏg + + u8 i2c_stat = IICS1; // volatilê + + // ǂݏoI + if( !bit_iics_ackd // 荞ݗvNAKif[^M̍Ōj + || bit_iics_spd ) // XgbvRfBV(!ACKD ɗƂ͊荞ݗȂ (SPIE = 0)) + { + /* + I2C̔xẴtOOSTDĂ܂Ƃ + ǁAȂ삷‚ + */ + + // WX^[hŁA荞݃slQ[g + // ܂ǂ܂ĂȂ荞݂΁AēxAT[g + if( irq_readed ) + { + IRQ0_neg; + irq_readed = false; + if( !( (( vreg_ctr[VREG_C_IRQ0] & vreg_ctr[VREG_C_IRQ_MASK0 ] ) == 0 ) + && (( vreg_ctr[VREG_C_IRQ1] & vreg_ctr[VREG_C_IRQ_MASK1 ] ) == 0 ) + && (( vreg_ctr[VREG_C_IRQ2] & vreg_ctr[VREG_C_IRQ_MASK2 ] ) == 0 ) + && (( vreg_ctr[VREG_C_IRQ3] & vreg_ctr[VREG_C_IRQ_MASK3 ] ) == 0 ) )) + { + while( !IRQ0 ){;} // ԉ҂sv + IRQ0_ast; + } + } + + // I2CIɉ镨 // + hosu_read_end( ); // vǂݏoI + rtc_unlock( ); + + state = IIC_IDLE; + SPIE = 0; + LREL = 1; + EI(); + return; + } + + if( bit_iics_std ) // 荞ݗvFX^[gRfBV + { + if( !( state == IIC_IDLE || state == IIC_TX_OR_RX )) + { + // sp/nack 葹˂ + dbg_nop(); // Ȃ͂... +/* + // pPbg̐擪stƌȂB + // ʂɑs + state = IIC_IDLE; +/*/ + // gCĂ炤 + state = IIC_IDLE; + SPIE = 0; + LREL = 1; + EI(); +//*/ + } + // ʏ + } + + EI(); + + switch ( state ) + { + case ( IIC_IDLE ): + // njĂяoɉB + // Ȃ + iic_burst_state = 0; + SPIE = 1; + WREL = 1; // EFCg + state = IIC_RCV_REG_ADRS; + return; + + case ( IIC_RCV_REG_ADRS ): // QoCgځiWX^AhXjMɗ + // WX^AhXM + reg_adrs = IICA; + + WREL = 1; + adrs_access_from = reg_adrs; + tx_buf = vreg_ctr_read( reg_adrs ); // f[^̏Ă + state = IIC_TX_OR_RX; + return; + + case ( IIC_TX_OR_RX ): // ̎ɗ銄荞݁BSTȂ瑗MAf[^珑܂ + // if( TRC ) // MtO ŋʂ̂́A荞ݒxɕsN肦 + if( bit_iics_std ) + { // X^[gRfBVotO + // [h + if( bit_iics_coi ) + { // AhXvtO + state = IIC_TX; + // no break, no return // + } + else + { + // X^[gňႤfoCXĂ΂ꂽI + SPIE = 0; + LREL = 1; // EFCg? + state = IIC_IDLE; // I + return; + } + } + else + { + state = IIC_RX; // f[^1oCgM̊荞݂ + // no break, no return // + } + /* FALLTHROUGH */ + + default: // o[Xg R/W łĂ΂邱ƂɂȂ + if( state == IIC_TX ) + { // M + IICA = tx_buf; + vreg_ctr_after_read( reg_adrs, tx_buf ); // ǂ񂾂NAȂǂ̏ + } + else + { // M + rx_buf = IICA; + +#ifdef _I2C_ERR_ABORT_ + if( reg_adrs >= 0x80 || reg_adrs <= 1 ) + { + LREL = 1; // Ȃ񂩃f[^̂ŒʐMI nakԂ̂Ȃc + return; + } +#endif + vreg_ctr_write( reg_adrs, rx_buf ); + WREL = 1; + } + + // WX^AhX̃CNg + /// ANZX|C^i߂ȂȃWX^ + switch( adrs_access_from ) + { + case( VREG_C_ACC_HOSU_HIST ): + case( VREG_C_LED_NOTIFY_DATA ): + case( VREG_C_LED_POW ): + case( VREG_CX_INFO ): + case( VREG_CX_FREE_DATA ): + break; + case( VREG_CX_FREE_ADRS ): + if( reg_adrs == VREG_CX_FREE_ADRS ) + { + reg_adrs = VREG_CX_FREE_DATA; + } + break; + default: + reg_adrs ++; + } + + if( state == IIC_TX ) + { // ɂ‚ɑf[^̏VeINBSPĎgȂȂ + tx_buf = vreg_ctr_read( reg_adrs ); + } + break; + } +} + + + +// ======================================================== +void IIC_ctr_Init( void ) +{ + + IICAEN = 1; + + IICE = 0; /* IICA disable */ + + IICAMK = 1; /* INTIICA disable */ + IICAIF = 0; /* clear INTIICA interrupt flag */ + +// IICAPR0 = 1; /* set INTIICA high priority */ +// IICAPR1 = 0; /* set INTIICA high priority */ X^bNs + + P20 &= ~0x3; + + SVA = IIC_C_SLAVEADDRESS; + IICF = 0x01; + + STCEN = 1; // X^[g̋ + IICRSV = 1; // ʐM\Ȃ:X[uɓO + + SPIE = 0; // XgbvRfBVł̊荞݂֎~ + WTIM = 1; // ACKԂclkLɌŒ肷 + ACKE = 1; + + IICWH = 5; + IICWL = 10; // LԂ̒ + + SMC = 1; // [h + DFC = 1; // fW^tB^on (@fast mode) + + IICAMK = 0; // 荞݂ + + IICE = 1; + + PM20 &= ~0x3; /* set clock pin for IICA */ + + state = IIC_IDLE; +} + + + +// ======================================================== +void IIC_ctr_Stop( void ) +{ + IICE = 0; /* IICA disable */ + IICAEN = 0; +} + + + diff --git a/tags/2.04/i2c_ctr.h b/tags/2.04/i2c_ctr.h new file mode 100644 index 0000000..16234ff --- /dev/null +++ b/tags/2.04/i2c_ctr.h @@ -0,0 +1,210 @@ +#ifndef _MDSERIAL_A_ +#define _MDSERIAL_A_ + + +/* IIC operation enable (IICE0) */ +#define IIC0_OPERATION 0x80 +#define IIC0_OPERATION_DISABLE 0x00 /* stop operation */ +#define IIC0_OPERATION_ENABLE 0x80 /* enable operation */ + +/* Exit from communications (LREL0) */ +#define IIC0_COMMUNICATION 0x40 +#define IIC0_COMMUNICATION_NORMAL 0x00 /* normal operation */ +#define IIC0_COMMUNICATION_EXIT 0x40 /* exit from current communication */ + +/* Wait cancellation (WREL0) */ +#define IIC0_WAITCANCEL 0x20 +#define IIC0_WAIT_NOTCANCEL 0x00 /* do not cancel wait */ +#define IIC0_WAIT_CANCEL 0x20 /* cancel wait */ + +/* Generation of interrupt when stop condition (SPIE0) */ +#define IIC0_STOPINT 0x10 +#define IIC0_STOPINT_DISABLE 0x00 /* disable */ +#define IIC0_STOPINT_ENABLE 0x10 /* enable */ + +/* Wait and interrupt generation (WTIM0) */ +#define IIC0_WAITINT 0x08 +#define IIC0_WAITINT_CLK8FALLING 0x00 /* generate at the eighth clocks falling edge */ +#define IIC0_WAITINT_CLK9FALLING 0x08 /* generated at the ninth clocks falling edge */ + +/* Acknowledgement control (ACKE0) */ +#define IIC0_ACK 0x04 +#define IIC0_ACK_DISABLE 0x00 /* enable acknowledgement */ +#define IIC0_ACK_ENABLE 0x04 /* disable acknowledgement */ + +/* Start condition trigger (STT0) */ +#define IIC0_STARTCONDITION 0x02 +#define IIC0_START_NOTGENERATE 0x00 /* do not generate start condition */ +#define IIC0_START_GENERATE 0x02 /* generate start condition */ + +/* Stop condition trigger (SPT0) */ +#define IIC0_STOPCONDITION 0x01 +#define IIC0_STOP_NOTGENERATE 0x00 /* do not generate stop condition */ +#define IIC0_STOP_GENERATE 0x01 /* generate stop condition */ + +/* + IIC Status Register 0 (IICS0) +*/ +/* Master device status (MSTS0) */ +#define IIC0_MASTERSTATUS 0x80 +#define IIC0_STATUS_NOTMASTER 0x00 /* slave device status or communication standby status */ +#define IIC0_STATUS_MASTER 0x80 /* master device communication status */ + +/* Detection of arbitration loss (ALD0) */ +#define IIC0_ARBITRATION 0x40 +#define IIC0_ARBITRATION_NO 0x00 /* arbitration win or no arbitration */ +#define IIC0_ARBITRATION_LOSS 0x40 /* arbitration loss */ + +/* Detection of extension code reception (EXC0) */ +#define IIC0_EXTENSIONCODE 0x20 +#define IIC0_EXTCODE_NOT 0x00 /* extension code not received */ +#define IIC0_EXTCODE_RECEIVED 0x20 /* extension code received */ + +/* Detection of matching addresses (COI0) */ +#define IIC0_ADDRESSMATCH 0x10 +#define IIC0_ADDRESS_NOTMATCH 0x00 /* addresses do not match */ +#define IIC0_ADDRESS_MATCH 0x10 /* addresses match */ + +/* Detection of transmit/receive status (TRC0) */ +#define IIC0_STATUS 0x08 +#define IIC0_STATUS_RECEIVE 0x00 /* receive status */ +#define IIC0_STATUS_TRANSMIT 0x08 /* transmit status */ + +/* Detection of acknowledge signal (ACKD0) */ +#define IIC0_ACKDETECTION 0x04 +#define IIC0_ACK_NOTDETECTED 0x00 /* ACK signal was not detected */ +#define IIC0_ACK_DETECTED 0x04 /* ACK signal was detected */ + +/* Detection of start condition (STD0) */ +#define IIC0_STARTDETECTION 0x02 +#define IIC0_START_NOTDETECTED 0x00 /* start condition not detected */ +#define IIC0_START_DETECTED 0x02 /* start condition detected */ + +/* Detection of stop condition (SPD0) */ +#define IIC0_STOPDETECTION 0x01 +#define IIC0_STOP_NOTDETECTED 0x00 /* stop condition not detected */ +#define IIC0_STOP_DETECTED 0x01 /* stop condition detected */ + +/* + IIC Flag Register 0 (IICF0) +*/ +/* STT0 clear flag (STCF) */ +#define IIC0_STARTFLAG 0x80 +#define IIC0_STARTFLAG_GENERATE 0x00 /* generate start condition */ +#define IIC0_STARTFLAG_UNSUCCESSFUL 0x80 /* start condition generation unsuccessful */ + +/* IIC bus status flag (IICBSY) */ +#define IIC0_BUSSTATUS 0x40 +#define IIC0_BUS_RELEASE 0x00 /* bus release status */ +#define IIC0_BUS_COMMUNICATION 0x40 /* bus communication status */ + +/* Initial start enable trigger (STCEN) */ +#define IIC0_STARTWITHSTOP 0x02 +#define IIC0_START_WITHSTOP 0x00 /* generation of a start condition without detecting a stop condition */ +#define IIC0_START_WITHOUTSTOP 0x02 /* generation of a start condition upon detection of a stop condition */ + +/* Communication reservation function disable bit (IICRSV) */ +#define IIC0_RESERVATION 0x01 +#define IIC0_RESERVATION_ENABLE 0x00 /* enable communication reservation */ +#define IIC0_RESERVATION_DISABLE 0x01 /* disable communication reservation */ + +/* + IIC clock selection register 0 (IICCL0) +*/ +#define IICCL0_INITIALVALUE 0x00 +/* Detection of SCL0 pin level (CLD0) */ +#define IIC0_SCLLEVEL 0x20 +#define IIC0_SCL_LOW 0x00 /* clock line at low level */ +#define IIC0_SCL_HIGH 0x20 /* clock line at high level */ + +/* Detection of SDA0 pin level (DAD0) */ +#define IIC0_SDALEVEL 0x10 +#define IIC0_SDA_LOW 0x00 /* data line at low level */ +#define IIC0_SDA_HIGH 0x10 /* data line at high level */ + +/* Operation mode switching (SMC0) */ +#define IIC0_OPERATIONMODE 0x08 +#define IIC0_MODE_STANDARD 0x00 /* operates in standard mode */ +#define IIC0_MODE_HIGHSPEED 0x08 /* operates in high-speed mode */ + +/* Digital filter operation control (DFC0) */ +#define IIC0_DIGITALFILTER 0x04 +#define IIC0_FILTER_OFF 0x00 /* digital filter off */ +#define IIC0_FILTER_ON 0x04 /* digital filter on */ + +/* Operation mode switching (CL01, CL00) */ +#define IIC0_CLOCKSELECTION 0x03 + +/* Combine of (SMC0, CL01, CL00)*/ +#define IIC0_CLOCK0 0x00 +#define IIC0_CLOCK1 0x01 +#define IIC0_CLOCK2 0x02 +#define IIC0_CLOCK3 0x03 +#define IIC0_CLOCK4 0x08 +#define IIC0_CLOCK5 0x09 +#define IIC0_CLOCK6 0x0a +#define IIC0_CLOCK7 0x0b + +/* + IIC function expansion register 0 (IICX0) +*/ +/* IIC clock expension (CLX0) */ +#define IIC0_CLOCKEXPENSION 0x01 +#define IIC0_EXPENSION0 0x00 +#define IIC0_EXPENSION1 0x01 + +/* Operation clock (CLX0, SMC0, CL01, CL00) + | IIC0_EXPENSION0 | IIC0_EXPENSION1 | +------------|-------------------|-------------------|---------------------- +IIC0_CLOCK0 | fprs/2 | prohibited | selection clock(fw) + | fprs/88 | | transfer clock + | normal | | mode +------------|-------------------|-------------------|---------------------- +IIC0_CLOCK1 | fprs/2 | prohibited | selection clock(fw) + | fprs/172 | | transfer clock + | normal | | mode +------------|-------------------|-------------------|---------------------- +IIC0_CLOCK2 | fprs/2 | prohibited | selection clock(fw) + | fprs/344 | | transfer clock + | normal | | mode +------------|-------------------|-------------------|---------------------- +IIC0_CLOCK3 |prohibited/fexscl0 | prohibited | selection clock(fw) + | fw/66 | | transfer clock + | normal | | mode +------------|-------------------|-------------------|---------------------- +IIC0_CLOCK4 | fprs/2 | fprs/2 | selection clock(fw) + | fprs/48 | fprs/24 | transfer clock + | high speed | high speed | mode +------------|-------------------|-------------------|---------------------- +IIC0_CLOCK5 | fprs/2 | fprs/2 | selection clock(fw) + | fprs/48 | fprs/24 | transfer clock + | high speed | high speed | mode +------------|-------------------|-------------------|---------------------- +IIC0_CLOCK6 | fprs/4 | fprs/4 | selection clock(fw) + | fprs/96 | fprs/48 | transfer clock + | high speed | high speed | mode +------------|-------------------|-------------------|---------------------- +IIC0_CLOCK7 |prohibited/fexscl0 | prohibited | selection clock(fw) + | fw/18 | | transfer clock + | high speed | | mode +------------|-------------------|-------------------|---------------------- +*/ + +#define ADDRESS_COMPLETE 0x80 +#define IIC_MASTER_FLAG_CLEAR 0x00 + +/****************************************************************************** + * Macro define + ******************************************************************************/ + + + +/****************************************************************************** + * Function define + ******************************************************************************/ + +void IIC_ctr_Init( void ); +void IIC_ctr_Stop( void ); + + +#endif diff --git a/tags/2.04/i2c_mcu.c b/tags/2.04/i2c_mcu.c new file mode 100644 index 0000000..58f5cb2 --- /dev/null +++ b/tags/2.04/i2c_mcu.c @@ -0,0 +1,655 @@ +/* ======================================================== + ȈI2CiytFgpjʐM + de JHL cJZ + '09 Feb - + ======================================================== */ +#ifndef _WIN32 +#pragma sfr +#pragma di +#pragma ei +#pragma nop +#pragma inline // memcpy()CCWJ(̕I) +#endif + +#include "incs_loader.h" +#include "i2c_mcu.h" + + +// ======================================================== +// WX^̃rbg +// vtBbNXbAꕔ̃rbgWX^ɂԂ邽... +// SMR0n +#define bCKS0 ( 1 << 15 ) +#define bCCS0 ( 1 << 14 ) +#define bSTS0 ( 1 << 8 ) +#define bSIS0 ( 1 << 6 ) +#define bMD0n2 ( 1 << 2 ) +#define bMD0n1 ( 1 << 1 ) +#define bMD0n0 ( 1 << 0 ) +#define bSMR0n_FIXEDBIT ( 1 << 5 ) + +// SSR0n +#define bit_TSF0 6 +#define PEF0 ( 1 << 1 ) + +// SIR0n +#define PECT0 ( 1 << 1 ) + +// SCR0n +#define TXE0 ( 1 << 15 ) +#define RXE0 ( 1 << 14 ) +#define SLC02 4 +#define DLS02 0 +#define TSF0 ( 1 << 6 ) + +// SOn +#define TAUS_MASK 0x0B0B; + +// DMCn +#define DRS ( 1 << 6 ) + + + +// ======================================================== +static void iic_mcu_send_st( ); +static void iic_mcu_send_re_st( ); +static void iic_mcu_send_sp( ); +static err iic_mcu_send_a_byte( u8 ); +static err iic_mcu_call_slave( u8 slave ); + + + +// ======================================================== +bit iic_mcu_wo_dma; +volatile bit iic_mcu_busy; +static volatile bit iic_mcu_initialized; + + +static u8 iic_send_work[4]; +static u8 *p_iic_send_wo_dma_dat; +static u8 iic_send_wo_dma_len; + +u8 iic_mcu_result; // ꕶ[h̎̓f[^ԂB + // Xe[^XKvȂ炱Ă + +#ifdef i2c_timeout_test +extern bit i2c_mcu_time_out_error; +#endif + +// ======================================================== +void nop8() +{ + // ɗ call 3clk, return 6clk +} + + +static err iic_mcu_wait_free() +{ + u16 tot = 0; + + iic_mcu_start( ); + while( 1 ) + { + DI(); + if( !iic_mcu_busy ) + { + iic_mcu_busy = true; + EI(); + break; + } + EI(); + if( ++tot == 0 ) + { +#ifdef i2c_timeout_test + i2c_mcu_time_out_error = true; +#endif + return( ERR_ERR ); + } + } + return( ERR_SUCCESS ); +} + + +/* ======================================================== + X[u w1x [h + Ԓlf[^̂̂łB + ======================================================== */ +u8 iic_mcu_read_a_byte( u8 SLA, u8 adrs ) +{ + u8 dat; + +#if 1 + // bp[ + if( iic_mcu_read( SLA, adrs, 1, &dat ) == ERR_SUCCESS ) + { + iic_mcu_result = ERR_OK; + } + else + { + iic_mcu_result = ERR_NOSLAVE; + } + return ( dat ); + +#else + iic_mcu_wait_free(); + + // X^[gRfBVƃX[ǔĂяoAWX^AhX̑M + if( iic_mcu_call_slave( SLA ) != 0 ) + { + iic_mcu_result = ERR_NOSLAVE; + iic_mcu_busy = false; + return ( 0 ); + } + + // WX^AhX̑M + iic_mcu_send_a_byte( adrs ); // I܂ŋAĂȂ + // if( err != ERR_SUCCESS )` + + // f[^M // + iic_mcu_send_re_st( ); // X^[gRfBV + iic_mcu_send_a_byte( SLA | 0x01 ); // M܂Ŗ߂Ă܂B + + ST0 = 0x0004; // M[hɐݒς̂ŃWbN~ + SCR02 = RXE0 | 1 << SLC02 | 7 << DLS02; // Mݒ + SS0 = 0x0004; // ʐMҋ@ + + SOE0 = 0x0000; // 1oCgMȂ̂ŁAŌNAK𑗂 + IICIF10 = 0; + SIO10 = 0xFF; // _~[f[^ƎMJn + + while( IICIF10 == 0 ) + { // M҂ + ; + } + dat = SIO10; + + iic_mcu_send_sp( ); + IICIF10 = 0; // Ȃ + iic_mcu_busy = false; + return ( dat ); +#endif +} + + + +/* ======================================================== + X[ũ[h + 0 I + 1 X[uȂ + 2 oXNɐLĂă^CAEg + 3 ӖsG[ + yz + X[uEFCgRfBVoƂ͋֎~łB + ̏ꍇłG[oȂǂł܂ + ======================================================== */ +err iic_mcu_read( u8 slave, u8 adrs, u8 len, u8 * dest ) +{ + +#if 1 + if( iic_mcu_wait_free() != ERR_SUCCESS ) + { + return( ERR_ERR ); + } +#else + // gpȂA +#endif + + // X^[gRfBVƃX[ǔĂяoAWX^AhX̑M + if( iic_mcu_call_slave( slave ) != 0 ) + { + iic_mcu_busy = false; + return ( ERR_NOSLAVE ); + } + + // WX^AhX̑M + iic_mcu_send_a_byte( adrs ); // I܂ŋAĂȂ + // if( err != ERR_SUCCESS )` + + // f[^M // + iic_mcu_send_re_st( ); // X^[gRfBV + iic_mcu_send_a_byte( slave | 0x01 ); // M܂Ŗ߂Ă܂B + + // f[^M + ST0 = 0x0004; // M[hɐݒς̂ŃWbN~ + SCR02 = RXE0 | 1 << SLC02 | 7 << DLS02; // Mݒ + SS0 = 0x0004; // ʐMҋ@ + + do + { + if( len == 1 ) + { + SOE0 = 0x0000; // ŌNAK + } + IICIF10 = 0; + SIO10 = 0xFF; // _~[f[^ƎMJn + while( IICIF10 == 0 ) + {;} // M҂ + + *dest = SIO10; + dest++; + len--; + } + while( len != 0 ); + + iic_mcu_send_sp( ); + + IICIF10 = 0; + iic_mcu_busy = false; + return ( ERR_SUCCESS ); +} + + + + +/* ======================================================== + X[u wPoCgx Cg + O̓]Î҂āACg܂B + Ԓl@iic_mcu_write@ɓ + ======================================================== */ +err iic_mcu_write_a_byte( u8 SLA, u8 adrs, u8 dat ) +{ + +#if 0 + static u8 temp; // ςȂŏIɊ֐𔲂i”\ĵstatic + + // ȂƁAđɏƂɑÕf[^j󂵂Ă܂ + while( iic_mcu_busy ) + { + NOP( ); + } + + temp = dat; + iic_mcu_wo_dma = true; + return ( iic_mcu_write( SLA, adrs, 1, &temp ) ); +#else + // P̎DMAƂNȂłƏI点 + if( iic_mcu_wait_free() != ERR_SUCCESS ) + { + return( ERR_ERR ); + } + + // X^[gRfBVƃX[ǔĂяo... + IICMK10 = 1; + if( iic_mcu_call_slave( SLA ) != ERR_SUCCESS ) + { + iic_mcu_busy = false; + return ( ERR_NOSLAVE ); + } + iic_mcu_send_a_byte( adrs ); + iic_mcu_send_a_byte( dat ); + iic_mcu_send_sp( ); + iic_mcu_busy = false; + return ( ERR_SUCCESS ); +#endif +} + + + +/* ======================================================== + X[uփCg + WX^ adrs 擪ɁA + *str + len܂B + + 0 I + 1 X[uȂ + 2 oXNɐLĂă^CAEg + 3 OɎwꂽʐM܂IĂȂ + yz + X[uEFCgRfBVoƂ͋֎~łB + ̏ꍇłG[oȂǂł܂ + DMA1gp܂B + ******************************************************************************/ +err iic_mcu_write( u8 slave, u8 adrs, u8 len, void * src ) +{ + if( iic_mcu_wait_free() != ERR_SUCCESS ) + { + return( ERR_ERR ); + } +#if 0 + // gpȂA +#endif + + // X^[gRfBVƃX[ǔĂяo... + IICMK10 = 1; + IICIF10 = 0; + if( iic_mcu_call_slave( slave ) != ERR_SUCCESS ) + { + iic_mcu_busy = false; + return ( ERR_NOSLAVE ); + } + + IICIF10 = 0; + if( !iic_mcu_wo_dma ) + { + // DMAgpiʏj + + // WX^AhX𑗂Af[^̏ + memcpy( iic_send_work, src, 4 ); //obt@Ƃ4oCgpӂĖ߁B + // DMAZbg + while( DST1 ) + {;} + + DEN1 = 1; + DSA1 = (u8)( &SIO10 ); + DRA1 = (u16)( &iic_send_work[0] ); + DBC1 = len; + DMC1 = DRS | 8; // RAM -> SFR, 8bit, IRQ, IIC10 + + DMAIF1 = 0; + DMAMK1 = 0; + DST1 = 1; + + SIO10 = adrs; // ςȂI 荞݂DMAX^[g + // c͊荞݃[` + } + else + { + // DMAgpȂ // + + // WX^AhX̑M + IICMK10 = 0; + SIO10 = adrs; + + iic_send_wo_dma_len = len; + p_iic_send_wo_dma_dat = src; + // c͊荞݃[` + } + + return ( ERR_SUCCESS ); +} + + + + +/* ======================================================== + DMAP]I荞 + IIC_mcu ̑MR[obN֐̂悤Ȃ + FDMA]IŁAI2C̓]͏IĂ܂ +@ 荞ݒȂǂŁADMA1̏xꍇA + IIC10̊荞݂̏łɁA荞݂𔭐ȂȂ + ꂪ܂B܂A@ɂ܂B + @̂߁ADMAdl̍ق́AŌ̃oCg͑M + tÕ|[OŊmF܂B + ======================================================== */ +__interrupt void int_dma1( ) +{ + EI(); + + DMAMK1 = 1; + DEN1 = 0; + while( ( SSR02L & TSF0 ) != 0 ) + { + u16 i = 0; + if( ++i == 0 ) // ^CAEgH + { + break; + } + } + +// iic_mcu_send_sp(); // ISRŊO̊֐ĂԂ͓̂siėpWX^ҔĵœWJ + { + ST0 = 0x0004; + SOE0 = 0; // M̎͂ƑOɁuvݒ肵ĂB(NACKo) + SO0 = 0x0000 | TAUS_MASK; // SCL +// nop8(); Ă񂶂Ⴞ + NOP(); NOP(); NOP(); NOP(); + NOP(); NOP(); NOP(); NOP(); + SO0 = 0x0400 | TAUS_MASK; // SCL + NOP(); NOP(); NOP(); NOP(); + NOP(); NOP(); NOP(); NOP(); + SO0 = 0x0404 | TAUS_MASK; + } + + IICMK10 = 1; + iic_mcu_busy = false; +} + + + +/* ======================================================== + IIC MCŨoCgo荞 + DMAgp͎gp܂B + @̊荞ݏDMÅ荞݂ɂ΂ȂꍇA + @IIC荞݂̃ZbgԂɍ킸邱Ƃ܂B + ======================================================== */ +__interrupt void int_iic10( ) +{ + EI(); + if( iic_send_wo_dma_len != 0 ) + { + SIO10 = *p_iic_send_wo_dma_dat; + p_iic_send_wo_dma_dat ++; + iic_send_wo_dma_len --; + return; + } + + // Ō̃oCgM + IICMK10 = 1; +// iic_mcu_send_sp(); // ISRŊO̊֐ĂԂ͓̂siėpWX^ҔĵœWJ + { + ST0 = 0x0004; + SOE0 = 0; // M̎͂ƑOɁuvݒ肵ĂB(NACKo) + SO0 = 0x0000 | TAUS_MASK; // SCL + NOP(); NOP(); NOP(); NOP(); + NOP(); NOP(); NOP(); NOP(); + SO0 = 0x0400 | TAUS_MASK; // SCL + NOP(); NOP(); NOP(); NOP(); + NOP(); NOP(); NOP(); NOP(); + SO0 = 0x0404 | TAUS_MASK; + } + + iic_mcu_wo_dma = false; + iic_mcu_busy = false; +} + + + +/* ======================================================== + X[ǔĂяo +@X[uAhXĂŁAACK̊mFB + ACK@@@@@@@@@@@@@@@@@@ԁF0 +@NACK @XgbvRfBVoB@ԁF1 + ======================================================== */ +static err iic_mcu_call_slave( u8 slave ) +{ + iic_mcu_send_st( ); + + SIR02 = SSR02; // NAKG[̃tONA + if( iic_mcu_send_a_byte( slave ) != ERR_SUCCESS ) + { + iic_mcu_send_sp( ); + return ( ERR_NAK ); // w̃X[uȂ / busy + } + + return ( ERR_SUCCESS ); +} + + + +/* ======================================================== + قƂɂPoCĝ + I܂ŋA܂ + ======================================================== */ +static err iic_mcu_send_a_byte( u8 dat ) +{ + IICMK10 = 1; + IICIF10 = 0; + SIO10 = dat; + while( IICIF10 == 0 ) + { +// NOP( ); + } // ʐM + if( SSR02 != 0 ) + { + SIR02 = SSR02; + return ( ERR_NAK ); + } + return ( ERR_SUCCESS ); +} + + + +/* ======================================================== + X^[gRfBV𔭍s + \tgEFA + ======================================================== */ +static void iic_mcu_send_st( ) +{ + SO0 &= ~0x0004; // SDA + nop8(); + + SO0 &= ~0x0400; // SCL + SOE0 = 0x0004; // n[h + + SCR02 = TXE0 | 1 << SLC02 | 7 << DLS02; // MAf[^͂WrbgP + SS0 = 0x0004; // ʐMҋ@ +} + + + +/* ======================================================== + X^[gs + ======================================================== */ +static void iic_mcu_send_re_st( ) +{ + ST0 |= 0x0004; + SO0 |= 0x0400 | TAUS_MASK; // ( SDA = H ), SCL -> H + nop8(); + + SOE0 &= ~0x0004; // ( SCL = H ), SDA -> L + nop8(); + + iic_mcu_send_st( ); +} + + + +/* ======================================================== + XgbvRfBVs + ̑OɁAuŌ̃oCg̑Mv̎ɑOKvłB + ======================================================== */ +static void iic_mcu_send_sp( ) +{ + ST0 = 0x0004; + SOE0 = 0; // M̎͂ƑOɁuvݒ肵ĂB(NACKo) + SO0 = 0x0000 | TAUS_MASK; // SCL + nop8(); + + SO0 = 0x0400 | TAUS_MASK; // SCL + nop8(); + + SO0 = 0x0404 | TAUS_MASK; +} + + + + +/* ======================================================== + ytFW[̏ + ======================================================== */ +void iic_mcu_start( ) +{ + if( iic_mcu_initialized ) + { + return; + } + + iic_mcu_busy = true; + DST1 = 0; + NOP( ); // 2clḱADSTn==0|[O + NOP( ); + DEN1 = 0; + + I2C_PU_on(); + wait_ms( 1 ); // オ̂50usʂ + + SAU0EN = 1; + nop8(); + + SPS0 = 0x0000; // VAjbg̃NbNOB(8M/2)/1 + SMR02 = bSMR0n_FIXEDBIT | bMD0n2; // ȈI2Cɐݒ + SDR02 = 10 << 9; // {[[gݒ 8M/1/(x+1)/2 + + SO0 = 0x0404 | TAUS_MASK; // ŏHH + iic_mcu_wo_dma = false; + + + // oX̃Zbg + IICIF10 = 0; + IICMK10 = 1; + + iic_mcu_send_st(); + + SIO10 = 0xFF; + while( IICIF10 == 0 ){;} // ʐM + iic_mcu_send_sp(); + + SIR02 = SSR02; + + iic_mcu_busy = false; + iic_mcu_initialized = true; +} + + + +/* ======================================================== + W[̒~ + ēxgƂ͏Kv + ======================================================== */ +void iic_mcu_stop( ) +{ + while( iic_mcu_busy ) + {;} // DMA쒆͂҂ + iic_mcu_send_re_st( ); // SCL,SDALLɂ + I2C_PU_off(); + SAU0EN = 0; + iic_mcu_initialized = false; +} + + + + + + + + + + +/* ======================================================== + R[fbN wPoCgx Cg + iic_mcu_write_a_byte CODECs[NAEh + ======================================================== */ +err iic_mcu_write_a_byte_codec( u8 adrs, u8 dat ) +{ + static u8 count; + + // P̎DMAƂNȂłƏI点 + if( iic_mcu_wait_free() != ERR_SUCCESS ) + { + return( ERR_ERR ); + } + + // X^[gRfBVƃX[ǔĂяo... + IICMK10 = 1; + if( iic_mcu_call_slave( IIC_SLA_CODEC ) != ERR_SUCCESS ) + { + iic_mcu_busy = false; + return ( ERR_NOSLAVE ); + } + iic_mcu_send_a_byte( adrs ); + iic_mcu_send_a_byte( dat ); + + // [NAEh + /// X^[gɂă_~[Cg + iic_mcu_send_re_st( ); + iic_mcu_send_a_byte( IIC_SLA_CODEC ); // _~[Cg + iic_mcu_send_a_byte( 0x20 ); + iic_mcu_send_a_byte( count ); + + count ++; + + iic_mcu_send_sp( ); + iic_mcu_busy = false; + return ( ERR_SUCCESS ); +} diff --git a/tags/2.04/i2c_mcu.h b/tags/2.04/i2c_mcu.h new file mode 100644 index 0000000..af2b1d1 --- /dev/null +++ b/tags/2.04/i2c_mcu.h @@ -0,0 +1,36 @@ +#ifndef __ic2_mcu__ +#define __ic2_mcu__ + + +// ======================================================== +#define ERR_OK 0 +#define ERR_NAK 1 +#define ERR_NOSLAVE 2 + + + +// ======================================================== +extern volatile bit iic_mcu_busy; +extern bit iic_mcu_wo_dma; + +extern u8 iic_mcu_result; + + +// ======================================================== +err iic_mcu_read( u8 SLA, u8 adrs, u8 len, u8 * dest ); +u8 iic_mcu_read_a_byte( u8 SLA, u8 adrs ); + +err iic_mcu_write( u8 SLA, u8 adrs, u8 len, void * src ); +err iic_mcu_write_a_byte( u8 SLA, u8 adrs, u8 dat ); + +err iic_mcu_write_a_byte_codec( u8 adrs, u8 dat ); + + +// ̒ʐM܂B +#define iic_mcu_set_wo_dma() { while( iic_mcu_busy ){;} iic_mcu_wo_dma = 1; } + +void iic_mcu_start( ); +void iic_mcu_stop( ); + + +#endif diff --git a/tags/2.04/i2c_twl.c b/tags/2.04/i2c_twl.c new file mode 100644 index 0000000..48c1447 --- /dev/null +++ b/tags/2.04/i2c_twl.c @@ -0,0 +1,231 @@ +#ifndef _WIN32 + +#pragma sfr /* @\WX^gp */ + +#endif + + +/*============================================================================*/ + +#include "config.h" + +#ifndef _WIN32 + +#pragma interrupt INTIICA0 int_iic_twl RB2 + +#endif + +#include "incs.h" +#include "i2c_twl_defs.h" +#include "i2c_twl.h" + +extern u8 vreg_twl[]; + +#ifdef _MCU_BSR_ +//#ifdef _MODEL_TS0_ || _MODEL_WM0_ + +// [LOfI2Ct +#define ACKD ACKD0 +#define ACKE ACKE0 +#define COI COI0 +#define IICAEN IICA0EN +#define IICRSV IICRSV0 +#define IICA IICA0 +#define IICAIF IICAIF0 +#define IICAMK IICAMK0 +#define IICAPR0 IICAPR00 +#define IICAPR1 IICAPR10 +#define IICCTL0 IICCTL00 +#define IICE IICE0 +#define IICF IICF0 +#define IICS IICS0 +#define IICWH IICWH0 +#define IICWL IICWL0 +#define LREL LREL0 +#define SPD SPD0 +#define SPIE SPIE0 +#define STCEN STCEN0 +#define STD STD0 +#define SVA SVA0 +#define WREL WREL0 +#define WTIM WTIM0 +#define SMC SMC0 +#define TRC TRC0 + +#endif // _MCU_BSR_ + +#ifndef _MCU_BSR_ + +// ke3̎̓_~[֐ +void IIC_twl_Stop( void ) +{ +} +void IIC_twl_Init( void ) +{ +} +#else // _MCU_BSR_ + + + +enum IIC_TWL_STATE{ + WAIT_ADRS = 0, + WAIT_DATA, + DATA_READED +}; + + + + +/*============================================================================*/ + +// I@̓}NȂ̂ŁAreturn̓C[vɖ߂܂B +#define wait_next { \ + tot = 0; \ + while( IICAIF != 1 ){ \ + tot ++; \ + if( tot == 0 ){ \ + LREL = 1; \ + return; \ + } \ + } \ +} + + +__interrupt void int_iic_twl( ) +{ + u8 vreg_adrs; + u8 state; + + // @ + WREL = 1; // EFCgĎ̃oCg҂ + WDT_Restart(); + state = WAIT_ADRS; + + while( 1 ) + { + u8 my_iics; + + { + u16 tot; + wait_next; // PoCgM҂ + } + + my_iics = IICS; + IICAIF = 0; + + if( my_iics & 0x02 ) // ( STD && !SPD ) + { + // X^[gRfBV + if( ( my_iics & 0x08 ) == 0 ) // ( TRC ) MtO 0:}CRM + { + // @f}CRłATWLgCƂƂ + // ɗ̂̓X[uĂяo̎ // + WREL = 1; + state = WAIT_ADRS; + /// WX^AhX̂҂ + } + else + { + // BR Rł̃X[uĂяo(X^[gRfBV) // + IICA = vreg_twl_read( vreg_adrs ); // f[^M + // Xgbv҂ALREL = 1 ɂȂƁAMobt@j󂳂邱Ƃ + state = DATA_READED; + } + } + else if( ( my_iics & 0x03 ) == 0 ) // ( !STD && !SPD ) + { + u8 rcvd; + + // 炩M + rcvd = IICA; + WREL = 1; + + if( state == WAIT_ADRS ) + { + // A + vreg_adrs = adrs_table_twl_ext2int( rcvd ); + /// f[^邩AX^[gœǂݏô҂ + state = WAIT_DATA; + } + else if( state == DATA_READED ) + { + // f[^1oCgM㔭 + LREL = 1; + return; + } + else + { + // BW + // f[^܂ + SVA = 0x5A; // _~[ + LREL = 1; // X^[gRfBV҂(AݖΉ̂) + vreg_twl_write( vreg_adrs, rcvd ); + SVA = IIC_T_SLAVEADDRESS; + return; // M܂ // + } + } + else if( my_iics & 0x01 ) // SPD + { + // I + LREL = 1; + return; + } + else + { + // NOP(); + } + } +} + + + +/*****************************************************/ +void IIC_twl_Init( void ) +{ + + IICAEN = 1; + + IICE = 0; /* IICA disable */ + + IICAMK = 1; /* INTIICA disable */ + IICAIF = 0; /* clear INTIICA interrupt flag */ + + IICAPR0 = 0; /* set INTIICA high priority */ + IICAPR1 = 0; /* set INTIICA high priority */ + P20 &= ~0x3; + + SVA = IIC_T_SLAVEADDRESS; + IICF = 0x01; + + STCEN = 1; // X^[g̋ + IICRSV = 1; // ʐM\Ȃ:X[uɓO + + SPIE = 0; // XgbvRfBVł̊荞݂֎~ + WTIM = 1; // ACKԂclkLɌŒ肷 + ACKE = 1; // _CPU͖Ď̒ʐM͂߂邩ȂőclkJȂƂȂ + + IICWH = 5; + IICWL = 10; // LԂ̒iHj + + SMC = 1; + + IICAMK = 0; // 荞݂ + + IICE = 1; + + PM20 &= ~0x3; /* set clock pin for IICA */ + + LREL = 1; +} + + + +//**************************************************************************** +void IIC_twl_Stop( void ) +{ + IICE = 0; /* IICA disable */ + IICAEN = 0; +} + + +#endif diff --git a/tags/2.04/i2c_twl.h b/tags/2.04/i2c_twl.h new file mode 100644 index 0000000..0f608b0 --- /dev/null +++ b/tags/2.04/i2c_twl.h @@ -0,0 +1,7 @@ +#ifndef _iic_twl_ +#define _iic_twl_ + +void IIC_twl_Init( void ); +void IIC_twl_Stop( void ); + +#endif diff --git a/tags/2.04/i2c_twl_defs.h b/tags/2.04/i2c_twl_defs.h new file mode 100644 index 0000000..be5d566 --- /dev/null +++ b/tags/2.04/i2c_twl_defs.h @@ -0,0 +1,196 @@ +#ifndef _MDSERIAL_ +#define _MDSERIAL_ + + +/* IIC operation enable (IICE0) */ +#define IIC0_OPERATION 0x80 +#define IIC0_OPERATION_DISABLE 0x00 /* stop operation */ +#define IIC0_OPERATION_ENABLE 0x80 /* enable operation */ + +/* Exit from communications (LREL0) */ +#define IIC0_COMMUNICATION 0x40 +#define IIC0_COMMUNICATION_NORMAL 0x00 /* normal operation */ +#define IIC0_COMMUNICATION_EXIT 0x40 /* exit from current communication */ + +/* Wait cancellation (WREL0) */ +#define IIC0_WAITCANCEL 0x20 +#define IIC0_WAIT_NOTCANCEL 0x00 /* do not cancel wait */ +#define IIC0_WAIT_CANCEL 0x20 /* cancel wait */ + +/* Generation of interrupt when stop condition (SPIE0) */ +#define IIC0_STOPINT 0x10 +#define IIC0_STOPINT_DISABLE 0x00 /* disable */ +#define IIC0_STOPINT_ENABLE 0x10 /* enable */ + +/* Wait and interrupt generation (WTIM0) */ +#define IIC0_WAITINT 0x08 +#define IIC0_WAITINT_CLK8FALLING 0x00 /* generate at the eighth clocks falling edge */ +#define IIC0_WAITINT_CLK9FALLING 0x08 /* generated at the ninth clocks falling edge */ + +/* Acknowledgement control (ACKE0) */ +#define IIC0_ACK 0x04 +#define IIC0_ACK_DISABLE 0x00 /* enable acknowledgement */ +#define IIC0_ACK_ENABLE 0x04 /* disable acknowledgement */ + +/* Start condition trigger (STT0) */ +#define IIC0_STARTCONDITION 0x02 +#define IIC0_START_NOTGENERATE 0x00 /* do not generate start condition */ +#define IIC0_START_GENERATE 0x02 /* generate start condition */ + +/* Stop condition trigger (SPT0) */ +#define IIC0_STOPCONDITION 0x01 +#define IIC0_STOP_NOTGENERATE 0x00 /* do not generate stop condition */ +#define IIC0_STOP_GENERATE 0x01 /* generate stop condition */ + +/* + IIC Status Register 0 (IICS0) +*/ +/* Master device status (MSTS0) */ +#define IIC0_MASTERSTATUS 0x80 +#define IIC0_STATUS_NOTMASTER 0x00 /* slave device status or communication standby status */ +#define IIC0_STATUS_MASTER 0x80 /* master device communication status */ + +/* Detection of arbitration loss (ALD0) */ +#define IIC0_ARBITRATION 0x40 +#define IIC0_ARBITRATION_NO 0x00 /* arbitration win or no arbitration */ +#define IIC0_ARBITRATION_LOSS 0x40 /* arbitration loss */ + +/* Detection of extension code reception (EXC0) */ +#define IIC0_EXTENSIONCODE 0x20 +#define IIC0_EXTCODE_NOT 0x00 /* extension code not received */ +#define IIC0_EXTCODE_RECEIVED 0x20 /* extension code received */ + +/* Detection of matching addresses (COI0) */ +#define IIC0_ADDRESSMATCH 0x10 +#define IIC0_ADDRESS_NOTMATCH 0x00 /* addresses do not match */ +#define IIC0_ADDRESS_MATCH 0x10 /* addresses match */ + +/* Detection of transmit/receive status (TRC0) */ +#define IIC0_STATUS 0x08 +#define IIC0_STATUS_RECEIVE 0x00 /* receive status */ +#define IIC0_STATUS_TRANSMIT 0x08 /* transmit status */ + +/* Detection of acknowledge signal (ACKD0) */ +#define IIC0_ACKDETECTION 0x04 +#define IIC0_ACK_NOTDETECTED 0x00 /* ACK signal was not detected */ +#define IIC0_ACK_DETECTED 0x04 /* ACK signal was detected */ + +/* Detection of start condition (STD0) */ +#define IIC0_STARTDETECTION 0x02 +#define IIC0_START_NOTDETECTED 0x00 /* start condition not detected */ +#define IIC0_START_DETECTED 0x02 /* start condition detected */ + +/* Detection of stop condition (SPD0) */ +#define IIC0_STOPDETECTION 0x01 +#define IIC0_STOP_NOTDETECTED 0x00 /* stop condition not detected */ +#define IIC0_STOP_DETECTED 0x01 /* stop condition detected */ + +/* + IIC Flag Register 0 (IICF0) +*/ +/* STT0 clear flag (STCF) */ +#define IIC0_STARTFLAG 0x80 +#define IIC0_STARTFLAG_GENERATE 0x00 /* generate start condition */ +#define IIC0_STARTFLAG_UNSUCCESSFUL 0x80 /* start condition generation unsuccessful */ + +/* IIC bus status flag (IICBSY) */ +#define IIC0_BUSSTATUS 0x40 +#define IIC0_BUS_RELEASE 0x00 /* bus release status */ +#define IIC0_BUS_COMMUNICATION 0x40 /* bus communication status */ + +/* Initial start enable trigger (STCEN) */ +#define IIC0_STARTWITHSTOP 0x02 +#define IIC0_START_WITHSTOP 0x00 /* generation of a start condition without detecting a stop condition */ +#define IIC0_START_WITHOUTSTOP 0x02 /* generation of a start condition upon detection of a stop condition */ + +/* Communication reservation function disable bit (IICRSV) */ +#define IIC0_RESERVATION 0x01 +#define IIC0_RESERVATION_ENABLE 0x00 /* enable communication reservation */ +#define IIC0_RESERVATION_DISABLE 0x01 /* disable communication reservation */ + +/* + IIC clock selection register 0 (IICCL0) +*/ +#define IICCL0_INITIALVALUE 0x00 +/* Detection of SCL0 pin level (CLD0) */ +#define IIC0_SCLLEVEL 0x20 +#define IIC0_SCL_LOW 0x00 /* clock line at low level */ +#define IIC0_SCL_HIGH 0x20 /* clock line at high level */ + +/* Detection of SDA0 pin level (DAD0) */ +#define IIC0_SDALEVEL 0x10 +#define IIC0_SDA_LOW 0x00 /* data line at low level */ +#define IIC0_SDA_HIGH 0x10 /* data line at high level */ + +/* Operation mode switching (SMC0) */ +#define IIC0_OPERATIONMODE 0x08 +#define IIC0_MODE_STANDARD 0x00 /* operates in standard mode */ +#define IIC0_MODE_HIGHSPEED 0x08 /* operates in high-speed mode */ + +/* Digital filter operation control (DFC0) */ +#define IIC0_DIGITALFILTER 0x04 +#define IIC0_FILTER_OFF 0x00 /* digital filter off */ +#define IIC0_FILTER_ON 0x04 /* digital filter on */ + +/* Operation mode switching (CL01, CL00) */ +#define IIC0_CLOCKSELECTION 0x03 + +/* Combine of (SMC0, CL01, CL00)*/ +#define IIC0_CLOCK0 0x00 +#define IIC0_CLOCK1 0x01 +#define IIC0_CLOCK2 0x02 +#define IIC0_CLOCK3 0x03 +#define IIC0_CLOCK4 0x08 +#define IIC0_CLOCK5 0x09 +#define IIC0_CLOCK6 0x0a +#define IIC0_CLOCK7 0x0b + +/* + IIC function expansion register 0 (IICX0) +*/ +/* IIC clock expension (CLX0) */ +#define IIC0_CLOCKEXPENSION 0x01 +#define IIC0_EXPENSION0 0x00 +#define IIC0_EXPENSION1 0x01 + +/* Operation clock (CLX0, SMC0, CL01, CL00) + | IIC0_EXPENSION0 | IIC0_EXPENSION1 | +------------|-------------------|-------------------|---------------------- +IIC0_CLOCK0 | fprs/2 | prohibited | selection clock(fw) + | fprs/88 | | transfer clock + | normal | | mode +------------|-------------------|-------------------|---------------------- +IIC0_CLOCK1 | fprs/2 | prohibited | selection clock(fw) + | fprs/172 | | transfer clock + | normal | | mode +------------|-------------------|-------------------|---------------------- +IIC0_CLOCK2 | fprs/2 | prohibited | selection clock(fw) + | fprs/344 | | transfer clock + | normal | | mode +------------|-------------------|-------------------|---------------------- +IIC0_CLOCK3 |prohibited/fexscl0 | prohibited | selection clock(fw) + | fw/66 | | transfer clock + | normal | | mode +------------|-------------------|-------------------|---------------------- +IIC0_CLOCK4 | fprs/2 | fprs/2 | selection clock(fw) + | fprs/48 | fprs/24 | transfer clock + | high speed | high speed | mode +------------|-------------------|-------------------|---------------------- +IIC0_CLOCK5 | fprs/2 | fprs/2 | selection clock(fw) + | fprs/48 | fprs/24 | transfer clock + | high speed | high speed | mode +------------|-------------------|-------------------|---------------------- +IIC0_CLOCK6 | fprs/4 | fprs/4 | selection clock(fw) + | fprs/96 | fprs/48 | transfer clock + | high speed | high speed | mode +------------|-------------------|-------------------|---------------------- +IIC0_CLOCK7 |prohibited/fexscl0 | prohibited | selection clock(fw) + | fw/18 | | transfer clock + | high speed | | mode +------------|-------------------|-------------------|---------------------- +*/ + +#define ADDRESS_COMPLETE 0x80 +#define IIC_MASTER_FLAG_CLEAR 0x00 + +#endif diff --git a/tags/2.04/incs.h b/tags/2.04/incs.h new file mode 100644 index 0000000..cd33a79 --- /dev/null +++ b/tags/2.04/incs.h @@ -0,0 +1,58 @@ +#ifndef _WIN32 +#pragma SFR +#pragma di +#pragma ei +#pragma nop +#pragma stop +#pragma halt +#endif + +#ifndef _WIN32 +#pragma section @@CODE ROM_CODE +//#pragma section @@CNST ROM_CNST +#endif + +#ifdef _WIN32 +// VC̐Ԑǂɂ +#include "sim/simOnWin.h" +# endif + + + +//========================================================= +#ifndef _incs_h_ +#define _incs_h_ + +// v_pc_ƂŐ؂ւĂ܂ +#define _mcu_ + +#include "jhl_defs.h" +#include "user_define.h" + +#include "hal.h" + +#include "bsr_system.h" +#include "renge\renge.h" +#include "loader.h" + +#include "vreg_ctr.h" +#include "vreg_twl.h" + +#include "i2c_mcu.h" +#include "i2c_twl.h" + +#include "rtc.h" + +#include "accero.h" + +#include "pm.h" + +#include "sw.h" + +#include "adc.h" + +#include "wdt.h" + +//========================================================= + +#endif diff --git a/tags/2.04/incs_loader.h b/tags/2.04/incs_loader.h new file mode 100644 index 0000000..4bb13b5 --- /dev/null +++ b/tags/2.04/incs_loader.h @@ -0,0 +1,47 @@ +#ifndef _WIN32 +#pragma SFR +#pragma di +#pragma ei +#pragma nop +#pragma stop +#pragma halt + + +#pragma section @@CODE LDR_CODE +#pragma section @@CODEL LDR_CODL + +//#pragma section @@R_INIT FSL_RINT // ƃX^[gAbv[`l +//#pragma section @@CNST FSL_CNST // ZbgĂȂ +#pragma section @@CNSTL LDR_CNSL + +#endif + +# ifdef _WIN32 +// VC̐Ԑǂɂ +#include "sim/simOnWin.h" +# endif + + +//========================================================= +#include "jhl_defs.h" +#include "user_define.h" + +#include "hal.h" + +#include "bsr_system.h" +#include "renge\renge.h" + +#include "vreg_ctr.h" +#include "vreg_twl.h" + +#include "loader.h" + +#include "i2c_mcu.h" + +#include "WDT.h" + + + +//========================================================= +void firm_update( ); +void firm_restore( ); diff --git a/tags/2.04/ini_VECT.c b/tags/2.04/ini_VECT.c new file mode 100644 index 0000000..10ea9ea --- /dev/null +++ b/tags/2.04/ini_VECT.c @@ -0,0 +1,383 @@ +#ifndef _WIN32 + +#pragma nop + +#endif + +#include "config.h" + +#ifndef _WIN32 +//#pragma interrupt INTWDTI fn_intwdti // gp +//#pragma interrupt INTLVI fn_intlvi // gp + +//#pragma interrupt INTP0 intp0_slp // SLP (CPUAv) |[O +//#pragma interrupt INTP1 fn_intp1 // (I2C) +//#pragma interrupt INTP2 fn_intp2 // (I2C) +//#pragma interrupt INTP3 fn_intp3 // +#pragma interrupt INTP4 intp4_extdc // EXTDC, doffN̂݁Bʏ̓|[O +#pragma interrupt INTP5 intp5_shell // SHELL_CLOSE, doffN̂݁Bʏ̓|[O +#pragma interrupt INTP6 intp6_PM_irq // CODECoRŋPMICւ̃R}h + +//#ifdef _MCU_BSR_ // 荞݂͎̂̂g܂ +//#pragma interrupt INTP21 intp21_RFTx // dgMpX +//#else +//#pragma interrupt INTP7 intp21_RFTx +//#endif + + +/* + + accero +#ifdef _MCU_BSR_ +#pragma interrupt INTP23 intp23_ACC_ready RB3 // xZTAf[^ +#endif +*/ + +//#pragma interrupt INTCMP0 fn_intcmp0 +//#pragma interrupt INTCMP1 fn_intcmp1 +//#pragma interrupt INTDMA0 fn_intdma0 +#pragma interrupt INTDMA1 int_dma1 + +//#pragma interrupt INTST0 fn_intst0 +/* #pragma interrupt INTCSI00 fn_intcsi00 */ +//#pragma interrupt INTSR0 fn_intsr0 +/* #pragma interrupt INTCSI01 fn_intcsi01 */ +//#pragma interrupt INTSRE0 fn_intsre0 + +//#pragma interrupt INTST1 fn_intst1 +/* #pragma interrupt INTCSI10 fn_intcsi10 */ +#pragma interrupt INTIIC10 int_iic10 +//#pragma interrupt INTSR1 fn_intsr1 +//#pragma interrupt INTSRE1 fn_intsre1 + + +/* +// TS̓}U{ŃeRAWM͉H}eRŌLjvc +#pragma interrupt INTIICA1 int_iic_ctr RB1 + +#pragma interrupt INTIICA0 int_iic_twl RB2 +*/ + +//#pragma interrupt INTTM00 fn_inttm00 +//#pragma interrupt INTTM01 fn_inttm01 +//#pragma interrupt INTTM02 fn_inttm02 +//#pragma interrupt INTTM03 fn_inttm03 + +#pragma interrupt INTAD int_adc +#pragma interrupt INTRTC int_rtc +#pragma interrupt INTRTCI int_rtc_int +#pragma interrupt INTKR int_kr +//#pragma interrupt INTMD fn_intmd + +//#pragma interrupt INTTM04 fn_inttm04 +//#pragma interrupt INTTM05 fn_inttm05 +//#pragma interrupt INTTM06 fn_inttm06 +//#pragma interrupt INTTM07 fn_inttm07 + + +//#define _irq_debug_ +/****************************************************/ +/* gp̃_~[֐` */ +/****************************************************/ +__interrupt void fn_intwdti( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +__interrupt void fn_intlvi( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +__interrupt void fn_intp0(){ +#ifdef _irq_debug_ +while( 1 ) + { + NOP(); + } +#endif +} + +__interrupt void fn_intp1( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} // +__interrupt void fn_intp2( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} +__interrupt void fn_intp3( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + + +__interrupt void intp21_RFTx( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + + +//__interrupt void fn_intp4(){ while(1){} } // pm.c +//__interrupt void fn_intp5(){ while(1){} } // pm.c +//__interrupt void fn_intp6(){ while(1){} } // pm.c +//__interrupt void fn_intp7(){ while(1){} } // led.c +//__interrupt void fn_intp21(){ while(1){} } // led.c + +__interrupt void fn_intcmp0( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +__interrupt void fn_intcmp1( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +__interrupt void fn_intdma0( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +//__interrupt void fn_intdma1(){} // i2c_mcu.cɂ + +__interrupt void fn_intst0( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +/* __interrupt void fn_intcsi00(){} */ +__interrupt void fn_intsr0( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +/* __interrupt void fn_intcsi01(){} */ +__interrupt void fn_intsre0( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +__interrupt void fn_intst1( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +/* __interrupt void fn_intcsi10(){} */ +//__interrupt void fn_intiic10(){ while(1){} } +__interrupt void fn_intsr1( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +__interrupt void fn_intsre1( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +//__interrupt void fn_intiica(){} // i2c.cɂ +/* __interrupt void fn_inttm00(){} *//* sub.cɂĒ` */ +__interrupt void fn_inttm01( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +__interrupt void fn_inttm02( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} +__interrupt void fn_inttm03( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +//__interrupt void fn_intad(){ while(1){} } // adc.c +__interrupt void fn_intrtc( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +//__interrupt void int_rtcint(){} // rtc.cɂ +//__interrupt void fn_intkr(){} // main.c +__interrupt void fn_intmd( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +__interrupt void fn_inttm04( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +__interrupt void fn_inttm05( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +__interrupt void fn_inttm06( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + +__interrupt void fn_inttm07( ) +{ +#ifdef _irq_debug_ + while( 1 ) + { + NOP(); + } +#endif +} + + + +/* ======================================================== + L[^[荞 + ======================================================== */ +__interrupt void int_kr( ) +{ + // N邾 +} + + + +/* ======================================================== + ext dc + ======================================================== */ +__interrupt void intp4( ) +{ + // N邾 +} + + + +/* ======================================================== + shell close + ======================================================== */ +__interrupt void intp5( ) +{ + // N邾 +} + + +#else + +#include "sim/sim_interrupt_decrare.c" + +#endif + diff --git a/tags/2.04/jhl_defs.h b/tags/2.04/jhl_defs.h new file mode 100644 index 0000000..b0b36c6 --- /dev/null +++ b/tags/2.04/jhl_defs.h @@ -0,0 +1,29 @@ +#ifndef __jhl_defs_h__ +#define __jhl_defs_h__ + +typedef unsigned char u8; +typedef signed char s8; +typedef unsigned short u16; +typedef signed short s16; + +typedef unsigned short ux16; +typedef signed short sx16; + +#define true 1 +#define false 0 + + +// typedef unsigned char err; + +#include "config.h" + +#define set_bit( cond, reg, pos ) \ +{ \ + if( cond ){ \ + reg |= pos; \ + }else{ \ + reg &= ~pos; \ + } \ +} + +#endif diff --git a/tags/2.04/led.c b/tags/2.04/led.c new file mode 100644 index 0000000..9dc9cc0 --- /dev/null +++ b/tags/2.04/led.c @@ -0,0 +1,349 @@ +/* ======================================================== + LED.c + ======================================================== */ +#ifndef _WIN32 + +#pragma sfr + +#endif + +#include "incs.h" +#include "led.h" + + + +// ======================================================== +// TPS0 +#define BIT_PRS012 ( 1 << 2 ) +#define BIT_PRS002 ( 1 << 6 ) + +// TMR0 +#define BIT_CKS0 15 +#define BIT_CCS0 12 +#define BIT_MASTER0 11 +#define BIT_STS0 8 +#define BIT_CIS0 6 +#define BIT_MD123 1 +#define BIT_MD0 0 + + + +// ======================================================== +bit ledInitialized; + + +// m点LED̃p^[f[^ +uni_info_LED info_LED; + + +bit info_led_off; +bit info_led_override; + + +// [dۂ +extern bit BT_IN_CHG_delayed_n; + + +// ======================================================== +#define led_fade_to( now, goal ) now = fade_to( now, goal ) + +/* ======================================================== + reg_ledgoalɂȂ܂ŃOf[V + Ƃ肠AXebvŒ + ====================================================== */ +u8 fade_to( u8 now, u8 goal ) +{ + if( now != goal ) + { + if( now > goal ) + { + now --; + } + else + { + now ++; + } + } + return( now ); +} + + + + +// ======================================================== +#define led_fade_to2( led, status ) \ + led = fade_to2( status ) + + +u8 fade_to2( st_LED_dim_status* status ) +{ + if( status->now != status->to ) + { + if( abs(( status->to - status->now )) > abs(status->delta) ) + { + status->now += status->delta; + } + else + { + status->now = status->to; + } + } + return( status->now / 128 ); +} + + + + +// ======================================================== + + +// ======================================================== +void LED_init( ) +{ +/** + PWM̃ZbgAƂ肠S + + }X^`lFO@(P01:/reset2)@}X^[͋`lłȂ + X[u@@@@P@rksnB(Rc kdcH) + @@@@@@@@Q@J + @@@@@@@@R@WiFi + @@@@@@@@S@(s͂qsb32kHz out Ɏgp) + @@@@@@@@T@[d + @@@@@@@@U@d k + @@@@@@@@V@d g + */ + TAU0EN = 1; + TPS0 = BIT_PRS012 | BIT_PRS002; // }X^[NbNCK01,8M/2 /2^4 = 250kHz + + TMR00 = + 1 << BIT_CKS0 | 0 << BIT_CCS0 | 1 << BIT_MASTER0 | 0 << BIT_STS0 | 0 + << BIT_CIS0 | 0 << BIT_MD123 | 1 << BIT_MD0; + TMR01 = TMR02 = TMR03 = TMR04 = TMR05 = TMR06 = TMR07 = + 1 << BIT_CKS0 | 0 << BIT_CCS0 | 0 << BIT_MASTER0 | 4 << BIT_STS0 | 0 + << BIT_CIS0 | 4 << BIT_MD123 | 1 << BIT_MD0; + ISC = 0; + TOM0 = 0x00FE; // o̓[hB4PWMo͂Ȃ1ɂȂTO5ȍ~ɃNbN͂Ȃ + + TOL0 = 0x0000; // o͂𔽓]邩tO + + TO0 = 0x0000; // ^C}[쒆ŁA^C}[o͂ɂĂȂƂ̃s̃b`B^C}[o͂gȂȂO + TOE0 = 0x00EE; // TOx^C}[W[H + + TS0 = 0x00EF; // Jn + + TDR00 = LED_BRIGHT_MAX - 1; // 10bit + +// system_status.info_fullcolor = 1; + + LED_duty_notify_red = 0; + LED_duty_notify_blu = 0; + LED_duty_notify_grn = 0; + LED_pow_red = 0; + LED_CAM = 0; + + if( system_status.reboot ) + { + vreg_ctr[VREG_C_LED_POW] = LED_POW_ILM_AUTO; + LED_duty_pow_blu = LED_BRIGHT_MAX; + } + info_led_off = false; + ledInitialized = true; +} + + + +void LED_stop( ) +{ + TT0 = 0x00EF; // Ē~iȂƂ߁j + TOE0 = 0x0000; // TOx^C}[W[H(GPIOɂȂ) + TAU0EN = 0; + LED_pow_red = 0; + LED_CAM = 0; + ledInitialized = false; +} + + + + + + + +/* ======================================================== + * 荞݂͎̂̂g܂ * + LED_Wifi 3 + ======================================================== */ +void tsk_led_wifi( ) +{ + static u8 task_interval; + static u8 state_wifi_tx; + static u8 flag_wifi_TX; + + if( task_interval-- != 0 ) + { + return; + } + + // MpX̃b` + if( WIFI_txLatch ) // 荞݃tÔ̂gĂ܂ + { + WIFI_txLatch = 0; + flag_wifi_TX = 1; + } + + if( flag_wifi_TX != 0 ) + { + vreg_ctr[ VREG_C_STATUS_1 ] |= REG_BIT_WIFI_TX; + // Mp^[ + switch ( state_wifi_tx ) + { + case ( 1 ): + case ( 3 ): + case ( 5 ): + LED_duty_WiFi = 0; + break; + default: + LED_duty_WiFi = vreg_ctr[VREG_C_LED_BRIGHT]; + } + state_wifi_tx ++; + if( state_wifi_tx == 32 ) // _ŌA_ĂԂ̒ + { + state_wifi_tx = 0; + flag_wifi_TX --; + } + task_interval = 25; + return; + } + else + { + task_interval = 30; + // MtO҂ + vreg_ctr[ VREG_C_STATUS_1 ] &= ~REG_BIT_WIFI_TX; + if( vreg_ctr[VREG_C_LED_WIFI] == WIFI_LED_OFF ) + { + LED_duty_WiFi = 0; + return; + } + else + { + if( LED_duty_WiFi == vreg_ctr[VREG_C_LED_BRIGHT] ) + { + return; + } + else if( LED_duty_WiFi < vreg_ctr[VREG_C_LED_BRIGHT] ) + { + LED_duty_WiFi ++; + } + else + { + LED_duty_WiFi --; + } + } + task_interval = 3; + return; + } +} + + + + +bit info_led_pattern_updated; +/* ======================================================== + m点LED + ======================================================== */ +// Of[VvZȂ +static void calc_info_led_fade_out( st_LED_dim_status* tgt_led ) +{ + tgt_led -> to = 0; + tgt_led -> delta = ( 0 - tgt_led -> now ) / 64; +} + + +static void calc_info_led_next_frame( st_LED_dim_status* tgt_led, u8 color ) +{ + tgt_led -> to = color * 128; + // Of[Ṽf^vZ + tgt_led -> delta = (( tgt_led -> to - tgt_led -> now ) ) / info_LED.info_LED.fade_time; +} + + +// { +void tsk_led_notify( ) +{ + static u8 time_to_next_frame; + static u8 frame; + static u8 loops; + static st_LED_dim_status LED_dim_status_info_R, LED_dim_status_info_G, LED_dim_status_info_B; + + if( info_led_override ) + { + // dr؂ꂪD悷 + return; + } + + if( system_status.pwr_state == ON_TRIG ) + { + LED_duty_notify_blu = 0; + LED_duty_notify_red = 0; + LED_duty_notify_grn = 0; + LED_dim_status_info_R.now = 0; + LED_dim_status_info_G.now = 0; + LED_dim_status_info_B.now = 0; + } + + if( info_led_off ) // doffȂNjoff + { + // tF[hAEg + calc_info_led_fade_out( &LED_dim_status_info_R ); + calc_info_led_fade_out( &LED_dim_status_info_G ); + calc_info_led_fade_out( &LED_dim_status_info_B ); + } + else + { + // ʏ^] + if( info_led_pattern_updated ) + { + info_led_pattern_updated = false; + vreg_ctr[ VREG_C_LED_NOTIFY_FLAG ] &= ~REG_BIT_IN_LOOP; + frame = 0; // Ə + time_to_next_frame = 0; + } + else + { + // ̃t[ɐi߂H + if( time_to_next_frame == 0 ) + { + time_to_next_frame = info_LED.info_LED.term; + + if( frame >= NOTIFY_LED_TERM -1 ) + { + vreg_ctr[ VREG_C_LED_NOTIFY_FLAG ] |= REG_BIT_IN_LOOP; + if( info_LED.info_LED.last_loop != 255 ) // 255:[v + { + loops ++; + if( loops > info_LED.info_LED.last_loop ) + { + frame = 0; + } + } + } + else + { + frame = (( frame + 1 ) & 0x1F ); // Ń}XNĂȂƍŏIt[`擪Ԃ̃OfȂ + vreg_ctr[ VREG_C_LED_NOTIFY_FLAG ] &= ~REG_BIT_IN_LOOP; + loops = 0; + } + + // Of[VvZ + calc_info_led_next_frame( &LED_dim_status_info_R, info_LED.info_LED.red[frame] ); + calc_info_led_next_frame( &LED_dim_status_info_G, info_LED.info_LED.grn[frame] ); + calc_info_led_next_frame( &LED_dim_status_info_B, info_LED.info_LED.blu[frame] ); + + } + time_to_next_frame --; + } + } + + led_fade_to2( LED_duty_notify_red, &LED_dim_status_info_R ); + led_fade_to2( LED_duty_notify_grn, &LED_dim_status_info_G ); + led_fade_to2( LED_duty_notify_blu, &LED_dim_status_info_B ); +} diff --git a/tags/2.04/led.h b/tags/2.04/led.h new file mode 100644 index 0000000..e92d209 --- /dev/null +++ b/tags/2.04/led.h @@ -0,0 +1,146 @@ +#ifndef __led__ +#define __led__ + + + +// ==================================== + +//#define LED_CHARGE P2.4 // PMŒ` + +// LED_DUTY +#define LED_duty_pow_blu TDR06 +#define LED_duty_WiFi TDR03 + +#define LED_duty_3d TDR01 +#define LED_duty_notify_red TDR07 +#define LED_duty_notify_grn TDR05 +#define LED_duty_notify_blu TDR02 + +// dutyς܂ +#ifndef _WIN32 +#define LED_pow_red P4.2 +#define LED_CAM P7.5 +#else +#define LED_pow_red mcuRegP[ _P4_2 ] +#define LED_CAM mcuRegP[ _P7_5 ] +#endif + +#define NOTIFY_LED_TERM 32 + + +#define LED_BRIGHT_MAX 0x00FF + +// ==================================== +#define WIFI_txLatch PIF21 // dgMpX + + + +// ==================================== +enum LED_ILUM_MODE +{ + LED_POW_ILM_AUTO = 0, + LED_POW_ILM_ON, + LED_POW_ILM_SLEEP, + LED_POW_ILM_OFF, + LED_POW_ILM_ONLY_RED, + LED_POW_ILM_ONLY_BLUE, + LED_POW_ILM_FORCE_BT_EMPTY +}; + + +enum LED_MODE_3D +{ + LED_3D_ILM_OFF = 0, + LED_3D_ILM_ON +}; + + +// VREG_C_WIFI_LED +enum WIFI_LED_MODE +{ + WIFI_LED_OFF = 0, + WIFI_LED_ON +}; + + +// VREG_C_WIFI_NOTIFY +enum NOTIFY_LED_MODE +{ + NOTIFY_LED_OFF = 0, + NOTIFY_LED_ON, + NOTIFY_LED_PTN0, + NOTIFY_LED_PTN1, + NOTIFY_LED_PTN2 +}; + + +// VREG_C_CAM_LED +enum CAM_LED_MODE +{ + CAM_LED_OFF = 0, + CAM_LED_BLINK, + CAM_LED_ON, + CAM_LED_BY_TWL, + CAM_LED_ON_PLUSE, + CAM_LED_OFF_PLUSE +}; + + + +// m点LED֌W // +typedef struct _st_info_LED +{ + u8 term; // 1t[`bNH + u8 fade_time; // `bNŎ̃t[̐FɒB邩 + u8 last_loop; // ŏIt[JԂH + u8 resv1; + u8 red[32]; + u8 grn[32]; + u8 blu[32]; +}st_info_LED; + +typedef union _uni_info_LED +{ + st_info_LED info_LED; + u8 bindata[ sizeof( st_info_LED ) ]; +}uni_info_LED; + +extern uni_info_LED info_LED; + + +// LED _Ō // +typedef struct _st_led_red_batt_empty +{ + u8 dats[4]; +}st_led_red_batt_empty; + +extern st_led_red_batt_empty led_red_batt_empty; + + +/* + m点LED +*/ +typedef struct _st_LED_dim_status +{ + sx16 to; + sx16 delta; + sx16 now; // _ȉoĂȂĂ͂ȂȂ +}st_LED_dim_status; + + + +// ==================================== +void LED_init( ); +void LED_stop( ); + + +extern void tsk_led_cam(); + + + +// ==================================== +extern bit ledInitialized; +extern bit info_led_override; + + +#endif diff --git a/tags/2.04/led_cam.c b/tags/2.04/led_cam.c new file mode 100644 index 0000000..6e0d28a --- /dev/null +++ b/tags/2.04/led_cam.c @@ -0,0 +1,146 @@ +/******************************************************//** + LED_Cam TO02 +\n BLINK,*_PLUSE ̎́A1͕K̏ԂɂȂ܂B +\n ̊Ԃ OFFBLINK ȂǂƁAOFF܂B + *********************************************************/ +#ifndef _WIN32 + +#pragma sfr + +#endif + +#include "incs.h" +#include "led.h" + + + +// ======================================================== +static u8 state_led_cam = 0; +static u16 task_interval; + +bit cam_led_update; + + + +// ======================================================== +static void cam_led_twl(); + + + +// ======================================================== +void tsk_led_cam( ) +{ + DI(); // WX^ւ݂̏ŋN邱Ƃ邽 + if( !cam_led_update ) + { + if( task_interval != 0 ) + { + task_interval --; + return; + } + } + + cam_led_update = false; // TWL ̃uNݒiꔭ_ĵ + EI(); + + if( system_status.pwr_state == SLEEP ) // sleepA + { + LED_CAM = 0; + state_led_cam = 0; + } + else + { + // uN̂悤ɑ҂ƂȊO͖TN + // (WX^̕ύXɂɔ) + switch ( vreg_ctr[VREG_C_LED_CAM] ) + { + case ( CAM_LED_OFF ): + default: + LED_CAM = 0; + state_led_cam = 0; + break; + + case ( CAM_LED_ON ): + LED_CAM = 1; + state_led_cam = 0; + break; + + case ( CAM_LED_BLINK ): + if( state_led_cam == 0 ) + { + LED_CAM = 1; + state_led_cam = 1; + } + else + { + LED_CAM = 0; + state_led_cam = 0; + } + task_interval = 250; + break; + + case ( CAM_LED_ON_PLUSE ): + if( state_led_cam == 0 ) + { + LED_CAM = 1; + state_led_cam = 1; + task_interval = 250; + } + else + { + vreg_ctr[VREG_C_LED_CAM] = CAM_LED_OFF; + } + break; + + case ( CAM_LED_OFF_PLUSE ): + if( state_led_cam == 0 ) + { + LED_CAM = 0; + state_led_cam = 1; + task_interval = 250; + } + else + { + vreg_ctr[VREG_C_LED_CAM] = CAM_LED_ON; + } + break; + + case( CAM_LED_BY_TWL ): + cam_led_twl(); + } + } // if( system_status.pwr_state == sleep ) ... else ... +} + + + +void cam_led_twl() +{ + // TWL݊ // + switch ( vreg_twl[ REG_TWL_INT_ADRS_CAM ] ){ + case( TWL_CAMLED_OFF ): + LED_CAM = 0; + state_led_cam = 0; + break; + + case( TWL_CAMLED_BLINK ): + if( state_led_cam == 0 ) + { + LED_CAM = 1; + state_led_cam = 1; + } + else + { + LED_CAM = 0; + state_led_cam = 0; + } + task_interval = (u8)( 600 / SYS_INTERVAL_TICK ) + 250; + break; + + case( TWL_CAMLED_ON ): + case( TWL_CAMLED_DEF_ON ): + default: + LED_CAM = 1; + state_led_cam = 1; + break; + } +} diff --git a/tags/2.04/led_pow.c b/tags/2.04/led_pow.c new file mode 100644 index 0000000..5906ee8 --- /dev/null +++ b/tags/2.04/led_pow.c @@ -0,0 +1,269 @@ +/* ======================================================== + // dLED + LED_POW_B,R 6,7 + + TDR00@(0x03FFBTPS0250kHzŃJEgAbvB10bitȂ250HzʂɂȂ) + TDR0x@Duty 0ŏATDR00( =0x03FFȏ)œ_łB + + enum pwr_state_{ + OFF_TRIG = 0, + ON_CHECK, + ON_TRIG, + ON, + SLEEP +}; + +enum LED_ILUM_MODE{ + LED_POW_ILM_AUTO, + LED_POW_ILM_ON, + LED_POW_ILM_SLEEP, + LED_POW_ILM_CEOFF +}; + ======================================================== */ +#ifndef _WIN32 + +#pragma sfr + +#endif + +#include "incs.h" +#include "led.h" + + +// ======================================================== +// X[vł̃e[uB}WB +const u8 LED_PTN_SLEEP[] = { + 25, 38, 52, 68, 83, 98, 110, 119, + 125, 128, 128, 125, 119, 110, 98, 83, + 68, 52, 38, 25, 16, 10, 8, 8, + 8, 8, 8, 8, 8, 8, 10, 16 + }; + + +// LED̓drcLED̓_Ńp^[ +st_led_red_batt_empty led_red_batt_empty = { 0x55, 0x55, 0x55, 0x55 }; +#define LED_SLEEP_FRAME_LEN 71 +#define LED_SLEEP_DIM_LEN 71 +#define LED_SLEEP_FRAME_NUM 32 + + + +// ======================================================== +static void led_pow_normal( ); +static void led_pow_sleep( ); +static void led_pow_bt_empty(); +static u8 led_pow_batt_low(); + +#define led_fade_to( now, goal ) now = fade_to( now, goal ) +extern u8 fade_to( u8 now, u8 goal ); + +#define led_fade_to2( led, status ) led = fade_to2( status ) +extern u8 fade_to2( st_LED_dim_status* status ); + + + +// ======================================================== +// dLED̃X[vp^[̃Xe[^X +static u8 time_to_next_frame_sleep = LED_SLEEP_FRAME_LEN; +static u8 frame_sleep; +static st_LED_dim_status LED_dim_status_sleep; + +extern bit ledInitialized; +extern bit BT_IN_CHG_delayed_n; + + + +// ======================================================== +void tsk_led_pow( ) +{ + if( ! ledInitialized ) + { + return; + // ܂ + } + + info_led_override = false; + + switch ( vreg_ctr[VREG_C_LED_POW] ) + { + case ( LED_POW_ILM_AUTO ): + default: + led_pow_normal( ); + break; + + case ( LED_POW_ILM_SLEEP ): + led_pow_sleep( ); + break; + + case ( LED_POW_ILM_ON ): + led_fade_to( LED_duty_pow_blu, vreg_ctr[VREG_C_LED_BRIGHT] ); + LED_pow_red = 0; + break; + + case ( LED_POW_ILM_OFF ): + led_fade_to( LED_duty_pow_blu, 0 ); + LED_pow_red = 0; + break; + + case ( LED_POW_ILM_ONLY_RED ): + LED_duty_pow_blu = 0; + LED_pow_red = 1; + break; + + case ( LED_POW_ILM_ONLY_BLUE ): + LED_duty_pow_blu = LED_BRIGHT_MAX; + LED_pow_red = 0; + break; + + case ( LED_POW_ILM_FORCE_BT_EMPTY ): + led_pow_bt_empty(); + break; + } + + if( system_status.pwr_state == OFF || system_status.pwr_state == ON_CHECK ) + { + LED_pow_red = 0; + info_led_override = false; + } + + if( info_led_override ) + { + LED_duty_notify_blu = 0; + LED_duty_notify_grn = 0; + LED_duty_notify_red = ( LED_pow_red == 0 )? 0 : 255; + } +} + + + +/* ======================================================== + drcʂŁA@ԁԓ_ + ======================================================== */ +static void led_pow_normal( ) +{ + time_to_next_frame_sleep = LED_SLEEP_FRAME_LEN; + frame_sleep = 0; + LED_dim_status_sleep.now = (sx16)LED_duty_pow_blu * 128; + + if( led_pow_batt_low() != 0 ) // Ԃ̓_łĂ܂ + { + return; + // ܂ + } + + // “_ + led_fade_to( LED_duty_pow_blu, vreg_ctr[VREG_C_LED_BRIGHT] ); +} + + + +/* ======================================================== + z^p^[ + drcʂŐԁԓ_łɂ + ======================================================== */ +static void led_pow_sleep( ) +{ + if( led_pow_batt_low() != 0 ) // Ԃ̓_łĂ܂ + { + time_to_next_frame_sleep = LED_SLEEP_FRAME_LEN; + frame_sleep = 0; + LED_dim_status_sleep.now = (sx16)LED_duty_pow_blu * 128; + return; + // ܂ + } + + LED_dim_status_sleep.to = LED_PTN_SLEEP[frame_sleep] * 128; + + // Of[Ṽf^vZ + LED_dim_status_sleep.delta = (( LED_dim_status_sleep.to - LED_dim_status_sleep.now ) ) / LED_SLEEP_DIM_LEN; + led_fade_to2( LED_duty_pow_blu, &LED_dim_status_sleep ); + + // ̃t[ɐi߂H + time_to_next_frame_sleep --; + if( time_to_next_frame_sleep == 0 ) + { + time_to_next_frame_sleep = LED_SLEEP_FRAME_LEN; + + frame_sleep ++; + if( frame_sleep >= LED_SLEEP_FRAME_NUM -1 ) + { + frame_sleep = 0; + } + } +} + + + +/* ======================================================== + drȂƂ̋ +@ԒlF@0@drȂȂ +@@@@@1@@@@Ȃ̂ŋʃp^[ɂ + ======================================================== */ +static u8 led_pow_batt_low() +{ + if( vreg_ctr[VREG_C_BT_REMAIN] > BATT_TH_LO ) + { + LED_pow_red = 0; + return 0; + // ܂ + } + + if(( vreg_ctr[VREG_C_BT_REMAIN] > BATT_TH_EMPTY ) || !BT_IN_CHG_delayed_n ) + // drcʂ5%i`10%j@܂́Aꖢł[d + { + // ԓ_ + led_fade_to( LED_duty_pow_blu, 0 ); + { + LED_pow_red = 1; + } + + } + else // dr5%@@A_v^Ȃ + { + led_pow_bt_empty(); + } + return 1; +} + + + + +/* ======================================================== +@drȂp^[ +@@wp^[𗬂 +@@m点㏑肷 + ======================================================== */ +static void led_pow_bt_empty() +{ + static u8 delay; + static u8 red_blink_poi; + + info_led_override = true; + + // ԓ_ + led_fade_to( LED_duty_pow_blu, 0 ); + + // Ԃ̓_Ńp^[wł + delay ++; + if( delay < 64 ) // t[̕ێԉ҂ + { + return; + } + delay = 0; + + if( led_red_batt_empty.dats[ red_blink_poi / 8 ] & ( 1 << ( red_blink_poi % 8 )) ) + { + LED_pow_red = 1; + } + else + { + LED_pow_red = 0; + } + red_blink_poi ++; + if( red_blink_poi >= 32 ) + { + red_blink_poi = 0; + } +} + + diff --git a/tags/2.04/loader.c b/tags/2.04/loader.c new file mode 100644 index 0000000..85c7d4e --- /dev/null +++ b/tags/2.04/loader.c @@ -0,0 +1,380 @@ +/* ======================================================== + MCU CTR BSR + 2009/03/30 + JZp c + + u[g[_[ + zXg̒ʐMƁAȏAt@[̃`FbNsB + + ======================================================== */ +#ifndef _WIN32 + +#pragma SFR +#pragma di +#pragma ei +#pragma nop +#pragma stop +#pragma halt +#pragma opc + +#endif +#include "incs_loader.h" + +#include +#include "fsl_user.h" + +#include "i2c_ctr.h" +#include "i2c_mcu.h" +#include "pm.h" +#include "rtc.h" + +#include "reboot.h" + +#include "magic.h" + + + +#define REG_BIT_RESF_WDT 0x10 +#define REG_BIT_RESF_TRAP 0x80 +#define REG_BIT_RESF_LVI 0x01 + + + +// ======================================================== +#if (FSL_DATA_BUFFER_SIZE>0) +fsl_u08 fsl_data_buffer[FSL_DATA_BUFFER_SIZE]; +#endif + + + +#ifdef FSL_INT_BACKUP +static fsl_u08 fsl_MK0L_bak_u08; /* if (interrupt backup required) */ +static fsl_u08 fsl_MK0H_bak_u08; /* { */ +static fsl_u08 fsl_MK1L_bak_u08; /* reserve space for backup information */ +static fsl_u08 fsl_MK1H_bak_u08; /* of interrupt mask flags */ +static fsl_u08 fsl_MK2L_bak_u08; /* */ +static fsl_u08 fsl_MK2H_bak_u08; /* } */ +#endif + + + +// ======================================================== +void hdwinit(); +static void hdwinit2(); +static void chk_platform_type(); +static void chk_firm_broke(); + + +extern void main_loop(); + + + +// ======================================================== +void main( ) +{ + while( 1 ) + { + WDT_Restart( ); + + if( RTCEN ) // TRAP(update)ɂgȂBWDTł͗Ȃ + { + system_status.reboot = true; + } + + { + volatile u8 my_resf = RESF; // ǂނƏ + if( ( my_resf & REG_BIT_RESF_WDT ) != 0 ) + { + vreg_ctr[ VREG_C_MCU_STATUS ] |= REG_BIT_STATUS_WDT_RESET; + // set_irq( VREG_C_IRQ0, REG_BIT_IRQ_WDT_RESET ); + // I2C̏ɍs + system_status.reboot = true; + } + else if( ( my_resf & REG_BIT_RESF_TRAP ) != 0 ) // ( FSL_ForceReset, 'r' ) + { + system_status.reboot = true; + } +/* + else if(( my_resf & REG_BIT_RESF_LVI ) != 0 ) + { + vreg_ctr[ VREG_C_MCU_STATUS ] |= ( 1 << 2 ); + } +*/ + } + + if( !system_status.reboot ) + { + // ʏ̓d + // drڑAƑ҂Ă݂(`^O΍) + u16 pwup_delay0; + for( pwup_delay0 = 0xFFFF; pwup_delay0 != 0; pwup_delay0 -- ){;}; + } + + hdwinit2( ); + +#ifndef _WIN32 + // t@[̐`FbN // + chk_firm_broke(); +#endif + + // V䔻 + chk_platform_type(); + + // ʏ^] + main_loop( ); + } +} + + + +void chk_firm_broke() +{ + u8 i; + u8 comp = 0; + + // [_[Ɩ{͓̂o[WH + /// ւ̃Abvf[g̓rŏIĂȂH + for( i = 0; i < sizeof( __TIME__ ); i++ ) // sizeof( __TIME__ ) = 8 炵 + { + comp += ( *( __far u8 * )( MGC_LOAD + i ) == *( u8 * )( MGC_FOOT + i ) ) ? 0 : 1; + comp += ( *( u8 * )( MGC_HEAD + i ) == *( u8 * )( MGC_FOOT + i ) ) ? 0 : 1; + } + + if( *( u8 * )( MGC_FOOT +2 ) != ':' ) // ς̂܂ + { + comp ++; + } + + if( comp != 0 ) + { + // t@[XgA݂ + firm_restore( ); + // AĂȂBZbgB + } +} + + +/* ======================================================== + fobK‚ȂłƏɔłȂƂ܂B +CTRt@~ + DEV_DET(P12.[2:1]) + +CTR̊J@ + P40,41 !! fobOLP40LMCUN܂I + HH @ + HL NBDV + LH X^hAV + LL ISfobK +======================================================== */ +void chk_platform_type() +{ + // CTRt@~ // + system_status.family = (enum _family)( DEV_DET >> 1 ); /// ... + if( system_status.family == FAMILY_SPFL ) + { + pm_reg_bit_vddlcd = PM_REG_BIT_VDDLCD_AMO; + } + else + { + pm_reg_bit_vddlcd = PM_REG_BIT_VDDLCD_CGS; + } + + // CTR̊J@ // + // ꉞ + system_status.is_dev = false; + system_status.taikendai = false; + system_status.taikendai_nbd = false; + + switch( DIPSW ) + { + case DIPSW_TAIKENDAI: + system_status.taikendai = true; + break; + + case DIPSW_TAIKENDAI_NBD: + system_status.taikendai_nbd = true; + break; + + case DIPSW_ISDEV: + system_status.is_dev = true; + break; + } +#ifdef _FORCE_TAIKENDAI_ + system_status.taikendai = true; +#endif + +#ifdef _FORCE_TAIKENDAI_NBD_ + system_status.taikendai_nbd = true; +#endif +} + + + + +// ======================================================== +void hdwinit( void ) +{ // X^[gAbv[`ɌĂт܂ + DI( ); /* }X^荞݋֎~ */ + + CMC = bits8(0,0,0,1, 0,0,0,0); /* X1U(̓|[g)AXT1gpAd͔U͕sɕtʏ */ + CSC = bits8(1,0,0,0, 0,0,0,0); /* X1UȂAXT1UAU */ + OSMC = 0x01; /* BWX^ */ + CKC = bits8(0,0,0,0, 1,0,0,0); /* CPU/ӃNbN=fMAINAfMAIN=fMXAfCLK=fMX */ + + /*--- doH̐ݒ ---*/ + /* Zbg̃ftHǵAIvVEoCgɂĎw肳 */ + LVIS = 0x00; /* VLVI = 4.22}0.1V */ +// LVIM = 0x00; /* LVI֎~ */ + /* dd(VDD)od(VLVI)Ɋ */ + /* dd(VDD)od tempA[0][1], "offset" => tempA[0][2], "type" => tempA[0][3], "data" => tempA[0][4], "CRC" => tempA[0][5] } + + break if src_in["type"].hex == 01 + break if src_in["len"].hex == 00 + # next if src_in["type"].hex != 00 + if( src_in["type"].hex != 00 ) +# p dat + next + end + + offset = src_in["offset"].hex + next if(( 0x1000 <= offset ) && ( offset < 0x2000 )) + + dataTemp = src_in["data"].scan(/\w\w/) + + ( 0...(src_in["len"].to_s.hex) ).each{|i| + bindata[ offset + i ] = ( dataTemp[ i ] ).to_s.hex + } +end + +### debug enable bit check ############# +# fobO‚ɂȂĂISfobKŋNȂiMCU삵Ȃj +p bindata[0xC3] +if( bindata[0xC3] != 0x04 ) + print( "!E debug enable!!" ) + exit( 1 ) +end + + +### format data and output ############# +4096.times{ + bindata.delete_at(4096) +} +dest.write( bindata[0..(0x4FFF - 0x1000)].pack("c*") ) +dest.close + +printf( "intel-HEX to bsr bin converter\n file converted!\n\n" ) diff --git a/tags/2.04/pedo_alg_thre_det2.c b/tags/2.04/pedo_alg_thre_det2.c new file mode 100644 index 0000000..2dbf6c4 --- /dev/null +++ b/tags/2.04/pedo_alg_thre_det2.c @@ -0,0 +1,574 @@ +/* ******************************************************** + v + 3x̃A^Cf[^AxNg̃moA + 臒l𒴂鎞ԁAԊuAm̑傫臒l؂ւȂ +********************************************************* */ +#ifndef _WIN32 + +#pragma mul +#pragma div +#pragma bcd + +#endif + +#include "incs.h" + +#ifndef _WIN32 +#include +#endif + +#include "accero.h" +#include "pedometer.h" + +#include "pool.h" + +// ======================================================== +// ̍ŏIL^ +// ̏Ԃ̓OǂݏȍԂł̂łȂł +// ԂɃAhX̎Ⴂ̂mۂ̂҂Ă܂... +typedef struct{ + u8 hour_bcd; + u8 day_bcd; + u8 month_bcd; + u8 year_bcd; + u8 min_bcd; + u8 sec_bcd; +}st_calender; + + + +// ======================================================== +static u16 get_long_hour(); +static u16 calc_hours_spend( u8 ); + + + +// ======================================================== +bit pedolog_overflow; // 192ԋL^ς݃tO(i2cœǂ߂) +extern uni_pool pool; // O͂̍\̂̒ +static u8 p_record; // Ȍ݈ʒu +static st_calender cal_log_latest; // ŌɕXV +static u16 last_hour_fny; // fny:from new year +static st_calender cal_temp; +static u16 now_longhour; + + + + + + +// ======================================================== +#define _use_my_sqrt_ +#ifdef _use_my_sqrt_ +static unsigned long my_sqrt( unsigned long ); +#endif + +// N͉[NH +#define is_leapyear( y ) (( y & 0x03 ) == 0 ) +// uNv͉[NH +#define is_firstyear( y ) (( y & 0x03 ) == 1 ) + + +// xZTlFIR-LPFɒʂB̌W +extern const s8 lpf_coeff[]; +#define TAP 64 +#define FIL_COEFF_QUANT 10 + + + +/*========================================================= +@v + ========================================================*/ +void pedometer() +{ + static s16 th_H = 15000; // 臒lBIύX܂ + static s16 th_L = 11000; + static u16 acc_norm[3]; // x̑傫̃qXgB傫 + static u16 acc_norm_temp; + static u8 interval_hh = 0xFF; // R-RԂ̎ԁBZ߂͂B + static u8 time_l; // Őɏ̌oߎ + static u16 peak_l; // J̐[ + static u16 norm_hist[TAP]; + + static u8 hist_indx; + + signed long filterd; + + u8 i; + + u16 sx16,sy16,sz16; + + DI(); + sx16 = abs( (u16)vreg_ctr[VREG_C_ACC_XH] * 256 + vreg_ctr[VREG_C_ACC_XL] ); + sy16 = abs( (u16)vreg_ctr[VREG_C_ACC_YH] * 256 + vreg_ctr[VREG_C_ACC_YL] ); + sz16 = abs( (u16)vreg_ctr[VREG_C_ACC_ZH] * 256 + vreg_ctr[VREG_C_ACC_ZL] ); + EI(); + + // xNg̃m +#ifdef _mcu_ +# ifndef _use_my_sqrt_ + norm_hist[ hist_indx & TAP-1 ] = sqrt( (long)sx16 * ( sx16 / 2 ) + + (long)sy16 * ( sy16 / 2 ) + + (long)sz16 * ( sz16 / 2 ) + ); +# else + norm_hist[ hist_indx & TAP-1 ] = my_sqrt( (long)sx16 * ( sx16 / 2 ) + + (long)sy16 * ( sy16 / 2 ) + + (long)sz16 * ( sz16 / 2 ) + ); +# endif +#endif + +#ifdef _pc_ + norm_hist[ hist_indx & TAP-1 ] = normh * 256 + norml; +#endif + + hist_indx ++; + + // qXgɃtB^(fir)|āA̒l߂ // + filterd = 0; +// for( i = 8; i != 55; i++ ) // WO΂̂ + for( i = 0; i != 46; i++ ) // We[u܂Bp[^ + { + filterd += (signed long)norm_hist[ ( hist_indx + i ) & TAP-1 ] * lpf_coeff[ i ]; + } + + filterd += (4096)*512; // DCZ...Ǝv + acc_norm_temp = (s16)( filterd /1024 & 0xFFFF ); // FIL_COEFF_QUANT琳K +/* + if( acc_norm[0] < acc_norm_temp ) + { + t_rise ++; + if( t_rise == 0 ) + t_rise == 254; + } + else + { + t_rise = 0; + } +*/ + if( acc_norm[0] != acc_norm_temp ) + { + acc_norm[2] = acc_norm[1]; // qXg + acc_norm[1] = acc_norm[0]; + acc_norm[0] = acc_norm_temp; + } + + if( acc_norm[2] <= acc_norm[1] && acc_norm[1] > acc_norm[0] + && acc_norm[0] > th_H ) + // ɑŁA臒l𒴂Ă + { + if( 21 < interval_hh ) + // Őɑ傩̊Ԋuقǂ悢 + { + if(( interval_hh < 160 ) && ( time_l < interval_hh )) + // Jł + { + if( acc_norm[0] - peak_l > 4200 ){ + // ܂ + hosu_increment_if_necessary(); + } + } + interval_hh = 0; + } + // Ȃ񂿂臒l̓IύX + if( acc_norm[0] > 18000 ) + { + th_L = acc_norm[0] - 10000; + } + else + { + th_L = 11000; + } + } + else + { + if( interval_hh != 255 ) // OaZĊyɏ炢̂ + { + interval_hh ++; + } + } + + // (2) ߂̋ɏ̎ + if( acc_norm[2] >= acc_norm[1] && acc_norm[1] < acc_norm[0] + && acc_norm[0] < th_L ) + { + // ɏo + time_l = 0; + peak_l = acc_norm[0]; + } + else + { + if( time_l != 255 ) + { + time_l ++; + } + } +} + + +/*========================================================= +@{P +@@ݐςCNg + @XV + *2011/01/20 + dlύX@OςɂȂ炻Ŏ~߂ + ========================================================*/ + + +#define HOSU_NODATA 0xFFFF +#define HOSU_MAX 0xFFFE + +void hosu_increment_if_necessary() +{ + u8 year_compd; // hourE␳ς݌ݔNBcomp(ensation -ed) + + // ݎ擾 + DI(); + RWAIT = 1; + while( !RWST ){;} + + cal_temp.hour_bcd = HOUR; + cal_temp.day_bcd = DAY; + cal_temp.month_bcd = MONTH; + cal_temp.year_bcd = YEAR; + cal_temp.min_bcd = MIN; + cal_temp.sec_bcd = SEC; + + RWAIT = 0; + EI(); + + year_compd = bcdtob( cal_temp.year_bcd ); + + now_longhour = get_long_hour(); + + // ݃|C^̍XV + if( ! ( vreg_ctr[ VREG_C_ACC_HOSU_L ] == 0 && // vonAŏ̈܂ł͑O񂩂̌oߎԂvZȂ + vreg_ctr[ VREG_C_ACC_HOSU_M ] == 0 && + vreg_ctr[ VREG_C_ACC_HOSU_H ] == 0 )) //. SrbgORŃ[肷̂̓fW^H݂̕ + { + // v~܂ĂԂlĕKvȂi߂ + // ␳vZ@U뎞ōɂȂꍇAA23ɏ㏑ + if( now_longhour == (u16)-1 ) // NA23䈵̂ƂAvZʂ -1 ɂȂĂ + { + now_longhour = 365 * 24 -1; + if( is_firstyear(year_compd) ) + { + now_longhour += 24; + } + year_compd --; + } + fill_hosu_hist_hours( calc_hours_spend( year_compd ) ); // ݃|C^̍XVs + + // OӂŋL^~H + if( pedolog_overflow ) + { + return; + // ܂BO̍XVȂB + } + } + + // CNgėǂ + cal_log_latest = cal_temp; // OXV + last_hour_fny = now_longhour; + + // O@CNg + if( pool.vreg_c_ext.pedo_log[ p_record ] == HOSU_MAX ) + { + // Ȃł܂ + //. v̍vƗ݌vȂȂ̂邽߂낤ǁAǂȂ́H + return; + } + else if( pool.vreg_c_ext.pedo_log[ p_record ] == HOSU_NODATA ) // ̎ԑэŏ̃JEg̎ + { // ꂵȂ1Ȃ + pool.vreg_c_ext.pedo_log[ p_record ] = 1; + } + else + { + // ʏpX + pool.vreg_c_ext.pedo_log[ p_record ] ++; + } + + // ݐς̍XV // + DI(); + if( ++vreg_ctr[ VREG_C_ACC_HOSU_L ] == 0 ) // JXg`FbN + { + if( ++vreg_ctr[ VREG_C_ACC_HOSU_M ] == 0 ) + { + if( ++vreg_ctr[ VREG_C_ACC_HOSU_H ] == 0 ){ + vreg_ctr[ VREG_C_ACC_HOSU_L ] = 255; //. 낢뎸s... + vreg_ctr[ VREG_C_ACC_HOSU_M ] = 255; + vreg_ctr[ VREG_C_ACC_HOSU_H ] = 255; + } + } + } + EI(); +} + + + +/* ======================================================== +󔒂̎ԂK؂0ɂāA +܂ނPԂ̃f[^ʒuɃ|C^Hi߂ +======================================================== */ +static void fill_hosu_hist_hours( u16 hours ) +{ + // OӂH + if( (u16)p_record + hours >= PEDOMETER_LOG_SIZE ) + { + pedolog_overflow = true; + return; + } + + // 󔒂̐Ԃ̐ݒ + while( hours != 0 ) + { + // Vdl@ςŒ~ + p_record ++; +#if 1 // debug + if( p_record >= PEDOMETER_LOG_SIZE ) + { + pedolog_overflow = true; +// dbg_nop(); // ɗ悤ƃoO + break; + } + else +#endif + { + pool.vreg_c_ext.pedo_log[ p_record ] = 0; + } + hours --; + } + + return; +} + + + +/* ======================================================== +󔒂̎ԂK؂0ɂāA +܂ނPԂ̃f[^ʒuɃ|C^Hi߂ +======================================================== */ +void clear_hosu_hist() +{ + u8 hours = PEDOMETER_LOG_SIZE; + do + { + hours --; + pool.vreg_c_ext.pedo_log[ hours ] = 0xFFFF; + } + while( hours != 0 ); + + DI(); + vreg_ctr[ VREG_C_ACC_HOSU_L ] = 0; + vreg_ctr[ VREG_C_ACC_HOSU_M ] = 0; + vreg_ctr[ VREG_C_ACC_HOSU_H ] = 0; + p_record = 0; + pedolog_overflow = false; + EI(); +} + + +extern u8 iic_burst_state; +bit pedolog_read_msb; +/* ======================================================== + vqXgǂݏǒ㏈() + ǂݏo|C^̃NA +======================================================== */ +/* }Nɂ܂ +void hosu_read_end( ) +{ + pedolog_read_msb = 0; +} +*/ + + + +/* ======================================================== + ṽqXgԂB + PĂԓxɁAqXg̉ʁAʁAꎞԑkĉʏ... +======================================================== */ +u8 hosu_read( ) +{ + u8 rv; + static u8 p_record_buffer; + static st_calender cal_buff; // ꉞAAg~bN + + if( iic_burst_state == 0 ) + { + p_record_buffer = p_record; + DI(); + cal_buff = cal_log_latest; + EI(); + } + + if( iic_burst_state <= 5 ) + { + rv = *( (u8*)&cal_buff + iic_burst_state ); // + iic_burst_state ++; + return( rv ); + } + else + { + u16 temp; + // 16rbgŋL^Ă̂ł΂炵đ /// Ɗy@񂶂 + temp = pool.vreg_c_ext.pedo_log[ p_record_buffer ]; + if( !pedolog_read_msb ) + { + rv = (u8)( temp & 0x00FF ); + } + else + { + rv = (u8)(( temp >> 8 ) & 0x00FF ); + if( p_record_buffer == 0 ) + { + p_record_buffer = PEDOMETER_LOG_SIZE-1; + } + else + { + p_record_buffer --; + } + } + pedolog_read_msb ^= 1; + return( rv ); + } + +} + + + +/* ======================================================== + ŇǓoߎ(hour)ԂB + + Ԓl u16 long_hour +======================================================== */ +const u16 DAYS_FROM_HNY[] = { + 0, + 31, + 31+28, // =59B@cRO͂PTX + 31+28+31, + 31+28+31+30, + 31+28+31+30+31, + 31+28+31+30+31+30, + 31+28+31+30+31+30+31, + 31+28+31+30+31+30+31+31, + 31+28+31+30+31+30+31+31+30, + 31+28+31+30+31+30+31+31+30+31, + 31+28+31+30+31+30+31+31+30+31+30 + }; + +static u16 get_long_hour() +{ + u8 year = bcdtob( cal_temp.year_bcd ); + u8 month = bcdtob( cal_temp.month_bcd ); + u8 day = bcdtob( cal_temp.day_bcd ); + u8 hour = bcdtob( cal_temp.hour_bcd ); + u8 min_bcd = cal_temp.min_bcd; // 召rȂ̂bcd̂܂܂ł悢 + u8 sec_bcd = cal_temp.sec_bcd; + u16 long_hour; + + // ܂̕ + long_hour = DAYS_FROM_HNY[ month -1 ]; // -1̓CfbNX킹 + if( is_leapyear(year) && ( 3 <= month )) + { + // [NŁA[ + long_hour ++; + } + long_hour += day - 1; + long_hour *= 24; // + + long_hour += hour; + + // EȆOHH + if( ( min_bcd > vreg_ctr[ VREG_C_ACC_HOSU_HOUR_BOUNDARY ] ) + || ( ( min_bcd >= vreg_ctr[ VREG_C_ACC_HOSU_HOUR_BOUNDARY ] ) + && ( sec_bcd >= vreg_ctr[ VREG_C_ACC_HOSU_HOUR_BOUNDARY_SEC ] )) + ) + { + return( long_hour ); + } + else + { + return( long_hour -1 ); // 1ԑOɊ܂߂ ӁFUōNɂƂB-1 ɂȂ + } +} + + + +/* ======================================================== +@yʕB +@Kv\Ȑxőł؂ + pcŃV~[Vđv +======================================================== */ +static unsigned long my_sqrt(unsigned long x) +{ + unsigned long s, t; + + if (x <= 0) return 0; + + s = 1; + t = x; + while (s < t) + { + s <<= 1; + t >>= 1; + } + do + { + t = s; + s = (x / s + s) >> 1; + } while (s < t); + + return t; +} + + + + +/* ======================================================== +@‚ OĂ΂ꂽƁAݎ̍߂BԂ̂fill_hosu_hist_hours ɂ̂܂ܓn + //. year_bcd Ȃ̂Ƃ₾... +======================================================== */ +static u16 calc_hours_spend( u8 year ) +{ + u8 cal_log_latest_year = bcdtob( cal_log_latest.year_bcd ); + + // N̓ + if( cal_log_latest_year == year ) + { + if( now_longhour > last_hour_fny ) + { + return( now_longhour - last_hour_fny ); + } + else if( now_longhour == 0 && last_hour_fny != 0 ) + { + // N΂ŁAEzځBȂƍNŌɉZĂ܂B + return( 1 ); + } + else + { + return( 0 ); // ԑ(ƁA߂B@ǂȂĂmȂ) + } + } + else if( cal_log_latest_year == ( year -1 ) ) + { + // N܂łƂ + u16 temp = 365 * 24 - last_hour_fny + now_longhour; + if( is_firstyear(year) ) + { + temp += 24; + } + return( temp ); + } + else if( cal_log_latest_year < year ) + { + // Nu + return( PEDOMETER_LOG_SIZE +1 ); + } + else + { + // J_[߂Ȃ + // m[PAł悢cAslƂ킯ɂȂ + return( 0 ); + } +} diff --git a/tags/2.04/pedo_lpf_coeff.c b/tags/2.04/pedo_lpf_coeff.c new file mode 100644 index 0000000..2e16755 --- /dev/null +++ b/tags/2.04/pedo_lpf_coeff.c @@ -0,0 +1,83 @@ + +#include "incs.h" + +// ========================================================= +#define TAP 64 +#define FIL_COEFF_QUANT 10 +const s8 lpf_coeff[]={ +/* +Window Function Algorithm LPF +Sampling Frequency = 100.0 +cutoff1 = 6.0000000 +Tap Count =64 +Kaiser Constant = 7.000000 +Quantized by 11 [bits] + */ +/* 0,// [0] + 0, + 0, + 0, + 0, + 0, + 0, + 0, +*/ + 1,// 8 + 2, + 2, + 3, + 3, + 2, + 0, + -2, + -5,// 16 + -9, + -13, + -16, + -16, + -13, + -6, + 4, + 18,// 24 + 37, + 56, + 77, + 95, + 110, + 119, + 122, + 119,// 32 + 110, + 95, + 77, + 56, + 37, + 18, + 4, + -6,// 40 + -13, + -16, + -16, + -13, + -9, + -5, + -2, + 0,// 48 + 2, + 3, + 3, + 2, + 2, + 1, +/* + 0, + 0,// 56 + 0, + 0, + 0, + 0, + 0, + 0, + 0 +*/ +}; diff --git a/tags/2.04/pedo_lpf_coeff.h b/tags/2.04/pedo_lpf_coeff.h new file mode 100644 index 0000000..f81d6c2 --- /dev/null +++ b/tags/2.04/pedo_lpf_coeff.h @@ -0,0 +1,84 @@ +#ifndef _pedo_coeff_h_ +#define _pedo_coeff_h_ + +// ========================================================= +#define TAP 64 +#define FIL_COEFF_QUANT 10 +const s8 lpf_coeff[]={ +/* +Window Function Algorithm LPF +Sampling Frequency = 100.0 +cutoff1 = 6.0000000 +Tap Count =64 +Kaiser Constant = 7.000000 +Quantized by 11 [bits] + */ +/* 0,// [0] + 0, + 0, + 0, + 0, + 0, + 0, + 0, +*/ + 1,// 8 + 2, + 2, + 3, + 3, + 2, + 0, + -2, + -5,// 16 + -9, + -13, + -16, + -16, + -13, + -6, + 4, + 18,// 24 + 37, + 56, + 77, + 95, + 110, + 119, + 122, + 119,// 32 + 110, + 95, + 77, + 56, + 37, + 18, + 4, + -6,// 40 + -13, + -16, + -16, + -13, + -9, + -5, + -2, + 0,// 48 + 2, + 3, + 3, + 2, + 2, + 1, +/* + 0, + 0,// 56 + 0, + 0, + 0, + 0, + 0, + 0, + 0 +*/ +}; +#endif diff --git a/tags/2.04/pedometer.h b/tags/2.04/pedometer.h new file mode 100644 index 0000000..8760308 --- /dev/null +++ b/tags/2.04/pedometer.h @@ -0,0 +1,36 @@ +#ifndef _pedo_ +#define _pedo_ + +#ifdef WIN32 +typedef unsigned char bit; +typedef unsigned char u8; +typedef unsigned short u16; + + +#endif + + +// ========================================================= +extern bit pedolog_read_msb; + + + +// ========================================================= +//void hosu_read_end( ); }N +#define hosu_read_end() pedolog_read_msb = 0 + +u8 hosu_read( ); +void hosu_increment_if_necessary(); +void fill_hosu_hist_hours( u16 ); +void clear_hosu_hist(); +void pedometer(); + + + +// ========================================================= +#define PEDOMETER_LOG_SIZE ( 24 * 7 ) + + + +// ========================================================= +#endif diff --git a/tags/2.04/pm.c b/tags/2.04/pm.c new file mode 100644 index 0000000..e3a7893 --- /dev/null +++ b/tags/2.04/pm.c @@ -0,0 +1,1388 @@ +/* ======================================================== + PMIC + cJZ + nintendo + '08 Dec + ======================================================== */ +#ifndef _WIN32 + +#pragma nop + +#endif + +#include "incs.h" +#include "adc.h" +#include "led.h" +#include "pm.h" +#include "renge\renge.h" + +#include "batt_params.h" + +#include +#include "fsl_user.h" + + + +// ======================================================== +u8 raw_adc_temperature; +BT_VENDER battery_manufacturer = BT_VENDER_NOT_CHECKED; +static u8 ntr_pm_reg_shadow; // NTR PMIC WX^~[ +bit bt_authorized; // obep[^MρB[dJn +u8 chg_led_override; // A_v^ƂA[d邵ȂɊւ炸΂炭_ + +static u16 bt_volt16; + +static bit ntr_pm_bt_low_old; + +bit BT_IN_CHG_delayed_n; +bit temp_zone_charge_disable; // xŏ[d~鎞ɃqXeVXt邽 + +u8 pmic_version; +u8 mgic_version[2]; + +u8 pm_reg_bit_vddlcd; + +static bt_param_* p_bt_param; +extern const bt_param_ bt_param[]; + + + +// ======================================================== +static void BT_model_detect(); +static void BT_mgic_quick_start(); +static void BT_mgic_init(); +static void bt_chk_temparature(); +static void bt_get_charge_status(); +static void bt_param_select(); +static void bt_batt_update_twl(); +static void bt_batt_update_ntr(); + +// bp[ +static err send_cmd_mgic_2B( u8 reg, u16 dat ); +static err read_mgic_2B( u8 reg, u8* dat ); +static err read_BT_SOC( u8* dest ); +static err read_BT_voltage( u8* dest ); +static u8 conv_ctr_bt_to_twl_bt(); + + + +// ======================================================== +#define swap_endian_16( x ) (unsigned int)(( x << 8 ) | ( x >> 8 )) + + + +// ======================================================== +const u8 BT_MANUF_BORDER[] = { + 5, 33, 79, 123, 158, 197, 233 + }; + + + +/* ======================================================== + dr̊Ǘ + + ȉ̃s͎ɂőEĎ܂B + EPM_BT_AUTH AGPI in + EPM_CHARGE_n CCIC /CHG in + EPM_CHARGE_ERR_n /FLT in + EPM_EXTDC_n /DOK INTP4 in + EPM_CHARGE_EN_n /CEN out + + ȉ͊̕֌W肻łʂ̂ƂŎɊĎĂ܂B + ELED_Pow R, B, Charge tsk_LED + EBT_TEMP,_P tsk_ADC + + PM_EXTDC͊荞݃Cɂ邩 + ======================================================== */ +#define INTERVAL_TSK_BATT 60 +// 100Ə[dG[ɂ܂_łȂ̂ + +void tsk_batt( ) +{ + static u8 task_interval; + + if( task_interval -- != 0 ) + { + return; + } + else + { + task_interval = (u8)( INTERVAL_TSK_BATT / SYS_INTERVAL_TICK ); + } + + // A_v^Xe[^XXV // + pm_chk_adapter(); + + // [d // + bt_chk_temparature(); // x`FbN + if( !temp_zone_charge_disable && bt_authorized && !PM_EXTDC_n ) + { + BT_CHG_ENABLE(); // x͈OKŏ[dĊJ + } + else + { + BT_CHG_DISABLE(); // x댯I@[d~ + } + + bt_get_charge_status(); // CCIC + + if( ! BT_IN_CHG_delayed_n ) // LEDɔf + { + LED_CHARGE = 1; + } + else + { + LED_CHARGE = 0; + } + + // A_v^‚ȂuԁA[dłb킴Ɠ_BdĂ邱Ƃ킩点邽߁B + if( chg_led_override != 0 ){ // 猩΂킩邪Au(NbN)鎖BC‚l邩ȁcH + chg_led_override --; + LED_CHARGE = 1; + } + + // WX^̏[drbgLEDɓ + set_bit( LED_CHARGE, vreg_ctr[VREG_C_STATUS], REG_BIT_BATT_CHARGE ); // set_bit̂݁B + + // 荞 + // tsk_misc󂯂 + + // drc // + BT_get_left(); +} + + +#define RAW_TEMP_LH 75 // 50 [degC] +#define RAW_TEMP_LL 61 // 55 +#define RAW_TEMP_HL 184 // 1 +#define RAW_TEMP_HH 189 // -1 +#define AVG_COUNT 40 + +/* ******************************************************* + x`FbN + xtqXeVX + ******************************************************* */ +void bt_chk_temparature() +{ + static u8 heikinka_h,heikinka_l; + + if(( RAW_TEMP_LH <= raw_adc_temperature ) + && ( raw_adc_temperature <= RAW_TEMP_HL )) + { + if( heikinka_h < AVG_COUNT ) + { + heikinka_h++; + } + else + { + temp_zone_charge_disable = false; // [d + } + } + else if(( raw_adc_temperature <= RAW_TEMP_LL ) + || ( RAW_TEMP_HH <= raw_adc_temperature )) + { + if( heikinka_l < AVG_COUNT ) + { + heikinka_l++; + } + else + { + temp_zone_charge_disable = true; // [d֎~ + } + } + else + { + // temp_zone_charge_disable ̂܂ + heikinka_h = 0; + heikinka_l = 0; + } +} + + + +void bt_get_charge_status() +{ + // CCIC̕s̂߁A/CHG̃lQ[gƒJɒx + static u8 anti_chatter; + + if( !BT_IN_CHG_n ) + { + // Ƀ`^O + if( anti_chatter < 2 ) // drŃA_v^āAdɂ킳 + { // Ə[dLED̂ + anti_chatter++; + } + else + { + BT_IN_CHG_delayed_n = 0; // [d + } + } + else + { + // "Jɒx" todo:Ƃ@H + if( !BT_CHG_Ena_n && vreg_ctr[ VREG_C_BT_REMAIN ] < 60 ) + { + BT_IN_CHG_delayed_n = 0; // [dƈB[dIĂ͂Ȃ + } + else + { + BT_IN_CHG_delayed_n = 1; + anti_chatter = 0; + } + } +} + + + +/******************************************************** +A_v^̗L`FbN + doff̃A_v^ŊOĂ΂邽ߕ + ***********************************************************/ +void pm_chk_adapter() +{ + static bit pm_extdc_old; + + if( pm_extdc_old != PM_EXTDC_n ) // HAL ʂ߁A PM_EXTDC_n volatile ɂSzȂ + { + pm_extdc_old = PM_EXTDC_n; + if( !PM_EXTDC_n ) + { + // h + set_bit( 1, vreg_ctr[VREG_C_STATUS], REG_BIT_POW_SUPPLY ); + set_irq( VREG_C_IRQ1, REG_BIT_BT_DC_CONNECT ); + chg_led_override = (u8)( 3000 / INTERVAL_TSK_BATT ); // 덷~ςŎ4.5sec炢AȂ + } + else + { + u8 temp_v[2]; + + // + set_bit( 0, vreg_ctr[VREG_C_STATUS], REG_BIT_POW_SUPPLY ); + set_irq( VREG_C_IRQ1, REG_BIT_BT_DC_DISC ); + chg_led_override = 0; + + // drcʂ1%ŁAA_v^L̎ɂ͖{̂NAQ[ + // 1%ɉ񕜂OɃA_v^ƂA荞݂ȂƊҒʂ + // łȂBʑΉ̂߂ + if( read_mgic_2B( BT_GAUGE_REG_VCELL, temp_v ) == ERR_SUCCESS ) + { + bt_volt16 = ( temp_v[0] * 256 + temp_v[1] ); + } + + if(( bt_volt16 < V_TH_ZERO ) || ( vreg_ctr[ VREG_C_BT_REMAIN ] == 0 )) + { + set_irq( VREG_C_IRQ1, REG_BIT_BT_REMAIN ); + } + } + } +} + + + +/******************************************************** +dr֌W̏ + +@@@Q[W@@b@L@@@@@b@ +@@[[[[[[[[[[[[[[[[[[[[[[[ +@@@dr@Lb@@@@@@@b@H +@@[[[[[[[[[[[[[[[[[[[[[[[ +@@@@@@b@@@@@@b@sr +@@@@@@@@b@@dr@b +@@[[[[[[[[[[[[[[[[[[[[[[[ + +@@Q[WLAdr@̔^@ʂ́A +@drxŔ肷 + + ԒlF@dr 0xFF + drςĂȂ 0 + drς 1 + +***********************************************************/ +bit bt_force_update; + +void BT_chk() +{ + BT_VENDER battery_manufacturer_old; + + battery_manufacturer_old = battery_manufacturer; + + BT_model_detect(); + bt_param_select(); // obecʕ␳p[^ȂǃZbg @łAƂ肠̒l(pi)wɂĂB + // ʂrcompvZ邪A|C^QƂ̂₾A@ȂvZȂƂʓ| + + if( system_status.model != MODEL_JIKKI ) + { + bt_authorized = false; + return; + // ܂ + } + + if(( battery_manufacturer_old != battery_manufacturer ) || + bt_force_update ) + { + bt_force_update = false; + iic_mcu_start( ); // ŏtOĂ̂ŌĂт܂ėǂ@ȂƂɁcorz + if( (( battery_manufacturer_old == BT_VENDER_OPEN ) || + ( battery_manufacturer_old == BT_VENDER_NOT_CHECKED )) && + !system_status.reboot ) + { + BT_mgic_quick_start(); + } + BT_mgic_init(); // @픻s܂ + } + bt_authorized = true; + renge_task_immed_add( tski_BT_temp_update ); // drxĎ +} + + + + +void BT_model_detect() +{ + u8 temp; + + BT_DET_P = 1; + BT_TEMP_P = 1; + wait_ms( 5 ); // dオ̂ɎԂ| + + raw_adc_temperature = get_adc( ADC_SEL_BATT_TEMP ); + temp = get_adc( ADC_SEL_BATT_DET ); + BT_DET_P = 0; + + system_status.captureBox = 0; + // vbgtH[ // + if( raw_adc_temperature > 0xF0 ) + { + // TS // + system_status.model = MODEL_TS_BOARD; + } + else if( raw_adc_temperature < 4 ) + { + // // + system_status.model = MODEL_SHIROBAKO; + + // āFLv`{[h // + if(( iic_mcu_read_a_byte( IIC_SLA_BT_GAUGE, BT_GAUGE_REG_VERSION ) == 0x01 ) && + ( iic_mcu_result == ERR_OK )) + { + system_status.captureBox = 1; + } + } + else + { + // @AcIC NACK( obe܂͎cIC̏ ) + system_status.model = MODEL_JIKKI; // obe̎́ŏ㏑ + } + + // TShome{^A@͖ڑȂ̂ŗv[q /// gndɂƂ΂悩c + if( system_status.model == MODEL_TS_BOARD ) + { + PM_SW_HOME_n_TSBOARD = 1; + } + else + { + PM_SW_HOME_n_TSBOARD = 0; + SW_HOME_n_TSBOARD_RAW = 0; /// @open ǂł񂾂 + } + + // dr[J[̎ // + { + u8 i; + + battery_manufacturer = BT_VENDER_OPEN; // ftHgl + for(i=0; i<=7; i++) + { + if( temp <= BT_MANUF_BORDER[ i ] ) + { + battery_manufacturer = (BT_VENDER)i; + break; + /* + BT_VENDER_MAXELL; // = 0 + BT_VENDER_1; + BT_VENDER_2; + BT_VENDER_3; + BT_VENDER_4; + BT_VENDER_PANA; + BT_VENDER_6; + + BT_VENDER_OPEN; + */ + } + } + } + + + if( ( battery_manufacturer == BT_VENDER_OPEN ) && + ( system_status.model == MODEL_JIKKI ) ) + { + system_status.model = MODEL_JIKKI_NOBATT; + } +} + + + +static void BT_mgic_quick_start() +{ + wait_ms( 10 ); // MGIC̋NɊ| + + // 0. obecIC NCbNX^[g + send_cmd_mgic_2B( BT_GAUGE_REG_MODE, swap_endian_16( 0x4000 ) ); + + wait_ms( 150 ); +} + + +#define MGIC_CMD_UNLOCK_KEY 0x4A57 +#define MGIC_CMD_RESET 0x5400 +static void BT_mgic_init() +{ + u8 origParam[4]; + + /* + // -1. ZbgĂ݂ + Ⴞ! + i2c_send_buff_2B._u16 = swap_endian_16( MGIC_CMD_RESET ); + send_cmd_mgic_2B( BT_GAUGE_REG_COMMAND ); // ‚NACKԂ + */ + + if( system_status.model != MODEL_JIKKI ) + { + return; + // ܂ + } + + // 1. bN + if( send_cmd_mgic_2B( BT_GAUGE_REG_LOCK, swap_endian_16( MGIC_CMD_UNLOCK_KEY ) ) != ERR_SUCCESS ) + { + // cIC NACK + vreg_ctr[ VREG_C_STATUS_1 ] |= REG_BIT_MGIC_ERR; + return; + // ܂ + } + + vreg_ctr[ VREG_C_STATUS_1 ] &= ~REG_BIT_MGIC_ERR; + + // wait_ms( 5 + 1 ); OɃEFCgĂ̂ŕsv + + // 2. p[^ꎞۑ + iic_mcu_read( IIC_SLA_BT_GAUGE, BT_GAUGE_REG_RCOMP, 4, origParam ); + + // 3. ꎞIOCVύX + send_cmd_mgic_2B( BT_GAUGE_REG_OCV, swap_endian_16( p_bt_param->ocv )); // }WbNio[IȂ́B[J[w + + // 4. ꎞIRCOMPύX + send_cmd_mgic_2B( BT_GAUGE_REG_RCOMP, swap_endian_16( 0xFF00 ) ); + + // 5.[J[ʃp[^̃[h + { + u8 loop; + + // 16oCgƂɋ؂Ƃ̂Ɓ@imCY΍Ƃ񂾂ǁAӖ񂩁Hj + for( loop = 0; loop < 4; loop ++ ) + { + iic_mcu_set_wo_dma( ); + iic_mcu_write( IIC_SLA_BT_GAUGE, BT_GAUGE_REG_BT_PARAM + loop*16, 16, p_bt_param->mg_param + loop*16 ); + } + } + + // 6. 150msȏ҂ + wait_ms( 150 + 15 ); + + // 7. OCVɁuƂlv + send_cmd_mgic_2B( BT_GAUGE_REG_OCV, swap_endian_16( p_bt_param->ocv ) ); // }WbNio[IȂ́B[J[w + + // 8. 150`600ms҂B600ms͌ + wait_ms( 150 + 15 ); + + // 9. SOCǂށBxt@Ĉ߁B + { u8 temp; + temp = iic_mcu_read_a_byte( IIC_SLA_BT_GAUGE, BT_GAUGE_REG_SOC ); + + if(( p_bt_param->verify.low <= temp ) && ( temp <= p_bt_param->verify.hi )) + { + // JX^fOKI + }else{ + // s烊gĈH + // dbg_nop(); + } + } + + // 10.RCOMPOCV߂ + iic_mcu_write( IIC_SLA_BT_GAUGE, BT_GAUGE_REG_RCOMP, 4, origParam ); + + // 11. bN + send_cmd_mgic_2B( BT_GAUGE_REG_LOCK, swap_endian_16( 0x0000 ) ); // lock key +} + + + +extern u16 _dbg_rcomp; +/* ======================================================== + raw_adc_temperatureɓĂlɕϊƂƂɁA + EWX^ɃZbg + EcICɃZbg + ======================================================== */ +task_status_immed tski_BT_temp_update( ) +{ + static u8 rawdat_old; + static s8 temperature; + s16 newrcomp; + static u8 heikinka; + +/* + T[~X^ - 10k_̎A + pxł͕̃J[uقڃjAŁA + c T[] = 81.48 - 111.97 x ratio + TDK T = 81.406 - 111.81 x ratio +*/ + + if( rawdat_old != raw_adc_temperature ) + { + if( heikinka < 40 ) + { + heikinka ++; + } + else + { + heikinka = 0; + rawdat_old = raw_adc_temperature; + // temperature = 81.45 - 111.9 * raw_adc_temperature/256.0; + // ꂼ256{Ă + temperature = (u8)(( 20851 - 112 * raw_adc_temperature + (256/2) ) /256); + vreg_ctr[VREG_C_BT_TEMP] = (u8)temperature; + + newrcomp = 0; + if( temperature > 20 ) + { + newrcomp = ( ( temperature - 20 ) * p_bt_param->rcomp.up )/256; + } + else + { + newrcomp = ( ( temperature - 20 ) * p_bt_param->rcomp.down )/256; + } + newrcomp = p_bt_param->rcomp.rcomp + newrcomp; + + if( newrcomp > 255 ) + { + newrcomp = 255; + } + if( newrcomp < 0 ) + { + newrcomp = 0; + } + _dbg_rcomp = newrcomp; + + if( send_cmd_mgic_2B( BT_GAUGE_REG_RCOMP, newrcomp ) == ERR_SUCCESS ) // swapsv + { + rawdat_old = raw_adc_temperature; + } + else + { + vreg_ctr[ VREG_C_STATUS_1 ] |= REG_BIT_MGIC_ERR; + } + } + } + return ( ERR_FINISED ); +} + + + +/********************************************************** + drcICcʂ擾AWX^ɏށB + @drcICȄȂǂ̎͂Ƃ肠c99%ƂB + @@@@@@@@ status_1ŊmF”\BdɃ`FbNĂ܂B + @BT_chk()sĂKv܂B +**********************************************************/ +void BT_get_left(){ + u8 temp[2]; + u8 reg_volatile_temp_bt_remain,reg_volatile_temp_bt_remain_fine; // I2C̔񓯊ǂݍ݂ł̂‚h~ Lbv̏ + u8 fuel_cap_by_voltage; // dŃLbvɎg + + // drc + if( system_status.model == MODEL_TS_BOARD + || system_status.model == MODEL_SHIROBAKO ) + { + // TS & // + if( read_BT_SOC( temp ) == ERR_SUCCESS ) + { + reg_volatile_temp_bt_remain = temp[0]; + reg_volatile_temp_bt_remain_fine = temp[1]; + } + else + { + // G~[V@\ + // @œdf͕sւ邾낤 + reg_volatile_temp_bt_remain = 99; + reg_volatile_temp_bt_remain_fine = 0; + } + } + else + { + // @ // + // cʃ[h + if( read_BT_SOC( temp ) != ERR_SUCCESS ) + { + // cICNACK cobe͂ꂽ + vreg_ctr[ VREG_C_STATUS_1 ] |= REG_BIT_MGIC_ERR; + bt_authorized = false; + reg_volatile_temp_bt_remain = 0; + force_off = true; + } + else + { + u16 temp_u16; + + // obep[^̊֌WŃrbgVtgKv + temp_u16 = temp[0] * 256 + temp[1]; + temp_u16 /= p_bt_param->v_scale; + reg_volatile_temp_bt_remain = (u8)(( temp_u16 >> 8 ) & 0xFF ); + if( reg_volatile_temp_bt_remain == 0 ) + { + // 0%̎1.00%ɏグ + // [dJn΂炭͓drcʂ̂ + // 0%ɓBĂ܂Ƃ̂ + reg_volatile_temp_bt_remain = 1; + reg_volatile_temp_bt_remain_fine = 0; + } + else + { + reg_volatile_temp_bt_remain_fine = (u8)(temp_u16 & 0xFF); + } + } + } + + // drd + { + if( read_BT_voltage( temp ) != ERR_SUCCESS ) // 2byte read + { + temp[0] = (u8)( V_BT_4000MV / 256 ); // drdǂ߂Ȃ4000mVƂɂĂB + temp[1] = 0; + } + vreg_ctr[ VREG_C_BT_VOLTAGE ] = temp[0]; + bt_volt16 = ( temp[0] * 256 + temp[1] ); + } + + + // dŃLbv...̏ + { + static u16 hysteresis; + + if( bt_volt16 > V_TH_30 ) + { + fuel_cap_by_voltage = 100; + hysteresis = 0; + } + else if( bt_volt16 - hysteresis > V_TH_LO ) + { + fuel_cap_by_voltage = 30; + hysteresis = 0; + } + else if( bt_volt16 > V_TH_EMPTY ) + { + fuel_cap_by_voltage = BATT_TH_LO; // + hysteresis = 500; + } + else if( bt_volt16 > V_TH_ZERO ) + { + fuel_cap_by_voltage = BATT_TH_EMPTY; + hysteresis = 500; + } + else if( bt_volt16 > V_TH_FORCE_OFF ) + { + fuel_cap_by_voltage = 0; + hysteresis = 500; + } + else + { + force_off = true; + hysteresis = 500; + } + } + + + // [diA_v^hĂĵɏ[dĂȂ + // AiȂƂjf̓drcʂ60%ȏiCCICoOj + // = [dBdrւĂMGIC100%ԂȂ + if( !BT_CHG_Ena_n && BT_IN_CHG_delayed_n ){ + reg_volatile_temp_bt_remain = 100; + reg_volatile_temp_bt_remain_fine = 0; + } + else + { // dł̃Lbv|邩H + if( fuel_cap_by_voltage < reg_volatile_temp_bt_remain ) + { + reg_volatile_temp_bt_remain = fuel_cap_by_voltage; + reg_volatile_temp_bt_remain_fine = 0; + } + } + + /* + \ɖȂdĂ炵̂ŃPAł悵 + if( system_status.taikendai_nbd && system_status.model != MODEL_TS_BOARD ) // dr[qɓd‚ȂĂĒlsȂߏ㏑B + { + reg_volatile_temp_bt_remain = 100; + } + */ + + vreg_ctr[ VREG_C_BT_REMAIN ] = reg_volatile_temp_bt_remain; + vreg_ctr[ VREG_C_BT_REMAIN_FINE ] = reg_volatile_temp_bt_remain_fine; + + // twl̃WX^XV@(CTRɊ荞ݓOɍXVȂƊ荞݂̃^C~O܂Ȃ) + bt_batt_update_twl(); + + // cʂŊ荞݁B}ɌƔԂƂ // + { + static u8 bt_remain_old_ctr; + + if( bt_remain_old_ctr != reg_volatile_temp_bt_remain ) + // CTRɒʒm + { + if( (( vreg_ctr[ VREG_C_BT_REMAIN ] <= BATT_TH_LO ) && ( BATT_TH_LO < bt_remain_old_ctr ))|| + (( vreg_ctr[ VREG_C_BT_REMAIN ] <= BATT_TH_EMPTY ) && ( BATT_TH_EMPTY < bt_remain_old_ctr ))|| + (( vreg_ctr[ VREG_C_BT_REMAIN ] == 0 ) && ( bt_remain_old_ctr != 0 )) ) + { + set_irq( VREG_C_IRQ1, REG_BIT_BT_REMAIN ); + } + } + bt_remain_old_ctr = vreg_ctr[ VREG_C_BT_REMAIN ]; + } + + // PMIC-NTRɓdrcʂĂ + bt_batt_update_ntr(); +} + + + +/* ======================================================== + tn̓d + @Xe[^XtO͂ɗĂĂ܂B + @sԂ邵A + NsłΓd + ʂ̃^XNœd͊ĎĂāAXe[^XNA + ======================================================== */ +// BSR // +err PM_LCD_on( ) +{ + u8 rv; + + PM_VDDLCD_on( ); + + if( system_status.family == FAMILY_SPFL ) + { + SPFL_LCD_AMOL_HV_CONT = 1; + } + + wait_ms( DELAY_PM_TSS_50B_AND_TCOM ); + + PM_TCOM_on( ); + + wait_ms( DELAY_PM_TCOM_TO_VCS ); + + PM_VCS_on( ); + + wait_ms( DELAY_PM_VCS_TO_BL ); + + rv = (u8)PM_chk_LDSW( ); + + if( rv != 0 ) // pX + { + // dNG[Ȃd؂Ă܂Bł̓PAȂ + vreg_ctr[VREG_C_STATUS] |= REG_BIT_LCD_POW; + set_irq( VREG_C_IRQ3, REG_BIT_LCD_ON ); + return ( ERR_SUCCESS ); + } + + return ( ERR_ERR ); +} + +// BSR // +void PM_LCD_off() +{ + // BL‚ĂB// `FbN̂͊荞݂̊֌W + if( ( read_pmic( PM_REG_ADRS_BL ) & 0x03 ) != 0 ) + { + u8 tot; + + PM_BL_set( REG_BIT_CMD_BL_U_OFF | REG_BIT_CMD_BL_L_OFF ); + vreg_ctr[VREG_C_STATUS] &= bits8(1,0,0,1, 1,1,1,1); + + if( (( REG_BIT_BL_U_OFF | REG_BIT_BL_L_OFF ) & ~vreg_ctr[ VREG_C_IRQ_MASK3 ] ) != 0 ) + { + vreg_ctr[ VREG_C_IRQ3 ] |= ( ( REG_BIT_BL_U_OFF | REG_BIT_BL_L_OFF ) & ~vreg_ctr[ VREG_C_IRQ_MASK3 ] ); + IRQ0_neg; + tot = 0; + while( !IRQ0 && ( ++tot != 0 ) ){;} + IRQ0_ast; + } + vreg_ctr[VREG_C_COMMAND2] &= ~( REG_BIT_CMD_BL_U_OFF | REG_BIT_CMD_BL_L_OFF ); + } + + + // td؂ // + SPFL_LCD_AMOL_HV_CONT = 0; // ̃t@~łLȂ̂ŕQȂ + + // 50msƂ҂‚AmF܂傤ˁc + if( read_pmic( PM_REG_ADRS_VDD_LCD ) != 0 ) + { + if( system_status.family == FAMILY_SPFL ) + { + wait_ms( 10 ); // At@X15V؂Ƃ̃EFCgB + } + + PM_TCOM_off(); + wait_ms( 1 ); + PM_TCOM_VCS_off( ); + wait_ms( DELAY_PM_LCD_OFF ); + + PM_VDDLCD_off( ); // cĂ̑S~߂܂B + vreg_ctr[VREG_C_STATUS] &= ~REG_BIT_LCD_POW; + } + + set_irq( VREG_C_IRQ3, REG_BIT_LCD_OFF ); // ɔB}XN΁B +} + + + +/* ======================================================== +@obNCǧ•on/off +@󂩂@on/off/ێ@̃tOȂ̂Ŗʓ| +@@Ⴆ΁ABL on/on ̏ԂŁAon/onɂƌĂAon/on荞݂܂B +======================================================== */ +err PM_BL_set( u8 dat ) +{ + u8 blset; + u8 intset = 0; + // RMWs + + // Read + blset = read_pmic( PM_REG_ADRS_BL ); + + // Modify + // ue + if(( dat & REG_BIT_CMD_BL_U_ON ) != 0 ) + { + blset |= PM_REG_BIT_BL_U; + intset |= REG_BIT_BL_U_ON; + } + else if(( dat & REG_BIT_CMD_BL_U_OFF ) != 0 ) + { + blset &= ~PM_REG_BIT_BL_U; + intset |= REG_BIT_BL_U_OFF; + } + + // shita + if(( dat & REG_BIT_CMD_BL_L_ON ) != 0 ) + { + blset |= PM_REG_BIT_BL_L; + intset |= REG_BIT_BL_L_ON; + } + else if(( dat & REG_BIT_CMD_BL_L_OFF ) != 0 ) + { + blset &= ~PM_REG_BIT_BL_L; + intset |= REG_BIT_BL_L_OFF; + } + + if( blset != 0 ) // BLtꍇ̓EFCg܂ȂPWMĂ炸 + // Vbg_E邱Ƃ + { + wait_ms( 16 + 10 ); + } + send_cmd_pmic( PM_REG_ADRS_BL, blset ); + +#if 0 +// SoCPWMo悤WX^ZbgĂxL邽߁AXe[^X +// XVĂ܂B +#endif + // PMICBL̃rbgƁAMCUSTATUSWX^̃rbgʒutȂߓւ + vreg_ctr[VREG_C_STATUS] = (( vreg_ctr[VREG_C_STATUS] & bits8(1,0,0,1, 1,1,1,1) ) + | ( (( blset << 6 ) | ( blset << 4 )) & bits8(0,1,1,0, 0,0,0,0) )); + + // 荞 + /// rbg܂Ƃ߂čŝŁA‚̊֐gps + { + u8 tot; + + if( ( intset & ~vreg_ctr[ VREG_C_IRQ_MASK3 ] ) != 0 ) + { + vreg_ctr[ VREG_C_IRQ3 ] |= ( intset & ~vreg_ctr[ VREG_C_IRQ_MASK3 ] ); + IRQ0_neg; + tot = 0; + while( !IRQ0 && ( ++tot != 0 ) ){;} + IRQ0_ast; + } + } + + return( ERR_SUCCESS ); // łُ͈`FbNsv +} + + + +/* ======================================================== + t̑Όd̐ݒs܂B + zWX^̓e𑗂邾 + ======================================================== */ +void PM_LCD_vcom_set( ) +{ + send_cmd_pmic( PM_REG_ADRS_POW_DAC1, vreg_ctr[VREG_C_VCOM_T] ); // ȂƂɁAPMIC̓o[Xgݕs + send_cmd_pmic( PM_REG_ADRS_POW_DAC2, vreg_ctr[VREG_C_VCOM_B] ); + return; +} + + + +/* ======================================================== + ŁAWX^݂Ăяo鎞̂ + @I2C̎荇̊֌WłĂ + ======================================================== */ +task_status_immed tski_vcom_set( ) +{ + PM_LCD_vcom_set( ); + return ( ERR_FINISED ); +} + + + +/* ======================================================== + V[PX̒ʂd𗧂グĂ䂫܂B + Ԓl 0 Ō܂ŐɊB + 1 V[gȂǂœd肫Ȃ + + ȉ̃s͎ɂőEĎ܂B + EPOW_CONT1,2 TEGd̂ + ======================================================== */ +err PM_sys_pow_on( ) +{ + // dグ +// PM_reset_ast( ); sv PM_LDSW_on܂ + RESET2_ast; + FCRAM_RST_ast; + GYRO_DISABLE(); + + PM_LDSW_on( ); + + wait_ms( 1 + DELAY_PM_TW_PWUP ); + + PM_VDD_normMode(); + PM_VDD_on( ); +// wait_ms( DELAY_PM_TW_PWUP ); // GYROނ + wait_ms( 10 ); + GYRO_ENABLE(); + wait_ms( DELAY_PM_TW_PWUP - 10 ); + + PM_VDD50A_on( ); // tdł͂ȂAledƂɎĝł + + wait_ms( DELAY_PM_TW_PWUP ); + + // dN`FbNB + if( !PM_chk_LDSW() ) + { + return ( ERR_ERR ); // reset1͂قƂėǂ + } + + // dIC + pmic_version = read_pmic( PM_REG_ADRS_VER ); + read_mgic_2B( BT_GAUGE_REG_VERSION, mgic_version ); + + // ZbgȂǁBVXeNI + PM_reset_neg(); + FCRAM_RST_neg; + RESET2_neg; + + codec_reg_init(); // CODEC s背WX^(reset2̌łȂƂȂ̂) + ntr_pm_reg_shadow = 0; // @V@ȂƂ... + + return ( ERR_SUCCESS ); +} + + + + +/* ======================================================== + dOFFV[PX + ======================================================== */ +void PM_sys_pow_off( ) +{ +// if( RESET1_n ) + if( PM_chk_LDSW() ) + { + // ُ펞͌Ă΂Ȃ + PM_BL_set( REG_BIT_CMD_BL_U_OFF | REG_BIT_CMD_BL_L_OFF ); + PM_LCD_off(); // TCOM,VCS OFF Ă܂B + wait_ms( 20 ); + + PM_reset_ast(); + } + + RESET2_ast; + FCRAM_RST_ast; + + wait_ms( 20 ); + + PM_off( ); + PM_LDSW_off( ); + + return; +} + + + +/*========================================================= + extDC荞 + dOFFNi[d̉xĎ̂߁ĵ + i̓|[O(pm) + =========================================================*/ +__interrupt void intp4_extdc( ) +{ +// chg_led_override = (u8)( 1000 / INTERVAL_TSK_BATT ); +// chg_led_override = 4; +} + + + +/*========================================================= + t^J‚ߊ荞 + i̓|[O(misc) + =========================================================*/ +__interrupt void intp5_shell( ) +{ + ; +} + + +/*========================================================= + PMICւ̃R}h + =========================================================*/ +__interrupt void intp6_PM_irq( ) +{ + EI(); + if( system_status.pwr_state == ON ) + { + renge_task_immed_add( tski_ntr_pmic_comm ); + } +} + + +/* ======================================================== + PMIC̊荞݂󂯂āANTR PMIC݊WX^烊[h + ======================================================== */ +task_status_immed tski_ntr_pmic_comm( ) +{ + u8 reg1_old; + u8 irq_work = 0; + + reg1_old = ntr_pm_reg_shadow; + ntr_pm_reg_shadow = iic_mcu_read_a_byte( IIC_SLA_CODEC, CODEC_REG_PM ); + if( iic_mcu_result != ERR_SUCCESS ) + { + return ( ERR_FINISED ); + } + +// DI( ); + + // obNCg //////////////////////////////////// + if( ( ( reg1_old ^ ntr_pm_reg_shadow ) & REG_BIT_TWL_REQ_BL_U ) != 0 ) + { + if( ( ntr_pm_reg_shadow & REG_BIT_TWL_REQ_BL_U ) == 0 ) // + { + irq_work = REG_BIT_TWL_BL_U_OFF; + } + else + { + irq_work = REG_BIT_TWL_BL_U_ON; + } + } + + // obNCg + if( ( ( reg1_old ^ ntr_pm_reg_shadow ) & REG_BIT_TWL_REQ_BL_L ) != 0 ) + { + if( ( ntr_pm_reg_shadow & REG_BIT_TWL_REQ_BL_L ) == 0 ) // + { + irq_work |= REG_BIT_TWL_BL_L_OFF; + } + else + { + irq_work |= REG_BIT_TWL_BL_L_ON; + } + } + +// EI(); + + vreg_ctr[ VREG_C_STATUS_1 ] = ( vreg_ctr[ VREG_C_STATUS_1 ] & ~0x0C ) | ( ntr_pm_reg_shadow & 0x0C ); // TWLobNCg̃~[ + + irq_work &= ~vreg_ctr[ VREG_C_IRQ_MASK2 ]; + // set_irq i + if( irq_work != 0 ) + { + u8 tot; + + vreg_ctr[ VREG_C_IRQ2 ] |= irq_work; + IRQ0_neg; // uグăpX𑗂蒼 + tot = 0; + while( !IRQ0 && ( ++tot != 0 ) ){;} // O.DȂ̂łƂ̂҂ IRQ_mcu LɔĂƍ(•s) + IRQ0_ast; + } + +#if 0 + // obNCgݒ + // ɏĂ + /// ̂Ƃ낳ɍׂ͕Ȃǁc + if( ( ntr_pm_reg_shadow & ( REG_BIT_TWL_REQ_BL_U | REG_BIT_TWL_REQ_BL_U ) ) == 0 ) + { + vreg_ctr[ VREG_C_COMMAND2 ] = ( REG_BIT_CMD_BL_U_OFF | REG_BIT_CMD_BL_U_OFF ); + renge_task_immed_add( tski_PM_BL_set ); + } +#endif + + // offNGXg ////////////////////////////////////// + if( ( ntr_pm_reg_shadow & REG_BIT_TWL_REQ_OFF_REQ ) != 0 ) + { + set_irq( VREG_C_IRQ2, REG_BIT_TWL_OFF_REQ ); + } + + // ZbgNGXg ///////////////////////////////// + if( ( ntr_pm_reg_shadow & REG_BIT_TWL_REQ_RST_REQ ) != 0 ) + { +#if 0 + // CODECoO + // ZbgPiłȂ疳 + if( ( reg1_old ^ ntr_pm_reg_shadow ) == REG_BIT_TWL_REQ_RST_REQ ) +#endif + { + set_irq( VREG_C_IRQ2, REG_BIT_TWL_RESET_REQ ); + } + } + + // obNCg}XNď߂ + EI( ); + if( ( ntr_pm_reg_shadow & ( REG_BIT_TWL_REQ_OFF_REQ | REG_BIT_TWL_REQ_RST_REQ )) != 0 ) + { + ntr_pm_reg_shadow &= ~( REG_BIT_TWL_REQ_OFF_REQ | REG_BIT_TWL_REQ_RST_REQ ); + iic_mcu_write_a_byte_codec( CODEC_REG_PM, ntr_pm_reg_shadow ); + } + return ( ERR_FINISED ); +} + + + +/********************************************************** + command2 tn +@ bp[IȕBERR_SUCCESSԂȂc +**********************************************************/ +task_status_immed tski_PM_LCD_on() +{ + PM_LCD_on(); + return( ERR_FINISED ); +} + +task_status_immed tski_PM_LCD_off() +{ + PM_LCD_off(); + return( ERR_FINISED ); +} + +task_status_immed tski_PM_BL_set() +{ + u8 cmd_BL; // volatileƂtȂĂv݂ + + do + { + cmd_BL = vreg_ctr[VREG_C_COMMAND2]; + PM_BL_set( cmd_BL ); // }XNς + } + while( cmd_BL != vreg_ctr[VREG_C_COMMAND2] ); // <- PM_BL_setXV + vreg_ctr[VREG_C_COMMAND2] = 0; + + return( ERR_FINISED ); +} + + + +/********************************************************** +@reset2 CODEC ɃZbgAWX^sɂȂ邽 +**********************************************************/ +void codec_reg_init() +{ + wait_ms( 100 ); + + ntr_pm_bt_low_old = conv_ctr_bt_to_twl_bt(); + + iic_mcu_write_a_byte_codec( CODEC_REG_BT, (u8)ntr_pm_bt_low_old ); // SoC 珑 + + vol_reset(); +// renge_task_immed_add( tski_vol_update ); |[ÔŁB + vol_polling = 3; +} + + +/* ============================================================ + wp[Ƃbp[ƂH + ROMߖ̂ + ============================================================ */ +err send_cmd_mgic_2B( u8 reg, u16 dat ) // Mobt@ +{ + u16 temp = dat; + return iic_mcu_write( IIC_SLA_BT_GAUGE, reg, 2, &temp ); // DMA]̂őMf[^obt@̃|C^ǂKv +} + +err read_mgic_2B( u8 reg, u8* dat ) // Mobt@͌Œ +{ + return iic_mcu_read( IIC_SLA_BT_GAUGE, reg, 2, dat ); +} + +err send_cmd_pmic( u8 reg, u8 dat ) +{ + return iic_mcu_write_a_byte( IIC_SLA_PMIC, reg, dat ); +} + +u8 read_pmic( u8 reg ) +{ + return iic_mcu_read_a_byte( IIC_SLA_PMIC, reg ); +} + + +/* ============================================================ + dr[J[ƃfAgdrp[^̌ + ============================================================ */ +void bt_param_select() +{ + BT_TYPE bt_type_temp; + // ΉĂ番R[h‚ + if( battery_manufacturer <= BT_VENDER_3 ) + { + bt_type_temp = BT_PARAM_CTR_MAXELL; + } + else + { + bt_type_temp = BT_PARAM_CTR_PANA; + } + + if( system_status.family == FAMILY_SPFL ) + { + bt_type_temp += BT_PARAM_SPFL_MAXELL; // ItZbg cOȎŁcB + } + else if( system_status.family == FAMILY_SHRIMP ) + { + bt_type_temp += BT_PARAM_SHRIMP_MAXELL; + } + p_bt_param = &bt_param[ bt_type_temp ]; +} + + + +/* ============================================================ + TWLɓdrcʂĂ + ============================================================ */ +static void bt_batt_update_twl() +{ + if (vreg_ctr[VREG_C_BT_REMAIN] > 80) + { + vreg_twl[REG_TWL_INT_ADRS_POWER_INFO] = 0x0F; + } + else if (vreg_ctr[VREG_C_BT_REMAIN] > 50) + { + vreg_twl[REG_TWL_INT_ADRS_POWER_INFO] = 0x0B; + } + else if (vreg_ctr[VREG_C_BT_REMAIN] > BATT_TH_LO) + { + vreg_twl[REG_TWL_INT_ADRS_POWER_INFO] = 0x07; + } + else if (( vreg_ctr[ VREG_C_BT_REMAIN ] > BATT_TH_EMPTY )|| + !BT_CHG_Ena_n ) + { // A_v^̗LŒグ + vreg_twl[REG_TWL_INT_ADRS_POWER_INFO] = 0x03; + } + else if (vreg_ctr[VREG_C_BT_REMAIN] > 0) + { + vreg_twl[REG_TWL_INT_ADRS_POWER_INFO] = 0x01; + } + else + { + vreg_twl[REG_TWL_INT_ADRS_POWER_INFO] = 0x00; + } +} + + +/* ============================================================ + NTRɓdrcʂĂ + ============================================================ */ +static void bt_batt_update_ntr() +{ + static bit initialized; + static bit flag; // HstaticłȂƃRpCɓ{ + + if( system_status.pwr_state == OFF_TRIG ) + { + initialized = false; + } + else + { + + flag = conv_ctr_bt_to_twl_bt(); + + if(( ntr_pm_bt_low_old != flag ) || !initialized ) + { + initialized = true; + ntr_pm_bt_low_old = flag; + iic_mcu_write_a_byte_codec( CODEC_REG_BT, (u8)flag ); + } + } +} + + +/* ======================================================== +========================================================= */ +static err read_BT_SOC( u8* dest ) +{ +#ifdef _ENABLE_HAL_ + if( vreg_ctr[ VREG_C_HAL_OVW_BT_FUEL ] != 0xFF ) // trueȂHALL +#else + if( 0 ) +#endif + { + *dest = vreg_ctr[ VREG_C_HAL_OVW_BT_FUEL ]; + *(dest+1) = 0x00; + return ERR_SUCCESS; + } + else + { + return( read_mgic_2B( BT_GAUGE_REG_SOC, dest ) ); + } +} + + +/* ======================================================== +========================================================= */ +static err read_BT_voltage( u8* dest ) +{ +#ifdef _ENABLE_HAL_ + if( vreg_ctr[ VREG_C_HAL_OVW_BT_VOLTAGE ] != 0xFF ) // trueȂHALL +#else + if( 0 ) +#endif + { + *dest = vreg_ctr[ VREG_C_HAL_OVW_BT_VOLTAGE ]; +// *(dest+1) = 0x00; // gȂ@ǂQoCg[h֐pӂĂȂ̂ł + return ERR_SUCCESS; + } + else + { + return( read_mgic_2B( BT_GAUGE_REG_VCELL, dest ) ); + } +} + + +/* ======================================================== + drcʂtwlɃtOɂĕԂ +========================================================= */ +static u8 conv_ctr_bt_to_twl_bt() +{ +// ntr_pm_bt_low_old = ( vreg_ctr[ VREG_C_BT_REMAIN ] <= BATT_TH_LO )? NTR_PM_BT_EMPTY: NTR_PM_BT_ENOUGH; // 1œdr؂ + if( vreg_ctr[ VREG_C_BT_REMAIN ] <= BATT_TH_LO ) + { + return NTR_PM_BT_EMPTY; + } + else + { + return NTR_PM_BT_ENOUGH; + } +} diff --git a/tags/2.04/pm.h b/tags/2.04/pm.h new file mode 100644 index 0000000..423d771 --- /dev/null +++ b/tags/2.04/pm.h @@ -0,0 +1,216 @@ +#ifndef __PM__ +#define __PM__ + + + +#define IIC_SLA_PMIC 0x84 +#define IIC_SLA_BT_GAUGE 0x6C + +#define VCOM_DEFAULT_T 92 +#define VCOM_DEFAULT_B 95 + + + +#define BATT_TH_LO 10 +#define BATT_TH_EMPTY 5 + +// dWX^ƒڔrłpɃItZbg +#define V_BT_4000MV (u16)( 4000 * 12.8 ) // dǂݏosp 4000mVݒ +#define V_TH_30 (u16)( 3300 * 12.8 ) // 30% +#define V_TH_LO (u16)( 3200 * 12.8 ) // 10% +#define V_TH_EMPTY (u16)( 3150 * 12.8 ) // 5% +#define V_TH_ZERO (u16)( 3100 * 12.8 ) // 0% +#define V_TH_FORCE_OFF (u16)( 2900 * 12.8 ) // 2.9V ŏIf + + +//========================================================= +#ifdef _WIN32 +#define LED_CHARGE mcuRegP[ _P2_4 ] +#else +#define LED_CHARGE P2.4 +#endif + + +//========================================================= +enum PMIC_REG_ADRS +{ + PM_REG_ADRS_VER = 0x00, // verinfo Ȃ + PM_REG_ADRS_VDD_SYS, // VXegpd + PM_REG_ADRS_VDD_LCD, // td + PM_REG_ADRS_CONT, // /RESET1, LoadSwitch + PM_REG_ADRS_BL, // obNCg on/off + PM_REG_ADRS_POW_SAVE, // ȓd͐ݒ + PM_REG_ADRS_POW_DAC1, + PM_REG_ADRS_POW_DAC2 +}; + +enum BT_GAUGE_REG_ADRS +{ + BT_GAUGE_REG_VCELL = 0x02, // ꂼ16rbĝ + BT_GAUGE_REG_SOC = 0x04, + BT_GAUGE_REG_MODE = 0x06, + BT_GAUGE_REG_VERSION = 0x08, + BT_GAUGE_REG_OCV = 0x0E, + BT_GAUGE_REG_RCOMP = 0x0C, + BT_GAUGE_REG_LOCK = 0x3E, + BT_GAUGE_REG_BT_PARAM = 0x40, + BT_GAUGE_REG_COMMAND = 0xFE +}; + + +typedef enum BT_VENDER +{ + BT_VENDER_MAXELL = 0, // V[g + BT_VENDER_1, // 120 + BT_VENDER_2, // 360 + BT_VENDER_3, // 750 + BT_VENDER_4, // 1.3k + BT_VENDER_PANA = 5, // 2.7k + BT_VENDER_6, // 8.2k + BT_VENDER_OPEN = 7, // open + BT_VENDER_NOT_CHECKED = 0xFF, +}BT_VENDER; + + + +enum NTR_PM_BT_STATUS{ + NTR_PM_BT_ENOUGH, + NTR_PM_BT_EMPTY, + NTR_PM_BT_NOT_INITIALIZED = 0xFF +}; + + + +//========================================================= +// CODECPMIC݊WX^ +#define CODEC_REG_PM 0x10 +#define CODEC_REG_BL 0x11 +#define CODEC_REG_BT 0x12 +//#define CODEC_REG_VOL 0x13 // ...sɂAadc.hŒ` + +// TWLSPIPMICɓR}h +#define REG_BIT_TWL_REQ_OFF_REQ ( 1 << 6 ) +#define REG_BIT_TWL_REQ_RST_REQ ( 1 << 0 ) +#define REG_BIT_TWL_REQ_BL ( 3 << 2 ) + + + + +// 0x03 pw cnt3 +#define PM_REG_BIT_LDSW ( 1 << 0 ) +#define PM_REG_BIT_nRST1 ( 1 << 1 ) + +// 0x01 pw cnt1 +#define PM_REG_BIT_VDD 0x0F +#define PM_REG_BIT_VDD50A ( 1 << 4 ) + +// 0x02 pw cnt2 +#define PM_REG_BIT_VDDLCD_CGS 0x07 +#define PM_REG_BIT_VDDLCD_AMO 0x05 +#define PM_REG_BIT_LCD_VCS ( 0x01 << 4 ) +#define PM_REG_BIT_LCD_TCOM ( 0x01 << 3 ) + +// 0x04 bl cnt +#define PM_REG_BIT_BL_U 0x01 +#define PM_REG_BIT_BL_L 0x02 + + +// 0x05 pow save +#define PM_REG_BIT_VDD1P_1R15 bits8(0,0,0,0, 0,0,0,0) +#define PM_REG_BIT_VDD1P_1R05 bits8(0,0,0,0, 1,0,0,0) +#define PM_REG_BIT_VDD1P_0R90 bits8(0,0,1,0, 0,0,0,0) +#define PM_REG_BIT_VDD_AUTO bits8(0,0,0,0, 0,1,1,1) +#define PM_REG_BIT_VDD_PWM bits8(0,0,0,0, 0,0,0,0) + + +#define DELAY_PM_TW_PWUP 16 + 2 +#define DELAY_PM_TSS_50B_AND_TCOM 17 + 1 +#define DELAY_PM_5V_TO_TCOM 17 + 1 +#define DELAY_PM_TCOM_TO_VCS 3 +#define DELAY_PM_VCS_TO_BL ( 17 + 5 ) +#define DELAY_PM_LCD_OFF ( 50 + 1 ) + + +//========================================================= +extern u8 raw_adc_temperature; +extern BT_VENDER battery_manufacturer; +extern bit bt_force_update; + +extern u8 pmic_version; +extern u8 mgic_version[]; + +extern u8 pm_reg_bit_vddlcd; // At@XΉ(dV[PXႤ) + + +//========================================================= +err PM_sys_pow_on( ); +void PM_sys_pow_off( ); +//err PM_bt_auth( ); +void PM_LCD_vcom_set( ); + +err PM_LCD_on( ); +void PM_LCD_off( ); +err PM_BL_set( u8 ); + + +void BT_chk(); +void BT_get_left(); +void pm_chk_adapter(); + +void codec_reg_init(); + + +task_status_immed tski_BT_temp_update( ); +task_status_immed tski_vcom_set( ); +task_status_immed tski_PM_LCD_on(); +task_status_immed tski_PM_LCD_off(); +task_status_immed tski_PM_BL_set(); + + +err send_cmd_pmic( u8 reg, u8 dat ); +u8 read_pmic( u8 reg ); + + +#define PM_Chg_Stop() { BT_TEMP_P = 0; BT_CHG_DISABLE(); LED_CHARGE = 0; bt_authorized = false; } +// @ĂԑOɁA݉xĂKv܂B +#define PM_reset() ( send_cmd_pmic( PM_REG_ADRS_CONT, 0x00 ) ) + + +//========================================================= + + +// // +#define PM_LDSW_on() ( send_cmd_pmic( PM_REG_ADRS_CONT, PM_REG_BIT_LDSW )) +#define PM_LDSW_off() ( send_cmd_pmic( PM_REG_ADRS_CONT, 0 )) + + +// VXed // +#define PM_VDD_on() ( send_cmd_pmic( PM_REG_ADRS_VDD_SYS, PM_REG_BIT_VDD )) +#define PM_VDD50A_on() ( send_cmd_pmic( PM_REG_ADRS_VDD_SYS, ( PM_REG_BIT_VDD | PM_REG_BIT_VDD50A ))) +#define PM_VDD_off() ( send_cmd_pmic( PM_REG_ADRS_VDD_SYS, 0 )) +#define PM_off() PM_VDD_off() + +#define PM_VDD_normMode() ( send_cmd_pmic( PM_REG_ADRS_POW_SAVE, PM_REG_BIT_VDD1P_1R15 | PM_REG_BIT_VDD_PWM )) +#define PM_VDD_ecoMode() ( send_cmd_pmic( PM_REG_ADRS_POW_SAVE, PM_REG_BIT_VDD1P_0R90 | PM_REG_BIT_VDD_AUTO )) +// todo YŃRAdς邩Ȃ + +// ق // +#define PM_reset_neg() ( send_cmd_pmic( PM_REG_ADRS_CONT, ( PM_REG_BIT_LDSW | PM_REG_BIT_nRST1 ))) +#define PM_reset_ast() ( send_cmd_pmic( PM_REG_ADRS_CONT, ( PM_REG_BIT_LDSW ))) +#define PM_chk_LDSW() ( read_pmic( PM_REG_ADRS_CONT ) & PM_REG_BIT_LDSW ) +// 0 ƈُ + +// tnd // +#define PM_VDDLCD_on() ( send_cmd_pmic( PM_REG_ADRS_VDD_LCD, pm_reg_bit_vddlcd )) +#define PM_TCOM_on() ( send_cmd_pmic( PM_REG_ADRS_VDD_LCD, ( pm_reg_bit_vddlcd | PM_REG_BIT_LCD_TCOM ))) +#define PM_VCS_on() ( send_cmd_pmic( PM_REG_ADRS_VDD_LCD, ( pm_reg_bit_vddlcd | PM_REG_BIT_LCD_VCS | PM_REG_BIT_LCD_TCOM ))) +#define PM_TCOM_off() ( send_cmd_pmic( PM_REG_ADRS_VDD_LCD, ( pm_reg_bit_vddlcd | PM_REG_BIT_LCD_VCS ))) +#define PM_TCOM_VCS_off() PM_VDDLCD_on() +#define PM_VDDLCD_off() ( send_cmd_pmic( PM_REG_ADRS_VDD_LCD, 0 ) ) + +#define PM_set_BL( dat ) ( send_cmd_pmic( PM_REG_ADRS_BL, dat ) ) +#define PM_set_adc1( dat ) ( send_cmd_pmic( PM_REG_ADRS_POW_DAC1, dat ) ) +#define PM_set_adc2( dat ) ( send_cmd_pmic( PM_REG_ADRS_POW_DAC2, dat ) ) + + +#endif // __PM__ diff --git a/tags/2.04/pool.h b/tags/2.04/pool.h new file mode 100644 index 0000000..81c8091 --- /dev/null +++ b/tags/2.04/pool.h @@ -0,0 +1,24 @@ +#ifndef _pool_h_ +#define _pool_h_ + + +#include "pedometer.h" + +#define VREG_C_FREE_SIZE 200 + +// 󂢂Ă郁 +typedef struct _st_vreg_c_ext{ + unsigned short pedo_log[ PEDOMETER_LOG_SIZE ]; + unsigned char vreg_c_free[ VREG_C_FREE_SIZE ]; +}st_vreg_c_ext; + +typedef union _uni_pool +{ + st_vreg_c_ext vreg_c_ext; + u8 self_update_work[ 256 ]; // 256ȏ͂܂ƂߏłȂ +}uni_pool; + +extern uni_pool pool; + + +#endif diff --git a/tags/2.04/reboot.c b/tags/2.04/reboot.c new file mode 100644 index 0000000..b784f15 --- /dev/null +++ b/tags/2.04/reboot.c @@ -0,0 +1,24 @@ +/********************************************************//* + + ނ胊u[g + + t@CɃCCAZuƁA + ̃W[SœKȂȂ邽ߒǂo + + **********************************************************/ +#pragma SFR + +#include "incs_loader.h" + + +void my_reboot(){ +#asm + + MOV PSW,#06H ; _~[PSWZbg + MOVW AX,#000d0h ; Zbg̃xN^l荞ł܂B + PUSH PSW + PUSH AX ; RETÎ߂̃X^bN + RETI ; ŃZbgExN^ɕ + +#endasm +} diff --git a/tags/2.04/reboot.h b/tags/2.04/reboot.h new file mode 100644 index 0000000..c20e11e --- /dev/null +++ b/tags/2.04/reboot.h @@ -0,0 +1,6 @@ +#ifndef __MYREBOOT__ +#define __MYREBOOT__ + +void my_reboot(); + +#endif diff --git a/tags/2.04/renge/renge.c b/tags/2.04/renge/renge.c new file mode 100644 index 0000000..1c7562a --- /dev/null +++ b/tags/2.04/renge/renge.c @@ -0,0 +1,315 @@ +#ifndef _WIN32 + +#pragma section @@CODE ROM_CODE +#pragma nop +#pragma ei +#pragma di +#pragma sfr + +#endif + + +#ifdef _WIN32 +typedef unsigned char bit; +typedef unsigned char u8; +#endif + +/****************************************************************************** + ^XNVXeH + ȂقǁAiTRONɂ̓RtBM[^͂B + ܂ + ctr_mcu_config.rb QƁB task_config.h쐬܂B + *****************************************************************************/ +#include "renge.h" +#include "renge_task_intval.h" +#include "renge_task_immediate.h" +#include "..\WDT.h" +#include "..\config.h" +#include "..\user_define.h" + +#ifdef _WIN32 +#include "../sim/simOnWin.h" +#endif +//#define _renge_test_ + +#define true 1 +#define false 0 + +//****************************************************************************** +u8 renge_flg_interval; +bit renge_task_interval_run_force; +bit renge_task_immediate_not_empty; + +bit renge_task_interval_in_force; + + +#include "..\bsr_system.h" +extern system_status_ system_status; + + +//****************************************************************************** +static void renge_task_immed_init(); +static void renge_task_immed_del(); + + + +//****************************************************************************** +task_status_immed ( *tasks_immed[ TASK_IMMED_RUN_LIST_MAX ] )(); + + + +/****************************************************************************** + +E^XNVXe̓Ȉ +EC^[o^C} + *****************************************************************************/ +void renge_init(){ + renge_task_immed_init(); + /* + Cxg^C}̃ZbgȂ + RTC𗬗pĂ̂ŃRgAEg + #define renge_tick 19xxxxxxx [ms] + renge_interval_init(); RTC_init(); + */ +} + + + +/****************************************************************************** + VXe`bNi߂ + *****************************************************************************/ +/* +void renge_interval(){ +// RTCĂ +__interrupt void int_rtc_int(); +} +*/ + + + +/****************************************************************************** + RpCɌ܂ĂAC^[oÑ^XN + ̂ANƍ邩ȂB + *****************************************************************************/ +err renge_task_interval_run(){ + u8 i; + + // C^[oN + DI(); + if(( renge_flg_interval != 0 ) || + ( renge_task_interval_run_force )) /// ȁc + { + renge_task_interval_in_force = renge_task_interval_run_force; + renge_task_interval_run_force = false; // N^XNA荞ރ^XNŃtO‚Ȃ̂ + if( renge_flg_interval != 0 ) + { + renge_flg_interval --; + WDT_Restart( ); + } + EI(); + for( i = 0; i != TSK_LAST; i ++ ) + { + tasks[ i ](); + // N^XNԂɋ + renge_task_immed_run(); + } + } + EI(); + return( ERR_SUCCESS ); +} + + + +/***************************************************************************** + N^XN + + task_immed Ԃ֐B + VXetickA炩̊荞݁iI2CʐMȂǁj + X[v畜A^C~OŎs܂B + +Ԓl@ERR_FINISED@^XN폜 +@@@@ȊO ̃^C~Oł܂s + + *****************************************************************************/ + + +/************************************** + **************************************/ +void renge_task_immed_init(){ + u8 i; + + for( i = 0; i < TASK_IMMED_RUN_LIST_MAX; i++ ){ + tasks_immed[ i ] = TSK_IMM_EMPTY_; + } +} + + + +/************************************** + s^XN̓o^ + 荞݋֎~ 36us + **************************************/ +err renge_task_immed_add( task_status_immed (*new_task)() ){ + u8 i; + + // Xg̋󂫂̐擪ɓo^ + // 폜΂̃^XŃA폜}[N(TSK_IMM_DELETED_)ƂȂA󂫂Ƃ͖Iɋʂ + // do^ + for( i = 0; i < TASK_IMMED_RUN_LIST_MAX; i ++ ) + { + DI(); + if( tasks_immed[ i ] == TSK_IMM_EMPTY_ ) + { + // 󂫂‚ + tasks_immed[ i ] = new_task; + EI(); + return( ERR_SUCCESS ); + } + else + { + // do^`FbN + /// ɂȂĂȂAOl߂ĂO + if( tasks_immed[ i ] == new_task ) + { + // do^͂Ȃ + EI(); + return( ERR_ERR ); + } + } + EI(); + } + // ^XNo^(͂ + return( ERR_ERR ); +} + + + +/************************************** + s^XN̎s + **************************************/ +err renge_task_immed_run(){ + u8 list_id; + +// while( tasks_immed[ 0 ] != TSK_IMM_EMPTY_ ) + if( tasks_immed[ 0 ] != TSK_IMM_EMPTY_ ) + { + DI(); + for( list_id = 0; list_id < TASK_IMMED_RUN_LIST_MAX; list_id ++ ){ + if( tasks_immed[ list_id ] == TSK_IMM_EMPTY_ ){ + // Xg + EI(); + break; + } +#ifdef _renge_test_ + else if( tasks_immed[ list_id ] == TSK_IMM_DELETED_ ) + { + EI(); + NOP(); + // ^XNǗ̕s + // ݂Ȃ^XNs悤Ƃ + // ^XN̍폜̏܂ + // \Ȃ^C~O immed_run Ă΂ꂽ + } +#endif + else + { + u8 rv; + + EI(); + rv = tasks_immed[ list_id ](); + if( rv == ERR_SUCCESS ) + { + tasks_immed[ list_id ] = TSK_IMM_DELETED_; + } + } + DI(); + } + // Xg̃^XNʂs + + // ^XN폜 // + { + u8 i = 0; // Xg̕בւ + u8 j = 1; + + // K i < jAj < TASK_IMMED_RUN_LIST_MAX (łȂƃ^XNӂ) + while( 1 ) + { + if( tasks_immed[ i ] == TSK_IMM_EMPTY_ ) + { + // Olߊ && Xg + // break; + goto imm_list_sort_fin; + } + else if( tasks_immed[ i ] == TSK_IMM_DELETED_ ) + { + for( ; j < TASK_IMMED_RUN_LIST_MAX; j++ ) + { + if( tasks_immed[ j ] == TSK_IMM_DELETED_ ) + { + // ׁiHj폜Ώۂ + // next j + } + else + { + DI(); + if( tasks_immed[ j ] == TSK_IMM_EMPTY_ ) + { + do{ + j --; + tasks_immed[ j ] = TSK_IMM_EMPTY_; + // XgOlߊ + }while( i < j ); + EI(); + goto imm_list_sort_fin; + } + else + { + // Ol߂ׂ^XN‚ + tasks_immed[ i ] = tasks_immed[ j ]; + tasks_immed[ j ] = TSK_IMM_DELETED_; + i ++; + EI(); + } + } + } + } + else + { + // ̃^XNAؗ + } + i ++; + } + } + } + +imm_list_sort_fin: + // ܂łŊSɑOl߂Ă +#ifdef _renge_test_ + /// ق? + { + u8 a,b; + + a = 0; + for( b = 0 ; b < TASK_IMMED_RUN_LIST_MAX; b++ ) + { + if( tasks_immed[ b ] == TSK_IMM_EMPTY_ ) + { + a = 1; + } + else + { + if( a != 0 ) + { + NOP(); // EMPTYɃ^XNdeletedL + } + } + } + } +#else + NOP(); // Ȃ񂩖ƃJ{ +#endif +// } + return( ERR_SUCCESS ); +} + + diff --git a/tags/2.04/renge/renge.h b/tags/2.04/renge/renge.h new file mode 100644 index 0000000..ee1d9f9 --- /dev/null +++ b/tags/2.04/renge/renge.h @@ -0,0 +1,28 @@ +#ifndef __renge__ +#define __renge__ + +//****************************************************************************** + + + +//****************************************************************************** +#include "renge_defs.h" +#include "renge_task_immediate.h" +// #include "renge_task_interval_run.h" // O狭N֎~I + +//****************************************************************************** +void renge_init(); +void renge_task_immed_init(); +err renge_task_immed_run(); +err renge_task_immed_add( task_status_immed (*p_task_func)() ); +// static err renge_task_immed_del( u8 ); + + + +//****************************************************************************** +err renge_task_interval_run(); +extern u8 renge_flg_interval; +extern bit renge_task_interval_run_force; // ^XNstO +extern bit renge_task_interval_in_force; // stO + +#endif diff --git a/tags/2.04/renge/renge_defs.h b/tags/2.04/renge/renge_defs.h new file mode 100644 index 0000000..0199d76 --- /dev/null +++ b/tags/2.04/renge/renge_defs.h @@ -0,0 +1,55 @@ +#ifndef __renge_defs__ +#define __renge_defs__ +/****************************************************************************** + Renge Ver.0 (2009/04/09) + 2009- 7k4jhl R.Fujita @ RED.nintendo + + OSɂ͂قljAȈՓIȃ^XNVXeB + Range Typo ł͂ȂłBQłB + + Ȃ Q ͑̂œ{ QQ + ǖɗ–𑐂łB + 傫ĂˁI + ******************************************************************************/ + +typedef unsigned char u8; +typedef signed char s8; +typedef unsigned short u16; +typedef signed short s16; + + +// ************************************ +#define SYS_INTERVAL_TICK 1.953 + + + +// ************************************ +typedef enum _ERR +{ + ERR_SUCCESS = 0, + ERR_ERR +}err; + + +typedef enum _IMMED_TASK_ERR +{ + ERR_FINISED = 0, + ERR_CONTINUE +}IMMED_TASK_ERR; + + + +/************************************** + C^[oN + *************************************/ +typedef void task_status; + + +/************************************** + Ñ^XNXg + p~ɂȂ邩Ȃ + *************************************/ +typedef IMMED_TASK_ERR task_status_immed; + + +#endif diff --git a/tags/2.04/renge/renge_task_config.rb b/tags/2.04/renge/renge_task_config.rb new file mode 100644 index 0000000..c2de509 --- /dev/null +++ b/tags/2.04/renge/renge_task_config.rb @@ -0,0 +1,59 @@ +#!/usr/bin/ruby -Ks + +tasklist = Array.new + + +if( ARGV[0] == nil ) + printf( "t@C renge_tasks.txt gp܂" ) + datfile = "renge_tasks.txt" +else + datfile = ARGV[0] +end + +if( !File.exist?( datfile ) ) + printf("ݒt@C‚܂B") + exit( 1 ) +end + + +setting = File.open( datfile ) + +setting.each{|dat| + dat.chomp! + if( dat != nil ) + tasklist << dat + end +} + +tasklist.each{|dat| + printf( "\n%s" , dat ) +} +printf( "\n----------\n^XN %d \n", tasklist.size ) + + +#----- ÓI^XN̗ ------------------------------------------------------- +conf = File.new( "renge_task_intval.h", "w+" ) + +conf << "/*XNvgɂ鎩łB蓮ŏȂ悢ł*/\n\n" +conf << "#ifndef __renge_task__\n#define __renge_task__\n\n" +conf << "#include \"renge_defs.h\"\n\n" + +conf << "enum {\n " +tasklist.each{|dat| + conf << "TSK_" << dat.upcase << ", " +} +conf << "TSK_LAST \n };\n\n" + + +tasklist.each{|dat| + conf << "extern void tsk_" << dat << "();\n" +} +conf << "\n" + +conf << "const void ( *tasks[ TSK_LAST ] )() = {\n" +tasklist.each{|dat| + conf << " tsk_" << dat << ",\n" +} +conf << " };\n" + +conf << "\n#endif\n" diff --git a/tags/2.04/renge/renge_task_immediate.h b/tags/2.04/renge/renge_task_immediate.h new file mode 100644 index 0000000..7c5016d --- /dev/null +++ b/tags/2.04/renge/renge_task_immediate.h @@ -0,0 +1,25 @@ +#ifndef __tasks__ +#define __tasks__ + +#include "renge_defs.h" + +// ************************************* +#define TASK_IMMED_RUN_LIST_MAX 10 + + +extern task_status_immed tski_do_command0( ); +extern task_status_immed tski_ntr_pmic_comm(); +extern task_status_immed tski_acc_read(); +extern task_status_immed tski_acc_write(); +//extern task_status_immed tski_acc_hosu_set(); // accero.h +extern task_status_immed tski_mcu_reset(); +extern task_status_immed tski_vol_update(); + + +// ************************************* +#define TSK_IMM_EMPTY_ ( void * )( 0x0000 ) +#define TSK_IMM_DELETED_ ( void * )( 0x0001 ) + + + +#endif diff --git a/tags/2.04/renge/renge_task_intval.h b/tags/2.04/renge/renge_task_intval.h new file mode 100644 index 0000000..9b0d9ea --- /dev/null +++ b/tags/2.04/renge/renge_task_intval.h @@ -0,0 +1,37 @@ +/*XNvgɂ鎩łB蓮ŏȂ悢ł*/ + +#ifndef __renge_task__ +#define __renge_task__ + +#include "renge_defs.h" + +enum TSK +{ + TSK_SW, TSK_ADC, TSK_BATT, TSK_LED_POW, TSK_LED_WIFI, TSK_LED_NOTIFY, TSK_LED_CAM, TSK_MISC, TSK_STATUS, TSK_SYS, TSK_LAST + }; + +extern void tsk_sw(); +extern void tsk_adc(); +extern void tsk_batt(); +extern void tsk_led_pow(); +extern void tsk_led_wifi(); +extern void tsk_led_notify(); +extern void tsk_led_cam(); +extern void tsk_misc(); +extern void tsk_status(); +extern void tsk_sys(); + +const void ( *tasks[ TSK_LAST ] )() = { + tsk_sw, + tsk_adc, + tsk_batt, + tsk_led_pow, + tsk_led_wifi, + tsk_led_notify, + tsk_led_cam, + tsk_misc, + tsk_status, + tsk_sys, + }; + +#endif diff --git a/tags/2.04/renge/renge_tasks.txt b/tags/2.04/renge/renge_tasks.txt new file mode 100644 index 0000000..73af545 --- /dev/null +++ b/tags/2.04/renge/renge_tasks.txt @@ -0,0 +1,11 @@ +sw +adc +batt +led_pow +led_wifi +led_notify +led_cam +misc +status +debug +sys diff --git a/tags/2.04/rtc.c b/tags/2.04/rtc.c new file mode 100644 index 0000000..a539a97 --- /dev/null +++ b/tags/2.04/rtc.c @@ -0,0 +1,175 @@ +/* ======================================================== + RTC + ======================================================== */ +#ifndef _WIN32 + +#pragma sfr +#pragma inline + +#endif + +#include "incs.h" + + +#define RTC_DATA_SIZE 7 +// ======================================================== +static u8 rtc_work[RTC_DATA_SIZE]; +static bit rtc_lock; +static bit rtc_dirty; +bit rtc_alarm_dirty; + + +/* ======================================================== + ytF̏ + WX^̓drrbg̃Zbg + ======================================================== */ +void RTC_init( void ) +{ + + if( !RTCEN ) // rbgĂ烊u[g + { + RTCEN = 1; // W[ON + + // RTCݒ + RTCC0 = bits8(0,0,0,0, 1,0,0,0); /* ~A24ԐA32kóu܂ȂvA荞݂Ȃ */ + // (RTCE 0 RCLOE1 RCLOE0 AMPM CT2 CT1 CT0) + RTCC1 = bits8(1,1,0,0, 0,0,0,0); /* A[荞ݗLJn */ + // (WALE WALIE 0 WAFG RIFG 0 RWST RWAIT) + RTCC2 = bits8(1,0,0,0, 0,0,0,0); /* C^[o:32k/2^6=2msARTCDIVo͂Ȃ */ + // (RINTE RCLOE2 RCKDIV 0 0 ICT2 ICT1 ICT0) + + HOUR = 0x00; + MIN = 0x00; + SEC = 0x00; + MONTH = 0x01; + DAY = 0x01; + WEEK = 0x01; // Mon + YEAR = 0x01; + + ALARMWW = 0x7F; + + vreg_ctr[VREG_C_MCU_STATUS] |= REG_BIT_RTC_BLACKOUT; + } + // 荞ݐݒ + RTCIF = 0; + RTCIIF = 0; + RTCMK = 1; /* 荞()֎~ */ + RTCIMK = 0; /* 荞(A[&C^[o) */ + + RTCE = 1; /* Jn */ + + RWAIT = 1; + while( !RWST ) + {;} + RWAIT = 0; + + rtc_lock = false; + rtc_dirty = false; + rtc_alarm_dirty = false; +} + + + +/* ======================================================== + RTC A[荞 + ======================================================== */ +__interrupt void int_rtc( ) +{ + RWAIT = 1; + while( !RWST ) + {;} + // tw + if( ( vreg_ctr[VREG_C_RTC_ALARM_DAY] == DAY ) + && ( vreg_ctr[VREG_C_RTC_ALARM_MONTH] == MONTH ) + && ( vreg_ctr[VREG_C_RTC_ALARM_YEAR] == YEAR ) ) + { + set_irq( VREG_C_IRQ1, REG_BIT_RTC_ALARM ); + } + RWAIT = 0; +} + + + +/* ======================================================== + RTC ̃[h + WX^́Asec,min,hour,week,day,month,year ̏ + ======================================================== */ +void rtc_buf_refresh( ) +{ + if( !rtc_lock ) + { + rtc_lock = true; + RWAIT = 1; + while( !RWST ) + {;} + + memcpy( &vreg_ctr[VREG_C_RTC_SEC], &SEC, RTC_DATA_SIZE ); + RWAIT = 0; +// renge_task_immed_add( tski_rtc_close ); + } +} + + + +/* ======================================================== + RTC ̃Cg + set_rtc_close Ƒ΂ŎgĉB + ‚̓obt@ɃRs[邾ŁA + ۂRTCɃZbĝset_rtc_close()łB + ======================================================== */ +void set_rtc( u8 adrs, u8 data ) +{ + if( !rtc_dirty ) + { + rtc_dirty = true; + memcpy( rtc_work, &SEC, RTC_DATA_SIZE ); +// renge_task_immed_add( tski_rtc_close ); // I2CIɍs + } + rtc_work[adrs] = data; +} + + + +/* ======================================================== + KvȂ΁ARTCWX^̍XV + ======================================================== */ +// task_status_immed tski_rtc_close(){ +void rtc_unlock( ) +{ + // [hbN + rtc_lock = false; + + // CgbN + if( rtc_dirty ) + { + rtc_dirty = false; + RWAIT = 1; + while( !RWST ) + {;} + memcpy( &SEC, rtc_work, RTC_DATA_SIZE ); + RWAIT = 0; + } + + // A[Zbg + if( rtc_alarm_dirty ) + { + rtc_alarm_dirty = false; + WALE = 0; + ALARMWM = vreg_ctr[VREG_C_RTC_ALARM_MIN]; + ALARMWH = vreg_ctr[VREG_C_RTC_ALARM_HOUR]; + WALE = 1; + } +} + + + + + +/* ======================================================== + RTC VXe`bN^C}荞݃xN^ + 2^6/fXTi1.953125 msj + ======================================================== */ +__interrupt void int_rtc_int( ) +{ + renge_flg_interval ++; // CNg/fNg߂ĝ DI()sv +} diff --git a/tags/2.04/rtc.h b/tags/2.04/rtc.h new file mode 100644 index 0000000..6b2d9f8 --- /dev/null +++ b/tags/2.04/rtc.h @@ -0,0 +1,21 @@ +#ifndef __rtc_h__ +#define __rtc_h__ + + +void RTC_init( void ); +void rtc_buf_refresh( ); +void set_rtc( u8 adrs, u8 data ); + +//task_status_immed tski_rtc_close(); +void rtc_unlock( ); + +// ------------------------------------ +#define RTC_32k_on() { RCLOE0 = 1; } +#define RTC_32k_off() { RCLOE0 = 0; } + + +// ------------------------------------ +extern bit rtc_alarm_dirty; + + +#endif diff --git a/tags/2.04/self_flash.c b/tags/2.04/self_flash.c new file mode 100644 index 0000000..d1ff4dd --- /dev/null +++ b/tags/2.04/self_flash.c @@ -0,0 +1,608 @@ +/* ======================================================== + ȃAbvf[^ + ======================================================== */ +#ifndef _WIN32 + +#pragma SFR +#pragma di +#pragma ei +#pragma nop +#pragma stop +#pragma halt + +#endif + +#include "incs_loader.h" + +#include +#include "fsl_user.h" +#include "i2c_ctr.h" + +#include "pool.h" +#include "magic.h" + +#include "pm.h" + +// ======================================================== +const u8 fsl_fx_MHz_u08 = 8; +const u8 fsl_low_voltage_u08 = 1; + + +// ȃtbVp[^ +#define SAM_BLOCK_SIZE 1024 + // 256oCgȏ͂܂Ƃ߂Ă܂B +#define SELF_UPDATE_BUFF_SIZE 256 +#define SELF_UPDATE_SPLIT_WRITE_NUM ( SAM_BLOCK_SIZE / SELF_UPDATE_BUFF_SIZE ) +#define SAM_WORD_SIZE 4 + +// ubNԍi1ubN1kBj +#define INACTIVE_BOOTSECT_TOP 4 +#define FIRM_TOP 8 +#define FIRM_SIZE 12 +#define ALTERNATE_FIRMTOP 20 + + +#ifdef _MCU_BSR_ +#define ACKD ACKD1 +#define ACKE ACKE1 +#define COI COI1 +#define IICAEN IICA1EN +#define IICAPR0 IICAPR10 +#define IICRSV IICRSV1 +#define IICA IICA1 +#define IICAIF IICAIF1 +#define IICAMK IICAMK1 +#define IICAPR1 IICAPR11 +#define IICCTL0 IICCTL01 +#define IICE IICE1 +#define IICF IICF1 +#define IICS IICS1 +#define IICWH IICWH1 +#define IICWL IICWL1 +#define LREL LREL1 +#define SPD SPD1 +#define SPIE SPIE1 +#define STCEN STCEN1 +#define STD STD1 +#define SVA SVA1 +#define WREL WREL1 +#define WTIM WTIM1 +#endif + +#ifndef _WIN32 +#define LED_POW1 P1.5 +#define LED_PM_POW1 PM1.5 +#else +#define LED_POW1 mcuRegP[ _P1_5 ] +#define LED_PM_POW1 mcuRegPM[ _P1_5 ] +#endif + +// ======================================================== +static void FSL_Open( void ); +static void FSL_Close( void ); +void firm_restore( ); + +static err my_FSL_Init(); +static err firm_duplicate( u8 block_src, u8 block_dest ); + +#ifdef _DBG_LED_PRINT_ +void alert( u8 ); +void led_print( u8 ); +#else +# define alert( x ) ; +# define led_print( x ) ; +#endif + + +// ======================================================== +extern uni_pool pool; + + +// 0.Dȍ~ VAbvf[^ +// Vt@[͑vH +#define N_MGC_L 0x1FF6 +#define N_MGC_T 0x4FF6 + + + +/* ======================================================== + I2CŎMāA + ݁A + `FbNOK@@Vt@[ɐ؂ւčċN + @@@@NG@@ijt@[ɖ߂čċN + i̊֐͖߂܂j + ======================================================== */ +void firm_update( ) +{ + u8 target_block; + u8 split_write_count; // ubNւ܂܏ރJE^ + + // ւO ///////////////////////////////////// + my_FSL_Init(); + + /* t@[̃obNAbv + JnAhXAݐ̐擪hubNԍh (TCY FIRM_SIZE) + 0x2000 - 0x4FFF + 0x5000 - 0x7FFF (ubN 20 - 31) ɃRs[ + */ + firm_duplicate( FIRM_TOP, + ALTERNATE_FIRMTOP ); + + // SubN폜 ///////////////////////////////////// + // df𔻒肷邽߁AŏɑSNX^ + //iVt@[ƂɎcĂAȑÕt@[̃tb^j + for( target_block = INACTIVE_BOOTSECT_TOP; + target_block < ALTERNATE_FIRMTOP; + target_block ++ ) + { + FSL_Erase( target_block ); + } + + + // ւ /////////////////////////////////////////// + // XgbvRfBV܂ő + // IAX^[gAbv[`ɔ + for( target_block = INACTIVE_BOOTSECT_TOP; + target_block < ALTERNATE_FIRMTOP; + target_block ++ ) + { + u8 my_spd; + +/* łɏĂBłȂƒfꂽƂIĂ邩ʏoȂ +// // Vt@[̈폜 +// FSL_Erase( target_block ); +*/ + // + for( split_write_count = 0; + split_write_count < SELF_UPDATE_SPLIT_WRITE_NUM; + split_write_count ++ ) + { + u8* p_buffer = &pool.self_update_work[0]; + u16 buff_written_size = 0; + + WDT_Restart( ); + + // I2C珑݃f[^obt@ɂ߂ + do + { + while( !IICAIF && !SPD ) + {;} + my_spd = SPD; + IICAIF = 0; + *p_buffer = IICA; + WREL = 1; + p_buffer ++; + buff_written_size ++; + } + while( ( buff_written_size != SELF_UPDATE_BUFF_SIZE ) + && !SPD ); + + my_spd += SPD; + + // + // ŌゾƁAS~pfBO邪ʂɂ܂Ȃ + if( FSL_Write( ( fsl_u32 ) ( target_block * SAM_BLOCK_SIZE + + split_write_count * SELF_UPDATE_BUFF_SIZE ), + ( fsl_u08 ) ( SELF_UPDATE_BUFF_SIZE / SAM_WORD_SIZE ) ) + + != FSL_OK ) + { + alert(1); + // ݌̃`FbNG[ + // XgA + firm_duplicate( ALTERNATE_FIRMTOP, FIRM_TOP ); + FSL_ForceReset(); // Zbg + // FSL_SwapBootCluster( ); // u[gXbvuɁvċNďoȂ炵 + // ߂ĂȂ // + } + + if( my_spd != 0 ) + { + break; + } + } + + // 1ubN݊Bxt@Cs + if( FSL_IVerify( target_block ) != FSL_OK ){ + alert(2); + // ēx xt@CJԂ_ł... /// ďׂ݂H + // XgA + firm_duplicate( ALTERNATE_FIRMTOP, FIRM_TOP ); + FSL_ForceReset(); // Zbg + // FSL_SwapBootCluster( ); // u[gXbvuɁvċNďoȂ炵 + // ߂ĂȂ // + } + + if( my_spd != 0 ) + { + break; + } + } + + LREL = 1; + + // 񂾃t@[̃`FbN // + { + u8 i; + u8 comp = 0; + + // [_[̃}WbNƁA{̖̃}WbN͓mF + for( i = 0; i < sizeof( __TIME__ ); i++ ) + { + comp += (u8)(( (*( __far u8 * ) ( N_MGC_L + i )) == (*( u8 * ) ( N_MGC_T + i ) )) ? 0 : 1); + } + if( *( __far u8 * )( N_MGC_L +2 ) != ':' ) // ς̂܂ + { + comp ++; + } + + if( comp == 0 ) + { + // OK! + FSL_InvertBootFlag( ); + FSL_SwapBootCluster( ); // ZbgɓBFSL_Close͕sv + } + else + { + // f[^(}WbNio[ĂȂ)G[ + // XgA + alert(3); + + firm_duplicate( ALTERNATE_FIRMTOP, FIRM_TOP ); + FSL_ForceReset(); // Zbg + // FSL_SwapBootCluster( ); // u[gXbvuɁvċNďoȂ炵 + } + // ߂ĂȂ // + } +} + + + + +/* ======================================================== + @t@[obNAbv̈悩烊XgA܂B + @`FbNAŌ̍ŌŃu[gXbv̂ŁA +@ł̓u[gXbv͕svłB + + ======================================================== */ +void firm_restore( ) +{ + DBG_LED_on; + LED_PM_POW1 = 0; + + // obNAbv͐H // + { + u16 i; + u8 comp = 0; + + for( i = 0; i < sizeof( __TIME__ ); i++ ) // sizeof( __TIME__ ) = 8 炵 + { + comp += ( *( __far u8 * )( MGC_LOAD + i ) == *( u8 * )( MGC_HEAD_BKUP + i ) ) ? 0 : 1; + comp += ( *( u8 * )( MGC_HEAD_BKUP + i ) == *( u8 * )( MGC_FOOT_BKUP + i ) ) ? 0 : 1; + } + if( *( u8 * )( MGC_FOOT_BKUP ) == 0xFF ) + { + comp ++; + } + + if( comp != 0 ) + { + // obNAbv̈ꂽ... + comp = 0; + + // 3.3VオȂƍ + EI( ); + iic_mcu_start( ); + RESET2_ast; + FCRAM_RST_ast; + GYRO_DISABLE(); + PM_LDSW_on(); + wait_ms( 1 + DELAY_PM_TW_PWUP ); + PM_VDD_on( ); + + while(1) + { + WDT_Restart(); + + { + // LED sRsR + comp++; + LED_POW1 = ( comp == 1 || comp == 3 )? 1: 0; + if( comp == 8 ) + { + comp = 0; + } + } + + { + // d{^œdoff + static u8 sw_hold_count; + + if( !SW_POW_n_RAW ) + { + sw_hold_count++; + } + else + { + sw_hold_count = 0; + } + + if( sw_hold_count > 16 ) + { + sw_hold_count = 0; + // doff + PM_LDSW_off( ); + break; + } + } + + // EFCg + for( i = 1; i != 0; i++ ) + { + NOP(); + NOP(); + NOP(); + NOP(); + } + } + { + // ǁAǂ悤cB + + KRM = ( KR_SW_POW ); // Mask ł͂ȂAModeȂ̂B킵 + MK0 = 0xFFFF; + MK1 = ~( INT_MSK1_KR ); + MK2L = 0xFF; + + // PU5 ̂܂ + PU7 = bits8(0,0,0,0, 1,0,0,0); // PWSWI + PU20 = bits8(0,0,0,0, 0,0,0,0);; // SW_HOME ~ + + STOP( ); + + mcu_wdt_reset; + } + } + } + + + if( my_FSL_Init() != ERR_SUCCESS ){ + alert(1); + } + + /* t@[̃XgA + 0x4800 - 0x7FFF (ubN 18 - 27) + 0x2000 - 0x47FF (ubN 8 - 17) փRs[ + */ + if( firm_duplicate( ALTERNATE_FIRMTOP, FIRM_TOP ) != ERR_SUCCESS ) + { + alert(2); + } + DBG_LED_off; + + // todo XgAsALEDƂāAT[rXɂĂ炤H + +/* +// u[g + if( FSL_InvertBootFlag() != ERR_SUCCESS ) + { + alert(3); + } +*/ + FSL_ForceReset(); // Zbg + // FSL_SwapBootCluster( ); // u[gXbvuɁvċNďoȂ炵 +} + + + +// ======================================================== +static void FSL_Open( void ) +{ + /* save the configuration of the interrupt controller and set */ +#ifdef FSL_INT_BACKUP + fsl_MK0L_bak_u08 = MK0L; /* if (interrupt backup required) */ + fsl_MK0H_bak_u08 = MK0H; /* { */ + fsl_MK1L_bak_u08 = MK1L; /* */ + fsl_MK1H_bak_u08 = MK1H; /* save interrupt controller */ + fsl_MK2L_bak_u08 = MK2L; /* configuration */ + fsl_MK2H_bak_u08 = MK2H; /* */ + MK0L = FSL_MK0L_MASK; /* */ + MK0H = FSL_MK0H_MASK; /* */ + MK1L = FSL_MK1L_MASK; /* prepare interrupt controller */ + MK1H = FSL_MK1H_MASK; /* for selfprogramming */ + MK2L = FSL_MK2L_MASK; /* */ + MK2H = FSL_MK2H_MASK; /* } */ +#endif + + while( DST1 ){;} // DMA~ + DEN1 = 0; + + MK0 = 0xFFFF; + MK1 = 0xFFFF; + MK2 = 0xFFFF; +/* + LVIM = bits8(0,0,0,0, 0,0,1,0); + LVIS = bits8(0,0,0,0, 1,0,0,0); + LVIM = bits8(1,0,0,0, 0,0,1,0); +*/ + FSL_FLMD0_HIGH; // tbVւ +} + + + +/*----------------------------------------------------------------------------------------------*/ +/* leave the "user room" and restore previous conditions */ +/*----------------------------------------------------------------------------------------------*/ +static void FSL_Close( void ) +{ + // nH + + FSL_FLMD0_LOW; // tbVCgveNg + +#ifdef FSL_INT_BACKUP + MK0L = fsl_MK0L_bak_u08; /* do{ */ + MK0H = fsl_MK0H_bak_u08; /* restore interrupt controller */ + MK1L = fsl_MK1L_bak_u08; /* configuration */ + MK1H = fsl_MK1H_bak_u08; /* */ + MK2L = fsl_MK2L_bak_u08; /* */ + MK2H = fsl_MK2H_bak_u08; /* } */ +#endif +} + + + +/* ======================================================== +@}CRŃt@[Rs[܂B + __far u8 * p_rom Rs[̐擪AhX + block_dest Rs[̐擪ubN + + Rs[ɏ悤my_FSL_Init炩ߎsKv܂B + ======================================================== */ +//static err firm_duplicate( __far u8 * p_rom, +// u8 block_dest ) +static err firm_duplicate( u8 block_src, + u8 block_dest ) +{ + u8 target_block; + u8 split_write_count; // ubNւ܂܏ރJE^ + __far u8* p_src = ( __far u8* )( block_src * 0x400 ); + u8 retry_error; + + led_print(1); + + // ݐubN̐JԂ + for( target_block = block_dest; + target_block < ( block_dest + FIRM_SIZE ); + target_block ++ ) + { + led_print(2); + WDT_Restart( ); + // ubN + retry_error = 5 + 1; + while( FSL_BlankCheck( target_block ) != FSL_OK ) + { + led_print(3); + FSL_Erase( target_block ); + if( -- retry_error == 0 ) + { + // tbVH + FSL_Close( ); + return ( ERR_ERR ); // ZbgA݂@ǂȂ邩m + } + } + + led_print(4); + // ݕJԂ + for( split_write_count = 0; + split_write_count < SELF_UPDATE_SPLIT_WRITE_NUM; + split_write_count ++ ) + { + u16 buff_written_size; + u8* p_buff; + + // ݃f[^obt@ɂ߂ + buff_written_size = 0; + p_buff = &pool.self_update_work[0]; + do + { + *p_buff = *p_src; + p_src ++; + p_buff ++; + buff_written_size ++; + } + while( buff_written_size != SELF_UPDATE_BUFF_SIZE ); + + // + if( FSL_Write( ( fsl_u32 ) ( target_block * SAM_BLOCK_SIZE + + split_write_count * SELF_UPDATE_BUFF_SIZE ), + ( fsl_u08 ) ( SELF_UPDATE_BUFF_SIZE / SAM_WORD_SIZE ) ) + != FSL_OK ) + { + // Jo̓u[g // + FSL_Close( ); + led_print(5); +// while(1){} + return ( ERR_ERR ); + } + } + led_print(6); + + // 1ubN݊Bd`FbNs + while( FSL_IVerify( target_block ) != FSL_OK ) + { + // Jo̓u[g // + led_print(7); + return ( ERR_ERR ); + } + } + return( ERR_SUCCESS ); + +} + + + +/* ======================================================== + ======================================================== */ +static err my_FSL_Init() +{ + u8 rv; + + RTCE = 0; + + // ւO // + DI( ); + FSL_Open( ); // 荞݋֎~Ȃ + + FSL_Init( &pool.self_update_work[0] ); // CuB荞ݒfl + rv = FSL_ModeCheck( ); // CgveNg`FbNBs邱Ƃl + + return( (err)rv ); +} + + +task_status_immed tski_mcu_reset() +{ + // ʂɍċN + my_FSL_Init(); + + FSL_ForceReset(); // Zbg + FSL_Close( ); + + // یH // + mcu_wdt_reset; + return( ERR_SUCCESS ); // no reach +} + + +#ifdef _DBG_LED_PRINT_ +// P1.5 = led_pow_red_old +void alert( u8 num ) +{ + u8 i; + + while(1) + { + WDT_Restart(); + LED_POW1 = 1; + for( i = 0; i < num; i++ ) + { + DBG_LED_on; + DBG_LED_off; + } + LED_POW1 = 0; + } +} + + +void led_print( u8 num ) +{ + u8 i; + + DBG_LED_on; + for( i = 0; i < num; i++ ) + { + LED_POW1 = 1; + LED_POW1 = 0; + } + DBG_LED_off; +} +#endif diff --git a/tags/2.04/self_flash.h b/tags/2.04/self_flash.h new file mode 100644 index 0000000..768565e --- /dev/null +++ b/tags/2.04/self_flash.h @@ -0,0 +1,9 @@ +#ifndef _self_flash_h_ +#define _self_flash_h_ + + +void firm_update(); + + +#endif + diff --git a/tags/2.04/sw.c b/tags/2.04/sw.c new file mode 100644 index 0000000..5fd74ed --- /dev/null +++ b/tags/2.04/sw.c @@ -0,0 +1,188 @@ +#ifndef _WIN32 + +#pragma SFR +#pragma NOP +#pragma HALT +#pragma STOP + +#endif + +#include "incs.h" + +#include "i2c_twl.h" +#include "i2c_ctr.h" +#include "led.h" +#include "pm.h" +#include "rtc.h" +#include "sw.h" + + +//========================================================= +/* + vreg_ctrǂ݂̂Ńwb_ +#define INTERVAL_TSK_SW +#define CLICK_THRESHOLD + +#define HOLD_THREASHOLD +#define FORCEOFF_THREASHOLD +*/ +#define TIME_MUKAN ( u8)( 300 / INTERVAL_TSK_SW ) +#define TIME_MUKAN_PWSW_RED_TRIAL (u16)( 15000 / INTERVAL_TSK_SW ) // VAhome}XN + +//========================================================= +u16 SW_pow_count; +bit SW_pow_mask; + +static u8 SW_home_count, SW_wifi_count, SW_home_count_rel; +static u8 sw_wifi_mukan_time; + +u16 off_timeout_timer; + +static u16 sw_pwsw_mukan_time; + +//========================================================= +// Ԃ𐔂BςȂł0ɖ߂Ȃ +// mask0̎́Ax܂Ŗ +#define count_sw_n( sw, counter, mask ) \ + { \ + if( sw ){ \ + mask = 0; \ + counter = 0; \ + }else{ \ + if( mask != 0 ){ \ + counter = 0; \ + }else{ \ + counter ++; \ + if( counter == 0 ) counter = -1; \ + } \ + } \ + } + + +#define chk_clicked( button, count, irq_bit_name ) \ + if( !button ) \ + { \ + if( count < CLICK_THRESHOLD ) \ + { \ + count ++; \ + if( count == CLICK_THRESHOLD ) \ + { \ + count ++; \ + set_irq( VREG_C_IRQ0, irq_bit_name ); \ + } \ + } \ + } \ + else \ + { \ + count = 0; \ + } + + + +/* ======================================================== + XCb`̊Ď + @`^O͂˂AAgKȂǂ̌oȂ + ======================================================== */ +void tsk_sw( ) +{ + static u8 task_interval; + + if( system_status.pwr_state == OFF_TRIG ) + { + SW_pow_count = 0; // dɔăNA +// task_interval = 0; + } + + if( system_status.pwr_state != ON_CHECK ) // 莞(PWSW_POWON_TIME)ẐŃvXP[@łȂƃ`^܂肫Ȃ + { + if( task_interval != 0 ) + { + task_interval--; + return; + // ܂ + } + + task_interval = (u8)( INTERVAL_TSK_SW / SYS_INTERVAL_TICK ) -1; // vXP[ɎgĂ܂ˁc + // -1̓|XgfNĝ߂̒ + } + + // 8ms ɂ܂ + switch ( system_status.pwr_state ) + { + case ( ON ): + case ( SLEEP ): + case ( OFF ): + case ( ON_CHECK ): + // @̏ꍇ + if( ! system_status.taikendai ) + { + + // dXCb`̊Ď // + if( SW_pow_count == ( TIME_PWSW_CLICK ) ) // NbNԂɓB + { + set_irq( VREG_C_IRQ0, REG_BIT_SW_POW_CLICK ); + } + else if( SW_pow_count == ( HOLD_THREASHOLD ) ) // ɓB + { + set_irq( VREG_C_IRQ0, REG_BIT_SW_POW_HOLD ); + if( off_timeout_timer == 0 ) // dfJEg_EJnAxȂ悤ɁB + { + off_timeout_timer = vreg_ctr[ VREG_C_OFF_DELAY ] * 16; + } + } + + if( off_timeout_timer != 0 ) // 荞݌A^CAEgŋItB + { + off_timeout_timer --; + if( off_timeout_timer == 0 ) + { + force_off = true; + } + } + + }else{ + // X^hAV + // dXCb`̊Ď // + if( SW_pow_count == ( TIME_PWSW_CLICK ) ) + { + if( sw_pwsw_mukan_time == 0 ) + { + set_irq( VREG_C_IRQ0, REG_BIT_SW_POW_CLICK ); + // ȃ^C~OPWSWHOMEj[ɓĂ܂̂邽߂̃}XN^C}[ + sw_pwsw_mukan_time = TIME_MUKAN_PWSW_RED_TRIAL; + } + } + else if( SW_pow_count == ( HOLD_THREASHOLD ) ) + { + force_off = true; + } + + if( sw_pwsw_mukan_time != 0 ) + { + sw_pwsw_mukan_time--; + } + } + + count_sw_n( SW_POW_n, SW_pow_count, SW_pow_mask ); // {^Ԃ̃JEg + + // HOME sw // + chk_clicked( SW_HOME_n, SW_home_count, REG_BIT_SW_HOME_CLICK ); + chk_clicked( !SW_HOME_n, SW_home_count_rel, REG_BIT_SW_HOME_RELEASE ); + + // wifi sw // + /// ňȎȂ̂͂킩Ă邪AsɏoĂ܂sǃXCb`~ + if( sw_wifi_mukan_time != 0 ) + { + sw_wifi_mukan_time--; + } + else + { + chk_clicked( SW_WIFI_n, SW_wifi_count, REG_BIT_SW_WIFI_CLICK ); + if( SW_wifi_count == CLICK_THRESHOLD +1 ) // 蔭I + { + sw_wifi_mukan_time = TIME_MUKAN; + } + } + } +} + diff --git a/tags/2.04/sw.h b/tags/2.04/sw.h new file mode 100644 index 0000000..abe9715 --- /dev/null +++ b/tags/2.04/sw.h @@ -0,0 +1,20 @@ +#ifndef _sw_ +#define _sw_ + +#include "config.h" + +extern u16 SW_pow_count; +extern bit SW_pow_mask; + +#define INTERVAL_TSK_SW 8 +#define CLICK_THRESHOLD 5 + +#define HOLD_THREASHOLD (u16)( 3000 /INTERVAL_TSK_SW ) +#define TIME_PWSW_CLICK (u8)( 220 /INTERVAL_TSK_SW ) +#define FORCEOFF_THREASHOLD (u8)( 12000 /INTERVAL_TSK_SW /16 ) + + +extern u16 off_timeout_timer; +#define clear_pow_off_countdown(){ off_timeout_timer = 0; force_off = false; } + +#endif diff --git a/tags/2.04/task_debug.c b/tags/2.04/task_debug.c new file mode 100644 index 0000000..54b594b --- /dev/null +++ b/tags/2.04/task_debug.c @@ -0,0 +1,120 @@ +#ifndef _WIN32 + +#pragma SFR +#pragma NOP +#pragma HALT +#pragma STOP + +#endif + +#include "incs_loader.h" +//#include "incs.h" +#include "renge\renge.h" +#include "pm.h" +#include "accero.h" + + +/* ======================================================== + ======================================================== */ + +// 7ZO 4oCg +# define IIC_SLA_DBG_MONITOR 0x44 + + +#if 0 + +ӁI@^XNXgOĂ܂̂ŁAgȂ畜ĉI + +void tsk_debug( ) +{ +// u8 temp; + +#ifdef _DBG_PEDO_AUTO_ENABLE_ + if( system_status.pwr_state == ON_TRIG ){ + // vNonɂ + vreg_ctr[ VREG_C_ACC_CONFIG ] = 0x03; + renge_task_immed_add( tski_acc_hosu_set ); + } +#endif + + /* + if( system_status.pwr_state == ON_TRIG ){ + { + static u8 count = 0; + // fobOLEDi8bitj̏ + temp = iic_mcu_read_a_byte( IIC_SLA_8LEDS, IIC_8LEDS_REG_DO ); + count ++; + iic_mcu_write_a_byte( IIC_SLA_8LEDS, IIC_8LEDS_REG_DO, count ); + iic_mcu_write_a_byte( IIC_SLA_DBG_MONITOR, 3, count ); + } + } + */ + +// iic_mcu_write_a_byte( IIC_SLA_DBG_MONITOR, 2, vreg_ctr[ VREG_C_IRQ1 ] ); +// iic_mcu_write_a_byte( IIC_SLA_DBG_MONITOR, 1, boot_ura ); +// iic_mcu_write_a_byte( IIC_SLA_DBG_MONITOR, 1, vreg_ctr[ VREG_C_SND_VOL ] ); +// iic_mcu_write_a_byte( IIC_SLA_DBG_MONITOR, 1, vreg_ctr[ VREG_3D ] ); +// iic_mcu_write_a_byte( IIC_SLA_DBG_MONITOR, 0, vreg_ctr[ VREG_C_ACC_ZH ] ); +// iic_mcu_write_a_byte( IIC_SLA_DBG_MONITOR, 3, vreg_ctr[ VREG_C_3D ] ); +// iic_mcu_write_a_byte( IIC_SLA_DBG_MONITOR, 2, vreg_ctr[ VREG_C_SND_VOL ] ); +// iic_mcu_write_a_byte( IIC_SLA_DBG_MONITOR, 1, vreg_ctr[ VREG_C_STATUS ] ); +// iic_mcu_write_a_byte( IIC_SLA_DBG_MONITOR, 0, vreg_ctr[ VREG_C_ACC_ZH ] ); + + /* + { + u8 str[4]; + + if( ( system_status.pwr_state == ON ) || ( system_status.pwr_state == SLEEP ) ) + { + str[3] = vreg_ctr[ VREG_C_FREE0 ]; + str[2] = vreg_ctr[ VREG_C_FREE1 ]; + str[1] = vreg_ctr[ VREG_C_STATUS ]; + str[0] = vreg_ctr[ VREG_C_RTC_SEC ]; + + str[3] = vreg_ctr[ VREG_C_SND_VOL ]; + str[2] = vreg_ctr[ VREG_C_3D ]; + str[1] = vreg_ctr[ VREG_C_ACC_CONFIG ]; + str[0] = SEC; + iic_mcu_write( IIC_SLA_DBG_MONITOR, 0x03, 4, &str ); + } + } + */ +} + +#endif + + +#if 0 +/* ======================================================== + ^XNЂȌ` + ======================================================== */ +task_interval tsk_hina( ) +{ + switch ( system_status.pwr_state ) + { + case ON_CHECK: + case ON_TRIG: + case ON: + case SLEEP: + case OFF_TRIG: + default: + } + + return; // tic Ă΂邱ƂɂȂ܂ +} + + +// |C^ʼn炤̂͊댯ȋCĂ +/* ̂悤Ɏg + renge_task_immed_add( ^XN֐ւ̃|C^ ); +*/ +task_status_immed tski_hina( u8 * arg ) +{ + return ( ERR_FINISED ); + // ERR_FINISED ^XN폜 + // ERR_CONTINUE ɂȂ񂩊荞݂ȂA[U[ȂAVXe`bN + // Ƃɍēxs +} + + +#endif diff --git a/tags/2.04/task_misc.c b/tags/2.04/task_misc.c new file mode 100644 index 0000000..bcc8696 --- /dev/null +++ b/tags/2.04/task_misc.c @@ -0,0 +1,374 @@ +#ifndef _WIN32 + +#pragma SFR +#pragma NOP +#pragma HALT +#pragma STOP + +#endif + +#include "incs.h" +#include "renge\renge.h" +#include "pm.h" + +#include "accero.h" +#include "adc.h" +#include "i2c_mcu.h" +#include "led.h" +#include "vreg_twl.h" + + + +#ifdef _MCU_BSR_ +#define ACKD ACKD1 +#define ACKE ACKE1 +#define COI COI1 +#define IICAEN IICA1EN +#define IICRSV IICRSV1 +#define IICA IICA1 +#define IICAIF IICAIF1 +#define IICAMK IICAMK1 +#define IICAPR0 IICAPR11 +#define IICAPR1 IICAPR01 +#define IICCTL0 IICCTL10 +#define IICE IICE1 +#define IICF IICF1 +#define IICS IICS1 +#define IICWH IICWH1 +#define IICWL IICWL1 +#define LREL LREL1 +#define SPD SPD1 +#define SPIE SPIE1 +#define STCEN STCEN1 +#define STD STD1 +#define SVA SVA1 +#define WREL WREL1 +#define WTIM WTIM1 +#define TRC TRC1 +#define SMC SMC1 +#define DFC DFC1 +#endif + + + +// ======================================================== +bit twl_ver_read; // twl home menuverǂ񂾂݊J[lɊ荞݂邽 +bit going_to_sleep; // SoCAsleepɓʒm炤Bslp_i HԂ0ɂȂ + // X[v畜AłȂȂ̂h + + +// eXgp +bit reserve_pedo_increnent; + + +// ======================================================== +static void update_LED_3D(); +static void check_twl_vol_irq(); + + + +/* ======================================================== + Xe[^XWX^Ȃ + ======================================================== */ +void tsk_misc( ) +{ + /* ======================================================== + xZT荞݃sIWi}CRɂ͖̂ + |[OB + vp + BSR}CRaccero.cŊ荞݃[`^XNo^܂B + ======================================================== */ + // 荞݂̎肱ڂH + if( ACC_VALID ) + { + if( renge_task_immed_add( tski_cbk_accero ) == ERR_SUCCESS ){ + // dbg_nop(); + } + } + + if( system_status.pwr_state == ON ) + { + /* ======================================================== + PM݊WX^ւ̏ + |[OĂȂB荞݁H + ======================================================== */ + if( !PM_IRQ_n ) + { + renge_task_immed_add( tski_ntr_pmic_comm ); + // dbg_nop(); + } + + /* ======================================================== + TWL`[NƂCTRm肽炵 + ======================================================== */ + if( twl_ver_read ) + { + twl_ver_read = false; + set_irq( VREG_C_IRQ2, REG_BIT_TWL_VER_READ ); + } + + // TWL ̉ʕω荞݃`FbN // + check_twl_vol_irq(); + } + + // 3D vXV // + update_LED_3D(); + + if( reserve_pedo_increnent ) + { + reserve_pedo_increnent = 0; + hosu_increment_if_necessary(); + } + +} + + + +/* ======================================================== + TWLVol̂ƁAXC_̑삪obeBO + sN鎖Ah + TWLł8ʏ펞A{^8iKBɍ킹Ċ荞݂ꂽ + ======================================================== */ +void check_twl_vol_irq() +{ + static u8 vol_level_twl_sent; + static u8 mabiki; + + if( !is_TWL ) + { + return; + // ܂ + } + + if( mabiki != 0 ) + { + mabiki--; + return; + // ܂ + } + + mabiki = 9; // 1t[͊J + if( vol_level_twl != vol_level_twl_sent ) + { + vol_level_twl_sent = vol_level_twl; + set_irq( VREG_C_IRQ2, REG_BIT_SLIDE_VOL_ACROSS_TWL_BOUNDARY ); + } +} + + + +// 3D_LED ///////////////////////////////////// +void update_LED_3D() +{ + if( system_status.pwr_state != ON ) + { + LED_duty_3d = 0; + return; + // ܂ // + } + + if( vreg_ctr[VREG_C_LED_3D] == LED_3D_ILM_OFF ) + { + if( LED_duty_3d != 0 ) + { + LED_duty_3d --; + } + } + else + { + if( LED_duty_3d != vreg_ctr[VREG_C_LED_BRIGHT] ) + { + if( LED_duty_3d < vreg_ctr[VREG_C_LED_BRIGHT] ) + { + LED_duty_3d ++; + } + else + { + LED_duty_3d --; + } + } + } +} + + + +/* ======================================================== + N^XN + ======================================================== */ + +/* ======================================================== + COMMANDWX^ւ̏ +@ 0ȂĂ΂܂BPAsv + ======================================================== */ +task_status_immed tski_do_command0( ) +{ + u8 temp_command; + + // command0 {̓dȂ + DI(); + temp_command = vreg_ctr[VREG_C_COMMAND0]; + vreg_ctr[VREG_C_COMMAND0] = 0; + EI(); + + if( temp_command & REG_BIT_GOING_TO_SLEEP ) + { + going_to_sleep = true; + } + + if( ( temp_command & ( REG_BIT_OFF_REQ | REG_BIT_RESET1_REQ | REG_BIT_FCRAM_RESET_REQ | REG_BIT_RESET2_REQ )) != 0x00 ) + { + if( temp_command & REG_BIT_OFF_REQ ) + { + system_status.pwr_state = OFF_TRIG; + } + else + { + if( temp_command & REG_BIT_RESET1_REQ ) + { + PM_reset_ast( ); + RESET2_ast; + FCRAM_RST_ast; + } + if( temp_command & REG_BIT_RESET2_REQ ) + { + RESET2_ast; + if( vreg_twl[ REG_TWL_INT_ADRS_MODE ] == 0 ) + { + FCRAM_RST_ast; // twlntr[hœ삵Ă + } + // TWL[hDS[hւ̐؂ւɃZbg + // IRQǂ܂Ȃꍇ̂TWLWX^ + vreg_twl_init(); + } + if( temp_command & REG_BIT_FCRAM_RESET_REQ ) + { + FCRAM_RST_ast; + } + wait_ms( 5 ); + FCRAM_RST_neg; + PM_reset_neg(); + RESET2_neg; + + // CODEC s背WX^ // + codec_reg_init(); + } + } +/* + X[vvɓdOFFEZbgR}h͗܂ + if( vreg_ctr[VREG_C_COMMAND0] != 0 ) + { + return ( ERR_CONTINUE ); + } +*/ + return ( ERR_FINISED ); +} + + + +/* fobOEeXgp ============================== */ +u16 _dbg_rcomp; +extern u8 raw_adc_temperature; + +extern u8 iic_burst_state; +extern bit temp_zone_charge_disable; +extern bit bt_authorized; + + +/* ======================================================== +@fobOpɂ낢ǂł܂B +@Ԓl̓f[^̂ + oĂ鏇́A + 1) vbgtH[ + 2) PMIC o[W + 3) dr[J[ + 4) KXQ[Wo[W + 5) V + 6) ( rcomp & 0xFF ) + 7) raw_adc_temperature + 8) ( !temp_zone_charge_disable | ( bt_authorized << 1 ) ) + 9) m点LED̓tJ[H + 10) system_status.family + ======================================================== */ + +#define KOUMOKU 19 + +static u8 infos_bits[2]; +static u8 infos_temp[5]; + +static const u8 *infos_table[] = { + &infos_temp[0], /* 0 */ + &pmic_version, + (u8*)&battery_manufacturer, + &mgic_version[0], + &mgic_version[1], + &infos_temp[1], /* 5 */ + &raw_adc_temperature, + &infos_temp[2], + &infos_temp[3], + (u8*)&system_status.family, +// LED_pow_red, /* 10 */ + &infos_bits[0], + (u8*)&LED_duty_pow_blu, + (u8*)&LED_duty_3d, + (u8*)&LED_duty_notify_red, + (u8*)&LED_duty_notify_grn, + (u8*)&LED_duty_notify_blu, /* 15 */ + &infos_bits[1], +// &LED_CAM, + (u8*)&LED_duty_WiFi, + &infos_temp[4] /* 18 */ + /* ڑƂ KOUMOKU ɒ */ +}; + + u8 extinfo_read(void) +{ + u8 ret = 0xFF; + + /* + * temp͌vZKvȃf[^Bɗ]TȂ̂ŌvZKv + * ϐ́Av/svɊւ炸vZ|V[ + */ + + if( iic_burst_state < KOUMOKU ) + { + infos_temp[0] = system_status.captureBox? MODEL_CAPTURE_BOX + : ( system_status.is_dev? MODEL_ISBAKO: (u8)system_status.model ); + infos_temp[1] = (u8)( _dbg_rcomp & 0xFF ); + infos_temp[2] = ( !temp_zone_charge_disable | ( bt_authorized << 1 ) ); + infos_temp[3] = 1; /* dlύXɂ1ŒɂȂ */ + infos_temp[4] = 0 +// | ( PM_EXTDC_n ? REG_BIT_HAL0_PM_EXTDC_n : 0 ) // status0ɂ + | ( RBR_RESET_n ? REG_BIT_HAL0_PM_EXTDC_n : 0 ) // 󂫂g킹Ă炤 + | ( BT_IN_CHG_n ? REG_BIT_HAL0_BT_IN_CHG_n : 0 ) + | ( BT_CHG_Ena_n ? REG_BIT_HAL0_RSV_5 : 0 ) // 󂫃rbggp,out pin + | 0 // WL_TX gȂ +// | ( SHELL_OPEN ? REG_BIT_HAL0_SHELL_OPEN : 0 ) // status0ɂ + | ( RBR_FLIGHT ? REG_BIT_HAL0_SHELL_OPEN : 0 ) // 󂫂g킹Ă炤 + | ( SW_WIFI_n ? REG_BIT_HAL0_SW_WIFI_n : 0 ) + | ( SW_HOME_n ? REG_BIT_HAL0_SW_HOME_n : 0 ) + | ( SW_POW_n ? REG_BIT_HAL0_SW_POW_n : 0 ); + + infos_bits[0] = (u8)LED_pow_red; + infos_bits[1] = (u8)LED_CAM; + + ret = *infos_table[iic_burst_state]; + iic_burst_state ++; + } + + return ret; +} + + +#ifdef i2c_timeout_test +void i2c_mcu_error_monitor() +{ + LED_duty_pow_blu = 0xff; + LED_duty_3d = 0xff; + LED_duty_notify_red = 0xff; + LED_duty_notify_grn = 0xff; + LED_duty_notify_blu = 0xff; + LED_pow_red = 1; + LED_CAM = 1; +} +#endif + diff --git a/tags/2.04/task_status.c b/tags/2.04/task_status.c new file mode 100644 index 0000000..0d07510 --- /dev/null +++ b/tags/2.04/task_status.c @@ -0,0 +1,84 @@ +#ifndef _WIN32 + +#pragma SFR +#pragma NOP +#pragma HALT +#pragma STOP + +#endif + +#include "incs_loader.h" +#include "renge\renge.h" +#include "hal.h" + +#include "pm.h" + +#include "accero.h" +#include "adc.h" +#include "i2c_mcu.h" +#include "led.h" + + +// ======================================================== +#define INTERVAL_TSK_STATUS 4 + + +/* ======================================================== + Xe[^XWX^Ȃ + ======================================================== */ +void tsk_status( ) +{ + static u8 state_old; // Xe[^Xωo荞 ̈ + u8 diff; + + // WJ`FbN + set_bit( SHELL_OPEN, vreg_ctr[VREG_C_STATUS], REG_BIT_ST_SHELL_OPEN ); + + // Xe[^XWX^֌W 荞 // + // pm.c ŁȀōs܂B + // REG_BIT_LCD_ON/OFF + // REG_BIT_BL_ON/OFF + // REG_BIT_BT_DC_CONNECT/DISC + + diff = (u8)( vreg_ctr[VREG_C_STATUS] ^ state_old ); + if( diff != 0 ) + { + state_old = vreg_ctr[VREG_C_STATUS]; + + if( system_status.pwr_state == ON ) + { + if( diff & REG_BIT_BATT_CHARGE ) + { + // [dԂɈȉ + if( vreg_ctr[VREG_C_STATUS] & REG_BIT_BATT_CHARGE ) + { + set_irq( VREG_C_IRQ1, REG_BIT_BT_CHG_START ); + } + else + { + set_irq( VREG_C_IRQ1, REG_BIT_BT_CHG_STOP ); + } + } + } + + if(( system_status.pwr_state == ON ) || + ( system_status.pwr_state == SLEEP ) + ) + { + if( diff & REG_BIT_ST_SHELL_OPEN ) + { + // W̊J‚ + if( vreg_ctr[VREG_C_STATUS] & REG_BIT_ST_SHELL_OPEN ) + { + set_irq( VREG_C_IRQ0, REG_BIT_SHELL_OPEN ); + } + else + { + set_irq( VREG_C_IRQ0, REG_BIT_SHELL_CLOSE ); + } + } + } + } + return; +} + diff --git a/tags/2.04/task_sys.c b/tags/2.04/task_sys.c new file mode 100644 index 0000000..e9e9edd --- /dev/null +++ b/tags/2.04/task_sys.c @@ -0,0 +1,638 @@ +#ifndef _WIN32 + +#pragma SFR +#pragma NOP +#pragma HALT +#pragma STOP + +#endif + +#include "incs.h" + +#include "i2c_twl.h" +#include "i2c_ctr.h" +#include "led.h" +#include "accero.h" +#include "pm.h" +#include "rtc.h" +#include "sw.h" +#include "adc.h" +#include "self_flash.h" + + +//========================================================= +#define WAIT_SHIROBAKO_POW_CONTROL 240 + + +//========================================================= +extern void nop8(); + + +static void chk_emergencyExit(); +static void force_off_check(); +static void send_getup_to_soc(); + + + +//========================================================= +extern bit info_led_off; +extern bit going_to_sleep; +extern bit bt_authorized; + +static u8 timeout_sleep; +extern u8 chg_led_override; + +#ifdef i2c_timeout_test +extern bit i2c_mcu_time_out_error; +#endif + + +//========================================================= +#define PWSW_POWON_TIME (u8)( 20 / SYS_INTERVAL_TICK ) // [ms] // INTERVAL_TSK_SW ŊȂBl珬̂ + +/* ======================================================== + }CRŕKvȂ +Eȓd͂ɓ + @system_status.pwr_state == OFF_TRIG ŁÃ^XNĂ΂ƁA + ȓd̓[hɓ܂ + ======================================================== */ +void tsk_sys( ) +{ + static u8 pwsw_timeout = 0; // d{^`^OB@^CAEg܂łɓdm肵Ȃoffɖ߂ + + hal_update(); + + switch ( system_status.pwr_state ) + { + case ON_CHECK: //------------------------------------------------------- + // ̊荞݂HALT(X[v) ^@A_v^L + + // dXCb`HALT // + if( system_status.poweron_reason == RSN_PWSW ) + { + if( PM_EXTDC_n ) + { + // A_v^Ȃ + if( SW_pow_count != 0 ) + { + pwsw_timeout = 0; + } + else + { + pwsw_timeout ++; + } + + if( pwsw_timeout > 100 ) + { + SW_pow_count = 0; + system_status.pwr_state = OFF_TRIG; // XCb`̓mCYBQB + renge_task_interval_run_force = true; + return; + } + } + else + { + BT_chk(); // v|[OBdrꌟô߁BiKvI2C_m_initĂł܂j + } + + if( SW_pow_count < PWSW_POWON_TIME ) + { + // ԂZēdonɓBĂȂ + return; + } + } + // else { if( system_status.poweron_reason == RSN_TRIALAc ) d } + + SW_pow_mask = true; // pwswςȂœd/ JԂȂ悤 + + // d // + iic_mcu_start( ); + + bt_force_update = false; + BT_chk(); // @obe̔AdrcIC̐ݒ + +#ifndef _ALLOW_NOBATT_ + if( system_status.model == MODEL_JIKKI_NOBATT ) + { + renge_task_interval_run_force = true; + system_status.pwr_state = OFF_TRIG; + return; + } +#endif + + // cʃ`FbN + BT_get_left(); // ɁABT_chk()sĂKv܂B + if( +// ( vreg_ctr[VREG_C_BT_REMAIN] < 1 ) // Ŕ肷ƓdrقƂǖƂ +// // A_v^ĂNłȂȂႤ + (( vreg_ctr[VREG_C_BT_VOLTAGE] < ( V_TH_ZERO / 256 ) ) && PM_EXTDC_n ) // dr && A_v^Ȃ + ) + { + // drȂ̂ŋNȂ(d`FbNĂ) + renge_task_interval_run_force = true; + system_status.pwr_state = OFF_TRIG; + return; + } + + // |[g̕ݒ@dOɁB + PM_SW_WIFI_n = 1; + PM_SW_HOME_n_JIKKI = 1; + PM_WL_TX = 1; + PM_SW_SEL_n = 1; + PM_ACCEL_INT1 = 1; + PM_ACC_VALID = 1; + + if( PM_sys_pow_on( ) != ERR_SUCCESS ) // ZbgĂ܂ + { // dNsƒG[ + renge_task_interval_run_force = true; + system_status.pwr_state = OFF_TRIG; + return; + } + + // ܂ŗƁAdm // + // vAbvon + PU_BT_IN_CHG_n = 1; + PU7 = bits8(0,0,0,1, 1,1,0,1); // 4:SW_WIFI 3:SW_PWSW 2:PM_IRQ 0:PM_EXTDC_n + PU_SW_HOME_n_JIKKI = 1; // SW_HOME + + if( system_status.poweron_reason == RSN_PWSW || + system_status.poweron_reason == RSN_TRIAL ) + { + // d{^łon̎́ALED_ + vreg_ctr[VREG_C_LED_POW] = LED_POW_ILM_AUTO; + } + else + { + // Ƃ肠ALEDԂŋN + vreg_ctr[VREG_C_LED_POW] = LED_POW_ILM_OFF; + } + + system_status.pwr_state = ON_TRIG; + + PM_LCD_vcom_set( ); // LCD̑ΌdlȂǏ + + break; + + case ON_TRIG: //------------------------------------------------------- +#ifdef i2c_timeout_test + LED_duty_pow_blu = 0; // debug + LED_duty_3d = 0; + LED_duty_notify_red = 0; + LED_duty_notify_grn = 0; + LED_duty_notify_blu = 0; + LED_pow_red = 0; + LED_CAM = 0; + i2c_mcu_time_out_error = false; +#endif + IIC_ctr_Init( ); + IIC_twl_Init( ); + RTC_32k_on( ); + + vreg_twl_init( ); + vreg_ctr_reset( ); + + KRM = bits8(0,0,0,0, 0,0,0,0); + PIF0 = 0; + + system_status.poweron_reason = NONE; + renge_task_interval_run_force = true; + + MK0 = INT_MSK0_RSV; + MK1 = INT_MSK1_RSV; + + iic_mcu_start(); + +// MK2 = ~( INT_MSK2_IIC_TWL | INT_MSK2_WIFI_TX_BSR | INT_MSK2_CODEC_PMIRQ ); +// PMK21 = 0; // wifi gȂ + PMK6 = 0; // pm_irq + + // todo Iɂ͊SɃWX^ + RBR_RESET_n = 1; + RBR_FLIGHT = 0; + + // u[gAXe[^XƂȂXV + if( system_status.reboot ) + { + u8 bl_status_temp; + + bl_status_temp = read_pmic( PM_REG_ADRS_BL ); + vreg_ctr[ VREG_C_STATUS ] |= (( bl_status_temp & 0x03 ) << 5 ); + set_bit( ( read_pmic( PM_REG_ADRS_VDD_LCD ) != 0 ), + vreg_ctr[ VREG_C_STATUS ], REG_BIT_LCD_POW ); + BT_chk(); + } + + LED_init( ); // reboot́BT_Chk,BT_chkɍs + + system_status.reboot = 0; + system_status.pwr_state = ON; + + // WDTZbgAI2C̏܂Ŋ荞ݕۗ + // قƂ͂ɂׂȂ... + if( ( vreg_ctr[ VREG_C_MCU_STATUS ] & REG_BIT_STATUS_WDT_RESET ) != 0 ) + { + set_irq( VREG_C_IRQ0, REG_BIT_IRQ_WDT_RESET ); + } + + break; + + case ON: //--------------------------------------------- + // PMICɂ鋭df`FbN + // fobKreset1AT[g邱ƂB̂Ƃ͑SZbg + chk_emergencyExit(); + + // SLPĎ + if( going_to_sleep ) // ΂ SLP_REQ ̑Oɗ\ + { + timeout_sleep ++; + if( timeout_sleep == 0 || // I[o[t[ҁBsleepČLjuŋNċC‚Ȃ + ( PIF0 && !SLP_REQ )) // slp荞݂CANĂ܂ + { + PIF0 = 0; + send_getup_to_soc(); + } + if( PIF0 && SLP_REQ ){ + PIF0 = 0; + PM_VDD_ecoMode(); + system_status.pwr_state = SLEEP; + renge_task_interval_run_force = true; + } + } + + // offJEg + force_off_check(); + +#ifndef _TAIKENDAI_SEISAN_SPECIAL_ + if( system_status.taikendai ) // A_v^玩œdoff + { + if( PM_EXTDC_n ) + { + system_status.pwr_state = OFF_TRIG; + } + } +#endif + + break; + + case SLEEP: //------------------------------------------ + chk_emergencyExit(); + // X[v畜A + if( !SLP_REQ ){ + PM_VDD_normMode(); + wait_ms( 5 ); // tdly_sw + send_getup_to_soc(); + system_status.pwr_state = ON; + } + + force_off_check(); + +#ifndef _TAIKENDAI_SEISAN_SPECIAL_ + if( system_status.taikendai ) // A_v^hĂ玩œdon + { + if( PM_EXTDC_n ) + { + system_status.pwr_state = OFF_TRIG; + } + } + break; +#endif + + default: //--------------------------------------- + system_status.pwr_state = OFF_TRIG; // 蓾ȂXe[gBfobOp + /* FALLTHROUGH */ + + case OFF_TRIG: //--------------------------------------- + // LED҂ + vreg_ctr[ VREG_C_LED_POW ] = LED_POW_ILM_OFF; + vreg_ctr[ VREG_C_LED_WIFI ] = WIFI_LED_OFF; + vreg_ctr[ VREG_C_LED_3D ] = LED_3D_ILM_OFF; + info_led_off = true; + if( LED_duty_pow_blu != 0 ) + { + return; + } + + // dfJEg_E^C}NA + clear_pow_off_countdown(); + + // xZT~ + vreg_ctr[ VREG_C_ACC_CONFIG ] = 0x00; + tski_acc_hosu_set(); + + // ̑ytF~ + LED_stop( ); + IIC_ctr_Stop( ); + IIC_twl_Stop( ); + RTC_32k_off(); + + // todo }Nɂł + RBR_RESET_n = 0; + RBR_FLIGHT = 0; + + // irqtONA + vreg_ctr[VREG_C_IRQ0] = 0; + vreg_ctr[VREG_C_IRQ1] = 0; + vreg_ctr[VREG_C_IRQ2] = 0; + vreg_ctr[VREG_C_IRQ3] = 0; + +// dI̊荞݃Zbg +// PWSW KR3 L +// BG24 KR4 +// ӂJ INTP5 ‚L +// ACA_v^ INTP4 A_v^L +// RTC + while( iic_mcu_busy ) + {;} + + KRM = ( KR_SW_POW ); // Mask ł͂ȂAModeȂ̂B킵 + MK0 = ~( INT_MSK0_EXTDC ); + MK1 = ~( INT_MSK1_KR | INT_MSK1_RTCINTVAL ); // INT_MSK1_RTCALARM | RTCA[ + MK2L = 0xFF; + + // PU5 ̂܂ + PU7 = bits8(0,0,0,0, 1,0,0,1); // PWSWI,PM_EXTTDC,( IRQ0_deactive(), PM_IRQ_deactive ) + PU_SW_HOME_n_JIKKI = 0; // SW_HOME ~ + + IF0 = 0; + IF1 = 0; + IF2 = 0; + + IRQ0_disable; + + PM_sys_pow_off( ); // dJbgIt + + // |[gނ~[hɁBHłALo͂ɂȂႾ߂ȁB + SW_WIFI_n_RAW = 0; + PM_SW_WIFI_n = 0; + + SW_HOME_n_JIKKI_RAW = 0; + PM_SW_HOME_n_JIKKI = 0; + + WL_TX = 0; + PM_WL_TX = 0; + + SW_SEL_n = 0; + PM_SW_SEL_n = 0; + + ACCEL_INT1 = 0; + PM_ACCEL_INT1 = 0; + ACC_VALID = 0; + PM_ACC_VALID = 0; + + system_status.pwr_state = OFF; + SW_pow_mask = true; + SW_pow_count = 0; + + // HALfobOZbg@YƓdonoȂȂ邱Ƃc + hal_reset(); + /* FALLTHROUGH */ + + case OFF: + // Fł͓d{^d͂܂B + + system_status.poweron_reason = NONE; + pwsw_timeout = 0; + + if( !PM_EXTDC_n + || chg_led_override != 0 ) // ꂪ[ɂȂ܂ő҂ + { + // A_v^L /////////////////////////////// ܂́AA_v^ĂRb͏[dLED_Ă + + // d{^`FbN + SW_pow_mask = false; + system_status.poweron_reason = RSN_PWSW; + system_status.pwr_state = ON_CHECK; + + // VȂ玩œdē + if( system_status.taikendai ) + { + vreg_ctr[ VREG_C_HAL_OVW_CONT0 ] = vreg_ctr[ VREG_C_HAL_OVW_CONT1 ] = 0; + wait_ms(46); // pmic̓dēdl̂ + system_status.poweron_reason = RSN_TRIAL; + system_status.pwr_state = ON_CHECK; + } + } + else + { + // A_v^Ȃ /////////////////////////////// + + // ȓd͂ֈڍs + iic_mcu_stop( ); + pm_chk_adapter(); + PM_Chg_Stop(); + + bt_force_update = true; + + while( RWST ) + {;} + + // 荞ݑ҂ŐQ // + RTCIMK = 1; // systickpC^[o^C}[荞݃}XN + + CKC = bits8(0,0,0,0, 1,0,0,1); + OSMC = 0x00; +#ifdef _DBG_CHK_OFF_LEAK_ + { + // offpinݒ~X`FbN + volatile u8 ports_i[12]; + volatile u8 ports_o[12]; + + ports_i[0] = ( PM0 & PU0 & ~P0 ); // vAbv؂YH + ports_i[1] = ( PM1 & PU1 & ~P1 ); + ports_i[2] = 0; + ports_i[3] = ( PM3 & PU3 & ~P3 ); + ports_i[4] = ( PM4 & PU4 & ~P4 ); + ports_i[5] = ( PM5 & PU5 & ~P5 ); + ports_i[6] = 0; + ports_i[7] = ( PM7 & PU7 & ~P7 ); + ports_i[8] = ( PM12 & PU12 & ~P12 ); + ports_i[9] = ( PM14 & PU14 & ~P14 ); + ports_i[10] = 0; + ports_i[11] = ( PM20 & PU20 & ~P20 ); + + ports_o[0] = ( ~PM0 & P0 ); // H o͂Ă邩 + ports_o[1] = ( ~PM1 & P1 ); + ports_o[2] = ( ~PM2 & P2 ); + ports_o[3] = ( ~PM3 & P3 & ~POM3 ); + ports_o[4] = ( ~PM4 & P4 ); // bit3chg_enȂ̂1ł悢 + ports_o[5] = ( ~PM5 & P5 ); + ports_o[6] = ( ~PM6 & P6 ); + ports_o[7] = ( ~PM7 & P7 ); + ports_o[8] = ( ~PM12 & P12 ); + ports_o[9] = ( ~PM14 & P14 ); + ports_o[10] = ( ~PM15 & P15 ); + ports_o[11] = ( ~PM20 & P20 ); + NOP(); // u[Nu + } + +#endif + if( PM_EXTDC_n ) // ǂ^C~Oő}N邱Ƃ + { + STOP(); + } + + // N // + // N + // EKeyReturn荞݁id{^j + // ERTCA[iݕj + + renge_flg_interval = 0; + hal_update(); + + OSMC = 0x01; + CKC = bits8(0,0,0,0, 1,0,0,0); + + // NŔH + if( !PM_EXTDC_n ){ + system_status.pwr_state = OFF; // ĂāAON_CHECKɍs + } +/* // RTCA[B + else if( vreg_ctr[ VREG_C_IRQ1 ] & REG_BIT_RTC_ALARM ) + { + system_status.poweron_reason = RSN_RTC_ALARM; + system_status.pwr_state = ON_CHECK; + } + // else if( ̊荞݂œdon ){ + // 󑼂̗vł͋NȂ + // } +*/ + else // if( !SW_POW_n ) // iȊOȂjd{^ŋN + { + SW_pow_mask = false; + system_status.poweron_reason = RSN_PWSW; + system_status.pwr_state = ON_CHECK; + } + + RTCIMK = 0; // sys tick ^C}[L + + if( system_status.taikendai ) + { + system_status.pwr_state = OFF_TRIG; + } + + } + return; + +#if 0 + default: + NOP( ); // 蓾ȂXe[g +#endif + + } +} + + + +/*******************************************************//** + PMICdُŎ~߂mF + **********************************************************/ +static void chk_emergencyExit(){ + static u8 shirobako_power_control_count; + + if( shirobako_power_control_count == 0 ) + { + if( !RESET1_n ) // PM_chk_LDSW() I2C_mgpARXg + { + if( PM_chk_LDSW( ) == 0 ) + { + // ZbgĂ + /// PMICُIf + system_status.pwr_state = OFF_TRIG; + renge_task_interval_run_force = true; + } + else + { + // ̎d + shirobako_power_control_count = 1; + } + } + } + else + { + if( shirobako_power_control_count == WAIT_SHIROBAKO_POW_CONTROL ) // }WbNio[ + // fobKBreset1܂ł͖ + { + if( RESET1_n ) // ZbglQ[g҂ + { + shirobako_power_control_count = 0; + } + else + { + // nothing to do + } + } + else if( shirobako_power_control_count == 200 ) // * (sys_tick)[ms] + // fobK炵 + { +#ifndef _RVD_ + // ͓d؂肽炵 + system_status.pwr_state = OFF_TRIG; + renge_task_interval_run_force = true; + shirobako_power_control_count = WAIT_SHIROBAKO_POW_CONTROL; +#endif + } + else + { + if( !RESET1_n ) + { + if( shirobako_power_control_count != 255 ) + shirobako_power_control_count ++; + } + else + { + // (TS{[hŎ蓮/fobK)Zbg炵 + send_cmd_pmic( PM_REG_ADRS_BL, 0 ); + vreg_ctr[VREG_C_STATUS] = ( vreg_ctr[VREG_C_STATUS] & bits8(1,0,0,1, 1,1,1,1) ); + vreg_ctr[VREG_C_COMMAND0] |= REG_BIT_RESET1_REQ; + renge_task_immed_add( tski_do_command0 ); + shirobako_power_control_count = WAIT_SHIROBAKO_POW_CONTROL; + } + } + } +} + + + +/* ======================================================== + Ed{^ + Edr؂ + Edr + ł̋OFFBƉs\ + ======================================================== */ +static void force_off_check() +{ + if( force_off ) + { + system_status.pwr_state = OFF_TRIG; + renge_task_interval_run_force = true; + } +} + + + +/* ======================================================== + SoCN +@@dʏɖ߂ĂĂʼnB + ======================================================== */ +void send_getup_to_soc() +{ + going_to_sleep = false; + timeout_sleep = 0; +#ifdef _MODEL_CTR_ + SLP_ACK = 1; + nop8(); + SLP_ACK = 0; +#endif +} + + + + +/* ======================================================== + firm_update() task_status_immed^ Ԃ悤ɂ΂̂ł... + ======================================================== */ +task_status_immed tski_firm_update(){ + firm_update(); + return( ERR_SUCCESS ); +} + diff --git a/tags/2.04/user_define.h b/tags/2.04/user_define.h new file mode 100644 index 0000000..701ee3a --- /dev/null +++ b/tags/2.04/user_define.h @@ -0,0 +1,234 @@ +#ifndef _USER_DEF_ +#define _USER_DEF_ + + +#define IIC_T_SLAVEADDRESS 0x4A +#define IIC_C_SLAVEADDRESS 0x4A +#define IIC_C_SLAVEADDRESS_DMY 0x4C + +//#define IIC_SLA_DCP 0x50 + +#define bits8(a,b,c,d,e,f,g,h) ( a<<7 | b<<6 | c<<5 | d<<4 | e<<3 | f<<2 | g<<1 | h ) + +#ifndef _WIN32 +// @‹ + +#ifdef _debug_led_ +/*spflΉȍ~AncłȂȂ̂Ŏg܂ +# define DBG_LED_on { PM2.1 = 0; P2.1 = 1; } +# define DBG_LED_off { P2.1 = 0; } +# define DBG_LED_toggle ( P2.1 ^= 1 ) +# define DBG_LED2_on { PM2.2 = 0; P2.2 = 1; } +# define DBG_LED2_off { P2.2 = 0; } +# define DBG_LED2_toggle ( P2.2 ^= 1 ) +*/ +#else +# define DBG_LED_on ; +# define DBG_LED_off ; +# define DBG_LED_toggle ; +# define DBG_LED2_on ; +# define DBG_LED2_off ; +# define DBG_LED2_toggle ; +#endif // _debug_led_ + +#define IIC_SLA_CODEC 0xA4 +#define IIC_SLA_ACCEL 0x30 // ST LIS331DLH + + +#define SLP_ACK P7.7 + + +// PMx0ŏo̓[h + +// SoC +#define IRQ0_ast { P7.6 = 0; PM7.6 = 0; } +#define IRQ0_neg { P7.6 = 1; } +#define IRQ0_enable { PM7.6 = 0; } +#define IRQ0_disable { PM7.6 = 1; } +#define IRQ0 ( P7.6 ) + + +// h~ +#define RESET1_n ( P0.0 ) + +#if 0 // PM_RESET1`g +# define RESET1_ast { P0.0 = 0; PM0.0 = 0; } +# define RESET1_neg { PM0.0 = 1; } +#endif + +#define RESET2_ast { P0.1 = 0; PM0.1 = 0; } +#define RESET2_neg { PM0.1 = 1; } + +#define SLP_REQ P12.0 + +// CTR,SPFL,܂ʔh@ +#define DEV_DET ( P12 & 0x00000110 ) +#define DEV_CTR ( 0b00 << 1 ) +#define DEV_SPFL ( 0b01 << 1 ) +#define DEV_SHRIMP ( 0b10 << 1 ) +#define DEV_RSV2 ( 0b11 << 1 ) + +// FCRAM +#define FCRAM_RST P3.0 +#define FCRAM_RST_ast { P3.0 = 0; } +#define FCRAM_RST_neg { P3.0 = 1; } + +// CODEC +#define PM_IRQ_n P7.2 +// INTP6 + +// PM +#define PM_EXTDC_n_RAW P7.0 +// INTP7 +//#define BT_TEMP P15.0 +// ANI8 +//#define BT_DET P15.1 +// ANI9 +#define BT_DET_P P1.6 +#define BT_TEMP_P P1.7 + + +// SPFL̃At@XLCDŕKvȁ}15V̓dB +#define SPFL_LCD_AMOL_HV_CONT P20.2 + + +// [d(out) +// _łBӁB +#define BT_CHG_ENABLE() ( P4.3 = 0 ) +#define BT_CHG_DISABLE() ( P4.3 = 1 ) +#define BT_CHG_Ena_n ( P4.3 ) + +// [d(in) +#define BT_IN_CHG_n_RAW P5.1 +#define PM_BT_IN_CHG_n PM5.1 +#define PU_BT_IN_CHG_n PU5.1 + +#define SW_WIFI_n_RAW P7.4 +#define PM_SW_WIFI_n PM7.4 +// KR4 +#define SW_POW_n_RAW P7.3 +// KR3 +#define SW_SEL_n P2.3 +#define PM_SW_SEL_n PM2.3 +//#define VOL P2.7 +// ANI7 + +#define SW_HOME_n_JIKKI_RAW P20.4 +#define PM_SW_HOME_n_JIKKI PM20.4 +#define PU_SW_HOME_n_JIKKI PU20.4 + +// INTP22 +#define SW_HOME_n_TSBOARD_RAW P2.0 // TS}U[pull up(P2͓p.u.) +#define PM_SW_HOME_n_TSBOARD PM2.0 + +// WiFi +#define WL_TX P20.3 // INTP21 +#define PM_WL_TX PM20.3 // INTP21 + +// RBR +#define RBR_RESET_n P2.1 +#define RBR_FLIGHT P2.2 + +//#define LED_CAM P1.0 // TO02 +//#define LED_WIFI P1.1 // TO03 +//#define LED_NOTIFY P1.3 // TO05 +//#define LED_3D P5.2 // SLTO TO01 +//#define LED_POW2 P1.4 // TO06 ( ) +//#define LED_POW1 P1.5 // TO07 ( ) +//#define LED_CHARGE P2.4 + +// P5.3 ɉAP5.5, P140 P141 +// P140o͐pȂ̂... +#define I2C_PU_on() { P14 |= 0x03; PM5.3 = 0; PM3.3 = 0; } +#define I2C_PU_off() { PM5.3 = 1; PM3.3 = 1; P14 &= ~0x03; } + +#define GYRO_ENABLE() P5.0 = 0 +#define GYRO_DISABLE() P5.0 = 1 + +//#define I2C_M_SDA P3.1 // SDA10 +//#define I2C_M_SCL P3.2 // SCL10 + +//#define I2C_0_SCL P6.0 // IIC_TWL SCL0 +//#define I2C_0_SDA P6.1 // SDA0 + +//#define I2C_1_SCL P20.0 // IIC CTR SCL1 +//#define I2C_1_SDA P20.1 // SDA1 + +//#define 32kHz_O P1.2 // RTCCL +//#define 32k_I1 P12.3 // XT1 +//#define 32k_I2 P12.4 // XT2 + +// @AJ@AV䔻ʁB +#define DIPSW ( P4 & 0b00000011 ) // mini cube & \tgEFAfBbvXCb` TOOL0,1B P4.0 L ӁI +#define DIPSW_CTR 0b11 // gp +#define DIPSW_ISDEV 0b00 // KuCBattGaugeŔ +#define DIPSW_TAIKENDAI 0b10 +#define DIPSW_TAIKENDAI_NBD 0b01 + + +#define SHELL_OPEN_RAW P7.1 // INTP5 ӂJ (‚L) + +#define ACC_VALID P20.5 +#define PM_ACC_VALID PM20.5 +#define ACCEL_INT1 P2.5 +#define PM_ACCEL_INT1 PM2.5 + + +#endif // _WIN32 + +// win32 sim‹Ƌ + +#define KR_SW_POW ( 1 << 3 ) +#define KR_SW_WIFI ( 1 << 4 ) + +/////////////////////////////////////////////////////////// + +#define INT_MSK0_IIC_M_DMA 1<<12 +#define INT_MSK0_SHELL 1<<7 +#define INT_MSK0_EXTDC 1<<6 +//#define INT_MSK0_SLP 1<<2 +#define INT_MSK0_RSV ~( INT_MSK0_IIC_M_DMA | INT_MSK0_SHELL | INT_MSK0_EXTDC ) + +#define INT_MSK1_KR 1<<11 +#define INT_MSK1_RTCINTVAL 1<<10 +#define INT_MSK1_RTCALARM 1<<9 +#define INT_MSK1_ADC 1<<8 +#define INT_MSK1_IIC_CTR 1<<3 +#define INT_MSK1_IIC_MCU 1<<0 +#define INT_MSK1_RSV ~( INT_MSK1_KR | INT_MSK1_RTCINTVAL | INT_MSK1_RTCALARM | INT_MSK1_ADC \ + | INT_MSK1_IIC_CTR | INT_MSK1_IIC_MCU ) + +#define INT_MSK2_WIFI_TX_KE3 1<<4 +#define INT_MSK2L_RSV ~( INT_MSK2_WIFI_TX_KE3 ) + +#define INT_MSK2_IIC_TWL 1<<8 +#define INT_MSK2_WIFI_TX_BSR 1<<10 +#define INT_MSK2_CODEC_PMIRQ 1<<3 +#define INT_MSK2_RSV ~( INT_MSK2_IIC_TWL | INT_MSK2_WIFI_TX_BSR | INT_MSK2_CODEC_PMIRQ ) + +#if 0 +#define INT_MSK0_IIC_M_DMA 0b0001000000000000 +#define INT_MSK0_SHELL 0b0000000010000000 +#define INT_MSK0_EXTDC 0b0000000001000000 +//#define INT_MSK0_SLP 0b0000000000000100 ) +//#define INT_MSK0_RSV 0b1110111100111011 ) +#define INT_MSK0_RSV 0b1110111100111111 + +#define INT_MSK1_KR 0b0000100000000000 +#define INT_MSK1_RTCINTVAL 0b0000010000000000 +#define INT_MSK1_RTCALARM 0b0000001000000000 +#define INT_MSK1_ADC 0b0000000100000000 +#define INT_MSK1_IIC_CTR 0b0000000000001000 +#define INT_MSK1_IIC_MCU 0b0000000000000001 +#define INT_MSK1_RSV 0b1111000011110110 + +#define INT_MSK2_WIFI_TX_KE3 0b00010000 +#define INT_MSK2L_RSV 0b11101111 + +#define INT_MSK2_IIC_TWL ( 0b0000000100000000 ) +#define INT_MSK2_WIFI_TX_BSR ( 0b0000010000000000 ) +#define INT_MSK2_CODEC_PMIRQ ( 0b0000000000001000 ) +#define INT_MSK2_RSV 0b1111101111110111 +#endif // 0 + +#endif // dupe include guard diff --git a/tags/2.04/voltable.c b/tags/2.04/voltable.c new file mode 100644 index 0000000..2aedcf0 --- /dev/null +++ b/tags/2.04/voltable.c @@ -0,0 +1,48 @@ +#include "incs.h" + +#define _10db_ + +#ifdef _10db_ +// max -10db +const u8 slider_to_codec[64] = +{ + 127, 126, 125, 124, 122, 121, 120, 119, + 118, 117, 116, 114, 113, 112, 111, 110, + 109, 108, 106, 105, 104, 103, 102, 101, + 100, 98, 97, 96, 95, 94, 93, 92, + 90, 89, 88, 87, 86, 85, 83, 82, + 81, 80, 79, 78, 77, 75, 74, 73, + 73, 72, 71, 70, 69, 67, 66, 65, + 64, 63, 62, 61, 59, 58, 57, 56 + }; +#endif + +#ifdef _15db_ +// max -15db +const u8 slider_to_codec[64] = +{ + 127, 127, 127, 127, 127, 126, 125, 123, + 122, 121, 120, 119, 118, 117, 116, 115, + 114, 113, 112, 110, 109, 108, 107, 106, + 105, 104, 103, 102, 101, 100, 99, 97, + 96, 95, 94, 93, 92, 91, 90, 89, + 88, 87, 86, 85, 84, 83, 82, 81, + 80, 79, 78, 77, 76, 75, 74, 73, + 71, 70, 69, 68, 67, 66, 66, 66 +}; +#endif + +#ifdef _4db_ +// max -4db +const u8 slider_to_codec[64] = +{ + 127, 127, 126, 125, 123, 122, 121, 119, + 118, 117, 115, 114, 112, 111, 110, 108, + 107, 106, 104, 103, 101, 100, 99, 97, + 96, 94, 93, 92, 90, 89, 88, 86, + 85, 83, 82, 81, 79, 78, 77, 75, + 74, 72, 71, 70, 68, 67, 66, 64, + 64, 63, 61, 60, 59, 57, 56, 54, + 53, 52, 50, 49, 48, 46, 44, 44 +}; +#endif diff --git a/tags/2.04/voltable.h b/tags/2.04/voltable.h new file mode 100644 index 0000000..6ff34ab --- /dev/null +++ b/tags/2.04/voltable.h @@ -0,0 +1,57 @@ +#ifdef _10db_ +// max -10db +/* +const u8 slider_to_codec[64] = +{ + 127, 127, 127, 127, 126, 125, 123, 122, + 121, 120, 118, 117, 116, 115, 113, 112, + 111, 110, 108, 107, 106, 105, 103, 102, + 101, 100, 98, 97, 96, 95, 93, 92, + 91, 90, 88, 87, 86, 85, 83, 82, + 81, 80, 78, 77, 76, 75, 73, 72, + 72, 71, 70, 68, 67, 66, 64, 63, + 62, 61, 59, 58, 57, 56, 55, 55 + }; +*/ +const u8 slider_to_codec[64] = +{ + 127, 126, 125, 124, 122, 121, 120, 119, + 118, 117, 116, 114, 113, 112, 111, 110, + 109, 108, 106, 105, 104, 103, 102, 101, + 100, 98, 97, 96, 95, 94, 93, 92, + 90, 89, 88, 87, 86, 85, 83, 82, + 81, 80, 79, 78, 77, 75, 74, 73, + 73, 72, 71, 70, 69, 67, 66, 65, + 64, 63, 62, 61, 59, 58, 57, 56 + }; +#endif + +#ifdef _15db_ +// max -15db +const u8 slider_to_codec[64] = +{ + 127, 127, 127, 127, 127, 126, 125, 123, + 122, 121, 120, 119, 118, 117, 116, 115, + 114, 113, 112, 110, 109, 108, 107, 106, + 105, 104, 103, 102, 101, 100, 99, 97, + 96, 95, 94, 93, 92, 91, 90, 89, + 88, 87, 86, 85, 84, 83, 82, 81, + 80, 79, 78, 77, 76, 75, 74, 73, + 71, 70, 69, 68, 67, 66, 66, 66 +}; +#endif + +#ifdef _4db_ +// max -4db +const u8 slider_to_codec[64] = +{ + 127, 127, 126, 125, 123, 122, 121, 119, + 118, 117, 115, 114, 112, 111, 110, 108, + 107, 106, 104, 103, 101, 100, 99, 97, + 96, 94, 93, 92, 90, 89, 88, 86, + 85, 83, 82, 81, 79, 78, 77, 75, + 74, 72, 71, 70, 68, 67, 66, 64, + 64, 63, 61, 60, 59, 57, 56, 54, + 53, 52, 50, 49, 48, 46, 44, 44 +}; +#endif diff --git a/tags/2.04/vreg_ctr.c b/tags/2.04/vreg_ctr.c new file mode 100644 index 0000000..ce2b59c --- /dev/null +++ b/tags/2.04/vreg_ctr.c @@ -0,0 +1,576 @@ +/* ======================================================== + +CTR MCU I2CWX^ + + ====================================================== */ +#include "incs.h" +#include "vreg_ctr.h" +#include "rtc.h" +#include "led.h" +#include "accero.h" +#include "pm.h" +#include "pool.h" + +#include + +#include "fsl_user.h" + + +extern u8 extinfo_read(); // task_misc.c + +extern u8 iic_burst_state; // o[XgANZX鎞̃JE^ +extern bit info_led_pattern_updated; // m点LED̃p^[擪ɖ߂ + +extern bit pedolog_overflow; +extern bit reserve_pedo_increnent; + + + +// ******************************************************** +#ifdef _DBG_PEDO_AUTO_ENABLE_ +u8 vreg_ctr[VREG_C_ENDMARK_ + 16]; +#else +u8 vreg_ctr[VREG_C_ENDMARK_]; +#endif + +static u8 vreg_free_adrs; // AhXł̂ł΂炭͂ +bit irq_readed; // AAA^̂߁B + + + +// ******************************************************** +extern task_status_immed tski_firm_update(); +extern task_status_immed tski_mcu_reset(); + + + +// ******************************************************** +#ifdef _MCU_BSR_ +#define IICAMK IICAMK1 +#endif + + +// ******************************************************** +// [̏l̎w肪KvȃAhX +// }CRZbgɌĂ΂܂ +void vreg_ctr_init( ) +{ + vreg_ctr[ VREG_C_VCOM_T ] = VCOM_DEFAULT_T; + vreg_ctr[ VREG_C_VCOM_B ] = VCOM_DEFAULT_B; + + vreg_ctr[ VREG_C_OFF_DELAY ] = FORCEOFF_THREASHOLD; + + vreg_ctr[ VREG_C_VOL_CAL_MIN ] = 0x36; + vreg_ctr[ VREG_C_VOL_CAL_MAX ] = 0xFF - 0x36; + + vreg_ctr[ VREG_C_RBR_CONTROL ] = REG_BIT_RESET_n; // todo | REG_BIT_FLIGHT; +} + + +// ******************************************************** +// {̂̓dɃZbg܂ +void vreg_ctr_reset( ) +{ + vreg_ctr[ VREG_C_MCU_VER_MAJOR ] = MCU_VER_MAJOR | 0x10; + vreg_ctr[ VREG_C_MCU_VER_MINOR ] = MCU_VER_MINOR; + + vreg_ctr[ VREG_C_LED_BRIGHT ] = 0xFF; + vreg_ctr[ VREG_C_LED_POW ] = 0; + vreg_ctr[ VREG_C_LED_WIFI ] = 0; + vreg_ctr[ VREG_C_LED_CAM ] = 0; + vreg_ctr[ VREG_C_LED_3D ] = 0; +// vreg_ctr[ VREG_C_VOL_CAL_MIN ] = 0x36; ŏ_I +// vreg_ctr[ VREG_C_VOL_CAL_MAX ] = 0xFF - 0x36; d邽тɃftHglɂȂĂ܂ + { + u8 i; + for( i = 0; i < sizeof( uni_info_LED ); i++ ) + { + info_LED.bindata[ i ] = 0; + } + } +} + + + +// ******************************************************** +// I2CzWX^ɏ܂B +//@ adrs ͓AhX +// @ȂAhXɃANZXꍇA܂B +// 񂾌ʁAI2C_mcuʐMꍇArenge_task_immed_add() +// gpȂƁAI2C_mcugpŃG[IꍇɃgC܂B +void vreg_ctr_write( u8 adrs, u8 data ) +{ + switch ( adrs ) + { + + case ( VREG_C_MCU_STATUS ): +// vreg_twl[ REG_TWL_INT_ADRS_MODE ] = (u8)( ( data >> 6 ) & 0x03 ); Rł悢B̑胊ZbgŃNA + vreg_ctr[ VREG_C_MCU_STATUS ] &= data; // bitNA͂邪Zbg͂ȂB + // ̕twlWX^~[͓ǂݏoꎞɍ + break; + + case ( VREG_C_VCOM_T ): + case ( VREG_C_VCOM_B ): + renge_task_immed_add( tski_vcom_set ); + vreg_ctr[adrs] = data; + break; + + case ( VREG_C_DBG03 ): + if( ( vreg_ctr[VREG_C_DBG01] == 'j' ) + && ( vreg_ctr[VREG_C_DBG02] == 'h' ) + && ( data == 'l' ) ) + { + renge_task_immed_add( tski_firm_update ); + IICAMK = 1; + } + vreg_ctr[ VREG_C_DBG03 ] = data; + break; + + case ( VREG_C_COMMAND0 ): + if( data != 0 ) + { + renge_task_immed_add( tski_do_command0 ); + vreg_ctr[ VREG_C_COMMAND0 ] |= data; + } + break; + + case ( VREG_C_COMMAND2 ): + // 炩̊荞݂҂ĂȂłB #--) ̂߂̊荞݂ + // td + if(( data & REG_BIT_CMD_LCD_ON ) != 0 ) + { + renge_task_immed_add( tski_PM_LCD_on ); + } + else if(( data & REG_BIT_CMD_LCD_OFF ) != 0 ) + { + renge_task_immed_add( tski_PM_LCD_off ); + } + + // obNCgݒ + /// ̂Ƃ낳ɍׂ͕Ȃǁc + if(( data & REG_BITS_CMD_BL ) != 0 ) + { + renge_task_immed_add( tski_PM_BL_set ); + vreg_ctr[adrs] = (u8)( data & REG_BITS_CMD_BL ); + } + break; + + case ( VREG_C_COMMAND1 ): + if( data != 0 ) + { + // u8 temp; ԕϐg΂łȂ... + // TWLɊ荞݂ + /// ۂɊ荞݂̂SoC + /// rbg̕тႤʓ| + vreg_twl[ REG_TWL_INT_ADRS_IRQ ] = ( ( data & REG_BIT_SEND_TWL_PWSW_DET ) != 0 ) ? REG_BIT_TWL_IRQ_PWSW_DET : 0x00; //pwsw_det + vreg_twl[ REG_TWL_INT_ADRS_IRQ ] |= ( ( data & REG_BIT_SEND_TWL_RESET_DET ) != 0 ) ? REG_BIT_TWL_IRQ_RESET : 0x00; //reset_req + + vreg_twl[ REG_TWL_INT_ADRS_IRQ ] |= ( ( data & REG_BIT_SEND_TWL_OFF_DET ) != 0 ) ? REG_BIT_TWL_IRQ_OFF : 0x00; //off_req + + vreg_twl[ REG_TWL_INT_ADRS_IRQ ] |= ( ( data & REG_BIT_SEND_TWL_BATT_LOW ) != 0 ) ? REG_BIT_TWL_IRQ_BT_LOW : 0x00; //batt_low + vreg_twl[ REG_TWL_INT_ADRS_IRQ ] |= ( ( data & REG_BIT_SEND_TWL_BATT_EMPTY ) != 0 ) ? REG_BIT_TWL_IRQ_BT_EMPTY : 0x00; //batt_empty + + if(( data & REG_BIT_SEND_TWL_VOL_CLICK ) != 0 ) + { + vreg_twl[ REG_TWL_INT_ADRS_IRQ ] |= REG_BIT_TWL_IRQ_VOL_CHANGE; //vol_changed + } + } + break; + + case ( VREG_C_LED_POW ): + if( iic_burst_state == 0 ) + { + vreg_ctr[ VREG_C_LED_POW ] = data; + iic_burst_state ++; + } + else if( iic_burst_state < 5 ) + { + led_red_batt_empty.dats[ iic_burst_state -1 ] = data; + iic_burst_state ++; + } + break; + + case ( VREG_C_LED_WIFI ): + case ( VREG_C_LED_CAM ): + case ( VREG_C_LED_3D ): + vreg_ctr[adrs] = (u8)( data & 0x0F ); + break; + + case ( VREG_C_LED_NOTIFY_DATA ): + if( iic_burst_state < sizeof( uni_info_LED ) ) + { + if(( iic_burst_state == 1 ) && ( data == 0 )) // fade_time == 0 ֎~ + { + data = 1; + } + info_LED.bindata[ iic_burst_state ] = data; + iic_burst_state ++; + if( iic_burst_state > 4 ) // p^[1ł + { + info_led_pattern_updated = true; + } + } + break; + + /// 񓯊œĂ邽߂ł͏ȂB + // \񂷂邾stopŏ + case ( VREG_C_RTC_SEC ): + case ( VREG_C_RTC_MIN ): + set_rtc( adrs - VREG_C_RTC_SEC, data & 0x7F ); + break; + + case ( VREG_C_RTC_DAY ): + case ( VREG_C_RTC_HOUR ): + set_rtc( adrs - VREG_C_RTC_SEC, data & 0x3F ); + break; + + case ( VREG_C_RTC_YOBI ): + set_rtc( adrs - VREG_C_RTC_SEC, data & 0x07 ); + break; + + case ( VREG_C_RTC_MONTH ): + set_rtc( adrs - VREG_C_RTC_SEC, data & 0x1F ); + break; + + case ( VREG_C_RTC_YEAR ): + set_rtc( adrs - VREG_C_RTC_SEC, data ); + break; + + case ( VREG_C_RTC_COMP ): + WDT_Restart(); + while(1) + { + RWAIT = 1; + while( !RWST ){} + if( SEC != 0 ) + { + break; + } + RWAIT = 0; + } + SUBCUD = data; + RWAIT = 0; + vreg_ctr[ VREG_C_RTC_COMP ] = data; + break; + + case ( VREG_C_RTC_ALARM_MIN ): + rtc_alarm_dirty = true; + vreg_ctr[ VREG_C_RTC_ALARM_MIN ] = (u8)( data & 0x7F ); + break; + + case ( VREG_C_RTC_ALARM_HOUR ): + rtc_alarm_dirty = true; + vreg_ctr[ VREG_C_RTC_ALARM_HOUR ] = (u8)( data & 0x3F ); + break; + + // ł悢 + case ( VREG_C_RTC_ALARM_DAY ): + vreg_ctr[ VREG_C_RTC_ALARM_DAY ] = (u8)( data & 0x3F ); + break; + + case ( VREG_C_RTC_ALARM_MONTH ): + vreg_ctr[ VREG_C_RTC_ALARM_MONTH ] = (u8)( data & 0x1F ); + break; + + case ( VREG_C_ACC_CONFIG ): + renge_task_immed_add( tski_acc_hosu_set ); + vreg_ctr[ VREG_C_ACC_CONFIG ] = data; + break; + + case ( VREG_C_ACC_R_ADRS ): + renge_task_immed_add( tski_acc_read ); + vreg_ctr[ VREG_C_ACC_R_ADRS ] = data; + break; + + case ( VREG_C_ACC_W_BUF ): + renge_task_immed_add( tski_acc_write ); + vreg_ctr[ VREG_C_ACC_W_BUF ] = data; + break; + + case ( VREG_C_ACC_HOSU_SETTING ): + if( ( data & 0x01 ) != 0 ) + { + clear_hosu_hist(); // NA + } + break; + + case ( VREG_CX_FREE_DATA ): + if( vreg_free_adrs < VREG_C_FREE_SIZE ) + { + pool.vreg_c_ext.vreg_c_free[ vreg_free_adrs ] = data; + vreg_free_adrs ++; + } + break; + + case ( VREG_CX_FREE_ADRS ): + vreg_free_adrs = data; + break; + + + case ( VREG_C_COMMAND3 ): + switch ( data ) + { + case ( 'r' ): + // 荞݃[`FSLCuĂԂ̂͋֎~ + // }CRċNB@WX^ނB + renge_task_immed_add( tski_mcu_reset ); + break; + +#ifdef _ENABLE_WDT_TEST_ + case ( 'w' ): + // WDTōċNieXgj + while(1) + { + NOP(); + } +// mcu_wdt_reset; // ̃R}hgӖȂłI + break; +#endif + case( 'p' ): + reserve_pedo_increnent = 1; + // ő₷ɂ̓X^bNȂBŗ\̂݁Atask_miscŏ +// hosu_increment_if_necessary(); // A + break; + } + +// vreg_ctr[ VREG_C_COMMAND3 ] = data; // KvȂ + break; + + case ( VREG_C_RBR_CONTROL ): + if(( data & REG_BIT_RESET_n ) != 0 ) + { + RBR_RESET_n = 1; + } + else + { + RBR_RESET_n = 0; + } + if(( data & REG_BIT_FLIGHT ) != 0 ) + { + RBR_FLIGHT = 1; + } + else + { + RBR_FLIGHT = 0; + } + vreg_ctr[ VREG_C_RBR_CONTROL ] = data; + break; + + // read only ////////////////////////////////////////// + case VREG_C_MCU_VER_MAJOR: + case VREG_C_MCU_VER_MINOR: + case VREG_C_3D: // ɃtbV + case VREG_C_SND_VOL: // ɃtbV + case VREG_C_BT_TEMP: // ɃtbV + case VREG_C_BT_REMAIN: // ɃtbV + case VREG_C_BT_REMAIN_FINE: // ɃtbV + case VREG_C_BT_VOLTAGE: // ɃtbV + case VREG_C_STATUS_1: // KɃtbV + case VREG_C_STATUS: // KɃtbV + case VREG_C_IRQ0: // ̂‚łɊ荞݋NĂقȂ... + case VREG_C_IRQ1: + case VREG_C_IRQ2: + case VREG_C_IRQ3: + case VREG_C_IRQ4: + case VREG_C_LED_NOTIFY_FLAG: // tbV + case VREG_C_RTC_SEC_FINE_L: // tbV + case VREG_C_RTC_SEC_FINE_H: // tbV + // VREG_C_ACC_RESERVE, // NȂ + // VREG_C_ACC_HOSU_HIST = 0x4F, + case VREG_C_ACC_XH: // tbV + case VREG_C_ACC_XL: + case VREG_C_ACC_YH: + case VREG_C_ACC_YL: + case VREG_C_ACC_ZH: + case VREG_C_ACC_ZL: + dbg_nop(); + // return( ERROR ) + break; + + case VREG_C_ACC_HOSU_L: // ĂǁAfobOpB(AhX0x4B == mcu sla(r)) + dbg_nop(); + /* FALLTHROUGH */ + + // ʂɏ邾 ///////////////////////////////// + default: + /* + case VREG_C_IRQ_MASK0: + case VREG_C_IRQ_MASK1: + case VREG_C_IRQ_MASK2: + case VREG_C_IRQ_MASK3: + case VREG_C_IRQ_MASK4: + case VREG_C_DBG01: + case VREG_C_DBG02: + case VREG_C_LED_BRIGHT: + case VREG_C_ACC_HOSU_L: + case VREG_C_ACC_HOSU_M: + case VREG_C_ACC_HOSU_H: + case VREG_C_ACC_HOSU_HOUR_BOUNDARY: + case VREG_C_FREE_ADRS: + case VREG_C_RTC_ALARM_YEAR: + case VREG_C_ACC_W_ADRS: + case VREG_C_OFF_DELAY: + case VREG_C_HAL_OVW_CONT0: + case VREG_C_HAL_OVW_DAT0: + case VREG_C_HAL_OVW_CONT1: + case VREG_C_HAL_OVW_DAT1: + */ + if( adrs < VREG_C_ENDMARK_ ) + { + vreg_ctr[adrs] = data; + break; + } + else + { + dbg_nop(); // `AhXɏ@Ȃ񂩃oOĂȂH + // return( ERROR ) + break; + } + } +// return( SUCCESS ) + return; +} + + + +// ******************************************************** +// I2CzWX^ǂ݂܂B +// ߂F xx f[^ +// ӁF̃AhX̏ŌĂ΂ ̂ŁA +// [hꂽNAȂǂ͋C‚ +// ( vreg_ctr_after_read( u8 adrs ) ) +u8 vreg_ctr_read( u8 adrs ) +{ + static u16 rsub_temp; + u8 temp; + + // RTC͓ǂݏorɌJオ̂邽 + if( ( VREG_C_RTC_SEC <= adrs ) && ( adrs <= VREG_C_RTC_YEAR ) ) + { + rtc_buf_refresh( ); + } + else if( adrs == VREG_C_MCU_STATUS ) + { + return( ( vreg_ctr[ VREG_C_MCU_STATUS ] & 0x03 ) | + ( ( vreg_twl[ REG_TWL_INT_ADRS_MODE ] & 0x03 ) << 6 ) | // sys_mode + ( ( vreg_twl[ REG_TWL_INT_ADRS_MODE ] & 0x80 ) >> 2 )); // vol32 + } + else if( adrs == VREG_C_RTC_SEC_FINE_L ) + { + rsub_temp = RSUBC; + return( (u8)( rsub_temp & 0xFF ) ); + } + else if( adrs == VREG_C_RTC_SEC_FINE_H ) + { + return( (u8)( ( rsub_temp >> 8 ) & 0xFF ) ); + } +/* + // debug I + else if( adrs == VREG_C_IRQ_MASK0 ) + { + return( vreg_ctr[ VREG_C_IRQ_MASK0 ] & 0x7F ); // `MSB0B1ȂʐMG[ + } +*/ + else if( adrs == VREG_C_ACC_HOSU_HIST ) + { + return( hosu_read() ); + } + else if( adrs == VREG_CX_FREE_DATA ) + { + temp = pool.vreg_c_ext.vreg_c_free[ vreg_free_adrs ]; + // vreg_free_adrs ++; // ʼnZĂ܂ƃCfbNX + return( temp ); + } + else if( adrs == VREG_CX_INFO ) + { + return( extinfo_read() ); + } + else if( adrs == VREG_C_ACC_HOSU_SETTING ) + { + if( pedolog_overflow ) + { + return( 0x10 ); + } + else + { + return( 0 ); + } + } + + if( adrs >= VREG_C_ENDMARK_ ) + { + // VREG_C_INFO > VREG_C_ENDMARK_ Ȃ̂łƂ + return( 0xFF ); + } + return ( vreg_ctr[adrs] ); +} + + + +// ******************************************************** +// I2CzWX^ǂ܂ĉ郌WX^ +void vreg_ctr_after_read( u8 adrs, u8 data ) +{ + // 荞݃tO̓[hŃNA + switch( adrs ) + { + case VREG_C_IRQ0: + case VREG_C_IRQ1: + case VREG_C_IRQ2: + case VREG_C_IRQ3: + case VREG_C_IRQ4: + DI(); + vreg_ctr[ adrs ] ^= data; + EI(); + irq_readed = true; + break; + + case VREG_CX_FREE_DATA: + vreg_free_adrs ++; + break; + + default: + break; + } +} + + + + + + +/****************************************************************************** + 荞݂ + 荞݃}XNKvƌƂłȎHڂɂȂ܂ + *****************************************************************************/ +#if 0 +// }XNĂAtO͗Ă邪A荞݂͓ȂB +#define set_irq( irqreg, bitpos ) \ +{ \ + vreg_ctr[ irqreg ] |= bitpos; \ + if( ( vreg_ctr[ irqreg+8 ] & bitpos ) == 0 ){ \ + IRQ0_ast; \ + } \ +} +#endif + +// }XNĂAtOuĂȂvA荞ݓȂB +void set_irq( u8 irqreg, u8 irq_flg ) +{ + u8 tot; + + if(( system_status.pwr_state == ON ) || + ( system_status.pwr_state == SLEEP )) + { + // DI(); + if( ( vreg_ctr[ irqreg + 8 ] & irq_flg ) == 0 ){ + vreg_ctr[ irqreg ] |= irq_flg; + IRQ0_neg; // uグ... + // EI(); + tot = 0; + while( !IRQ0 && ( ++tot != 0 ) ){;} // O.D.Ȃ̂łƂ̂҂ IRQ_mcu LɔĂƍ(•s) + IRQ0_ast; // ƂB + } + } +// EI(); +} diff --git a/tags/2.04/vreg_ctr.h b/tags/2.04/vreg_ctr.h new file mode 100644 index 0000000..a7ba785 --- /dev/null +++ b/tags/2.04/vreg_ctr.h @@ -0,0 +1,299 @@ +#ifndef __vreg_ctr__ +#define __vreg_ctr__ + + +#include "config.h" + +// VREG_C_MCU_STATUS +// bit[7.6] twl.sys_mode[1.0] ctr珑ȂAfcr_resetɓKɃZbg +// bit[5] V [7] ctr珑ȂAfcr_resetɓKɃZbg +#define REG_BIT_STATUS_WDT_RESET ( 1 << 1 ) +#define REG_BIT_RTC_BLACKOUT ( 1 << 0 ) + + +// VREG_C_STATUS, +#define REG_BIT_LCD_POW ( 1 << 7 ) +#define REG_BIT_BL_U ( 1 << 6 ) +#define REG_BIT_BL_L ( 1 << 5 ) +#define REG_BIT_BATT_CHARGE ( 1 << 4 ) +#define REG_BIT_POW_SUPPLY ( 1 << 3 ) +// gp ( 1 << 2 ) +#define REG_BIT_ST_SHELL_OPEN ( 1 << 1 ) +// gp ( 1 << 0 ) + + +// VREG_C_STATUS_X +// gp ( 1 << 6 ) +// gp ( 1 << 5 ) +#define REG_BIT_WIFI_TX ( 1 << 4 ) +// twl bl ̃~[[1: ( 1 << 3 ) +// 0]( 1 << 2 ) +#define REG_BIT_ACCERO_ERR ( 1 << 1 ) +#define REG_BIT_MGIC_ERR ( 1 << 0 ) + +// VREG_C_IRQ0 +#define REG_BIT_IRQ_WDT_RESET ( 1 << 7 ) +#define REG_BIT_SHELL_OPEN ( 1 << 6 ) +#define REG_BIT_SHELL_CLOSE ( 1 << 5 ) +#define REG_BIT_SW_WIFI_CLICK ( 1 << 4 ) +#define REG_BIT_SW_HOME_RELEASE ( 1 << 3 ) +#define REG_BIT_SW_HOME_CLICK ( 1 << 2 ) +#define REG_BIT_SW_POW_HOLD ( 1 << 1 ) +#define REG_BIT_SW_POW_CLICK ( 1 << 0 ) + +// VREG_C_IRQ1 +#define REG_BIT_BT_CHG_START ( 1 << 7 ) +#define REG_BIT_BT_CHG_STOP ( 1 << 6 ) +#define REG_BIT_BT_REMAIN ( 1 << 5 ) +#define REG_BIT_ACC_DAT_RDY ( 1 << 4 ) +#define REG_BIT_ACC_ACK ( 1 << 3 ) +#define REG_BIT_RTC_ALARM ( 1 << 2 ) +#define REG_BIT_BT_DC_CONNECT ( 1 << 1 ) +#define REG_BIT_BT_DC_DISC ( 1 << 0 ) + +// VREG_C_IRQ2 +#define REG_BIT_TWL_VER_READ ( 1 << 7 ) +//#define REG_BIT_TWL_SNDVOL_CHANGE ( 1 << 6 ) p~ +#define REG_BIT_SLIDE_VOL_ACROSS_TWL_BOUNDARY ( 1 << 6 ) +#define REG_BIT_TWL_BL_U_ON ( 1 << 5 ) +#define REG_BIT_TWL_BL_U_OFF ( 1 << 4 ) +#define REG_BIT_TWL_BL_L_ON ( 1 << 3 ) +#define REG_BIT_TWL_BL_L_OFF ( 1 << 2 ) +#define REG_BIT_TWL_OFF_REQ ( 1 << 1 ) +#define REG_BIT_TWL_RESET_REQ ( 1 << 0 ) + +// VREG_C_IRQ3 +#define REG_BIT_BL_U_ON ( 1 << 5 ) +#define REG_BIT_BL_U_OFF ( 1 << 4 ) +#define REG_BIT_BL_L_ON ( 1 << 3 ) +#define REG_BIT_BL_L_OFF ( 1 << 2 ) +#define REG_BIT_LCD_ON ( 1 << 1 ) +#define REG_BIT_LCD_OFF ( 1 << 0 ) + + +// ̂ǂ... +//#define REG_BIT_VR_3D_CHANGE ( 1 << 7 ) + + + +// VREG_C_COMMAND0 +//#define REG_BIT_CMD_LCD_ON ( 1 << 7 ) +//#define REG_BIT_CMD_LCD_OFF ( 1 << 6 ) +//#define REG_BIT_CMD_BL_ON ( 1 << 5 ) +//#define REG_BIT_CMD_BL_OFF ( 1 << 4 ) +#define REG_BIT_GOING_TO_SLEEP ( 1 << 4 ) +#define REG_BIT_FCRAM_RESET_REQ ( 1 << 3 ) +#define REG_BIT_RESET2_REQ ( 1 << 2 ) +#define REG_BIT_RESET1_REQ ( 1 << 1 ) +#define REG_BIT_OFF_REQ ( 1 << 0 ) + +// VREG_C_COMMAND1 (TWLɊ荞݂) +// gp ( 1 << 7 ) +// gp ( 1 << 6 ) +#define REG_BIT_SEND_TWL_VOL_CLICK ( 1 << 5 ) +#define REG_BIT_SEND_TWL_BATT_EMPTY ( 1 << 4 ) +#define REG_BIT_SEND_TWL_BATT_LOW ( 1 << 3 ) +#define REG_BIT_SEND_TWL_OFF_DET ( 1 << 2 ) +#define REG_BIT_SEND_TWL_RESET_DET ( 1 << 1 ) +#define REG_BIT_SEND_TWL_PWSW_DET ( 1 << 0 ) + +// VREG_C_COMMAND2 t֌W +#define REG_BIT_CMD_BL_U_ON ( 1 << 5 ) +#define REG_BIT_CMD_BL_U_OFF ( 1 << 4 ) +#define REG_BIT_CMD_BL_L_ON ( 1 << 3 ) +#define REG_BIT_CMD_BL_L_OFF ( 1 << 2 ) +#define REG_BIT_CMD_LCD_ON ( 1 << 1 ) +#define REG_BIT_CMD_LCD_OFF ( 1 << 0 ) +#define REG_BITS_CMD_BL ( REG_BIT_CMD_BL_U_ON | REG_BIT_CMD_BL_U_OFF | REG_BIT_CMD_BL_L_ON | REG_BIT_CMD_BL_L_OFF ) + + +// TWLɒʒmIRQWX^ +#define REG_BIT_TWL_IRQ_PWSW_DET 0x08 +#define REG_BIT_TWL_IRQ_RESET 0x01 +#define REG_BIT_TWL_IRQ_OFF 0x02 +#define REG_BIT_TWL_IRQ_BT_LOW 0x20 +#define REG_BIT_TWL_IRQ_BT_EMPTY 0x10 +#define REG_BIT_TWL_IRQ_VOL_CHANGE 0x40 + + +// CODECPMIC NTR ̑㗝WX^ +#define REG_BIT_TWL_REQ_OFF ( 1 << 6 ) +#define REG_BIT_TWL_REQ_BL_U ( 1 << 3 ) +#define REG_BIT_TWL_REQ_BL_L ( 1 << 2 ) +#define REG_BIT_TWL_REQ_RESET ( 1 << 0 ) + + +// VREG_C_LED_NOTIFY_FLAG +#define REG_BIT_IN_LOOP ( 1 << 0 ) + +// RBR control (0x57) +#define REG_BIT_FLIGHT ( 1 << 1 ) +#define REG_BIT_RESET_n ( 1 << 0 ) + + +// HAL bitfields 0 +#define REG_BIT_HAL0_PM_EXTDC_n ( 1 << 7 ) +#define REG_BIT_HAL0_BT_IN_CHG_n ( 1 << 6 ) +//#define REG_BIT_HAL0_PM_IRQ_n // gȂ +#define REG_BIT_HAL0_RSV_5 ( 1 << 5 ) +#define REG_BIT_HAL0_WL_TX ( 1 << 4 ) +#define REG_BIT_HAL0_SHELL_OPEN ( 1 << 3 ) // statusɂ܂ +#define REG_BIT_HAL0_SW_WIFI_n ( 1 << 2 ) +#define REG_BIT_HAL0_SW_HOME_n ( 1 << 1 ) +#define REG_BIT_HAL0_SW_POW_n ( 1 << 0 ) + + +// HAL bitfields 1 +#define REG_BIT_HAL1_DIPSW_1 ( 1 << 3 ) +#define REG_BIT_HAL1_DIPSW_0 ( 1 << 2 ) +#define REG_BIT_HAL1_HW_DET_1 ( 1 << 1 ) +#define REG_BIT_HAL1_HW_DET_0 ( 1 << 0 ) + +/* + ev +#define REG_BIT_ ( 1 << 7 ) +#define REG_BIT_ ( 1 << 6 ) +#define REG_BIT_ ( 1 << 5 ) +#define REG_BIT_ ( 1 << 4 ) +#define REG_BIT_ ( 1 << 3 ) +#define REG_BIT_ ( 1 << 2 ) +#define REG_BIT_ ( 1 << 1 ) +#define REG_BIT_ ( 1 << 0 ) +*/ + + + +/*============================================================================*/ +extern u8 vreg_ctr[]; + +/*============================================================================*/ +enum VREG_C_ADRS +{ // `AhX֏񂾍ۂ͕̓s + VREG_C_MCU_VER_MAJOR = 0x00, + VREG_C_MCU_VER_MINOR, + VREG_C_MCU_STATUS, + + VREG_C_VCOM_T = 0x03, + VREG_C_VCOM_B, + + VREG_C_DBG01 = 0x05, + VREG_C_DBG02, + VREG_C_DBG03, + + VREG_C_3D = 0x08, + VREG_C_SND_VOL, + VREG_C_BT_TEMP, + VREG_C_BT_REMAIN, + VREG_C_BT_REMAIN_FINE, + VREG_C_BT_VOLTAGE, + + VREG_C_STATUS_1 = 0x0E, + VREG_C_STATUS = 0x0F, + + VREG_C_IRQ0 = 0x10, + VREG_C_IRQ1, + VREG_C_IRQ2, + VREG_C_IRQ3, + VREG_C_IRQ4, + + VREG_C_IRQ_MASK0 = 0x18, + VREG_C_IRQ_MASK1, + VREG_C_IRQ_MASK2, + VREG_C_IRQ_MASK3, + VREG_C_IRQ_MASK4, + + VREG_C_COMMAND0 = 0x20, + VREG_C_COMMAND1, + VREG_C_COMMAND2, + VREG_C_COMMAND3, // 'r' Ń}CRZbgA 'w' WDTZbg + + VREG_C_OFF_DELAY = 0x24, +// VREG_C_VOL_DIGITAL = 0x25, // todo +// VREG_C_VOL_OPTION, + VREG_C_VOL_ADC_RAW = 0x27, + + VREG_C_LED_BRIGHT = 0x28, + VREG_C_LED_POW, + VREG_C_LED_WIFI, + VREG_C_LED_CAM, + VREG_C_LED_3D, + VREG_C_LED_NOTIFY_DATA, + VREG_C_LED_NOTIFY_FLAG, + + VREG_C_RBR_CONTROL = 0x2F, + + VREG_C_RTC_SEC = 0x30, + VREG_C_RTC_MIN, + VREG_C_RTC_HOUR, + VREG_C_RTC_YOBI, + VREG_C_RTC_DAY, + VREG_C_RTC_MONTH, + VREG_C_RTC_YEAR, + + VREG_C_RTC_COMP, + + VREG_C_RTC_ALARM_MIN = 0x38, + VREG_C_RTC_ALARM_HOUR, + VREG_C_RTC_ALARM_DAY, + VREG_C_RTC_ALARM_MONTH, + VREG_C_RTC_ALARM_YEAR, + + VREG_C_RTC_SEC_FINE_L, + VREG_C_RTC_SEC_FINE_H, + + VREG_C_ACC_CONFIG = 0x40, + VREG_C_ACC_R_ADRS, + VREG_C_ACC_RESERVE, + VREG_C_ACC_W_ADRS, + VREG_C_ACC_W_BUF, + + VREG_C_ACC_XL = 0x45, + VREG_C_ACC_XH, + VREG_C_ACC_YL, + VREG_C_ACC_YH, + VREG_C_ACC_ZL, + VREG_C_ACC_ZH, + + VREG_C_ACC_HOSU_L = 0x4B, + VREG_C_ACC_HOSU_M, + VREG_C_ACC_HOSU_H, + VREG_C_ACC_HOSU_SETTING, + VREG_C_ACC_HOSU_HIST = 0x4F, + + VREG_C_ACC_HOSU_HOUR_BOUNDARY = 0x50, + VREG_C_ACC_HOSU_HOUR_BOUNDARY_SEC, + + VREG_C_HAL_OVW_CONT0 = 0x52, + VREG_C_HAL_OVW_DAT0, + VREG_C_HAL_OVW_CONT1, // reserved + VREG_C_HAL_OVW_DAT1, // reserved + + VREG_C_HAL_OVW_BT_FUEL = 0x56, + VREG_C_HAL_OVW_BT_VOLTAGE, + + VREG_C_VOL_CAL_MIN = 0x58, + VREG_C_VOL_CAL_MAX, + + VREG_C_HAL_OVW_TEMPERATURE = 0x5A, + + VREG_C_ENDMARK_ +}; + +// Ԃ͔ɂāAmۂȂ߂ ʂ define Ă +#define VREG_CX_INFO 0x7F +#define VREG_CX_FREE_ADRS 0x60 +#define VREG_CX_FREE_DATA 0x61 +// VREG_C_AMBIENT_BRIGHTNESS = 0xXX, + + + + +/*============================================================================*/ +void vreg_ctr_init( ); +void vreg_ctr_reset( ); +void vreg_ctr_write( u8 adrs, u8 data ); +u8 vreg_ctr_read( u8 phy_adrs ); +void vreg_ctr_after_read( u8 adrs, u8 data ); +void set_irq( u8 irqreg, u8 irq_flg ); + +#endif diff --git a/tags/2.04/vreg_twl.c b/tags/2.04/vreg_twl.c new file mode 100644 index 0000000..0bd0caa --- /dev/null +++ b/tags/2.04/vreg_twl.c @@ -0,0 +1,150 @@ +/* ======================================================== + +TWL݊I2CWX^ + + ======================================================== */ +#include "incs.h" +#include "jhl_defs.h" +#include "led.h" + +#include "vreg_twl.h" +#include "vreg_ctr.h" + +// ======================================================== +#define TWL_REG_VER_INFO 0x35 +#define NON_EXIST_REG 0xFF + +// ======================================================== +u8 vreg_twl[_REG_TWL_INT_ADRS_ENDMARK]; + +extern bit twl_ver_read; +extern bit cam_led_update; + +extern bit vol_changed_by_twl; + + +/* ======================================================== + zWX^̏ + ======================================================== */ +void vreg_twl_init( ) +{ + vreg_twl[ REG_TWL_INT_ADRS_MODE ] = 0x03; + vreg_twl[ REG_TWL_INT_ADRS_IRQ ] = 0; + vreg_twl[ REG_TWL_INT_ADRS_CAM ] = 0; + vreg_twl[ REG_TWL_INT_ADRS_TEMP0 ] = 0; +} + +// ======================================================== +// I2CzWX^ɏEANV +//@ adrs ͓AhX +// @݂ȂAhXɃANZXꍇA܂B +void vreg_twl_write( u8 adrs, u8 data ) +{ + switch ( adrs ) + { + case ( REG_TWL_INT_ADRS_VOL ): + { + vol_changed_by_twl = true; + vreg_twl[ REG_TWL_INT_ADRS_VOL ] = data; + //renge_task_immed_add( tski_vol_update ); + vol_polling = 3; + break; + } + + case ( REG_TWL_INT_ADRS_MODE ): + vreg_twl[ REG_TWL_INT_ADRS_MODE ] = ( data & 0x83 ); // [8]vol32 [1:0]nand + break; + + case ( REG_TWL_INT_ADRS_CAM ): + vreg_twl[ REG_TWL_INT_ADRS_CAM ] = ( data & 0x03 ); + if( ( data & 0x03 ) == TWL_CAMLED_BLINK ) + { + cam_led_update = true; // łȂƈꔭɕs邽 + } + tsk_led_cam(); + break; + + case ( REG_TWL_INT_ADRS_TEMP0 ): + vreg_twl[ REG_TWL_INT_ADRS_TEMP0 ] = data; + break; + + case ( REG_TWL_INT_ADRS_COMMAND ): +/* + if( data <= 2 ){ + if( ( data & REG_BIT_TWL_OFF_REQ ) != 0 ) + { + set_irq( VREG_C_IRQ2, REG_BIT_TWL_OFF_REQ ); // OFFĂ炵B + break; + } + else if( ( data & REG_BIT_TWL_RESET_REQ ) != 0 ) + { + set_irq( VREG_C_IRQ2, REG_BIT_TWL_RESET_REQ ); //ZbgȂB̂́ASPI痈܂B + break; + } + } +*/ + if( data == REG_BIT_TWL_RESET_REQ ) + { + set_irq( VREG_C_IRQ2, REG_BIT_TWL_RESET_REQ ); //ZbgȂB̂́ASPI痈܂B + break; + } + } + return; +} + + + +// ======================================================== +// I2CzWX^ǂ݂܂B +//@ adrs O猩Ƃ́AAhX +//@߂ xx f[^ +// @݂ȂAhXɃANZXꍇA߂l0x5A +u8 vreg_twl_read( u8 phy_adrs ) +{ + u8 temp; + + switch( phy_adrs ){ + // 10%ȉŐԂɂȂ + case( REG_TWL_INT_ADRS_POWER_INFO ): + // x̃Zbg get_batt_left()ixĖłj + return( vreg_twl[ REG_TWL_INT_ADRS_POWER_INFO ] | ( !PM_EXTDC_n ? 0x80: 0x00 ) ); // A_v^bit(A_v^L) + + case( REG_TWL_INT_ADRS_IRQ ): + temp = vreg_twl[ REG_TWL_INT_ADRS_IRQ ]; + vreg_twl[ REG_TWL_INT_ADRS_IRQ ]= 0; + return( temp ); + + case( REG_TWL_INT_ADRS_VER_INFO ): +// set_irq( VREG_C_IRQ2, REG_BIT_TWL_VER_READ ); // xIɖȂ̂ + twl_ver_read = true; + return( TWL_REG_VER_INFO ); + + case( REG_TWL_ADRS_NON_EXIST ): + return( 0x00 ); + + default: + return( vreg_twl[ phy_adrs ] ); + } +} + + + +// ======================================================== +// O猩钎HAhXA̘AAhXɓǂݑւ +// 0xFF݂͑ȂAhXB +u8 adrs_table_twl_ext2int( u8 img ) +{ + switch( img ){ + case( REG_TWL_ADRS_IRQ ): return( REG_TWL_INT_ADRS_IRQ ); + case( REG_TWL_ADRS_COMMAND ): return( REG_TWL_INT_ADRS_COMMAND ); + case( REG_TWL_ADRS_POWER_INFO ): return( REG_TWL_INT_ADRS_POWER_INFO ); + case( REG_TWL_ADRS_VOL ): return( REG_TWL_INT_ADRS_VOL ); + case( REG_TWL_ADRS_CAM ): return( REG_TWL_INT_ADRS_CAM ); + case( REG_TWL_ADRS_TEMP0 ): return( REG_TWL_INT_ADRS_TEMP0 ); + case( REG_TWL_ADRS_VER_INFO ): return( REG_TWL_INT_ADRS_VER_INFO ); + case( REG_TWL_ADRS_MODE ): return( REG_TWL_INT_ADRS_MODE ); + default: return( REG_TWL_ADRS_NON_EXIST ); +// 0ǂ߂΂悢AȂėǂ +// case( REG_TWL_ADRS_WIFI ): return( REG_TWL_INT_ADRS_WIFI ); + } +} diff --git a/tags/2.04/vreg_twl.h b/tags/2.04/vreg_twl.h new file mode 100644 index 0000000..63cdd94 --- /dev/null +++ b/tags/2.04/vreg_twl.h @@ -0,0 +1,127 @@ +#ifndef __vreg_twl__ +#define __vreg_twl__ +/* ========================================================================= */ +extern u8 vreg_twl[]; + + +/* + * O猩Ƃ̃}CRWX^AhXB + * gȂǂlĔєтɂĂB + */ +/* + * 荞ݗvtO + * MSB:OdL/Ȃω ij + * 6:VolL[iύXɌ炸BMAXɁ{łBj + * 5:drd o + * 4: + * 3:dXCb` ꌟo + * 2:iݒj + * 1:dXCb` OFF ԉꌟo + * LSB: Zbg + */ +enum REG_TWL_ADRS +{ // `AhX֏񂾍ۂ͖ + REG_TWL_ADRS_VER_INFO = 0x00, + REG_TWL_ADRS_PMIC_INFO, + REG_TWL_ADRS_BATT_INFO, + REG_TWL_ADRS_IRQ = 0x10, + REG_TWL_ADRS_COMMAND, + REG_TWL_ADRS_MODE, + REG_TWL_ADRS_POWER_INFO = 0x20, + REG_TWL_ADRS_POWER_SAVE, + REG_TWL_ADRS_WIFI = 0x30, + REG_TWL_ADRS_CAM, + REG_TWL_ADRS_VOL = 0x40, + REG_TWL_ADRS_BL, + REG_TWL_ADRS_CODEC_MIC_GAIN = 0x50, + REG_TWL_ADRS_ADC_CALIB = 0x60, + REG_TWL_ADRS_ADC_CALIB_STATUS, + REG_TWL_ADRS_ADC_CALIB_VALUE, + REG_TWL_ADRS_POWER_LED, + REG_TWL_ADRS_TEMP0 = 0x70, + REG_TWL_ADRS_TEMP1, + REG_TWL_ADRS_TEMP2, + REG_TWL_ADRS_TEMP3, + REG_TWL_ADRS_TEMP4, + REG_TWL_ADRS_TEMP5, + REG_TWL_ADRS_TEMP6, + REG_TWL_ADRS_TEMP7, + REG_TWL_ADRS_TIME_PWSW_DELAY = 0x80, + REG_TWL_ADRS_TIME_PWSW_THRESHOLD +}; + +#define REG_TWL_ADRS_NON_EXIST 0xFF + +/* + * }CRł̃WX^̎ + * ‚߂Ă + */ +enum REG_TWL_ADRS_INT +{ + REG_TWL_INT_ADRS_VER_INFO = 0x00, +// REG_TWL_INT_ADRS_PMIC_INFO, +// REG_TWL_INT_ADRS_BATT_INFO, + REG_TWL_INT_ADRS_IRQ, // 0x10, + REG_TWL_INT_ADRS_COMMAND, + REG_TWL_INT_ADRS_MODE, + REG_TWL_INT_ADRS_POWER_INFO, // 0x20, +// REG_TWL_INT_ADRS_POWER_SAVE, +// REG_TWL_INT_ADRS_WIFI, // 0x30, + REG_TWL_INT_ADRS_CAM, + REG_TWL_INT_ADRS_VOL, // 0x40, +// REG_TWL_INT_ADRS_BL, +// REG_TWL_INT_ADRS_CODEC_MIC_GAIN, // 0x50, +// REG_TWL_INT_ADRS_CODEC_MIC_GAIN_RELOAD, +// REG_TWL_INT_ADRS_ADC_CALIB, // 0x60, +// REG_TWL_INT_ADRS_ADC_CALIB_STATUS, +// REG_TWL_INT_ADRS_ADC_CALIB_VALUE, +// REG_TWL_INT_ADRS_POWER_LED, + REG_TWL_INT_ADRS_TEMP0, // 0x70 - 0x77 + REG_TWL_INT_ADRS_TEMP1, + REG_TWL_INT_ADRS_TEMP2, + REG_TWL_INT_ADRS_TEMP3, + REG_TWL_INT_ADRS_TEMP4, + REG_TWL_INT_ADRS_TEMP5, + REG_TWL_INT_ADRS_TEMP6, + REG_TWL_INT_ADRS_TEMP7, +// REG_TWL_INT_ADRS_TIME_PWSW_DELAY, +// REG_TWL_INT_ADRS_TIME_PWSW_THRESHOLD + _REG_TWL_INT_ADRS_ENDMARK, +}; + + + +/* ========================================================================= */ +#define is_TWL ( vreg_twl[ REG_TWL_INT_ADRS_MODE ] & 0x01 ) +#define with_NAND ( vreg_twl[ REG_TWL_INT_ADRS_MODE ] & 0x02 ) +#define volSteps32 ( vreg_twl[ REG_TWL_INT_ADRS_MODE ] & 0x80 ) + +#define reg_wifi_led ( vreg_twl[ REG_TWL_INT_ADRS_WIFI ] & 0x01 ) +#define reg_wifi_led_blink ( vreg_twl[ REG_TWL_INT_ADRS_WIFI ] & 0x02 ) + +#define REG_TWL_ADRS_MODE__VOL32 ( 1 << 7 ) + +typedef enum CAM_LED_TWL_MODE +{ + TWL_CAMLED_OFF, + TWL_CAMLED_ON, + TWL_CAMLED_BLINK, + TWL_CAMLED_DEF_ON +}twl_camLed_mode; + + +/* ========================================================================= */ +void vreg_twl_init( ); +void vreg_twl_write( u8 adrs, u8 data ); +u8 adrs_table_twl_ext2int( u8 img ); +u8 vreg_twl_read( u8 phy_adrs ); + + +// ǂ񂾂NAȂǂ̏ +#define vreg_twl_after_read( reg_adrs ); \ + if( reg_adrs == REG_TWL_INT_ADRS_IRQ ) \ + { \ + vreg_twl[ REG_TWL_INT_ADRS_IRQ ]= 0;\ + } + +#endif diff --git a/tags/2.04/yav_mcu_bsr.plg b/tags/2.04/yav_mcu_bsr.plg new file mode 100644 index 0000000..c9ae21d --- /dev/null +++ b/tags/2.04/yav_mcu_bsr.plg @@ -0,0 +1,196 @@ +C:\Windows\system32\cmd.exe /c c:\cygwin\bin\touch magic.c +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no loader.c +loader.c(139) : CC78K0R warning W0401: Conversion may lose significant digits +loader.c(140) : CC78K0R warning W0401: Conversion may lose significant digits +loader.c(172) : CC78K0R warning W0401: Conversion may lose significant digits +Compilation complete, 0 error(s) and 3 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\loader.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no pm.c +pm.c(484) : CC78K0R warning W0401: Conversion may lose significant digits +pm.c(777) : CC78K0R warning W0401: Conversion may lose significant digits +pm.c(781) : CC78K0R warning W0401: Conversion may lose significant digits +pm.c(811) : CC78K0R warning W0401: Conversion may lose significant digits +pm.c(832) : CC78K0R warning W0401: Conversion may lose significant digits +pm.c(898) : CC78K0R warning W0401: Conversion may lose significant digits +pm.c(907) : CC78K0R warning W0401: Conversion may lose significant digits +pm.c(1110) : CC78K0R warning W0401: Conversion may lose significant digits +pm.c(1112) : CC78K0R warning W0401: Conversion may lose significant digits +Compilation complete, 0 error(s) and 9 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\pm.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no i2c_ctr.c +Compilation complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\i2c_ctr.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no main.c +Compilation complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\main.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no magic.c +Compilation complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\magic.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no WDT.c +Compilation complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\WDT.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no i2c_mcu.c +i2c_mcu.c(210) : CC78K0R warning W0401: Conversion may lose significant digits +Compilation complete, 0 error(s) and 1 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\i2c_mcu.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no i2c_twl.c +Compilation complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\i2c_twl.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no led.c +led.c(82) : CC78K0R warning W0745: Expected function prototype +led.c(331) : CC78K0R warning W0401: Conversion may lose significant digits +Compilation complete, 0 error(s) and 2 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\led.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no rtc.c +Compilation complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\rtc.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no vreg_ctr.c +vreg_ctr.c(165) : CC78K0R warning W0401: Conversion may lose significant digits +vreg_ctr.c(166) : CC78K0R warning W0401: Conversion may lose significant digits +vreg_ctr.c(168) : CC78K0R warning W0401: Conversion may lose significant digits +vreg_ctr.c(170) : CC78K0R warning W0401: Conversion may lose significant digits +vreg_ctr.c(171) : CC78K0R warning W0401: Conversion may lose significant digits +vreg_ctr.c(219) : CC78K0R warning W0401: Conversion may lose significant digits +vreg_ctr.c(219) : CC78K0R warning W0401: Conversion may lose significant digits +vreg_ctr.c(224) : CC78K0R warning W0401: Conversion may lose significant digits +vreg_ctr.c(224) : CC78K0R warning W0401: Conversion may lose significant digits +vreg_ctr.c(228) : CC78K0R warning W0401: Conversion may lose significant digits +vreg_ctr.c(228) : CC78K0R warning W0401: Conversion may lose significant digits +vreg_ctr.c(232) : CC78K0R warning W0401: Conversion may lose significant digits +vreg_ctr.c(232) : CC78K0R warning W0401: Conversion may lose significant digits +vreg_ctr.c(236) : CC78K0R warning W0401: Conversion may lose significant digits +Compilation complete, 0 error(s) and 14 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\vreg_ctr.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no vreg_twl.c +vreg_twl.c(55) : CC78K0R warning W0401: Conversion may lose significant digits +vreg_twl.c(59) : CC78K0R warning W0401: Conversion may lose significant digits +Compilation complete, 0 error(s) and 2 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\vreg_twl.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no adc.c +adc.c(102) : CC78K0R warning W0401: Conversion may lose significant digits +adc.c(183) : CC78K0R warning W0401: Conversion may lose significant digits +adc.c(229) : CC78K0R warning W0401: Conversion may lose significant digits +adc.c(288) : CC78K0R warning W0401: Conversion may lose significant digits +adc.c(409) : CC78K0R warning W0745: Expected function prototype +adc.c(438) : CC78K0R warning W0401: Conversion may lose significant digits +adc.c(443) : CC78K0R warning W0401: Conversion may lose significant digits +Compilation complete, 0 error(s) and 7 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\adc.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no renge\renge.c +Compilation complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\renge.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no accero.c +accero.c(105) : CC78K0R warning W0745: Expected function prototype +Compilation complete, 0 error(s) and 1 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\accero.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no self_flash.c +self_flash.c(280) : CC78K0R warning W0401: Conversion may lose significant digits +self_flash.c(281) : CC78K0R warning W0401: Conversion may lose significant digits +Compilation complete, 0 error(s) and 2 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\self_flash.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no sw.c +Compilation complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\sw.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no task_debug.c +Compilation complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\task_debug.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no task_misc.c +task_misc.c(335) : CC78K0R warning W0401: Conversion may lose significant digits +task_misc.c(337) : CC78K0R warning W0401: Conversion may lose significant digits +task_misc.c(349) : CC78K0R warning W0401: Conversion may lose significant digits +Compilation complete, 0 error(s) and 3 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\task_misc.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no task_sys.c +task_sys.c(219) : CC78K0R warning W0401: Conversion may lose significant digits +task_sys.c(585) : CC78K0R warning W0401: Conversion may lose significant digits +Compilation complete, 0 error(s) and 2 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\task_sys.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no pedo_alg_thre_det2.c +pedo_alg_thre_det2.c(102) : CC78K0R warning W0745: Expected function prototype +pedo_alg_thre_det2.c(118) : CC78K0R warning W0401: Conversion may lose significant digits +Compilation complete, 0 error(s) and 2 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\pedo_alg_thre_det2.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no ini_VECT.c +Compilation complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\ini_VECT.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no task_status.c +Compilation complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\task_status.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no led_cam.c +Compilation complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\led_cam.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no led_pow.c +led_pow.c(99) : CC78K0R warning W0401: Conversion may lose significant digits +led_pow.c(104) : CC78K0R warning W0401: Conversion may lose significant digits +led_pow.c(155) : CC78K0R warning W0401: Conversion may lose significant digits +led_pow.c(215) : CC78K0R warning W0401: Conversion may lose significant digits +led_pow.c(244) : CC78K0R warning W0401: Conversion may lose significant digits +Compilation complete, 0 error(s) and 5 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\led_pow.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no hal.c +Compilation complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\hal.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no batt_params.c +Compilation complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\batt_params.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no voltable.c +Compilation complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\voltable.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\bin\cc78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -irenge -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r" -ms -rd2 -qvjl2w -sainter_asm -zpb -no pedo_lpf_coeff.c +Compilation complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\ra78k0r.exe" -c9F0104 -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff inter_asm\pedo_lpf_coeff.asm +Assembly complete, 0 error(s) and 0 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\lk78k0r.exe" -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -obsr.lmf "..\..\..\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\lib78k0r\s0rm.rel" -gi1B339499E033F240BFAAh -pbsr_k0r.map -nkd -gb7EFBFFh -b"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\lib78k0r\fsl.lib" -bcl0rdm.lib -bcl0rm.lib -bcl0rmf.lib -i"C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\lib78k0r" -dbsr_mcu.dr -s -w2 loader.rel pm.rel i2c_ctr.rel main.rel magic.rel WDT.rel i2c_mcu.rel i2c_twl.rel led.rel rtc.rel vreg_ctr.rel vreg_twl.rel adc.rel renge.rel accero.rel self_flash.rel sw.rel task_debug.rel task_misc.rel task_sys.rel pedo_alg_thre_det2.rel ini_VECT.rel task_status.rel led_cam.rel led_pow.rel hal.rel batt_params.rel voltable.rel pedo_lpf_coeff.rel +RA78K0R warning W3420: File 'loader.rel' already has had error(s)/warning(s) by 'CC78K' + Read Device File Directory : C:\PROGRAM FILES (X86)\NEC ELECTRONICS TOOLS\DEV\ +RA78K0R warning W3420: File 'pm.rel' already has had error(s)/warning(s) by 'CC78K' +RA78K0R warning W3420: File 'i2c_mcu.rel' already has had error(s)/warning(s) by 'CC78K' +RA78K0R warning W3420: File 'led.rel' already has had error(s)/warning(s) by 'CC78K' +RA78K0R warning W3420: File 'vreg_ctr.rel' already has had error(s)/warning(s) by 'CC78K' +RA78K0R warning W3420: File 'vreg_twl.rel' already has had error(s)/warning(s) by 'CC78K' +RA78K0R warning W3420: File 'adc.rel' already has had error(s)/warning(s) by 'CC78K' +RA78K0R warning W3420: File 'accero.rel' already has had error(s)/warning(s) by 'CC78K' +RA78K0R warning W3420: File 'self_flash.rel' already has had error(s)/warning(s) by 'CC78K' +RA78K0R warning W3420: File 'task_misc.rel' already has had error(s)/warning(s) by 'CC78K' +RA78K0R warning W3420: File 'task_sys.rel' already has had error(s)/warning(s) by 'CC78K' +RA78K0R warning W3420: File 'pedo_alg_thre_det2.rel' already has had error(s)/warning(s) by 'CC78K' +RA78K0R warning W3420: File 'led_pow.rel' already has had error(s)/warning(s) by 'CC78K' + +Link complete, 0 error(s) and 13 warning(s) found. +"C:\Program Files (x86)\NEC Electronics Tools\RA78K0R\W1.33\bin\oc78k0r.exe" -y"c:\program files (x86)\nec electronics tools\dev" -_msgoff -o.\bsr.hex -nu -ki bsr.lmf +Object Conversion Complete, 0 error(s) and 0 warning(s) found. +C:\Windows\system32\cmd.exe /c ruby nec_s_2_bsrbin2.rb bsr.hex +4 +intel-HEX to bsr bin converter + file converted! + + +Build Total error(s) : 0 Total warning(s) : 66 diff --git a/tags/2.04/yav_mcu_bsr.pri b/tags/2.04/yav_mcu_bsr.pri new file mode 100644 index 0000000..aaeddd0 --- /dev/null +++ b/tags/2.04/yav_mcu_bsr.pri @@ -0,0 +1,1028 @@ +[Project.ID] +Ver=200 +Target=IDK0R32G +[Configuration] +Chip=uPD79F0104 +Internal Rom=32KB +Internal Ram=1536B +Clock=Target +Sub Clock=Target +Peripheral Break=0x3 +Firm Clock=System +Flash Programming=Permit +Low-voltage Flash Rewriting=On +Fail Safe Break=0x2000 +Port=1 +NMI=OFF +TRESET=ON +IRESET=OFF +WAIT=OFF +SysClock=None +SubClock=None +[Mapping] +Count=0 +[Main] +Geometry=39, 38, 1452, 1091 +Window=Normal +MDI_MAX=OFF +Button=ON +Mode=Auto +Trace=Uncond ON +Trace2=Non Stop +Coverage=OFF +Timer=OFF +Tracer=OFF +[Load File] +Dir=\\Tsclient\c\78k_data\yav-mcu-basara\trunk\ +SaveFilter=0 +Start=0 +End=0 +LoadFilter=5 +Offset=0 +Object=ON +Symbol=ON +Erase=OFF +HighSpeed=OFF +Symbol Reset=ON +CPU Reset=ON +File1=\\Tsclient\c\78k_data\yav-mcu-basara\trunk\bsr.lmf +LoadFilter1=5 +Offset1=0 +Object1=ON +Symbol1=ON +Erase1=OFF +HighSpeed1=OFF +CPU Reset1=ON +Symbol Reset1=ON +[View File] +Dir=\\Tsclient\c\78k_data\yav-mcu-basara\trunk\ +Filter=Source +[Debugger Option] +Source Path="" +Symbol Size=Byte +Symbol Format=Hex +Register Name=Func +Offset Label=OFF +Offset Mnemonic=ON +Tab Count=4 +Tab Size1=*.*, 8 +Tab Size2=*.c, 8 +Tab Size3=*.s, 8 +Tab Size4=*.asm, 8 +Default Source=*.c;*.s;*.asm +Default Module=*.lnk;*.lmf +Startup Start=_@cstart +Startup End=_@cend +Main Symbol=_main +Symbol Type=OFF +Language=C +Kanji=SJIS +[Source] +Geometry=78, 84, 822, 815 +Window=Normal +DispStart=73 +CaretPos=74,0 +Mode=Normal +DispFile= +Address1= +Address2= +Address3= +Address4= +Address5= +Address6= +Address7= +Address8= +Address9= +Address10= +Address11= +Address12= +Address13= +Address14= +Address15= +Address16= +Data1= +Data2= +Data3= +Data4= +Data5= +Data6= +Data7= +Data8= +Data9= +Data10= +Data11= +Data12= +Data13= +Data14= +Data15= +Data16= +Option=0 +Case=ON +Direction=Down +File1= +File2= +File3= +File4= +File5= +File6= +File7= +File8= +File9= +File10= +File11= +File12= +File13= +File14= +File15= +File16= +SaveRange=Screen +SaveStart= +SaveEnd= +Accumulative=ON +[Assemble] +Geometry=10, 12, 600, 947 +Window=Normal +DispStart=3446 +CaretPos=3446,27 +Address1= +Address2= +Address3= +Address4= +Address5= +Address6= +Address7= +Address8= +Address9= +Address10= +Address11= +Address12= +Address13= +Address14= +Address15= +Address16= +Data1=hdw +Data2= +Data3= +Data4= +Data5= +Data6= +Data7= +Data8= +Data9= +Data10= +Data11= +Data12= +Data13= +Data14= +Data15= +Data16= +Case=ON +Scan=OFF +Direction=Down +FindStart=0x0 +FindEnd=0x7FFFF +SaveRange=Screen +SaveStart= +SaveEnd= +[Assemble1] +Geometry=585, 65, 600, 400 +Window=Normal +DispStart=12181 +CaretPos=12209,27 +[Memory] +Geometry=24, 534, 550, 400 +Window=Normal +Boundary=163 +Format=Hex +Mode=Byte +Endian=Little +Ascii=OFF +Idtag=OFF +Address= +DispStart=000FFE70 +CaretPosData=50, 65509 +CaretPosAscii=0, 65487 +Address1= +Address2= +Address3= +Address4= +Address5= +Address6= +Address7= +Address8= +Address9= +Address10= +Address11= +Address12= +Address13= +Address14= +Address15= +Address16= +Data1= +Data2= +Data3= +Data4= +Data5= +Data6= +Data7= +Data8= +Data9= +Data10= +Data11= +Data12= +Data13= +Data14= +Data15= +Data16= +Binary=ON +Scan=OFF +Direction=DOWN +FindStart= +FindEnd= +Unit=Byte +SaveRange=Screen +SaveStart= +SaveEnd= +Accumulative=ON +[Memory fill] +Scope=0, 0 +Code=0 +[Memory copy] +Scope=0, 0 +To=0 +[Memory compare] +Source=0, 0 +Destination=0 +[I/O Port] +Line=0 +[Stack] +Geometry=0, 0, 0, 0 +Window=Hide +Boundary=0 +Mode=Proper +[Sfr] +Geometry=25, 25, 668, 937 +Window=Normal +Address1= +Address2= +Address3= +Address4= +Address5= +Address6= +Address7= +Address8= +Address9= +Address10= +Address11= +Address12= +Address13= +Address14= +Address15= +Address16= +Boundary=202, 89 +Mode=Hex +Attribute=Show +Sort=Unsort +Pickup=OFF +SelectSort=Address +Last Name=P0 +Line=531 +L1=P0 +L2=P1 +L3=P2 +L4=P3 +L5=P4 +L6=P5 +L7=P6 +L8=P7 +L9=P12 +L10=P14 +L11=P15 +L12=SDR00 +L13=SIO00 +L14=TXD0 +L15=SDR01 +L16=RXD0 +L17=SIO01 +L18=TDR00 +L19=TDR01 +L20=ADCRH +L21=PM0 +L22=PM1 +L23=PM2 +L24=PM3 +L25=PM4 +L26=PM5 +L27=PM6 +L28=PM7 +L29=PM12 +L30=PM14 +L31=PM15 +L32=ADM +L33=ADCE +L34=ADCS +L35=ADS +L36=KRM +L37=EGP0 +L38=EGN0 +L39=ISC +L40=TIS0 +L41=SDR02 +L42=SIO10 +L43=TXD1 +L44=SDR03 +L45=RXD1 +L46=IICA0 +L47=IICS0 +L48=SPD0 +L49=STD0 +L50=ACKD0 +L51=TRC0 +L52=COI0 +L53=EXC0 +L54=ALD0 +L55=MSTS0 +L56=IICF0 +L57=IICRSV0 +L58=STCEN0 +L59=IICBSY0 +L60=STCF0 +L61=TDR02 +L62=TDR03 +L63=TDR04 +L64=TDR05 +L65=TDR06 +L66=TDR07 +L67=RSUBC +L68=SEC +L69=MIN +L70=HOUR +L71=WEEK +L72=DAY +L73=MONTH +L74=YEAR +L75=SUBCUD +L76=ALARMWM +L77=ALARMWH +L78=ALARMWW +L79=RTCC0 +L80=RCLOE0 +L81=RCLOE1 +L82=RTCE +L83=RTCC1 +L84=RWAIT +L85=RWST +L86=RIFG +L87=WAFG +L88=WALIE +L89=WALE +L90=RTCC2 +L91=RCKDIV +L92=RCLOE2 +L93=RINTE +L94=CMC +L95=CSC +L96=HIOSTOP +L97=XTSTOP +L98=MSTOP +L99=OSTC +L100=OSTS +L101=CKC +L102=MCM0 +L103=MCS +L104=CSS +L105=CLS +L106=CKS0 +L107=PCLOE0 +L108=CKS1 +L109=PCLOE1 +L110=RESF +L111=LVIM +L112=LVIF +L113=LVIMD +L114=LVISEL +L115=LVION +L116=LVIS +L117=WDTE +L118=DSA0 +L119=DSA1 +L120=DRA0 +L121=DRA0L +L122=DRA0H +L123=DRA1 +L124=DRA1L +L125=DRA1H +L126=DBC0 +L127=DBC0L +L128=DBC0H +L129=DBC1 +L130=DBC1L +L131=DBC1H +L132=DMC0 +L133=DWAIT0 +L134=DS0 +L135=DRS0 +L136=STG0 +L137=DMC1 +L138=DWAIT1 +L139=DS1 +L140=DRS1 +L141=STG1 +L142=DRC0 +L143=DST0 +L144=DEN0 +L145=DRC1 +L146=DST1 +L147=DEN1 +L148=BECTL +L149=FLMDPUP +L150=PFCMD +L151=PFS +L152=FPRERR +L153=FLPMC +L154=BFAEN +L155=FWEPR +L156=BRAMEN +L157=IF2 +L158=IF2L +L159=TMIF05 +L160=TMIF06 +L161=TMIF07 +L162=PIF6 +L163=IF2H +L164=IICAIF1 +L165=PIF20 +L166=PIF21 +L167=PIF22 +L168=PIF23 +L169=MK2 +L170=MK2L +L171=TMMK05 +L172=TMMK06 +L173=TMMK07 +L174=PMK6 +L175=MK2H +L176=IICAMK1 +L177=PMK20 +L178=PMK21 +L179=PMK22 +L180=PMK23 +L181=PR02 +L182=PR02L +L183=TMPR005 +L184=TMPR006 +L185=TMPR007 +L186=PPR06 +L187=PR02H +L188=IICAPR01 +L189=PPR020 +L190=PPR021 +L191=PPR022 +L192=PPR023 +L193=PR12 +L194=PR12L +L195=TMPR105 +L196=TMPR106 +L197=TMPR107 +L198=PPR16 +L199=PR12H +L200=IICAPR11 +L201=PPR120 +L202=PPR121 +L203=PPR122 +L204=PPR123 +L205=IF0 +L206=IF0L +L207=WDTIIF +L208=LVIIF +L209=PIF0 +L210=PIF1 +L211=PIF2 +L212=PIF4 +L213=PIF5 +L214=IF0H +L215=DMAIF0 +L216=DMAIF1 +L217=CSIIF00 +L218=STIF0 +L219=CSIIF01 +L220=SRIF0 +L221=SREIF0 +L222=IF1 +L223=IF1L +L224=CSIIF10 +L225=IICIF10 +L226=STIF1 +L227=SRIF1 +L228=SREIF1 +L229=IICAIF0 +L230=TMIF00 +L231=TMIF01 +L232=TMIF02 +L233=TMIF03 +L234=IF1H +L235=ADIF +L236=RTCIF +L237=RTCIIF +L238=KRIF +L239=MDIF +L240=TMIF04 +L241=MK0 +L242=MK0L +L243=WDTIMK +L244=LVIMK +L245=PMK0 +L246=PMK1 +L247=PMK2 +L248=PMK4 +L249=PMK5 +L250=MK0H +L251=DMAMK0 +L252=DMAMK1 +L253=CSIMK00 +L254=STMK0 +L255=CSIMK01 +L256=SRMK0 +L257=SREMK0 +L258=MK1 +L259=MK1L +L260=CSIMK10 +L261=IICMK10 +L262=STMK1 +L263=SRMK1 +L264=SREMK1 +L265=IICAMK0 +L266=TMMK00 +L267=TMMK01 +L268=TMMK02 +L269=TMMK03 +L270=MK1H +L271=ADMK +L272=RTCMK +L273=RTCIMK +L274=KRMK +L275=MDMK +L276=TMMK04 +L277=PR00 +L278=PR00L +L279=WDTIPR0 +L280=LVIPR0 +L281=PPR00 +L282=PPR01 +L283=PPR02 +L284=PPR04 +L285=PPR05 +L286=PR00H +L287=DMAPR00 +L288=DMAPR01 +L289=CSIPR000 +L290=STPR00 +L291=CSIPR001 +L292=SRPR00 +L293=SREPR00 +L294=PR01 +L295=PR01L +L296=CSIPR010 +L297=IICPR010 +L298=STPR01 +L299=SRPR01 +L300=SREPR01 +L301=IICAPR00 +L302=TMPR000 +L303=TMPR001 +L304=TMPR002 +L305=TMPR003 +L306=PR01H +L307=ADPR0 +L308=RTCPR0 +L309=RTCIPR0 +L310=KRPR0 +L311=MDPR0 +L312=TMPR004 +L313=PR10 +L314=PR10L +L315=WDTIPR1 +L316=LVIPR1 +L317=PPR10 +L318=PPR11 +L319=PPR12 +L320=PPR14 +L321=PPR15 +L322=PR10H +L323=DMAPR10 +L324=DMAPR11 +L325=CSIPR100 +L326=STPR10 +L327=CSIPR101 +L328=SRPR10 +L329=SREPR10 +L330=PR11 +L331=PR11L +L332=CSIPR110 +L333=IICPR110 +L334=STPR11 +L335=SRPR11 +L336=SREPR11 +L337=IICAPR10 +L338=TMPR100 +L339=TMPR101 +L340=TMPR102 +L341=TMPR103 +L342=PR11H +L343=ADPR1 +L344=RTCPR1 +L345=RTCIPR1 +L346=KRPR1 +L347=MDPR1 +L348=TMPR104 +L349=MDAL +L350=MULA +L351=MDAH +L352=MULB +L353=MDBH +L354=MULOH +L355=MDBL +L356=MULOL +L357=PMC +L358=MAA +L359=ADPC +L360=PU0 +L361=PU1 +L362=PU3 +L363=PU4 +L364=PU5 +L365=PU7 +L366=PU12 +L367=PU14 +L368=PIM3 +L369=PIM7 +L370=POM3 +L371=POM7 +L372=NFEN0 +L373=NFEN1 +L374=NFEN2 +L375=MDCL +L376=MDCH +L377=MDUC +L378=DIVST +L379=DIVMODE +L380=PER0 +L381=SAU0EN +L382=IICA0EN +L383=ADCEN +L384=RTCEN +L385=PER2 +L386=TAU0EN +L387=OSMC +L388=BCDADJ +L389=SSR00 +L390=SSR00L +L391=SSR01 +L392=SSR01L +L393=SSR02 +L394=SSR02L +L395=SSR03 +L396=SSR03L +L397=SIR00 +L398=SIR00L +L399=SIR01 +L400=SIR01L +L401=SIR02 +L402=SIR02L +L403=SIR03 +L404=SIR03L +L405=SMR00 +L406=SMR01 +L407=SMR02 +L408=SMR03 +L409=SCR00 +L410=SCR01 +L411=SCR02 +L412=SCR03 +L413=SE0 +L414=SE0L +L415=SS0 +L416=SS0L +L417=ST0 +L418=ST0L +L419=SPS0 +L420=SPS0L +L421=SO0 +L422=SOE0 +L423=SOE0L +L424=SOL0 +L425=SOL0L +L426=TCR00 +L427=TCR01 +L428=TCR02 +L429=TCR03 +L430=TCR04 +L431=TCR05 +L432=TCR06 +L433=TCR07 +L434=TMR00 +L435=TMR01 +L436=TMR02 +L437=TMR03 +L438=TMR04 +L439=TMR05 +L440=TMR06 +L441=TMR07 +L442=TSR00 +L443=TSR00L +L444=TSR01 +L445=TSR01L +L446=TSR02 +L447=TSR02L +L448=TSR03 +L449=TSR03L +L450=TSR04 +L451=TSR04L +L452=TSR05 +L453=TSR05L +L454=TSR06 +L455=TSR06L +L456=TSR07 +L457=TSR07L +L458=TE0 +L459=TE0L +L460=TS0 +L461=TS0L +L462=TT0 +L463=TT0L +L464=TPS0 +L465=TPS0L +L466=TO0 +L467=TO0L +L468=TOE0 +L469=TOE0L +L470=TOL0 +L471=TOL0L +L472=TOM0 +L473=TOM0L +L474=IICCTL00 +L475=SPT0 +L476=STT0 +L477=ACKE0 +L478=WTIM0 +L479=SPIE0 +L480=WREL0 +L481=LREL0 +L482=IICE0 +L483=IICCTL10 +L484=DFC0 +L485=SMC0 +L486=DAD0 +L487=CLD0 +L488=WUP0 +L489=IICWL0 +L490=IICWH0 +L491=SVA0 +L492=PER3 +L493=IICA1EN +L494=P20 +L495=PM20 +L496=PU20 +L497=EGP2 +L498=EGN2 +L499=IICA1 +L500=IICS1 +L501=SPD1 +L502=STD1 +L503=ACKD1 +L504=TRC1 +L505=COI1 +L506=EXC1 +L507=ALD1 +L508=MSTS1 +L509=IICF1 +L510=IICRSV1 +L511=STCEN1 +L512=IICBSY1 +L513=STCF1 +L514=IICCTL01 +L515=SPT1 +L516=STT1 +L517=ACKE1 +L518=WTIM1 +L519=SPIE1 +L520=WREL1 +L521=LREL1 +L522=IICE1 +L523=IICCTL11 +L524=DFC1 +L525=SMC1 +L526=DAD1 +L527=CLD1 +L528=WUP1 +L529=IICWL1 +L530=IICWH1 +L531=SVA1 +[Local Variable] +Geometry=0, 0, 0, 0 +Window=Hide +Boundary=0 +Mode=Proper +[Trace View] +Geometry=0, 0, 0, 0 +Window=Hide +Mode=Normal +Frame=Show +Timetag=Clock +Address=Show +Data=Hex +Status=Show +Address2=Show +Data2=Hex +Status2=Show +Disasm=Show +Pick Up=Off +Synchronize=0 0 0 0 +Frameno= +Frameno1= +Frameno2= +Frameno3= +Frameno4= +Frameno5= +Frameno6= +Frameno7= +Frameno8= +Frameno9= +Frameno10= +Frameno11= +Frameno12= +Frameno13= +Frameno14= +Frameno15= +Frameno16= +ScanStatus=ALL +Access Size=B +ScanAddress=<>-<> +Mask Address= +ScanData= +Mask Data= +ScanExternal= +Mask External= +Scan=OFF +Direction=Down +FindStart= +FindEnd= +SaveRange=Screen +SaveStart= +SaveEnd= +[Register] +Geometry=50, 50, 250, 400 +Window=Normal +Mode=Hex +Boundary=159 +Pickup=OFF +Name=Functional +Register Bank=0 +RP0=1 +RP1=1 +RP2=1 +RP3=1 +PC=1 +SP=1 +PSW=1 +ES=1 +CS=1 +[Event Manager] +Geometry=0, 0, 0, 0 +Window=Hide +Sort by=Unsort +Detail=OFF +[Event Set] +Geometry=0, 0, 0, 0 +Window=Hide +Manager=ON +Sort by=Unsort +Detail=OFF +Last Name= +Count=0 +[Event Link] +Geometry=0, 0, 0, 0 +Window=Hide +Manager=ON +Sort by=Unsort +Detail=OFF +Last Name= +Count=0 +[Break] +Geometry=0, 0, 0, 0 +Window=Hide +Manager=ON +Sort by=Unsort +Detail=OFF +Last Name= +Count=0 +[Trace] +Geometry=0, 0, 0, 0 +Window=Hide +Manager=ON +Sort by=Unsort +Detail=OFF +Last Name= +Delay Count0=2 +Count=0 +[Snap] +Geometry=0, 0, 0, 0 +Window=Hide +Manager=ON +Sort by=Unsort +Detail=OFF +Last Name= +Count=0 +[Stub] +Geometry=0, 0, 0, 0 +Window=Hide +Manager=ON +Sort by=Unsort +Detail=OFF +Last Name= +Count=0 +[Timer] +Geometry=0, 0, 0, 0 +Window=Hide +Manager=ON +Sort by=Unsort +Detail=OFF +Last Name= +TimerRateRunBreak=0011 +TimerBreakOutRunBreak=OFF +Count=0 +[Timer Monitor] +Count=0 +[Dmm] +Geometry=0, 0, 0, 0 +Window=Hide +Manager=ON +Sort by=Unsort +Detail=OFF +Last Name= +Count=0 +[Variable] +Geometry=935, 61, 440, 634 +Window=Normal +Boundary=13762700 +0=.SW_pow_count,P,N,A,+,1 +Line=1 +[Quick Watch] +0=RTCC0,B,A,1 +1=RTCC1,B,A,1 +2=PM12,B,A,1 +3=P12,B,A,1 +4=CMC,B,A,1 +5=CSC,P,A,1 +6=OSMC,P,A,1 +7=KRM,P,A,1 +8=MK0,P,A,1 +9=MK1,P,A,1 +10=PU7,B,A,1 +11=PM7,B,A,1 +12=P7,B,A,1 +13=system_status,P,A,1 +14=PWSW_POWON_TIME,P,A,1 +15=SW_pow_count,P,A,1 +[Software Break] +Geometry=914, 762, 500, 200 +Window=Normal +Width=150 30 200 100 +Name0=Swb00002 +Address0=task_sys.c#_tsk_sys+0x4d +Window0=ASM +Status0=ON +Name1=Swb00003 +Address1=task_sys.c#_tsk_sys+0x5c +Window1=ASM +Status1=OFF +Count=2 +[Reset] +Debugger=ON +Symbol=OFF +Target CPU=OFF +[Extended Option] +OnClick Software Break=ON +TraceTimetag=x1 +Redraw=500 +Break When Access Function=OFF +Break When Access Whole=Select +Verify=ON +Break Sound=ON +TraceAutoClear=OFF +RRM Clock=Internal +CKC Register Value=0x09 +RRM Internal Clock Frequency=8.000 +[About] +Version=Program +[Pseudo Emulation] +Geometry=0, 0, 0, 0 +Window=Hide +[Data Flash Option] +Data Flash Emulation=OFF +[List] +Geometry=75, 75, 856, 846 +Window=Hide +[Console] +Geometry=0, 0, 0, 0 +Window=Hide diff --git a/tags/2.04/yav_mcu_bsr.prj b/tags/2.04/yav_mcu_bsr.prj new file mode 100644 index 0000000..f88c3e3 --- /dev/null +++ b/tags/2.04/yav_mcu_bsr.prj @@ -0,0 +1,1063 @@ +[ProjectManager] +Version=6.00 +Path=C:\78k_data\yav-mcu-basara\trunk\ +Title=yav-mcu +Series=78K0R.PM +Device=uPD79F0104 +DeviceVer=E1.00b +DebugMode=1 +Target=bsr.lmf +[BuildMode0] +BuildModeName=Debug Build +TargetFile=0 +[BuildMode1] +BuildModeName=Release Build +TargetFile=0 +[Tools] +MakeFile=yav_mcu_bsr.mak +Debugger=C:\Program Files (x86)\NEC Electronics Tools\ID78K0R-QB\V3.61\BIN\IDK0R32G.EXE +DebOption= +DebCpuReset=1 +DebSymReset=1 +MuitiLoad=0 +LoadPrjNum=0 +CheckVersion=CC78K0R|W2.13;RA78K0R|W1.33 +[Option.IDK0R32G] +File=\\Tsclient\c\78k_data\yav-mcu-basara\trunk\yav_mcu_bsr.pri +[BuildMode2] +BuildModeName=K0R_dbg +TargetFile=0 +[BuildMode3] +BuildModeName=BSR_dbg +TargetFile=0 +[BuildMode4] +BuildModeName=BSR_rel +TargetFile=0 +[BuildMode5] +BuildModeName=BSR_WM0 +TargetFile=0 +[Options.OC78K0R 0] +Version=100 +O0=.\bsr.hex +O1=bsr.hex +UC=1 +UN=FF +UST= +USZ= +K=1 +ZF=0 +S=1 +E=0 +CommandFile=0 +[Options.OC78K0R 1] +Version=100 +UC=1 +UN=FF +UST= +USZ= +K=1 +ZF=0 +S=1 +E=0 +CommandFile=0 +[Options.OC78K0R 2] +Version=100 +O0=.\bsr.hex +O1=bsr.hex +UC=0 +UN=FF +UST= +USZ= +K=0 +ZF=0 +S=1 +E=0 +CommandFile=0 +[Options.OC78K0R 3] +Version=100 +O0=.\bsr.hex +O1=bsr.hex +UC=1 +UN=FF +UST= +USZ= +K=1 +ZF=0 +S=1 +E=0 +CommandFile=0 +[Options.OC78K0R 4] +Version=100 +O0=.\bsr.hex +O1=bsr.hex +UC=1 +UN=FF +UST= +USZ= +K=1 +ZF=0 +S=1 +E=0 +CommandFile=0 +[Options.OC78K0R 5] +Version=100 +O0=.\bsr.hex +O1=bsr.hex +UC=1 +UN=FF +UST= +USZ= +K=1 +ZF=0 +S=1 +E=0 +CommandFile=0 +[BuildBefore-AfterCmd] +Before1=c:\cygwin\bin\touch magic.c +After1=ruby nec_s_2_bsrbin2.rb bsr.hex +[ToolSet] +ToolSetName=(ύX)78K0R Software Package V1.10 +Tool1=CC78K0R|W2.13 +Tool2=RA78K0R|W1.33 +Tool3=SK78K0R|V3.10 +Tool4=ID78K0R-QB|V3.61 +[Options.RA78K0R 0] +Version=100 +G=1 +GA=1 +E=0 +COMMON=0 +COMPATI=0 +P=1 +KA=1 +KS=0 +KX=0 +LF=0 +LW=132 +LL=0 +LT=8 +Z=0 +CommandFile=0 +RA_OPT= +[Options.RA78K0R 1] +Version=100 +G=0 +GA=0 +E=0 +COMMON=0 +COMPATI=0 +P=1 +KA=1 +KS=0 +KX=0 +LF=0 +LW=132 +LL=0 +LT=8 +Z=0 +CommandFile=0 +RA_OPT= +[Options.RA78K0R 2] +Version=100 +O0= +O1=obj +G=1 +GA=1 +E=0 +COMMON=0 +COMPATI=0 +P=1 +KA=1 +KS=0 +KX=0 +LF=0 +LW=132 +LL=0 +LT=8 +Z=0 +CommandFile=0 +RA_OPT= +[Options.RA78K0R 3] +Version=100 +G=1 +GA=1 +E=0 +COMMON=0 +COMPATI=0 +P=1 +KA=1 +KS=0 +KX=0 +LF=0 +LW=132 +LL=0 +LT=8 +Z=0 +CommandFile=0 +RA_OPT= +[Options.RA78K0R 4] +Version=100 +G=1 +GA=1 +E=0 +COMMON=0 +COMPATI=0 +P=1 +KA=1 +KS=0 +KX=0 +LF=0 +LW=132 +LL=0 +LT=8 +Z=0 +CommandFile=0 +RA_OPT= +[Options.RA78K0R 5] +Version=100 +G=1 +GA=1 +E=0 +COMMON=0 +COMPATI=0 +P=1 +KA=1 +KS=0 +KX=0 +LF=0 +LW=132 +LL=0 +LT=8 +Z=0 +CommandFile=0 +RA_OPT= +[SrcFile] +Source1=loader.c +Source2=pm.c +Source3=i2c_ctr.c +Source4=main.c +Source5=magic.c +Source6=WDT.c +Source7=i2c_mcu.c +Source8=i2c_twl.c +Source9=led.c +Source10=rtc.c +Source11=vreg_ctr.c +Source12=vreg_twl.c +Source13=adc.c +Source14=renge\renge.c +Source15=accero.c +Source16=self_flash.c +Source17=sw.c +Source18=task_debug.c +Source19=task_misc.c +Source20=task_sys.c +Source21=pedo_alg_thre_det2.c +Source22=ini_VECT.c +Source23=task_status.c +Source24=led_cam.c +Source25=led_pow.c +Source26=hal.c +Source27=batt_params.c +Source28=voltable.c +Source29=pedo_lpf_coeff.c +[IncFile] +Include1=incs_loader.h +Include2=sim\simOnWin.h +Include3=sim\sfrAlias.h +Include4=config.h +Include5=jhl_defs.h +Include6=user_define.h +Include7=hal.h +Include8=bsr_system.h +Include9=renge\renge.h +Include10=renge\renge_defs.h +Include11=renge\renge_task_immediate.h +Include12=vreg_ctr.h +Include13=vreg_twl.h +Include14=loader.h +Include15=i2c_mcu.h +Include16=WDT.h +Include17=..\..\..\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r\fsl.h +Include18=fsl_user.h +Include19=i2c_ctr.h +Include20=pm.h +Include21=rtc.h +Include22=reboot.h +Include23=magic.h +Include24=incs.h +Include25=i2c_twl.h +Include26=accero.h +Include27=pedometer.h +Include28=sw.h +Include29=adc.h +Include30=led.h +Include31=batt_params.h +Include32=pool.h +Include33=i2c_twl_defs.h +Include34=renge\renge_task_intval.h +Include35=..\..\..\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r\math.h +Include36=self_flash.h +Include37=sim\sim_interrupt_decrare.c +[Options.CC78K0R 0] +Version=210 +Include0=renge,C:\Program Files\NEC Electronics Tools\FSL78K0R_Type02ES\V1.20\inc78k0r +Include1=C:\Program Files\NEC Electronics Tools\FSL78K0R_Type02ES\V1.20\inc78k0r +Memorymodel=1 +Flashobj=0 +FlashStartadr= +FlashBranchStartadr= +Mirror=0 +Saddrglobalchk=0 +Saddrglobal=1066 +Saddrstaticchk=0 +Saddrstatic=1072 +Bitfieldmsb=0 +Onebytechk=0 +Pacstructchk=0 +AssignROMchk=0 +AssignROM=0 +Maxoptimizechk=0 +Maxoptimize=1104 +Charunexpandchk=1 +Unsignedchar=0 +Usesaddrchk=0 +Autoallocationchk=1 +Jumpoptimize=1 +Librarycallchk=0 +Librarycall=1129 +Aggressivechk=1 +Relativebranchchk=1 +Debugoptchk=0 +Outdebugchk=1 +Outdebug=1153 +Outasmsrccmb0=inter_asm +Outasmsrccmb1=bsr.asm +Outasmsrcchk=1 +Outasmsrc=1158 +Outasmoptall=1 +Common=0 +Outerrlistchk=0 +Outerrlist=1174 +Xreference=0 +Preprocess=0 +Prenocomment=0 +Predefine=0 +Preifdef=1 +Preinclude=0 +Preline=1 +Prenumber=1 +Formfeed=0 +Columns=132 +Lines=0 +Tablength=8 +Ansi=0 +Cpraspras=1 +Commentnest=0 +Intunexpand=0 +Kanjicode=1210 +Verbose=0 +CommandFile=0 +Warninglevel=0 +Startupchk=1 +Fixation=1 +FarROMization=0 +Objectsel=1305 +Librarychk=1 +Floatingpoint=0 +Muldivunit=1 +Mulunit=1 +Startup=s0rml.rel +Library1=cl0rdm.lib +Library2=cl0rm.lib +Library3=cl0rmf.lib +VfiFileBoot0= +VfiFileBoot1=boot.vfi +VF78K0Rchk=0 +VF78K0Rvs= +[Options.CC78K0R 1] +Version=210 +Memorymodel=2 +Flashobj=0 +FlashStartadr= +FlashBranchStartadr= +Mirror=0 +Saddrglobalchk=0 +Saddrglobal=1066 +Saddrstaticchk=0 +Saddrstatic=1072 +Bitfieldmsb=0 +Onebytechk=0 +Pacstructchk=0 +AssignROMchk=0 +AssignROM=0 +Maxoptimizechk=0 +Maxoptimize=1104 +Charunexpandchk=1 +Unsignedchar=0 +Usesaddrchk=0 +Autoallocationchk=1 +Jumpoptimize=1 +Librarycallchk=1 +Librarycall=1128 +Aggressivechk=1 +Relativebranchchk=0 +Debugoptchk=0 +Outdebugchk=0 +Outdebug=1153 +Outasmsrcchk=0 +Outasmsrc=1157 +Outasmoptall=1 +Common=0 +Outerrlistchk=0 +Outerrlist=1173 +Xreference=0 +Preprocess=0 +Prenocomment=0 +Predefine=0 +Preifdef=1 +Preinclude=0 +Preline=1 +Prenumber=1 +Formfeed=0 +Columns=132 +Lines=0 +Tablength=8 +Ansi=0 +Cpraspras=0 +Commentnest=0 +Intunexpand=0 +Kanjicode=1210 +Verbose=0 +CommandFile=0 +Warninglevel=1 +Startupchk=1 +Fixation=1 +FarROMization=1 +Objectsel=1305 +Librarychk=1 +Floatingpoint=0 +Muldivunit=1 +Mulunit=1 +Startup=s0rll.rel +Library1=cl0rdm.lib +Library2=cl0rm.lib +Library3=cl0rmf.lib +VF78K0Rchk=0 +VF78K0Rvs= +[Options.CC78K0R 2] +Version=210 +Define0= +Define1=_debug_,_TEG_,proc_is_ke3 +Define2=_debug_,_TEG_,proc_is_ke3,%time% +Define3=_TEG_,proc_is_ke3 +Define4=proc_is_ke3 +Include0=renge,C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r +Include1=renge,C:\Program Files\NEC Electronics Tools\FSL78K0R_Type02ES\V1.20\inc78k0r +Include2=C:\Program Files\NEC Electronics Tools\FSL78K0R_Type02ES\V1.20\inc78k0r +Memorymodel=1 +Flashobj=0 +FlashStartadr= +FlashBranchStartadr= +Mirror=0 +Saddrglobalchk=1 +Saddrglobal=1063 +Saddrstaticchk=0 +Saddrstatic=1072 +Bitfieldmsb=0 +Onebytechk=0 +Pacstructchk=0 +AssignROMchk=0 +AssignROM=0 +Maxoptimizechk=0 +Maxoptimize=1104 +Charunexpandchk=0 +Unsignedchar=0 +Usesaddrchk=0 +Autoallocationchk=1 +Jumpoptimize=1 +Librarycallchk=1 +Librarycall=1129 +Aggressivechk=1 +Relativebranchchk=0 +Debugoptchk=0 +Outdebugchk=1 +Outdebug=1153 +Outobjectcmb0= +Outobjectcmb1=obj +Outasmsrccmb0=inter_asm +Outasmsrccmb1=bsr.asm +Outasmsrcchk=1 +Outasmsrc=1158 +Outasmoptall=1 +Common=0 +Outerrlistchk=0 +Outerrlist=1174 +Xreference=0 +Preprocess=0 +Prenocomment=0 +Predefine=0 +Preifdef=1 +Preinclude=1 +Preline=1 +Prenumber=1 +Formfeed=0 +Columns=132 +Lines=0 +Tablength=8 +Ansi=0 +Cpraspras=1 +Commentnest=0 +Intunexpand=1 +Kanjicode=1210 +Verbose=0 +CommandFile=0 +Warninglevel=1 +Startupchk=1 +Fixation=0 +FarROMization=0 +Objectsel=1305 +Librarychk=1 +Floatingpoint=0 +Muldivunit=1 +Mulunit=1 +Startup=s0rm.rel +Library1=cl0rdm.lib +Library2=cl0rm.lib +Library3=cl0rmf.lib +VfiFileBoot0= +VfiFileBoot1=boot.vfi +VF78K0Rchk=0 +VF78K0Rvs= +[Options.CC78K0R 3] +Version=210 +Define0=_debug_,proc_is_bsr,_TEG_ +Define1=_debug_,proc_is_bsr +Define2=proc_is_bsr +Define3=_TEG_,proc_is_ke3 +Define4=proc_is_ke3 +Include0=renge,C:\Program Files\NEC Electronics Tools\FSL78K0R_Type02ES\V1.20\inc78k0r +Include1=C:\Program Files\NEC Electronics Tools\FSL78K0R_Type02ES\V1.20\inc78k0r +Memorymodel=1 +Flashobj=0 +FlashStartadr= +FlashBranchStartadr= +Mirror=0 +Saddrglobalchk=0 +Saddrglobal=1066 +Saddrstaticchk=0 +Saddrstatic=1072 +Bitfieldmsb=0 +Onebytechk=0 +Pacstructchk=0 +AssignROMchk=0 +AssignROM=0 +Maxoptimizechk=0 +Maxoptimize=1104 +Charunexpandchk=1 +Unsignedchar=0 +Usesaddrchk=0 +Autoallocationchk=1 +Jumpoptimize=1 +Librarycallchk=0 +Librarycall=1129 +Aggressivechk=1 +Relativebranchchk=1 +Debugoptchk=0 +Outdebugchk=1 +Outdebug=1153 +Outasmsrccmb0=inter_asm +Outasmsrccmb1=bsr.asm +Outasmsrcchk=1 +Outasmsrc=1158 +Outasmoptall=1 +Common=0 +Outerrlistchk=0 +Outerrlist=1174 +Xreference=0 +Preprocess=0 +Prenocomment=0 +Predefine=0 +Preifdef=1 +Preinclude=0 +Preline=1 +Prenumber=1 +Formfeed=0 +Columns=132 +Lines=0 +Tablength=8 +Ansi=0 +Cpraspras=1 +Commentnest=0 +Intunexpand=0 +Kanjicode=1210 +Verbose=0 +CommandFile=0 +Warninglevel=0 +Startupchk=1 +Fixation=1 +FarROMization=0 +Objectsel=1305 +Librarychk=1 +Floatingpoint=0 +Muldivunit=1 +Mulunit=1 +Startup=s0rml.rel +Library1=cl0rdm.lib +Library2=cl0rm.lib +Library3=cl0rmf.lib +VfiFileBoot0= +VfiFileBoot1=boot.vfi +VF78K0Rchk=0 +VF78K0Rvs= +[Options.CC78K0R 4] +Version=210 +Define0=proc_is_bsr +Include0=renge,C:\Program Files\NEC Electronics Tools\FSL78K0R_Type02ES\V1.20\inc78k0r +Include1=C:\Program Files\NEC Electronics Tools\FSL78K0R_Type02ES\V1.20\inc78k0r +Memorymodel=1 +Flashobj=0 +FlashStartadr= +FlashBranchStartadr= +Mirror=0 +Saddrglobalchk=0 +Saddrglobal=1066 +Saddrstaticchk=0 +Saddrstatic=1072 +Bitfieldmsb=0 +Onebytechk=0 +Pacstructchk=0 +AssignROMchk=0 +AssignROM=0 +Maxoptimizechk=0 +Maxoptimize=1104 +Charunexpandchk=1 +Unsignedchar=0 +Usesaddrchk=0 +Autoallocationchk=1 +Jumpoptimize=1 +Librarycallchk=0 +Librarycall=1129 +Aggressivechk=1 +Relativebranchchk=1 +Debugoptchk=0 +Outdebugchk=1 +Outdebug=1153 +Outasmsrccmb0=inter_asm +Outasmsrccmb1=bsr.asm +Outasmsrcchk=1 +Outasmsrc=1158 +Outasmoptall=1 +Common=0 +Outerrlistchk=0 +Outerrlist=1174 +Xreference=0 +Preprocess=0 +Prenocomment=0 +Predefine=0 +Preifdef=1 +Preinclude=0 +Preline=1 +Prenumber=1 +Formfeed=0 +Columns=132 +Lines=0 +Tablength=8 +Ansi=0 +Cpraspras=1 +Commentnest=0 +Intunexpand=0 +Kanjicode=1210 +Verbose=0 +CommandFile=0 +Warninglevel=0 +Startupchk=1 +Fixation=1 +FarROMization=0 +Objectsel=1305 +Librarychk=1 +Floatingpoint=0 +Muldivunit=1 +Mulunit=1 +Startup=s0rml.rel +Library1=cl0rdm.lib +Library2=cl0rm.lib +Library3=cl0rmf.lib +VfiFileBoot0= +VfiFileBoot1=boot.vfi +VF78K0Rchk=0 +VF78K0Rvs= +[Options.CC78K0R 5] +Version=210 +Define0= +Define1=_debug_,proc_is_bsr,_TEG_,_WM0_ +Define2=_debug_,proc_is_bsr,_TEG_,_WM0 +Define3=_debug_,proc_is_bsr,_TEG_ +Define4=_debug_,proc_is_bsr +Include0=renge,C:\Program Files\NEC Electronics Tools\FSL78K0R_Type02ES\V1.20\inc78k0r +Include1=C:\Program Files\NEC Electronics Tools\FSL78K0R_Type02ES\V1.20\inc78k0r +Memorymodel=1 +Flashobj=0 +FlashStartadr= +FlashBranchStartadr= +Mirror=0 +Saddrglobalchk=0 +Saddrglobal=1066 +Saddrstaticchk=0 +Saddrstatic=1072 +Bitfieldmsb=0 +Onebytechk=0 +Pacstructchk=0 +AssignROMchk=0 +AssignROM=0 +Maxoptimizechk=0 +Maxoptimize=1104 +Charunexpandchk=1 +Unsignedchar=0 +Usesaddrchk=0 +Autoallocationchk=1 +Jumpoptimize=1 +Librarycallchk=0 +Librarycall=1129 +Aggressivechk=1 +Relativebranchchk=1 +Debugoptchk=0 +Outdebugchk=1 +Outdebug=1153 +Outasmsrccmb0=inter_asm +Outasmsrccmb1=bsr.asm +Outasmsrcchk=1 +Outasmsrc=1158 +Outasmoptall=1 +Common=0 +Outerrlistchk=0 +Outerrlist=1174 +Xreference=0 +Preprocess=0 +Prenocomment=0 +Predefine=0 +Preifdef=1 +Preinclude=0 +Preline=1 +Prenumber=1 +Formfeed=0 +Columns=132 +Lines=0 +Tablength=8 +Ansi=0 +Cpraspras=1 +Commentnest=0 +Intunexpand=0 +Kanjicode=1210 +Verbose=0 +CommandFile=0 +Warninglevel=0 +Startupchk=1 +Fixation=1 +FarROMization=0 +Objectsel=1305 +Librarychk=1 +Floatingpoint=0 +Muldivunit=1 +Mulunit=1 +Startup=s0rml.rel +Library1=cl0rdm.lib +Library2=cl0rm.lib +Library3=cl0rmf.lib +VfiFileBoot0= +VfiFileBoot1=boot.vfi +VF78K0Rchk=0 +VF78K0Rvs= +[Options.LK78K0R 0] +Version=100 +O0=bsr_k0r.lmf +O1=bsr.lmf +O2=flash.lmf +O3=a.lmf +G=1 +E=0 +E0=flash.elk +E1=a.elk +GO=1 +GOValue=85 +GOStart=FC00 +GOSizeValue=1024 +GI=1 +GIValue=FFFFFFFFFFFFFFFFFFFF +CCZA=0 +MemInfoCheck=1 +P=1 +P0=bsr_k0r.map +P1=bsr.map +P2=flash.map +P3=a.map +MI=0 +GB=1 +GBValue=6EFBFF +KM=1 +KD=0 +KP=1 +KL=0 +LF=0 +LL=0 +B0=C:\Program Files\NEC Electronics Tools\FSL78K0R_Type02ES\V1.20\lib78k0r\fsl.lib +D0=bsr_mcu.dr +D1=user_area.dr +S=1 +W=0 +SELFCheck=1 +SELF=0 +ZB= +Etcetera0= +Etcetera1=boot.lmf +CommandFile=0 +[Options.LK78K0R 1] +Version=100 +O0=a.lmf +G=0 +E=0 +E0=a.elk +GO=0 +GOValue= +GOStart=FC00 +GOSizeValue=1024 +GI=0 +GIValue=FFFFFFFFFFFFFFFFFFFF +CCZA=1 +MemInfoCheck=0 +P=1 +P0=a.map +MI=0 +GB=0 +GBValue= +KM=1 +KD=1 +KP=0 +KL=0 +LF=0 +LL=0 +S=0 +W=1 +SELFCheck=0 +SELF=0 +ZB= +CommandFile=0 +[Options.LK78K0R 2] +Version=100 +O0=bsr.lmf +O1=bsr_k0r.lmf +O2=flash.lmf +O3=a.lmf +G=1 +E=0 +E0=flash.elk +E1=a.elk +GO=0 +GOValue=85 +GOStart=FC00 +GOSizeValue=1024 +GI=1 +GIValue=1B339499E033F240BFAA +CCZA=0 +MemInfoCheck=1 +P=1 +P0=bsr_k0r.map +P1=bsr.map +P2=flash.map +P3=a.map +MI=0 +GB=1 +GBValue=7EFBFF +KM=1 +KD=0 +KP=0 +KL=0 +LF=0 +LL=0 +B0=C:\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\lib78k0r\fsl.lib +B1=C:\Program Files\NEC Electronics Tools\FSL78K0R_Type02ES\V1.20\lib78k0r\fsl.lib +D0=bsr_mcu.dr +D1=user_area.dr +S=1 +W=2 +SELFCheck=0 +SELF=0 +ZB= +Etcetera0= +Etcetera1=boot.lmf +CommandFile=0 +OFILE=C:\78k_data\yav-mcu-basara\trunk\bsr.lmf +[Options.LK78K0R 3] +Version=100 +O0=bsr_bsr.lmf +O1=bsr_k0r.lmf +O2=bsr.lmf +O3=flash.lmf +O4=a.lmf +G=1 +E=0 +E0=flash.elk +E1=a.elk +GO=1 +GOValue=85 +GOStart=FC00 +GOSizeValue=1024 +GI=1 +GIValue=FFFFFFFFFFFFFFFFFFFF +CCZA=0 +MemInfoCheck=1 +P=1 +P0=bsr_bsr.map +P1=bsr_k0r.map +P2=bsr.map +P3=flash.map +P4=a.map +MI=0 +GB=1 +GBValue=6EFBFF +KM=1 +KD=0 +KP=1 +KL=0 +LF=0 +LL=0 +B0=C:\Program Files\NEC Electronics Tools\FSL78K0R_Type02ES\V1.20\lib78k0r\fsl.lib +D0=bsr_mcu.dr +D1=user_area.dr +S=1 +W=2 +SELFCheck=0 +SELF=0 +ZB= +Etcetera0= +Etcetera1=boot.lmf +CommandFile=0 +[Options.LK78K0R 4] +Version=100 +O0=bsr_k0r.lmf +O1=bsr.lmf +O2=flash.lmf +O3=a.lmf +G=1 +E=0 +E0=flash.elk +E1=a.elk +GO=1 +GOValue=85 +GOStart=FC00 +GOSizeValue=1024 +GI=1 +GIValue=FFFFFFFFFFFFFFFFFFFF +CCZA=0 +MemInfoCheck=1 +P=1 +P0=bsr_k0r.map +P1=bsr.map +P2=flash.map +P3=a.map +MI=0 +GB=1 +GBValue=6EFBFF +KM=1 +KD=0 +KP=1 +KL=0 +LF=0 +LL=0 +B0=C:\Program Files\NEC Electronics Tools\FSL78K0R_Type02ES\V1.20\lib78k0r\fsl.lib +D0=bsr_mcu.dr +D1=user_area.dr +S=1 +W=0 +SELFCheck=1 +SELF=0 +ZB= +Etcetera0= +Etcetera1=boot.lmf +CommandFile=0 +[Options.LK78K0R 5] +Version=100 +O0=bsr_bsr.lmf +O1=bsr_k0r.lmf +O2=bsr.lmf +O3=flash.lmf +O4=a.lmf +G=1 +E=0 +E0=flash.elk +E1=a.elk +GO=1 +GOValue=85 +GOStart=FC00 +GOSizeValue=1024 +GI=1 +GIValue=FFFFFFFFFFFFFFFFFFFF +CCZA=0 +MemInfoCheck=1 +P=1 +P0=bsr_bsr.map +P1=bsr_k0r.map +P2=bsr.map +P3=flash.map +P4=a.map +MI=0 +GB=1 +GBValue=6EFBFF +KM=1 +KD=0 +KP=1 +KL=0 +LF=0 +LL=0 +B0=C:\Program Files\NEC Electronics Tools\FSL78K0R_Type02ES\V1.20\lib78k0r\fsl.lib +D0=bsr_mcu.dr +D1=user_area.dr +S=1 +W=2 +SELFCheck=0 +SELF=0 +ZB= +Etcetera0= +Etcetera1=boot.lmf +CommandFile=0 +[Options.LCNV78K0R 0] +Version=100 +LCNV_GO=0 +E=0 +CommandFile=0 +[Options.LCNV78K0R 1] +Version=100 +LCNV_GO=0 +E=0 +CommandFile=0 +[Options.LCNV78K0R 2] +Version=100 +LCNV_GO=0 +O0=inter_asm +E=0 +CommandFile=0 +[Options.LCNV78K0R 3] +Version=100 +LCNV_GO=0 +E=0 +CommandFile=0 +[Options.LCNV78K0R 4] +Version=100 +LCNV_GO=0 +E=0 +CommandFile=0 +[Options.LCNV78K0R 5] +Version=100 +LCNV_GO=0 +E=0 +CommandFile=0 +[Options.78K0R] +BuildMode=2 +BuildMode2=K0R_dbg +BuildMode3=BSR_dbg +BuildMode4=BSR_rel +BuildMode5=BSR_WM0 +DefaultMode2=1 +DefaultMode3=1 +DefaultMode4=1 +DefaultMode5=1 diff --git a/tags/2.04/yav_mcu_bsr.prk b/tags/2.04/yav_mcu_bsr.prk new file mode 100644 index 0000000..7f8119d --- /dev/null +++ b/tags/2.04/yav_mcu_bsr.prk @@ -0,0 +1,42 @@ +[ProjectManager] +FrameMax=0 +FrameX=383 +FrameY=50 +FrameCX=1293 +FrameCY=1075 +OpenFile1=loader.c,0,248,38,1221,669,0,1,0,0 +OpenFile2=pm.c,0,373,197,1346,828,0,1,0,0 +OpenFile3=i2c_ctr.c,0,655,120,1628,751,0,1,0,0 +OpenFile4=main.c,0,250,250,1841,957,0,1,0,0 +OpenFile5=magic.c,0,300,300,1891,1007,0,1,0,0 +OpenFile6=WDT.c,0,275,275,1866,982,0,2,24,0 +OpenFile7=i2c_mcu.c,0,325,325,1916,1032,0,1,0,0 +OpenFile8=i2c_twl.c,0,364,126,1955,833,0,1,0,0 +OpenFile9=led.c,0,228,97,1819,804,0,1,0,0 +OpenFile10=rtc.c,0,364,142,1955,849,0,1,0,0 +OpenFile11=vreg_ctr.c,0,313,167,1904,874,0,1,0,0 +OpenFile12=vreg_twl.c,0,353,225,1944,932,0,1,0,0 +OpenFile13=adc.c,0,300,241,1891,948,0,1,0,0 +OpenFile14=renge\renge.c,0,342,270,1933,977,0,1,0,0 +OpenFile15=accero.c,0,355,308,1328,939,0,1,0,0 +OpenFile16=self_flash.c,0,346,268,1937,975,0,1,0,0 +OpenFile17=sw.c,0,358,322,1949,1029,0,1,0,0 +OpenFile18=task_debug.c,0,332,258,1923,965,0,1,0,0 +OpenFile19=task_misc.c,0,364,322,1955,1029,0,1,0,0 +OpenFile20=task_sys.c,0,351,450,1521,951,0,1,0,0 +OpenFile21=pedo_alg_thre_det2.c,0,414,74,1387,705,0,1,0,0 +OpenFile22=ini_VECT.c,0,275,275,1866,982,0,1,0,0 +OpenFile23=task_status.c,0,300,300,1891,1007,0,1,0,0 +OpenFile24=led_cam.c,0,325,325,1916,1032,0,1,0,0 +OpenFile25=led_pow.c,0,354,184,1945,891,0,1,0,0 +OpenFile26=hal.c,0,262,160,1853,867,0,1,0,0 +OpenFile27=batt_params.c,0,376,168,1967,875,0,1,0,0 +OpenFile28=voltable.c,0,300,300,1273,931,0,1,0,0 +OpenFile29=ProjectWindow +PrjPos=0,0,706,0,291 +OpenFile30=pedo_lpf_coeff.c,0,478,297,1451,928,0,1,19,0 +OpenFile31=OutputWindow +OutputPos=0,349,1040,690,1928 +ActivePRJ=yav_mcu_bsr.prj +[ProjectWindow] +ProjectWindowDispType=0 diff --git a/tags/2.04/yav_mcu_bsr.prw b/tags/2.04/yav_mcu_bsr.prw new file mode 100644 index 0000000..7c0bbd6 --- /dev/null +++ b/tags/2.04/yav_mcu_bsr.prw @@ -0,0 +1,8 @@ +[System] +System1=default +[default] +Project1=yav_mcu_bsr.prj +[BATCH_BUILD] +Build1=yav_mcu_bsr.prj,Debug Build,1 +Build2=yav_mcu_bsr.prj,Release Build,0 +Build3=yav_mcu_bsr.prj,BSR_WM0,0 diff --git a/tags/2.04/yav_mcu_bsr.sdb b/tags/2.04/yav_mcu_bsr.sdb new file mode 100644 index 0000000..5c855af --- /dev/null +++ b/tags/2.04/yav_mcu_bsr.sdb @@ -0,0 +1,305 @@ +[SdbInfo] +Ver=5 +[loader.c] +T=4e4248ee +1=incs_loader.h +2=..\..\..\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r\fsl.h +3=fsl_user.h +4=i2c_ctr.h +5=i2c_mcu.h +6=pm.h +7=rtc.h +8=reboot.h +9=magic.h +[pm.c] +T=4e4111a9 +1=incs.h +2=adc.h +3=led.h +4=pm.h +5=renge\renge.h +6=batt_params.h +7=..\..\..\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r\fsl.h +8=fsl_user.h +[i2c_ctr.c] +T=4e409e63 +1=config.h +2=incs.h +[main.c] +T=4e40c90e +1=incs_loader.h +2=WDT.h +3=rtc.h +4=pm.h +5=accero.h +6=led.h +7=adc.h +8=pool.h +[magic.c] +T=4e4248f2 +1=config.h +2=magic.h +[WDT.c] +T=4e424710 +1=incs_loader.h +[i2c_mcu.c] +T=4e4234b9 +1=incs_loader.h +2=i2c_mcu.h +[i2c_twl.c] +T=4e409e61 +1=config.h +2=incs.h +3=i2c_twl_defs.h +4=i2c_twl.h +[led.c] +T=4e423830 +1=incs.h +2=led.h +[rtc.c] +T=4e423614 +1=incs.h +[vreg_ctr.c] +T=4e409e63 +1=incs.h +2=vreg_ctr.h +3=rtc.h +4=led.h +5=accero.h +6=pm.h +7=pool.h +8=..\..\..\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r\fsl.h +9=fsl_user.h +[vreg_twl.c] +T=4d5e3e6f +1=incs.h +2=jhl_defs.h +3=led.h +4=vreg_twl.h +5=vreg_ctr.h +[adc.c] +T=4e42374e +1=incs.h +2=adc.h +3=pm.h +4=led.h +5=vreg_twl.h +[renge\renge.c] +T=4e40d459 +1=renge\renge.h +2=renge\renge_task_intval.h +3=renge\renge_task_immediate.h +4=WDT.h +5=config.h +6=user_define.h +7=sim\simOnWin.h +8=bsr_system.h +[accero.c] +T=4e422e91 +1=config.h +2=incs.h +3=..\..\..\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r\math.h +[self_flash.c] +T=4e409e18 +1=incs_loader.h +2=..\..\..\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r\fsl.h +3=fsl_user.h +4=i2c_ctr.h +5=pool.h +6=magic.h +7=pm.h +[sw.c] +T=4e4251bb +1=incs.h +2=i2c_twl.h +3=i2c_ctr.h +4=led.h +5=pm.h +6=rtc.h +7=sw.h +[task_debug.c] +T=4e409e1c +1=incs_loader.h +2=renge\renge.h +3=pm.h +4=accero.h +[task_misc.c] +T=4e409e61 +1=incs.h +2=renge\renge.h +3=pm.h +4=accero.h +5=adc.h +6=i2c_mcu.h +7=led.h +8=vreg_twl.h +[task_sys.c] +T=4e4251f0 +1=incs.h +2=i2c_twl.h +3=i2c_ctr.h +4=led.h +5=accero.h +6=pm.h +7=rtc.h +8=sw.h +9=adc.h +10=self_flash.h +[pedo_alg_thre_det2.c] +T=4e423b4a +1=incs.h +2=..\..\..\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r\math.h +3=accero.h +4=pedometer.h +5=pool.h +[ini_VECT.c] +T=4e409e1a +1=config.h +2=sim\sim_interrupt_decrare.c +[task_status.c] +T=4e409e1c +1=incs_loader.h +2=renge\renge.h +3=hal.h +4=pm.h +5=accero.h +6=adc.h +7=i2c_mcu.h +8=led.h +[led_cam.c] +T=4e409e1d +1=incs.h +2=led.h +[led_pow.c] +T=4e423450 +1=incs.h +2=led.h +[hal.c] +T=4e40c910 +1=incs_loader.h +[batt_params.c] +T=4e409e1b +1=jhl_defs.h +2=batt_params.h +[voltable.c] +T=4e422f23 +1=incs.h +[pedo_lpf_coeff.c] +T=4e422f1d +1=incs.h +[incs_loader.h] +T=4e409e1d +1=sim\simOnWin.h +2=jhl_defs.h +3=user_define.h +4=hal.h +5=bsr_system.h +6=renge\renge.h +7=vreg_ctr.h +8=vreg_twl.h +9=loader.h +10=i2c_mcu.h +11=WDT.h +[sim\simOnWin.h] +T=4e4243ba +1=sim\sfrAlias.h +[sim\sfrAlias.h] +T=4e409e19 +1=config.h +[config.h] +T=4e409e18 +[jhl_defs.h] +T=4df82cd1 +1=config.h +[user_define.h] +T=4e409e1d +[hal.h] +T=4e40c8f0 +[bsr_system.h] +T=4e409e1a +[renge\renge.h] +T=4cbf8235 +1=renge\renge_defs.h +2=renge\renge_task_immediate.h +[renge\renge_defs.h] +T=4c073c5a +[renge\renge_task_immediate.h] +T=4d37f8c8 +1=renge\renge_defs.h +[vreg_ctr.h] +T=4e409e1c +1=config.h +[vreg_twl.h] +T=4d42202e +[loader.h] +T=4c318e0f +[i2c_mcu.h] +T=4dde0033 +[WDT.h] +T=4c319dfc +[..\..\..\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r\fsl.h] +T=49a3bd4e +[fsl_user.h] +T=4e409e62 +[i2c_ctr.h] +T=4bf0d1e1 +[pm.h] +T=4e409e1c +[rtc.h] +T=4e409e1c +[reboot.h] +T=4bf0d1e1 +[magic.h] +T=4caab849 +[incs.h] +T=4e409e18 +1=sim\simOnWin.h +2=jhl_defs.h +3=user_define.h +4=hal.h +5=bsr_system.h +6=renge\renge.h +7=loader.h +8=vreg_ctr.h +9=vreg_twl.h +10=i2c_mcu.h +11=i2c_twl.h +12=rtc.h +13=accero.h +14=pm.h +15=sw.h +16=adc.h +17=WDT.h +[i2c_twl.h] +T=4bf4e29e +[accero.h] +T=4ca28964 +1=jhl_defs.h +2=pedometer.h +[pedometer.h] +T=4e409e19 +[sw.h] +T=4df2001a +1=config.h +[adc.h] +T=4dd5c8b2 +1=jhl_defs.h +[led.h] +T=4e409e1c +[batt_params.h] +T=4e409e1c +1=jhl_defs.h +[pool.h] +T=4c072cf1 +1=pedometer.h +[i2c_twl_defs.h] +T=4bf0d1e1 +[renge\renge_task_intval.h] +T=4d5e55a1 +1=renge\renge_defs.h +[..\..\..\Program Files (x86)\NEC Electronics Tools\CC78K0R\W2.13\inc78k0r\math.h] +T=45f12258 +[self_flash.h] +T=4bf0d1e0 +[sim\sim_interrupt_decrare.c] +T=4e409e19 diff --git a/tags/2.04/ベースからの変更.xls b/tags/2.04/ベースからの変更.xls new file mode 100644 index 0000000000000000000000000000000000000000..5212dac6485080dca2bfd246e855585895ff82af GIT binary patch literal 26624 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 literal 0 HcmV?d00001