/*----------------------------------------------------------------------- 函数Week(macro_U16_arg1, macro_U8_arg2, macro_U8_arg3) 入口: macro_U16_arg1 年(0x00~0x9999)BCD码 macro_U8_arg2 月(0x01~0x12)BCD码 macro_U8_arg3 日(0x01~0x31)BCD码 出口: macro_U8_Result 星期(0~6) 长度: 82字节 -----------------------------------------------------------------------*/ macro_Function_Arg3 (Week, macro_U16_arg1, macro_U8_arg2, macro_U8_arg3) { #define Week_LOOP -20 asm_MOV_R1(4),//将百年、年、月、日的BCD码换成二进制数 //Week_LOOP: asm_MOV_A(0x4f),//DataBuffer偏移,程序长度 //分别取出macro_U16H_arg1,macro_U16L_arg1macro_U8_arg2, macro_U8_arg3 asm_MOVC_A_aDPTR(), asm_MOV_R0_A(), asm_MOV_A_iR0(), asm_ANL_A(0x0f), asm_XCH_A_iR0(), asm_SWAP_A(), asm_ANL_A(0x0f), asm_MOV_B(10), asm_MUL_AB(), asm_ADD_A_iR0(), asm_MOV_iR0_A(), asm_INC_DPTR(), asm_DJNZ_R1(Week_LOOP),//四次未完继续 //(星期=百年%4*5+年+年/4+(13*月+8)/5+日)%7,特别注意1月2月的年为"去年" asm_CJNE_Rn(macro_U8_arg2, 0x03, 0),//判断月 asm_JNC(size_MOV_A_Rn() + size_ORL_A() + size_MOV_Rn_A() + size_DEC_Rn() + size_CJNE_Rn() + size_DEC_Rn()),//月 //月<=2 asm_MOV_A_Rn(macro_U8_arg2), asm_ORL_A(0x04),//1月2月同5月六月表 asm_MOV_Rn_A(macro_U8_arg2), asm_DEC_Rn(macro_U16L_arg1),//1月2月的年为"去年" asm_CJNE_Rn(macro_U16L_arg1, 0xff, size_DEC_Rn()),//Week_Start asm_DEC_Rn(macro_U16H_arg1), //Week_Start: //百年%4*5 asm_MOV_A_Rn(macro_U16H_arg1),//百年 asm_ANL_A(0x03), asm_MOV_Rn_A(macro_U16H_arg1),//百年%4 asm_CLR_C(), asm_RLC_A(), asm_CLR_C(), asm_RLC_A(),//百年%4*4 asm_ORL_A_Rn(macro_U16H_arg1),//百年%4*5 asm_MOV_Rn_A(macro_U16H_arg1),//保存(百年%4*5),最大值3*5=15 //年+年/4 asm_MOV_A_Rn(macro_U16L_arg1),//年 asm_CLR_C(), asm_RRC_A(), asm_CLR_C(), asm_RRC_A(), asm_ADD_A_Rn(macro_U16L_arg1),//年+年/4 asm_MOV_Rn_A(macro_U16L_arg1),//保存(年+年/4),最大值99+25=124 asm_MOV_A_Rn(macro_U8_arg2),//月 asm_MOV_B(13), asm_MUL_AB(),//13*月->A asm_MOV_B(8), asm_ADD_A_B(),//13*月+8 asm_MOV_B(5), asm_DIV_AB(),//(13*月+8)/5 商->A asm_MOV_Rn_A(macro_U8_arg2),//保存((13*月+8)/5)最大值33 //日 asm_ADD_A_Rn(macro_U8_arg3),//日,最大值31 asm_ADDC_A_Rn(macro_U16H_arg1),//(百年%4*5),最大值15 asm_ADDC_A_Rn(macro_U16L_arg1),//(年+年/4),最大值99+25=124 /* 此时ACC最大为15+124+33+31=203, 注意,蔡勒公式内无203.-2*C可能会越界,菜农给出的蔡勒公式完整表述: W = (203+C/4-2*C+Y+Y/4+(13*M+8)/5+D)%7 菜农星期公式: W = ( C%4*5+Y+Y/4+(13*M+8)/5+D)%7 */ asm_MOV_B(7),//取余数%7 asm_DIV_AB(), asm_XCH_A_B(), asm_MOV_Rn_A(macro_U8_Result),//送返回值(星期) macro_return(), //数据区DataBuffer asm_DB(macro_U16H_arg1), asm_DB(macro_U16L_arg1), asm_DB(macro_U8_arg2), asm_DB(macro_U8_arg3) };
|