最近遇到一个使用aarch64_be-gcc编译的ssh服务器出现不能通过ssh1协议使用密钥+passphrase不能正常登陆的问题。

(⊙o⊙)…不要奇怪为啥还在用SSH1,我也在奇怪。。

一顿捣鼓(重现问题),发现是64位的ssh-keygen生成的密钥的不能使用设置passphrase解密,于是问题就好办了,用x86_64的ssh-keygen生成一个密钥使用,ok,正常登陆了。

那么问题就结束了嘛,当然没有,怎么也得看一下为啥arm64的ssh-keygen就不正常了。

于是编译一个debug版本,去掉-O3优化,aarch64_be-gcc的-O3优化相当crazy,已经给我造成成吨的伤害了。。。

调试发现:

 Breakpoint 5, sshkey_private_rsa1_to_blob (key=0x556955a610,
blob=0x556955ad60, passphrase=0x556955ac20 "123456",
comment=0x7fffffc758 "root@trait") at sshkey.c:3474
3474 sshkey.c: No such file or directory.
(gdb) p cp
$10 = (u_char *) 0x556955aaa0 ">*"
(gdb) n
3482 in sshkey.c
(gdb) p cp
$11 = (u_char *) 0x556955aaa0 ">*>*"
(gdb) n
3483 in sshkey.c
(gdb) n
3482 in sshkey.c
(gdb) n
3484 in sshkey.c
(gdb) n
3483 in sshkey.c
(gdb) n
3485 in sshkey.c
(gdb) n
3484 in sshkey.c
(gdb) n Breakpoint 6, sshkey_private_rsa1_to_blob (key=0x556955a610,
blob=0x556955ad60, passphrase=0x556955ac20 "123456",
comment=0x7fffffc758 "trait@trait") at sshkey.c:3489
3489 in sshkey.c
(gdb) p cp
$12 = (u_char *) 0x556955aaa0 ""
(gdb) p buf
$13 = "\000\000\000UiU\255`"
(gdb) n
3490 in sshkey.c
(gdb) p buf
$14 = "\000\000\000\000\000\000\000"
(gdb) p cp
$15 = (u_char *) 0x556955aaa0 ""
(gdb) bt
#0 sshkey_private_rsa1_to_blob (key=0x556955a610, blob=0x556955ad60,
passphrase=0x556955ac20 "123456", comment=0x7fffffc758 "trait@trait")
at sshkey.c:3490
#1 0x00000055694fef48 in sshkey_private_to_fileblob (key=0x556955a610,
blob=0x556955ad60, passphrase=0x556955ac20 "123456",
comment=<optimized out>, force_new_format=<optimized out>,
new_format_cipher=<optimized out>, new_format_rounds=<optimized out>)
at sshkey.c:3610
#2 0x0000005569505024 in sshkey_save_private (key=0x556955a610,
filename=0x5569553168 <identity_file> "testpass1",
passphrase=0x556955ac20 "123456", comment=0x7fffffc758 "trait@trait",
force_new_format=0, new_format_cipher=0x0, new_format_rounds=0)
at authfile.c:85
#3 0x00000055694f6f30 in main (argc=<optimized out>, argv=0x3d4)
at ssh-keygen.c:2672

发现cp这个变量变成空字符串了,这里openssh的代码我就不分析了,因为我也没这么读,完全是因为这个三不管的ssh服务出问题了。

这么就变成空的了呢。。。

在X86的虚拟机上面也调试了一下:

 Breakpoint 1, sshkey_private_rsa1_to_blob (key=0x17c658, blob=0x17eaf8, passphrase=0x17ee20 "123456", comment=0xbffff139 "trait@trait")
at sshkey.c:3449
3449 {
(gdb) b sshkey.c:3490
Breakpoint 2 at 0x11dbea: file sshkey.c, line 3490.
(gdb) c
Continuing. Breakpoint 2, sshkey_private_rsa1_to_blob (key=0x17c658, blob=0x17eaf8, passphrase=0x17ee20 "123456", comment=0xbffff139 "trait@trait")
at sshkey.c:3490
3490 if ((r = sshbuf_put(buffer, buf, 8 - (sshbuf_len(buffer) % 8))) != 0)
(gdb) p cp
$1 = (u_char *) 0x17eb28 "\310\065\327\267\310\065\327\267 \353\027"
(gdb) bt
#0 sshkey_private_rsa1_to_blob (key=0x17c658, blob=0x17eaf8, passphrase=0x17ee20 "123456", comment=0xbffff139 "trait@trait") at sshkey.c:3490
#1 0x001244a5 in sshkey_private_to_fileblob (key=0x17c658, blob=0x17eaf8, passphrase=0x17ee20 "123456", comment=0xbffff139 "trait@trait",
force_new_format=0, new_format_cipher=0x0, new_format_rounds=0) at sshkey.c:3610
#2 0x0012d250 in sshkey_save_private (key=0x17c658, filename=0x17a0e0 "testpass", passphrase=0x17ee20 "123456", comment=0xbffff139 "trait@trait",
force_new_format=0, new_format_cipher=0x0, new_format_rounds=0) at authfile.c:85
#3 0x0011be51 in main (argc=1398664, argv=0xbffff618) at ssh-keygen.c:2672 Breakpoint 1, sshkey_private_rsa1_to_blob (key=0x17c658, blob=0x17eaf8, passphrase=0x17ee20 "123456", comment=0xbffff139 "trait@trait")
at sshkey.c:3449
3449 {
(gdb) b sshbuf.c:350
Breakpoint 3 at 0x11c9e5: file sshbuf.c, line 350.
(gdb) c
Continuing.

同样的代码,不同的结果,好吧

继续调试arm64的版本:

 Breakpoint 9, sshbuf_reserve (buf=0x5584d5c2e0, len=258, dpp=0x7fffffba60)
at sshbuf.c:347
347 in sshbuf.c
(gdb) p (u_char *) 0x5584d5baa0
$36 = (u_char *) 0x5584d5baa0 "\322\316\322\316"
(gdb) n
348 in sshbuf.c
(gdb) n
350 in sshbuf.c
(gdb) p (u_char *) 0x5584d5baa0
$37 = (u_char *) 0x5584d5baa0 "\322\316\322\316"
(gdb) n
356 in sshbuf.c
(gdb) p (u_char *) 0x5584d5baa0
$38 = (u_char *) 0x5584d5baa0 ""
(gdb) p rlen
$39 = 512
(gdb) p buf->d
$40 = (u_char *) 0x5584d5baa0 ""
(gdb) p dp
$41 = (u_char *) 0x5584d5cf70 "\322\316\322\316"

上面的cp指针与buf->d是同一个地址。openssh6.9p1 代码如下:

 if ((dp = realloc(buf->d, rlen)) == NULL) {
SSHBUF_DBG(("realloc fail"));
if (dpp != NULL)
*dpp = NULL;
return SSH_ERR_ALLOC_FAIL;
}

发现buf->d拷贝给了dp,但是自己内容被清空了,于是查看realloc的说明,只有一种情况貌似符合这种情况,就是buf->d指向的内存区域被移动了,这会是谁干的?realloc???

realloc在aarch64_be-gcc的奇怪表现的更多相关文章

  1. jQuery toggle方法的一个奇怪表现。

    function buildTree() { //$('.tree li:has(ul)').addClass('parent_li').find(' > span').attr('title' ...

  2. JS与Jquery学习笔记(一)

    一. Javascript的作用域,大坑! 1. JS作用域奇怪表现之一:预编译 在其他的语言里我们如果使用一个变量在声明其之前,是会报错的,但是在js里面却不一定,比如: function f1() ...

  3. css 用direction来改变元素水平方向,价值研究。

    "direction"有两个值:ltr | rtl ltr:从左往右 rtl:从右往左 默认:ltr 一起看个效果就懂了. <style> div{ direction ...

  4. 深入理解javascript 中的 delete(转)

    在这篇文章中作者从<JavaScript面向对象编程指南>一书中关于 delete 的错误讲起,详细讲述了关于 delete 操作的实现, 局限以及在不同浏览器和插件(这里指 firebu ...

  5. CSS浏览器兼容的那些事儿

    1.文字本身的大小不兼容.同样是font-size:14px的宋体文字,在不同浏览器下占的空间是不一样的,ie下实际占高16px,下留白3px,ff下实际占高17px,上留白1px,下留白3px,op ...

  6. 浏览器的不兼容,归纳几点html编码要素

    1.文字本身的大小不兼容.同样是font-size:14px的宋体文字,在不同浏览器下占的空间是不一样的,ie下实际占高16px,下留白3px,ff下实际占高17px,上留白1px,下留白3px,op ...

  7. javascript之delete操作符

    理解delete 理论 代码段的类型 执行上下文 活动对象 / 变量对象 属性的特性 内置属性与 DontDelete 未声明的赋值 Firebug的困惑 在eval中删除变量 浏览器兼容性 Geck ...

  8. esnext:Function.prototype.toString 终于有规范了

    从 ES1 到 ES5 的这 14 年时间里,Function.prototype.toString 的规范一字未变: An implementation-dependent representati ...

  9. 谈谈 TCP 的 TIME_WAIT

    由来 最近有同事在用 ab 进行服务压测,到 QPS 瓶颈后怀疑是起压机的问题,来跟我借测试机,于是我就趁机分析了一波起压机可能成为压测瓶颈的可能,除了网络 I/O.机器性能外,还考虑到了网络协议的问 ...

随机推荐

  1. 第6章 新建工程-寄存器版—零死角玩转STM32-F429系列

    第6章     新建工程—寄存器版 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.com/fireg ...

  2. Webpack4 学习笔记一初探Webpack

    前言 此内容是个人学习笔记,以便日后翻阅.非教程,如有错误还请指出 Webpack 打包文件 支持JS模块化 模式: production(0配置默认), development(生产环境) 更详细的 ...

  3. 第34-3题:LeetCode437. Path Sum III

    题目 二叉树不超过1000个节点,且节点数值范围是 [-1000000,1000000] 的整数. 示例: root = [10,5,-3,3,2,null,11,3,-2,null,1], sum ...

  4. org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'transactionManager' defined in class path resource [spring/applicationContext-service.xml]: Cannot resolve refer

    <!-- aop --> <aop:config> <aop:pointcut expression="execution(* com.zsn.Service. ...

  5. Java - 静态方法的线程安全问题

    若该静态方法中有对某个静态属性操作,那么它就不是线程安全的,反之,若只对实例属性操作,那么它就是线程安全的.     补充说明,因为,静态方法不对特定的实例操作,只能访问静态成员.实例方法可对特定的实 ...

  6. Java中使用webSocket

    Java中使用webSocket package com.yaoqi.controller.message; import javax.websocket.*; import javax.websoc ...

  7. FullCalendar日历插件(中文API)

    FullCalendar提供了丰富的属性设置和方法调用,开发者可以根据FullCalendar提供的API快速完成一个日历日程的开发,本文将FullCalendar的常用属性和方法.回调函数等整理成中 ...

  8. PHP开发搭建环境二:开发工具PhpStorm安装、激活以及配置

    关于php的开发工具很多,目前市面上最好用最强大的莫过于PhpStorm这款开发神器了,但是鉴于很多开发者朋友在网站上下载的PhpStorm开发工具不能用,或者使用起来很不方便,笔者把最好用的下载地址 ...

  9. 裸机——LCD

    1.先了解显示器们 CRT显示器 原理,使用电子轰击荧光粉实现显示. 特点,主动发光,颜色绚丽,但是大. 等离子显示器(PDP) 原理,在显示屏上排列上千个密封的小低压气体室,通过电流激发使其发出肉眼 ...

  10. html_parser.py

    coding=UTF-8 # HTML解释器 import re from bs4 import BeautifulSoup class htmlParser(): def parse(self, u ...