STM8L152按键程序实现及IO初始化

版权申诉
0 下载量 4 浏览量 更新于2024-10-06 收藏 6.41MB ZIP 举报
资源摘要信息:"本资源涉及STM8L152微控制器的按键程序开发,其中包含了基础的输入输出(IO)初始化方法。STM8L152作为STMicroelectronics(意法半导体)生产的一款8位微控制器,广泛应用于需要低功耗、高效率的嵌入式系统中。该资源主要面向需要对STM8L152进行按键控制程序开发的工程师,或者对按键输入功能感兴趣的嵌入式系统学习者。 STM8L152的特点包括低功耗、高性能的处理器核心,丰富的外设接口,以及灵活的时钟系统,使其能够适应不同的应用场景。在进行按键程序开发时,合理的IO初始化是至关重要的,它为按键检测提供了基本的硬件支持和配置。IO初始化通常涉及到设置GPIO(通用输入输出)引脚的工作模式,如输入、输出、上拉、下拉等,以及配置中断功能,以便在按键被按下时能产生相应的中断信号。 在本资源中,可以预期到将介绍如何利用STM8L152提供的硬件抽象层(HAL)或者直接操作寄存器来完成IO初始化。此外,还可能包含如何编写相应的中断服务例程(ISR),以便在按键动作发生时执行预定义的程序片段,实现按键与系统行为的交互。典型的按键应用示例可能包括开关控制、模式选择、菜单导航等。 开发STM8L152按键程序时,应考虑去抖动技术的应用。由于机械按键在接触时容易产生抖动,直接响应按键可能会导致程序错误地识别多次按键动作,因此软件层面的去抖动处理是必要的。这通常涉及到在检测到按键动作后,程序需要等待一小段时间(软件延时)再确认按键状态,以消除抖动带来的干扰。 为了使开发者更好地理解和应用该资源,可能还会包括如何使用开发工具链,例如IAR Embedded Workbench、ST Visual Develop或者其他集成开发环境(IDE),以及如何通过编程器将编译好的程序烧录到STM8L152的Flash存储中。 总之,此资源是STM8L152按键程序开发的实用指南,它不仅提供了按键程序的实现方法,还可能包含了硬件初始化的细节,以及如何处理按键的软件优化,是嵌入式系统开发者不可或缺的学习材料。"
2023-06-08 上传

int main(int argc, char *argv[]) { ec_param *ecp; sm2_ec_key *key_B; message_st message_data; int type = TYPE_GFp; int point_bit_length = 256; char **sm2_param = sm2_param_recommand; ecp = ec_param_new(); ec_param_init(ecp, sm2_param, type, point_bit_length); key_B = sm2_ec_key_new(ecp); sm2_ec_key_init(key_B, sm2_param_d_B[ecp->type], ecp); memset(&message_data, 0, sizeof(message_data)); sm2_hex2bin((BYTE *)sm2_param_k[ecp->type], message_data.k, ecp->point_byte_length); sm2_bn2bin(key_B->d, message_data.private_key, ecp->point_byte_length); sm2_bn2bin(key_B->P->x, message_data.public_key.x, ecp->point_byte_length); sm2_bn2bin(key_B->P->y, message_data.public_key.y, ecp->point_byte_length); message_data.decrypt = (BYTE *)OPENSSL_malloc(message_data.message_byte_length + 1); memset(message_data.decrypt, 0, message_data.message_byte_length + 1); BIGNUM *P_x; BIGNUM *P_y; //BIGNUM *d; BIGNUM *k; xy_ecpoint *P; xy_ecpoint *xy1; xy_ecpoint *xy2; int pos1; BYTE t; int i; sm2_hash local_C_3; P_x = BN_new(); P_y = BN_new(); k = BN_new(); P = xy_ecpoint_new(ecp); xy1 = xy_ecpoint_new(ecp); xy2 = xy_ecpoint_new(ecp); BN_bin2bn(message_data.public_key.x, ecp->point_byte_length, P_x); BN_bin2bn(message_data.public_key.y, ecp->point_byte_length, P_y); BN_bin2bn(message_data.k, ecp->point_byte_length, k); xy_ecpoint_init_xy(P, P_x, P_y, ecp); xy_ecpoint_mul_bignum(xy1, ecp->G, k, ecp); xy_ecpoint_mul_bignum(xy2, P, k, ecp); char cryptstring[1024]; scanf("%s", cryptstring); / 利用函数sm2_hex2bin将16进制字符串cryptstring转换成二进制流填充到message_data.C里 / / 计算明文长度 message_data.message_byte_length */ message_data.klen_bit = message_data.message_byte_length * 8;(请根据注释补充)

2023-05-26 上传

帮我把缩进修改正确import randomimport curses# 设置窗口s = curses.initscr()curses.curs_set(0)sh, sw = s.getmaxyx()w = curses.newwin(sh, sw, 0, 0)w.keypad(1)w.timeout(100)# 初始化游戏界面score = 0score_str = f"Score: {score}"w.addstr(0, sw//2 - len(score_str)//2, score_str)w.addstr(sh-1, sw-10, "Press 'q' to quit")w.refresh()# 初始化游戏参数snake_x = sw//4snake_y = sh//2snake = [ [snake_y, snake_x], [snake_y, snake_x-1], [snake_y, snake_x-2]]food = [sh//2, sw//2]w.addch(food[0], food[1], curses.ACS_PI)key = curses.KEY_RIGHTwhile True: next_key = w.getch() key = key if next_key == -1 else next_key # 判断是否退出游戏 if key == ord('q'): curses.endwin() quit() # 计算蛇头位置 new_head = [snake[0][0], snake[0][1]] if key == curses.KEY_DOWN: new_head[0] += 1 if key == curses.KEY_UP: new_head[0] -= 1 if key == curses.KEY_LEFT: new_head[1] -= 1 if key == curses.KEY_RIGHT: new_head[1] += 1 # 更新蛇的位置 snake.insert(0, new_head) if snake[0] == food: score += 1 score_str = f"Score: {score}" w.addstr(0, sw//2 - len(score_str)//2, score_str) food = None while food is None: # 随机生成食物的位置 nf = [ random.randint(1, sh-1), random.randint(1, sw-1) ] food = nf if nf not in snake else None w.addch(food[0], food[1], curses.ACS_PI) else: tail = snake.pop() w.addch(tail[0], tail[1], ' ') # 判断游戏是否结束 if snake[0][0] in [0, sh-1] or snake[0][1] in [0, sw-1] or snake[0] in snake[1:]: curses.endwin() quit() # 显示蛇的位置 w.addch(snake[0][0], snake[0][1], curses.ACS_CKBOARD)

2023-06-02 上传

grant execute on dbms_crypto to system; declare input_string VARCHAR2 (200) := 'Secret Message'; output_string VARCHAR2(2000); encrypted_raw RAW(2000); decrypted_raw RAW(2000); num_key_bytes NUMBER := 256/8; key_bytes_raw RAW(32); encryption_type PLS_INTEGER := DBMS_CRYPTO.ENCRYPT_AES256 + DBMS_CRYPTO.CHAIN_CBC + DBMS_CRYPTO.PAD_PKCS5; begin DBMS_OUTPUT.PUT_LINE(input_string); key_bytes_raw := DBMS_CRYPTO.RANDOMBYTES(num_key_bytes); encrypted_raw := DBMS_CRYPTO.ENCRYPT ( src => UTL_I18N.STRING_TO_RAW(input_string, 'AL32UTF8'), typ => encryption_type, key => key_bytes_raw ); decrypted_raw := DBMS_CRYPTO.DECRYPT ( src => encrypted_raw, typ => encryption_type, key => key_bytes_raw ); output_string := UTL_I18N.RAW_TO_CHAR(decrypted_raw, 'AL32UTF8'); DBMS_OUTPUT.PUT_LINE(output_string); end; declare l_src_data varchar2(20); l_type pls_integer :=DBMS_CRYPTO.ENCRYPT_AES128 + DBMS_CRYPTO.CHAIN_CBC + DBMS_CRYPTO.PAD_PKCS5; l_key varchar2(20) :='0123456789123456'; l_encval raw(2000); CURSOR secret_cursor IS select phonenumber from customer; begin OPEN secret_cursor; LOOP FETCH secret_cursor INTO l_src_data; l_encval :=dbms_crypto.encrypt( src=>utl_i18n.string_to_raw(l_src_data,'AL32UTF8'), typ=>l_type, key=>utl_i18n.string_to_raw(l_key,'AL32UTF8')); DBMS_OUTPUT.PUT_LINE (l_encval); EXIT WHEN secret_cursor%NOTFOUND; END LOOP; CLOSE secret_cursor; end; declare ;_src_data row(100) :=hextoraw("190248129038903853275ijdkvjkad'); l_type pls_integer :=dbms_crypto.encrypt_aes128+ + DBMS_CRYPTO.CHAIN_CBC + DBMS_CRYPTO.PAD_PKCS5; l_key varchar2(20) :='0123456789123456'; l_decval raw(200); begin l_decval :=dbms_crypto.decrypt( src=>l_src_data, typ=>l_type, key=>utl_i18n.string_to_raw(l_key,'AL32UTF8')); end; SELECT Price FROM PRODUCT WHERE ProductID = 5;修正这一段代码

2023-05-26 上传