mirror of
https://github.com/rvtr/ctr_mcu.git
synced 2025-10-31 13:51:10 -04:00
音量が一時的に急に変わるのを修正 ADCのチャンネル切り替え後、割り込みフラグをクリアするのを忘れていた フルカラーお知らせランプの自動判別 そのため、ポートの初期化順なども一部変更 同、パラメータの受信フォーマットの変更 8MHz動作しかしないので、4MHz動作の#ifdefを削除 I2C_TWL 反応遅延が激しいので逐次タスクの削除周り修正、割り込み禁止区間を細切れにしたり git-svn-id: file:///Volumes/Transfer/gigaleak_20231201/2020-05-23%20-%20ctr.7z%20+%20svn_v1.068.zip/ctr/svn/ctr_mcu@146 013db118-44a6-b54f-8bf7-843cb86687b1
429 lines
12 KiB
C
429 lines
12 KiB
C
/* ========================================================
|
||
|
||
CTR MCU I2Cレジスタ
|
||
|
||
====================================================== */
|
||
#include "incs.h"
|
||
#include "vreg_ctr.h"
|
||
#include "rtc.h"
|
||
#include "led.h"
|
||
#include "accero.h"
|
||
#include "pm.h"
|
||
#include "pool.h"
|
||
|
||
#include <fsl.h>
|
||
#include "fsl_user.h"
|
||
|
||
|
||
extern u8 mcu_info_read(); // task_misc.c
|
||
extern u8 iic_burst_state;
|
||
|
||
|
||
// ********************************************************
|
||
u8 vreg_ctr[VREG_C_ENDMARK_];
|
||
bit irq_readed; // AAA型のため。
|
||
|
||
|
||
// ********************************************************
|
||
extern task_status_immed tski_firm_update();
|
||
extern task_status_immed tski_mcu_info_read();
|
||
|
||
// ********************************************************
|
||
#ifdef _MCU_BSR_
|
||
#define IICAMK IICAMK1
|
||
#endif
|
||
|
||
|
||
// ********************************************************
|
||
// 非ゼロの初期値の指定が必要なアドレス
|
||
void vreg_ctr_init( )
|
||
{
|
||
vreg_ctr[VREG_C_LED_BRIGHT] = 0xFF;
|
||
|
||
#ifdef _PMIC_TWL_
|
||
vreg_ctr[VREG_C_MCU_VER_MAJOR] = MCU_VER_MAJOR;
|
||
#else
|
||
vreg_ctr[VREG_C_MCU_VER_MAJOR] = MCU_VER_MAJOR | 0x10;
|
||
#endif
|
||
vreg_ctr[VREG_C_MCU_VER_MINOR] = MCU_VER_MINOR;
|
||
|
||
vreg_ctr[VREG_C_VCOM_T] = VCOM_DEFAULT_T;
|
||
vreg_ctr[VREG_C_VCOM_B] = VCOM_DEFAULT_B;
|
||
}
|
||
|
||
|
||
|
||
|
||
// ********************************************************
|
||
// I2C仮想レジスタに書きます。
|
||
// 引数 adrs は内部アドレス
|
||
// 書けないアドレスにアクセスした場合、何もしません。
|
||
// ●書き込んだ結果、I2C_mcu通信が発生する場合、renge_task_immed_add()
|
||
// を使用しないと、I2C_mcu使用中でエラー終了した場合にリトライしません。
|
||
void vreg_ctr_write( u8 adrs, u8 data )
|
||
{
|
||
switch ( adrs )
|
||
{
|
||
|
||
case ( VREG_C_MCU_STATUS ):
|
||
vreg_twl[ REG_TWL_INT_ADRS_MODE ] = ( ( data & 0xC0 ) >> 6 );
|
||
vreg_ctr[adrs] = data;
|
||
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_DBG1 ):
|
||
case ( VREG_C_DBG2 ):
|
||
vreg_ctr[adrs] = data;
|
||
break;
|
||
case ( VREG_C_DBG3 ):
|
||
if( ( vreg_ctr[VREG_C_DBG1] == 'j' )
|
||
&& ( vreg_ctr[VREG_C_DBG2] == 'h' )
|
||
&& ( data == 'l' ) )
|
||
{
|
||
renge_task_immed_add( tski_firm_update );
|
||
IICAMK = 1;
|
||
}
|
||
vreg_ctr[adrs] = data;
|
||
break;
|
||
|
||
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 ):
|
||
vreg_ctr[adrs] = data;
|
||
break;
|
||
|
||
case ( VREG_C_COMMAND0 ):
|
||
if( data != 0 )
|
||
{
|
||
renge_task_immed_add( do_command0 );
|
||
}
|
||
vreg_ctr[adrs] |= data;
|
||
break;
|
||
|
||
case ( VREG_C_COMMAND2 ):
|
||
// こちらからの完了割り込みを待ってくれないそうです。 #-ω-) 何のための割り込みだ
|
||
// 液晶電源
|
||
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 );
|
||
}
|
||
|
||
// バックライト設定
|
||
/// 今のところさらに細かくは分けないけど…
|
||
if(( data & REG_BITS_CMD_BL ) != 0 )
|
||
{
|
||
renge_task_immed_add( tski_PM_BL_set );
|
||
vreg_ctr[adrs] = ( data & REG_BITS_CMD_BL );
|
||
}
|
||
break;
|
||
|
||
case ( VREG_C_COMMAND1 ):
|
||
if( data != 0 )
|
||
{
|
||
// TWLに割り込みを入れる
|
||
/// 実際に割り込みを入れるのはSoC
|
||
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
|
||
|
||
vreg_twl[REG_TWL_INT_ADRS_IRQ] |= ( ( data & REG_BIT_SEND_TWL_VOL_CLICK ) != 0 ) ? REG_BIT_TWL_IRQ_VOL_CHANGE : 0x00; //vol_changed
|
||
}
|
||
break;
|
||
|
||
case ( VREG_C_DBG20 ):
|
||
case ( VREG_C_DBG21 ):
|
||
case ( VREG_C_DBG22 ):
|
||
case ( VREG_C_DBG23 ):
|
||
vreg_ctr[adrs] = data;
|
||
break;
|
||
|
||
case ( VREG_C_LED_BRIGHT ):
|
||
vreg_ctr[adrs] = data;
|
||
break;
|
||
|
||
case ( VREG_C_LED_POW ):
|
||
if( iic_burst_state == 0 )
|
||
{
|
||
vreg_ctr[adrs] = data;
|
||
iic_burst_state += 1;
|
||
}
|
||
else if( iic_burst_state < 5 )
|
||
{
|
||
led_red_batt_empty.dats.dats[ iic_burst_state -1 ] = data;
|
||
iic_burst_state += 1;
|
||
}
|
||
break;
|
||
|
||
case ( VREG_C_LED_WIFI ):
|
||
case ( VREG_C_LED_CAM ):
|
||
case ( VREG_C_LED_TUNE ):
|
||
vreg_ctr[adrs] = data & 0x0F;
|
||
break;
|
||
|
||
case ( VREG_C_LED_NOTIFY_DATA ):
|
||
if( iic_burst_state < sizeof( uni_info_LED ) )
|
||
{
|
||
info_LED.bindata[ iic_burst_state ] = data;
|
||
iic_burst_state += 1;
|
||
}
|
||
|
||
|
||
/// 非同期で動いているためここでは書かない。
|
||
// 予約するだけで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_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_DAY ):
|
||
set_rtc( adrs - VREG_C_RTC_SEC, data & 0x3F );
|
||
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 ):
|
||
SUBCUD = data;
|
||
vreg_ctr[adrs] = data;
|
||
break;
|
||
|
||
case ( VREG_C_RTC_ALARM_MIN ):
|
||
rtc_alarm_dirty = 1;
|
||
vreg_ctr[adrs] = ( data & 0x7F );
|
||
break;
|
||
|
||
case ( VREG_C_RTC_ALARM_HOUR ):
|
||
rtc_alarm_dirty = 1;
|
||
vreg_ctr[adrs] = ( data & 0x3F );
|
||
break;
|
||
|
||
// 書くだけでよい
|
||
case ( VREG_C_RTC_ALARM_DAY ):
|
||
vreg_ctr[adrs] = ( data & 0x3F );
|
||
break;
|
||
|
||
case ( VREG_C_RTC_ALARM_MONTH ):
|
||
vreg_ctr[adrs] = ( data & 0x1F );
|
||
break;
|
||
|
||
case ( VREG_C_RTC_ALARM_YEAR ):
|
||
vreg_ctr[adrs] = data;
|
||
break;
|
||
|
||
|
||
case ( VREG_C_ACC_CONFIG ):
|
||
renge_task_immed_add( acc_hosu_set );
|
||
vreg_ctr[adrs] = data;
|
||
break;
|
||
|
||
case ( VREG_C_ACC_R_ADRS ):
|
||
renge_task_immed_add( acc_read );
|
||
vreg_ctr[adrs] = data;
|
||
break;
|
||
|
||
case ( VREG_C_ACC_W_ADRS ):
|
||
vreg_ctr[adrs] = data;
|
||
break;
|
||
|
||
case ( VREG_C_ACC_W_BUF ):
|
||
renge_task_immed_add( acc_write );
|
||
vreg_ctr[adrs] = data;
|
||
break;
|
||
|
||
case ( VREG_C_ACC_HOSU_L ):
|
||
case ( VREG_C_ACC_HOSU_M ):
|
||
case ( VREG_C_ACC_HOSU_H ):
|
||
vreg_ctr[adrs] = data;
|
||
break;
|
||
|
||
case ( VREG_C_ACC_HOSU_SETTING ):
|
||
if( ( data & 0x01 ) != 0 )
|
||
{
|
||
clear_hosu_hist(); // 履歴クリア
|
||
}
|
||
break;
|
||
|
||
case ( VREG_C_ACC_HOSU_HOUR_BOUNDARY ):
|
||
vreg_ctr[adrs] = data;
|
||
break;
|
||
|
||
case ( VREG_C_FREE_ADRS ):
|
||
vreg_ctr[adrs] = data;
|
||
break;
|
||
|
||
case ( VREG_C_FREE_DATA ):
|
||
if( vreg_ctr[ VREG_C_FREE_ADRS ] < VREG_C_FREE_SIZE )
|
||
{
|
||
pool.vreg_c_ext.vreg_c_free[ vreg_ctr[ VREG_C_FREE_ADRS ] ] = data;
|
||
vreg_ctr[ VREG_C_FREE_ADRS ] += 1;
|
||
}
|
||
break;
|
||
|
||
case ( VREG_C_COMMAND3 ):
|
||
switch ( data )
|
||
{
|
||
case ( 'r' ):
|
||
// 割り込みルーチンからFSLライブラリを呼ぶのは禁止のため
|
||
renge_task_immed_add( tski_mcu_reset );
|
||
break;
|
||
|
||
case ( 'w' ):
|
||
// WDTで再起動(テスト向け)
|
||
WDTE = 0xAA;
|
||
break;
|
||
}
|
||
vreg_ctr[adrs] = data;
|
||
break;
|
||
|
||
default:
|
||
break;
|
||
}
|
||
return;
|
||
}
|
||
|
||
|
||
|
||
// ********************************************************
|
||
// I2C仮想レジスタから読みます。
|
||
// 戻り: xx データ
|
||
// 注意:次のアドレスの準備で呼ばれる ので、
|
||
// リードされたらクリアなどは気をつける
|
||
u8 vreg_ctr_read( u8 adrs )
|
||
{
|
||
static u16 rsub_temp;
|
||
|
||
// RTCは読み出し途中に繰り上がるのを避けるため
|
||
if( ( VREG_C_RTC_SEC <= adrs ) && ( adrs <= VREG_C_RTC_YEAR ) )
|
||
{
|
||
rtc_buf_reflesh( );
|
||
}
|
||
else if( adrs == VREG_C_MCU_STATUS )
|
||
{
|
||
return( vreg_ctr[ VREG_C_MCU_STATUS ] | ( ( vreg_twl[ REG_TWL_INT_ADRS_MODE ] & 0x03 ) << 6 ) );
|
||
}
|
||
else if( adrs == VREG_C_ACC_HOSU_HIST )
|
||
{
|
||
return( hosu_read() );
|
||
}
|
||
else if( adrs == VREG_C_FREE_DATA )
|
||
{
|
||
return( pool.vreg_c_ext.vreg_c_free[ vreg_ctr[VREG_C_FREE_ADRS]++ ] );
|
||
}
|
||
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 ) );
|
||
}
|
||
else if( adrs == VREG_C_INFO )
|
||
{
|
||
// I2C_mを使うので、ここからでは割り込みが使えなくて困る
|
||
// なのでタスク登録する。
|
||
// 強制的にI2C_2割り込みをマスクする
|
||
renge_task_immed_add( tski_mcu_info_read );
|
||
IICAMK = 1;
|
||
return( 0x4A );
|
||
}
|
||
|
||
#if 1
|
||
if( adrs >= VREG_C_ENDMARK_ )
|
||
{
|
||
// VREG_C_INFO > VREG_C_ENDMARK_ なので
|
||
// いじるときは注意
|
||
return( 0xEE );
|
||
}
|
||
#endif
|
||
return ( vreg_ctr[adrs] );
|
||
}
|
||
|
||
|
||
|
||
// ********************************************************
|
||
// I2C仮想レジスタから読まれて何かするレジスタ
|
||
void vreg_ctr_after_read( u8 adrs )
|
||
{
|
||
// 割り込みフラグはリードでクリア
|
||
switch( adrs )
|
||
{
|
||
case VREG_C_IRQ0:
|
||
case VREG_C_IRQ1:
|
||
case VREG_C_IRQ2:
|
||
case VREG_C_IRQ3:
|
||
case VREG_C_IRQ4:
|
||
vreg_ctr[ adrs ] = 0;
|
||
irq_readed = 1;
|
||
break;
|
||
|
||
default:
|
||
break;
|
||
}
|
||
}
|
||
|
||
|
||
|
||
|
||
|
||
|
||
/******************************************************************************
|
||
割り込みを入れる
|
||
割り込みマスクが必要と言うことでこんな事をする羽目になりました
|
||
*****************************************************************************/
|
||
#if 0
|
||
// マスクされてたら、フラグは立てるが、割り込みは入れない。
|
||
#define set_irq( irqreg, bitpos ) \
|
||
{ \
|
||
vreg_ctr[ irqreg ] |= bitpos; \
|
||
if( ( vreg_ctr[ irqreg+8 ] & bitpos ) == 0 ){ \
|
||
IRQ0_ast; \
|
||
} \
|
||
}
|
||
#endif
|
||
|
||
// マスクされてたら、フラグも立てず、割り込みも入れない。
|
||
void set_irq( u8 irqreg, u8 irq_flg )
|
||
{
|
||
u8 tot;
|
||
|
||
// DI();
|
||
if( ( vreg_ctr[ irqreg + 8 ] & irq_flg ) == 0 ){
|
||
vreg_ctr[ irqreg ] |= irq_flg;
|
||
IRQ0_neg; // 一瞬上げて...
|
||
// EI();
|
||
tot = 0;
|
||
while( !IRQ0 && ( ++tot != 0 ) ){;} // O.D.なのでちゃんとあがるのを待つ & IRQ_mcu がLに縛られてると困る(基板不良)
|
||
IRQ0_ast; // 落とし直す。
|
||
}
|
||
// EI();
|
||
}
|