Ignore:
Timestamp:
Feb 1, 2019, 9:57:09 PM (5 years ago)
Author:
coas-nagasima
Message:

TINETとSocket APIなどを更新

Location:
asp3_tinet_ecnl_arm/trunk/app6_hot_water_pot
Files:
6 edited

Legend:

Unmodified
Added
Removed
  • asp3_tinet_ecnl_arm/trunk/app6_hot_water_pot/.cproject

    r352 r364  
    2222                        <storageModule moduleId="com.renesas.cdt.managedbuild.core.toolchainInfo">
    2323                                <option id="toolchain.id" value="gcc-arm-embedded"/>
    24                                 <option id="toolchain.version" value="5.4.1.20160919"/>
     24                                <option id="toolchain.version" value="6.3.1.20170620"/>
    2525                        </storageModule>
    2626                        <storageModule moduleId="cdtBuildSystem" version="4.0.0">
     
    127127                        <storageModule moduleId="com.renesas.cdt.managedbuild.core.toolchainInfo">
    128128                                <option id="toolchain.id" value="gcc-arm-embedded"/>
    129                                 <option id="toolchain.version" value="5.4.1.20160919"/>
     129                                <option id="toolchain.version" value="6.3.1.20170620"/>
    130130                        </storageModule>
    131131                        <storageModule moduleId="cdtBuildSystem" version="4.0.0">
  • asp3_tinet_ecnl_arm/trunk/app6_hot_water_pot/Debug/Makefile

    r352 r364  
    173173        CDEFS := -DTOPPERS_OMIT_TECS $(CDEFS)
    174174endif
    175 CDEFS := $(CDEFS) -DDHCP4_CLI_CFG -DUSE_PING -DUSE_RESOLVER -DUSE_NETAPP_SUBR -DECHONET_USE_MALLOC -DRamDisk=_binary_______ntshell_src_rom_fs_bin_start
     175CDEFS := $(CDEFS) -DDHCP4_CLI_CFG -DUSE_PING -DUSE_RESOLVER -DUSE_NETAPP_SUBR -DNOUSE_MPF_NET_BUF -DECHONET_USE_MALLOC -DRamDisk=_binary_______ntshell_src_rom_fs_bin_start
    176176INCLUDES := -I. -I$(SRCDIR)/include -I$(SRCDIR) \
    177177        -I$(SRCDIR)/../btstack/include \
     
    181181        -I$(SRCDIR)/../usbhost/src \
    182182        $(INCLUDES)
    183 LDFLAGS := $(LDFLAGS) -Wl,-Map=$(OBJNAME).map,--cref -L.
     183LDFLAGS := $(LDFLAGS) -L.
    184184LIBS := $(LIBS) $(CXXLIBS)
    185185CFLAGS = $(COPTS) $(CDEFS) $(INCLUDES)
     
    215215endif
    216216
    217 
    218 #
    219 #  ネットワークサービスの定義
    220 #
    221 NO_USE_TINET_LIBRARY = true
    222 
    223 #  ネットワークインタフェースの選択、何れか一つ選択する。
    224 NET_IF = ether
    225 
    226 #  イーサネット・ディバイスドライバの選択
    227 NET_DEV = if_btusb
    228 
    229 #  ネットワーク層の選択
    230 #SUPPORT_INET6 = true
    231 SUPPORT_INET4 = true
    232 
    233 #  API に組込む機能の選択
    234 #API_CFG_IP4MAPPED_ADDR = true
    235 
    236 #  トランスポート層の選択
    237 SUPPORT_TCP = true
    238 SUPPORT_UDP = true
    239 
    240 # IGMPを有効に設定
    241 SUPPORT_IGMP = true
    242 
    243 #
    244 #  ネットワークサービスの Makefile のインクルード
    245 #
    246 include $(SRCDIR)/$(TINETDIR)/Makefile.tinet
     217ifdef TINETDIR
     218        #
     219        #  ネットワークサービスの定義
     220        #
     221        NO_USE_TINET_LIBRARY = true
     222
     223        #  ネットワークインタフェースの選択、何れか一つ選択する。
     224        NET_IF = ether
     225
     226        #  イーサネット・ディバイスドライバの選択
     227        NET_DEV = if_btusb
     228
     229        #  ネットワーク層の選択
     230        #SUPPORT_INET6 = true
     231        SUPPORT_INET4 = true
     232
     233        #  API に組込む機能の選択
     234        #API_CFG_IP4MAPPED_ADDR = true
     235
     236        #  トランスポート層の選択
     237        SUPPORT_TCP = true
     238        SUPPORT_UDP = true
     239
     240        # IGMPを有効に設定
     241        SUPPORT_IGMP = true
     242
     243        #
     244        #  ネットワークサービスの Makefile のインクルード
     245        #
     246        include $(SRCDIR)/$(TINETDIR)/Makefile.tinet
     247endif
    247248
    248249#
     
    277278#  コンフィギュレータに関する定義
    278279#
    279 CFG_TRB := -T $(TINET_ROOT)/tinet.trb:tcpip -T ../../ntshell/echonet/echonet.trb:echonet -T $(TARGETDIR)/target_kernel.trb:kernel
    280 CFG_TABS := --api-table $(TINET_ROOT)/tcpip_api.def:tcpip \
     280ifndef TINETDIR
     281  CFG_TRB := -T $(TARGETDIR)/target_kernel.trb
     282  CFG_TABS := --api-table $(SRCDIR)/kernel/kernel_api.def \
     283                        --symval-table $(SRCDIR)/kernel/kernel_sym.def $(CFG_TABS)
     284else
     285  CFG_TRB := -T $(TINET_ROOT)/tinet.trb:tcpip -T ../../ntshell/echonet/echonet.trb:echonet -T $(TARGETDIR)/target_kernel.trb:kernel
     286  CFG_TABS := --api-table $(TINET_ROOT)/tcpip_api.def:tcpip \
    281287                        --api-table ../../ntshell/echonet/echonet_api.def:echonet \
    282288                        --api-table $(SRCDIR)/kernel/kernel_api.def:kernel \
     
    284290                        --symval-table ../../ntshell/echonet/echonet_sym.def \
    285291                        --symval-table $(SRCDIR)/kernel/kernel_sym.def $(CFG_TABS)
     292endif
    286293CFG_ASMOBJS := $(CFG_ASMOBJS)
    287294CFG_COBJS := kernel_cfg.o echonet_cfg.o $(CFG_COBJS)
     
    429436
    430437#
     438#  並列makeのための依存関係の定義
     439#
     440$(APPL_OBJS) $(filter-out $(CFG_DMY), $(SYSSVC_OBJS)): | kernel_cfg.timestamp
     441$(APPL_ASMOBJS) $(filter-out $(CFG_DMY), $(SYSSVC_ASMOBJS)) $(KERNEL_ASMOBJS) $(CFG_ASMOBJS): \
     442                                                                                                                | offset.timestamp
     443
     444#
    431445#  特別な依存関係の定義
    432446#
     
    437451#
    438452$(OBJFILE): $(ALL_OBJS) $(LIBS_DEP)
    439         $(LINK) $(CFLAGS) $(LDFLAGS) $(OBJ_LDFLAGS) -o $(OBJFILE) \
     453        $(LINK) $(CFLAGS) $(LDFLAGS) $(OBJ_LDFLAGS) -o $(OBJFILE) -Wl,-Map=$(OBJNAME).map,--cref \
    440454                        $(START_OBJS) $(APPL_OBJS) $(SYSSVC_OBJS) $(CFG_OBJS) \
    441455                        -Wl,--start-group $(ALL_LIBS) -Wl,--end-group $(END_OBJS)
  • asp3_tinet_ecnl_arm/trunk/app6_hot_water_pot/DebugEther/Makefile

    r352 r364  
    171171        CDEFS := -DTOPPERS_OMIT_TECS $(CDEFS)
    172172endif
    173 CDEFS := $(CDEFS) -DDHCP4_CLI_CFG -DUSE_PING -DUSE_RESOLVER -DUSE_NETAPP_SUBR -DECHONET_USE_MALLOC -DRamDisk=_binary_______ntshell_src_rom_fs_bin_start
     173CDEFS := $(CDEFS) -DDHCP4_CLI_CFG -DUSE_PING -DUSE_RESOLVER -DUSE_NETAPP_SUBR -DNOUSE_MPF_NET_BUF -DECHONET_USE_MALLOC -DRamDisk=_binary_______ntshell_src_rom_fs_bin_start
    174174INCLUDES := -I. -I$(SRCDIR)/include -I$(SRCDIR) \
    175175        -I$(SRCDIR)/../btstack/include \
     
    179179        -I$(SRCDIR)/../usbhost/src \
    180180        $(INCLUDES)
    181 LDFLAGS := $(LDFLAGS) -Wl,-Map=$(OBJNAME).map,--cref -L.
     181LDFLAGS := $(LDFLAGS) -L.
    182182LIBS := $(LIBS) $(CXXLIBS)
    183183CFLAGS = $(COPTS) $(CDEFS) $(INCLUDES)
     
    213213endif
    214214
    215 
    216 #
    217 #  ネットワークサービスの定義
    218 #
    219 NO_USE_TINET_LIBRARY = true
    220 
    221 #  ネットワークインタフェースの選択、何れか一つ選択する。
    222 NET_IF = ether
    223 
    224 #  イーサネット・ディバイスドライバの選択
     215ifdef TINETDIR
     216        #
     217        #  ネットワークサービスの定義
     218        #
     219        NO_USE_TINET_LIBRARY = true
     220
     221        #  ネットワークインタフェースの選択、何れか一つ選択する。
     222        NET_IF = ether
     223
     224        #  イーサネット・ディバイスドライバの選択
    225225        NET_DEV = if_mbed
    226226
    227 #  ネットワーク層の選択
    228 #SUPPORT_INET6 = true
    229 SUPPORT_INET4 = true
    230 
    231 #  API に組込む機能の選択
    232 #API_CFG_IP4MAPPED_ADDR = true
    233 
    234 #  トランスポート層の選択
    235 SUPPORT_TCP = true
    236 SUPPORT_UDP = true
    237 
    238 # IGMPを有効に設定
    239 SUPPORT_IGMP = true
    240 
    241 #
    242 #  ネットワークサービスの Makefile のインクルード
    243 #
    244 include $(SRCDIR)/$(TINETDIR)/Makefile.tinet
     227        #  ネットワーク層の選択
     228        #SUPPORT_INET6 = true
     229        SUPPORT_INET4 = true
     230
     231        #  API に組込む機能の選択
     232        #API_CFG_IP4MAPPED_ADDR = true
     233
     234        #  トランスポート層の選択
     235        SUPPORT_TCP = true
     236        SUPPORT_UDP = true
     237
     238        # IGMPを有効に設定
     239        SUPPORT_IGMP = true
     240
     241        #
     242        #  ネットワークサービスの Makefile のインクルード
     243        #
     244        include $(SRCDIR)/$(TINETDIR)/Makefile.tinet
     245endif
    245246
    246247#
     
    275276#  コンフィギュレータに関する定義
    276277#
    277 CFG_TRB := -T $(TINET_ROOT)/tinet.trb:tcpip -T ../../ntshell/echonet/echonet.trb:echonet -T $(TARGETDIR)/target_kernel.trb:kernel
    278 CFG_TABS := --api-table $(TINET_ROOT)/tcpip_api.def:tcpip \
     278ifndef TINETDIR
     279  CFG_TRB := -T $(TARGETDIR)/target_kernel.trb
     280  CFG_TABS := --api-table $(SRCDIR)/kernel/kernel_api.def \
     281                        --symval-table $(SRCDIR)/kernel/kernel_sym.def $(CFG_TABS)
     282else
     283  CFG_TRB := -T $(TINET_ROOT)/tinet.trb:tcpip -T ../../ntshell/echonet/echonet.trb:echonet -T $(TARGETDIR)/target_kernel.trb:kernel
     284  CFG_TABS := --api-table $(TINET_ROOT)/tcpip_api.def:tcpip \
    279285                        --api-table ../../ntshell/echonet/echonet_api.def:echonet \
    280286                        --api-table $(SRCDIR)/kernel/kernel_api.def:kernel \
     
    282288                        --symval-table ../../ntshell/echonet/echonet_sym.def \
    283289                        --symval-table $(SRCDIR)/kernel/kernel_sym.def $(CFG_TABS)
     290endif
    284291CFG_ASMOBJS := $(CFG_ASMOBJS)
    285292CFG_COBJS := kernel_cfg.o echonet_cfg.o $(CFG_COBJS)
     
    427434
    428435#
     436#  並列makeのための依存関係の定義
     437#
     438$(APPL_OBJS) $(filter-out $(CFG_DMY), $(SYSSVC_OBJS)): | kernel_cfg.timestamp
     439$(APPL_ASMOBJS) $(filter-out $(CFG_DMY), $(SYSSVC_ASMOBJS)) $(KERNEL_ASMOBJS) $(CFG_ASMOBJS): \
     440                                                                                                                | offset.timestamp
     441
     442#
    429443#  特別な依存関係の定義
    430444#
     
    435449#
    436450$(OBJFILE): $(ALL_OBJS) $(LIBS_DEP)
    437         $(LINK) $(CFLAGS) $(LDFLAGS) $(OBJ_LDFLAGS) -o $(OBJFILE) \
     451        $(LINK) $(CFLAGS) $(LDFLAGS) $(OBJ_LDFLAGS) -o $(OBJFILE) -Wl,-Map=$(OBJNAME).map,--cref \
    438452                        $(START_OBJS) $(APPL_OBJS) $(SYSSVC_OBJS) $(CFG_OBJS) \
    439453                        -Wl,--start-group $(ALL_LIBS) -Wl,--end-group $(END_OBJS)
  • asp3_tinet_ecnl_arm/trunk/app6_hot_water_pot/src/echonet_main.c

    r352 r364  
    11/*
    22 *  TOPPERS ECHONET Lite Communication Middleware
    3  * 
     3 *
    44 *  Copyright (C) 2014-2018 Cores Co., Ltd. Japan
    5  * 
     5 *
    66 *  上記著作権者は,以下の(1)~(4)の条件を満たす場合に限り,本ソフトウェ
    77 *  ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
     
    2626 *      由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
    2727 *      免責すること.
    28  * 
     28 *
    2929 *  本ソフトウェアは,無保証で提供されているものである.上記著作権者お
    3030 *  よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
     
    3232 *  アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
    3333 *  の責任を負わない.
    34  * 
     34 *
    3535 *  @(#) $Id$
    3636 */
    3737
    38 /* 
     38/*
    3939 *  サンプルプログラム(1)の本体
    4040 */
     
    113113{
    114114        /* サイズが1以外は受け付けない */
    115         if(size != 1)
     115        if (size != 1)
    116116                return 0;
    117117
    118118        *anno = *((uint8_t*)item->exinf) != *((uint8_t*)src);
    119119
    120         switch(*(uint8_t *)src){
     120        switch (*(uint8_t *)src) {
    121121        /* ONの場合 */
    122122        case 0x30:
     
    145145{
    146146        /* サイズが1以外は受け付けない */
    147         if(size != 1)
     147        if (size != 1)
    148148                return 0;
    149149
    150150        *anno = *((uint8_t *)item->exinf) != *((uint8_t *)src);
    151151
    152         switch(*(uint8_t *)src){
     152        switch (*(uint8_t *)src) {
    153153        /* 異常発生ありの場合 */
    154154        case 0x41:
     
    174174
    175175        /* サイズが1以外は受け付けない */
    176         if(size != 1)
     176        if (size != 1)
    177177                return 0;
    178178
    179179        *anno = *((uint8_t*)item->exinf) != *((uint8_t*)src);
    180180
    181         switch(*(uint8_t *)src){
     181        switch (*(uint8_t *)src) {
    182182        /* 湯切れ無しの場合 */
    183183        case 0x40:
     
    200200        data[0] = 0xB1;
    201201        ret = ecn_brk_wai(data, sizeof(data));
    202         if(ret != E_OK){
     202        if (ret != E_OK) {
    203203                syslog(LOG_ERROR, "ecn_brk_wai");
    204204        }
     
    213213{
    214214        /* サイズが1以外は受け付けない */
    215         if(size != 1)
     215        if (size != 1)
    216216                return 0;
    217217
    218218        *anno = *((uint8_t*)item->exinf) != *((uint8_t*)src);
    219219
    220         switch(*(uint8_t *)src){
     220        switch (*(uint8_t *)src) {
    221221        /* 出湯有の場合 */
    222222        case 0x41:
     
    262262
    263263        ret2 = get_tim(&now);
    264         if (ret2 != E_OK){
     264        if (ret2 != E_OK) {
    265265                syslog(LOG_ERROR, "get_tim");
    266266                return;
    267267        }
    268268
    269         for(;;){
     269        for (;;) {
    270270                prev = now;
    271271
     
    275275                /* 応答電文待ち */
    276276                ret = ecn_trcv_esv(&esv, timer);
    277                 if ((ret != E_OK) && (ret != E_BRK) && (ret != E_TMOUT)){
     277                if ((ret != E_OK) && (ret != E_BRK) && (ret != E_TMOUT)) {
    278278                        syslog(LOG_ERROR, "ecn_trcv_esv");
    279279                        break;
     
    281281
    282282                ret2 = get_tim(&now);
    283                 if (ret2 != E_OK){
     283                if (ret2 != E_OK) {
    284284                        syslog(LOG_ERROR, "get_tim");
    285285                        break;
     
    296296                        /* 領域解放 */
    297297                        ret = ecn_rel_esv(esv);
    298                         if (ret != E_OK){
     298                        if (ret != E_OK) {
    299299                                syslog(LOG_ERROR, "ecn_rel_esv");
    300300                                break;
     
    305305                        /* 応答電文待ちの割り込みデータ取得 */
    306306                        ret = ecn_get_brk_dat(esv, brkdat, sizeof(brkdat), &len);
    307                         if (ret != E_OK){
     307                        if (ret != E_OK) {
    308308                                syslog(LOG_ERROR, "ecn_get_brk_dat");
    309309                                break;
     
    315315                        /* 領域解放 */
    316316                        ret = ecn_rel_esv(esv);
    317                         if (ret != E_OK){
     317                        if (ret != E_OK) {
    318318                                syslog(LOG_ERROR, "ecn_rel_esv");
    319319                                break;
     
    326326}
    327327
    328 bool_t started = false;
    329 
    330328void echonet_change_netif_link(uint8_t link_up, uint8_t up)
    331329{
     
    335333                return;
    336334
    337         if (up && !started) {
    338                 started = true;
    339 
    340                 /* ECHONETミドルウェアを起動 */
    341                 ret = ecn_sta_svc();
    342                 if (ret != E_OK)
    343                         return;
    344 
    345                 /* ECHONETミドルウェアを起動するのを待つ */
    346                 dly_tsk(100);
     335        if (up) {
     336                /* インスタンスリスト通知の送信 */
     337                ret = ecn_ntf_inl();
     338                if (ret != E_OK) {
     339                        syslog(LOG_ERROR, "ecn_ntf_inl");
     340                }
    347341        }
    348342
     
    358352}
    359353
    360 enum main_state_t{
     354enum main_state_t {
     355        main_state_start,
    361356        main_state_idle,
    362357        main_state_search,
     
    365360
    366361int main_timer = TMO_FEVR;
    367 enum main_state_t main_state = main_state_idle;
     362enum main_state_t main_state = main_state_start;
    368363int main_retry;
    369364
     
    397392        gpio_write(&led_red, 0);
    398393
    399         /* 1秒後にブザーを検索 */
    400         main_state = main_state_search;
     394
     395        /* ECHONETミドルウェアを起動するのを待つ */
     396        main_state = main_state_start;
    401397        main_timer = 1000 * 1000;
    402398
     
    410406        main_btn2_state = btn2 != 0;
    411407
     408        /* メインタスクを起動 */
    412409        ER ret = act_tsk(MAIN_TASK);
    413410        if (ret != E_OK) {
     
    423420        int result = main_timer;
    424421
    425         if((result == TMO_FEVR)
    426                 || ((main_btn_timer != TMO_FEVR) && (main_btn_timer < result))){
     422        if ((result == TMO_FEVR)
     423                || ((main_btn_timer != TMO_FEVR) && (main_btn_timer < result))) {
    427424                result = main_btn_timer;
    428425        }
     
    436433static void main_progress(int interval)
    437434{
    438         if(main_timer != TMO_FEVR){
     435        if (main_timer != TMO_FEVR) {
    439436                main_timer -= interval;
    440                 if(main_timer < 0){
     437                if (main_timer < 0) {
    441438                        main_timer = 0;
    442439                }
    443440        }
    444441
    445         if(main_btn_timer != TMO_FEVR){
     442        if (main_btn_timer != TMO_FEVR) {
    446443                main_btn_timer -= interval;
    447                 if(main_btn_timer < 0){
     444                if (main_btn_timer < 0) {
    448445                        main_btn_timer = 0;
    449446                }
     
    464461
    465462        eobjid = ecn_get_eobj(esv);
    466         if(eobjid == EOBJ_NULL){
     463        if (eobjid == EOBJ_NULL) {
    467464                syslog(LOG_ERROR, "ecn_get_eobj");
    468465                return;
     
    470467
    471468        ret = ecn_itr_ini(&enm, esv);
    472         if(ret != E_OK){
     469        if (ret != E_OK) {
    473470                syslog(LOG_ERROR, "ecn_itr_ini");
    474471                return;
    475472        }
    476473
    477         for(;;) {
    478                 while((ret = ecn_itr_nxt(&enm, &epc, &pdc, p_edt)) == E_OK) {
     474        for (;;) {
     475                while ((ret = ecn_itr_nxt(&enm, &epc, &pdc, p_edt)) == E_OK) {
    479476                        switch (epc) {
    480477                        case 0xB1:
    481                                 switch(main_state){
     478                                switch (main_state) {
    482479                                /* プロパティ通知応答待ちの場合 */
    483480                                case main_state_wait_res:
    484481                                        /* プロパティ通知応答のみ処理 */
    485                                         if((esv->hdr.edata.esv == ESV_INFC_RES) && (eobjid == BUZZER_NODE_EOBJ)){
     482                                        if ((esv->hdr.edata.esv == ESV_INFC_RES) && (eobjid == BUZZER_NODE_EOBJ)) {
    486483                                                /* 応答受信 */
    487484                                                main_state = main_state_idle;
     
    492489                                break;
    493490                        case 0xD6:
    494                                 switch(main_state){
     491                                switch (main_state) {
    495492                                case main_state_search:
    496493                                        if (eobjid == BUZZER_NODE_EOBJ) {
     
    504501                        }
    505502                }
    506                 if(ret != E_BOVR){
     503                if (ret != E_BOVR) {
    507504                        syslog(LOG_ERROR, "ecn_itr_nxt");
    508505                        break;
    509506                }
    510                 if(enm.is_eof)
     507                if (enm.is_eof)
    511508                        break;
    512509        }
     
    526523        }
    527524
    528         switch(main_state){
     525        switch (main_state) {
    529526        case main_state_idle:
    530527        case main_state_wait_res:
    531                 if((len >= 1) && (*brkdat == 0xB1)){
     528                if ((len >= 1) && (*brkdat == 0xB1)) {
    532529                        /* ブザーに湯切れ警告状態通知 */
    533530                        ret = ecn_esv_infc(&esv, BUZZER_NODE_EOBJ, ELECTRIC_HOT_WATER_POT_EOBJ, 0xB1);
    534                         if(ret != E_OK){
     531                        if (ret != E_OK) {
    535532                                syslog(LOG_ERROR, "ecn_esv_infc");
    536533                                return;
     
    539536                        /* 電文送信 */
    540537                        ret = ecn_snd_esv(esv);
    541                         if(ret != E_OK){
     538                        if (ret != E_OK) {
    542539                                syslog(LOG_ERROR, "ecn_snd_esv");
    543540                        }
     
    560557static void main_timeout()
    561558{
    562         if(main_timer == 0){
     559        if (main_timer == 0) {
    563560                main_ontimer();
    564561        }
    565562
    566         if(main_btn_timer == 0){
     563        if (main_btn_timer == 0) {
    567564                main_btn_ontimer();
    568565        }
     
    576573        T_EDATA *esv;
    577574
    578         switch(main_state){
     575        switch (main_state) {
     576        case main_state_start:
     577                /* ECHONETミドルウェアを起動 */
     578                ret = ecn_sta_svc();
     579                if (ret != E_OK) {
     580                        syslog(LOG_ERROR, "ecn_sta_svc");
     581                }
     582
     583                /* 1秒後にブザーを検索 */
     584                main_state = main_state_search;
     585                main_timer = 1000 * 1000;
     586                break;
    579587        case main_state_idle:
    580588                syslog(LOG_ERROR, "timeout faild on main_state_idle");
     
    589597        case main_state_wait_res:
    590598                /* リトライアウトの場合 */
    591                 if(main_retry == 0){
     599                if (main_retry == 0) {
    592600                        /* あきらめる */
    593601                        main_state = main_state_idle;
     
    598606                /* ブザーに湯切れ警告状態通知を再送 */
    599607                ret = ecn_esv_infc(&esv, BUZZER_NODE_EOBJ, ELECTRIC_HOT_WATER_POT_EOBJ, 0xB1);
    600                 if(ret != E_OK){
     608                if (ret != E_OK) {
    601609                        syslog(LOG_ERROR, "ecn_esv_infc");
    602610                        main_state = main_state_idle;
     
    607615                /* 電文送信 */
    608616                ret = ecn_snd_esv(esv);
    609                 if(ret != E_OK){
     617                if (ret != E_OK) {
    610618                        syslog(LOG_ERROR, "ecn_snd_esv");
    611619                        main_state = main_state_idle;
     
    629637        /* ブザー検索 */
    630638        ret = ecn_esv_inf_req(&esv, EOBJ_NULL, 0xD6);
    631         if(ret != E_OK){
     639        if (ret != E_OK) {
    632640                syslog(LOG_ERROR, "ecn_esv_inf_req");
    633641                return;
     
    636644        /* 電文送信 */
    637645        ret = ecn_snd_esv(esv);
    638         if(ret != E_OK){
     646        if (ret != E_OK) {
    639647                syslog(LOG_ERROR, "ecn_snd_esv");
    640648        }
     
    656664
    657665        /* ボタン1の処理 */
    658         if((btn1 != 0) && !main_btn1_state){
     666        if ((btn1 != 0) && !main_btn1_state) {
    659667                main_btn1_count++;
    660                 if(main_btn1_count > 10){
     668                if (main_btn1_count > 10) {
    661669                        main_btn1_count = 0;
    662670                        main_btn1_state = true;
     
    665673                }
    666674        }
    667         else if((btn1 == 0) && main_btn1_state){
     675        else if ((btn1 == 0) && main_btn1_state) {
    668676                main_btn1_count++;
    669                 if(main_btn1_count > 10){
     677                if (main_btn1_count > 10) {
    670678                        main_btn1_count = 0;
    671679                        main_btn1_state = false;
     
    676684
    677685        /* ボタン2の処理 */
    678         if((btn2 != 0) && !main_btn2_state){
     686        if ((btn2 != 0) && !main_btn2_state) {
    679687                main_btn2_count++;
    680                 if(main_btn2_count > 10){
     688                if (main_btn2_count > 10) {
    681689                        main_btn2_count = 0;
    682690                        main_btn2_state = true;
     
    685693                }
    686694        }
    687         else if((btn2 == 0) && main_btn2_state){
     695        else if ((btn2 == 0) && main_btn2_state) {
    688696                main_btn2_count++;
    689                 if(main_btn2_count > 10){
     697                if (main_btn2_count > 10) {
    690698                        main_btn2_count = 0;
    691699                        main_btn2_state = false;
     
    708716
    709717        /* 押されて戻った時に処理する */
    710         if(push)
     718        if (push)
    711719                return;
    712720
     
    718726        /* プロパティ設定電文作成 */
    719727        ret = ecn_esv_seti(&esv, ELECTRIC_HOT_WATER_POT_EOBJ, 0xB1, 1, p_edt);
    720         if(ret != E_OK){
     728        if (ret != E_OK) {
    721729                syslog(LOG_ERROR, "ecn_esv_seti");
    722730                return;
     
    725733        /* 電文送信 */
    726734        ecn_snd_esv(esv);
    727         if(ret != E_OK){
     735        if (ret != E_OK) {
    728736                syslog(LOG_ERROR, "ecn_snd_esv");
    729737        }
     
    744752        /* プロパティ設定電文作成 */
    745753        ret = ecn_esv_seti(&esv, ELECTRIC_HOT_WATER_POT_EOBJ, 0xE2, 1, p_edt);
    746         if(ret != E_OK){
     754        if (ret != E_OK) {
    747755                syslog(LOG_ERROR, "ecn_esv_seti");
    748756                return;
     
    751759        /* 電文送信 */
    752760        ecn_snd_esv(esv);
    753         if(ret != E_OK){
     761        if (ret != E_OK) {
    754762                syslog(LOG_ERROR, "ecn_snd_esv");
    755763        }
  • asp3_tinet_ecnl_arm/trunk/app6_hot_water_pot/src/main.c

    r359 r364  
    7979
    8080ID ws_api_mailboxid = MAIN_DATAQUEUE;
     81#ifndef NOUSE_MPF_NET_BUF
    8182ID ws_mempoolid = MPF_NET_BUF_256;
     83#endif
    8284
    8385#ifdef IF_ETHER_BTUSB
     
    111113static void main_timeout();
    112114
     115extern int ntshell_exit;
     116
    113117int uart_read(char *buf, int cnt, void *extobj)
    114118{
    115         return serial_rea_dat(SIO_PORTID, (char *)buf, cnt);
     119        struct main_t *obj = (struct main_t *)extobj;
     120        int result;
     121        ER ret;
     122        int timer;
     123
     124        obj->prev = obj->now;
     125
     126        /* タイマー取得 */
     127        timer = main_get_timer();
     128
     129        /* 待ち */
     130        ret = serial_trea_dat(SIO_PORTID, buf, cnt, timer);
     131        if ((ret < 0) && (ret != E_OK) && (ret != E_TMOUT)) {
     132                syslog(LOG_NOTICE, "tslp_tsk ret: %s %d", itron_strerror(ret), timer);
     133                ntshell_exit = 1;
     134                return -1;
     135        }
     136        result = (int)ret;
     137
     138        ret = get_tim(&obj->now);
     139        if (ret != E_OK) {
     140                syslog(LOG_NOTICE, "get_tim ret: %s", itron_strerror(ret));
     141                ntshell_exit = 1;
     142                return -1;
     143        }
     144
     145                        /* 時間経過 */
     146        int elapse = obj->now - obj->prev;
     147        main_progress(elapse);
     148
     149        /* タイムアウト処理 */
     150        main_timeout();
     151
     152        return result;
    116153}
    117154
     
    119156{
    120157        return serial_wri_dat(SIO_PORTID, buf, cnt);
    121 }
    122 
    123 unsigned char ntstdio_xi(struct ntstdio_t *handle)
    124 {
    125         char buf[1];
    126         if(serial_rea_dat(SIO_PORTID, buf, 1) != 1)
    127                 return -EIO;
    128         return buf[0];
    129 }
    130 
    131 void ntstdio_xo(struct ntstdio_t *handle, unsigned char c)
    132 {
    133         char buf[1];
    134         buf[0] = c;
    135         serial_wri_dat(SIO_PORTID, buf, 1);
    136158}
    137159
     
    150172        main_initialize();
    151173
    152         ntshell_init(&ntshell, uart_read, uart_write, cmd_execute, NULL);
     174        ntshell_init(&ntshell, uart_read, uart_write, cmd_execute, &main_obj);
    153175        ntshell_set_prompt(&ntshell, "NTShell>");
    154176        ntshell_execute(&ntshell);
     
    168190        ER ret;
    169191
    170         ntshell_task_init();
     192#ifdef TOPPERS_OMIT_TECS
     193        serial_opn_por(SIO_PORTID);
     194#endif
     195        serial_ctl_por(SIO_PORTID, IOCTL_FCSND | IOCTL_FCRCV);
     196
     197        ntshell_task_init(uart_read, uart_write, &main_obj);
    171198
    172199        main_obj.timer = TMO_FEVR;
  • asp3_tinet_ecnl_arm/trunk/app6_hot_water_pot/src/main.cfg

    r352 r364  
    5454INCLUDE("tinet/tinet_asp.cfg");
    5555INCLUDE("tinet_main.cfg");
    56 INCLUDE("netinet/ip_igmp.cfg");
    5756
    5857/* DHCP クライアント */
Note: See TracChangeset for help on using the changeset viewer.