IDA Pro > IDA Pro教程 > 技术问题 > IDA Pro设置功能/项目类型(Set function/item type)

IDA Pro设置功能/项目类型(Set function/item type)

发布时间:2023-04-21 14: 04: 24

Action name:SetType

This command allows you to specify the type of the current item.

If the cursor is located on a name,the type of the named item will be edited.Otherwise,the current function type(if there is a function)or the current item type(if it has a name)will be edited.

The function type must be entered as a C declaration.Hidden arguments(like'this'pointer in C++)should be specified explicitly.IDA will use the type information to comment the disassembly with the information about function arguments.It can also be used by the Hex-Rays decompiler plugin for better decompilation.

Here is an example of a function declaration:

int main(int argc,const char*argv[]);

To delete a type declaration,please enter an empty string.

IDA supports the user-defined calling convention.In this calling convention,the user can explicitly specify the locations of arguments and the return value.For example:

int __usercall func (int x,int y );

denotes a function with 2 arguments:the first argument is passed on the stack(IDA automatically calculates its offset)and the second argument is passed in the ESI register and the return value is stored in the EBX register.Stack locations can be specified explicitly:

int __usercall runtime_memhash <^12.4>(void*p <^0.4>,int q <^4.4>,int r <^8.4>)

There is a restriction for a __usercall function type:all stack locations should be specified explicitly or all are automatically calculated by IDA.General rules for the user defined prototypes are:

-the return value must be in a register.

Exception:stack locations are accepted for the __golang and __usercall calling conventions.

-if the return type is'void',the return location must not be specified

-if the argument location is not specified,it is assumed to be

on the stack;consequent stack locations are allocated for such arguments

-it is allowed to declare nested declarations,for example:

int**__usercall func16 (int*(__usercall*x)

(int,long ,int) );

Here the pointer"x"is passed in the ESI register;

The pointed function is a usercall function and expects its second

argument in the ECX register,its return value is in the EBX register.

The rule of thumb to apply in such complex cases is to specify the

the registers just before the opening brace for the parameter list.

-registers used for the location names must be valid for the current

processor;some registers are unsupported(if the register name is

generated on the fly,it is unsupported;inform us about such cases;

we might improve the processor module if it is easy)

-register pairs can be specified with a colon like

-for really complicated cases this syntax can be used.

IDA also understands the"__userpurge"calling convention.It is the same thing as __usercall,the only difference is that the callee cleans the stack.

The name used in the declaration is ignored by IDA.

If the default calling convention is __golang then explicit specification of stack offsets is permitted.For example:

int __usercall myfunc<^8>(__int64 arg<^0>);

Function declarations may have the __spoils keyword.It is used to specify the list of registers spoiled by the function.The syntax is the following:

int __spoilsfunc(int x);

If the __spoils keyword is present,the specified list overrides the standard spoiled list.For x86,the standard spoiled list is.The list of spoiled registers may be empty.

IDA also understands some attributes in declarations.For example:

__attribute__((format(printf,2,3)))

int myprnt(int id,const char*format,...);

This declaration means that myprnt is a print-like function;the format string is the second argument and the variadic argument list starts at the third argument.

Below is the full list of attributes that can be handled by IDA.Please look up the details in the corresponding compiler help pages.

packed pack structure/union fields tightly,without gaps

aligned specify the alignment

noreturn declare as not returning function

ms_struct use microsoft layout for the structure/union

format possible formats:printf,scanf,strftime,strfmon

The following additional keywords can be used in type declarations:

_BOOL1 a boolean type with explicit size specification(1 byte)

_BOOL2 a boolean type with explicit size specification(2 bytes)

_BOOL4 a boolean type with explicit size specification(4 bytes)

__int8 a integer with explicit size specification(1 byte)

__int16 a integer with explicit size specification(2 bytes)

__int32 a integer with explicit size specification(4 bytes)

__int64 a integer with explicit size specification(8 bytes)

__int128 a integer with explicit size specification(16 bytes)

_BYTE an unknown type;the only known info is its size:1 byte

_WORD an unknown type;the only known info is its size:2 bytes

_DWORD an unknown type;the only known info is its size:4 bytes

_QWORD an unknown type;the only known info is its size:8 bytes

_OWORD an unknown type;the only known info is its size:16 bytes

_TBYTE 10-byte floating point value

_UNKNOWN no info is available

__pure pure function:always returns the same value and does not

modify memory in a visible way

__noreturn function does not return

__usercall user-defined calling convention;see above

__userpurge user-defined calling convention;see above

__spoils explicit spoiled-reg specification;see above

__hidden hidden function argument;this argument was hidden in the

source code(e.g.'this'argument in c++methods is hidden)

__return_ptr pointer to return value;implies hidden

__struct_ptr was initially a structure value

__array_ptr was initially an array

__unused unused function argument

__cppobj a c++style struct;the struct layout depends on this keyword

__ptr32 explicit pointer size specification(32 bits)

__ptr64 explicit pointer size specification(64 bits)

__shifted shifted pointer declaration

__high high level prototype(does not explicitly specify

hidden arguments like'this',for example)

this keyword may not be specified by the user but

IDA may use it to describe high level prototypes

 

以下为中文翻译

操作名称:SetType

此命令允许您指定当前项的类型。

如果光标位于名称上,则将编辑命名项的类型。否则,将编辑当前函数类型(如果有函数)或当前项类型(如果它有名称)。

函数类型必须以C声明的形式输入。

应显式指定隐藏参数(如C++中的“this”指针)。IDA将使用类型信息用函数参数的信息来注释反汇编。Hex Rays反编译器插件也可以使用它来进行更好的反编译。

下面是函数声明的示例:int main(int argc,const char*argv[]);

要删除类型声明,请输入一个空字符串。

IDA支持用户定义的调用约定。在这个调用约定中,用户可以显式指定参数的位置和返回值。例如:int __usercall func (int x,int y );

表示一个有两个参数的函数:第一个参数在堆栈上传递(IDA自动计算其偏移量),第二个参数在ESI寄存器中传递,返回值存储在EBX寄存器中。可以显式指定堆栈位置:int __usercall runtime_memhash <^12.4>(void*p <^0.4>,int q <^4.4>,int r <^8.4>)_

_usercall有限制函数类型:所有堆栈位置都

应该明确指定,或者由IDA自动计算。用户定义原型的一般规则是:-返回值必须在寄存器中。异常:__golang和__usercall调用约定接受堆栈位置。

-如果返回类型为“void”,则不得指定返回位置

-如果未指定参数位置,则假定它

在堆栈上;结果堆栈位置被分配给这样的参数

-允许声明嵌套声明,例如:int**__usercall func16 (int*(__usercall*x)

(int,long ,int) );

在这里,指针“x”是在ESI寄存器中传递的;指向函数是一个用户调用函数

,它的第二个参数在ECX寄存器中,它的返回值在EBX寄存器中。在这种复杂的情况下,经验法则是在参数列表的左大括号之前指定寄存器

用于位置名称的寄存器必须对当前处理器有效;有些寄存器不受支持(如果寄存器名是动态生成的,则不受支持;请告知我们此类情况;如果很容易,我们可能会改进处理器模块)

-寄存器对可以用类似于的冒号指定

-对于非常复杂的情况,可以使用此语法。

IDA还理解“__userpurge”调用约定。它

与__usercall相同,唯一的区别是

被调用者清理

堆栈。IDA忽略声明中使用的名称。

如果默认调用约定是__golang,则

允许显式指定堆栈偏移量。例如:int __usercall myfunc<^8>(__int64 arg<^0>);

函数声明可能包含__proports关键字。它用于指定被函数破坏的寄存器列表。语法如下:int __prets<eax,bh>func(int x);

如果存在__destroys关键字,则指定的列表将覆盖标准

损坏的列表。对于x86,标准的损坏列表是

损坏寄存器的列表可能是空的。

IDA也理解声明中的一些属性。例如:__attribute__((format(printf,2,3)))int myprnt(int id,const char*format,…);

这个声明意味着myprnt是一个类似打印的函数;

formatstring是第二个参数,可变

参数列表从第三个参数开始。下面是IDA可以处理的属性的完整列表。请在相应的编译器帮助页中查找详细信息。压缩包结构/联合字段紧密,没有对齐的间隙指定对齐noreturn声明为不返回函数

ms_struct使用microsoft布局进行结构/联合

格式可能的格式:printf,scanf,strftime,strfmon

以下附加关键字可用于类型声明:_BOOL1具有显式大小规范的布尔类型(1字节)

_BOOL2具有显式尺寸规范的布尔型

(2字节具有显式大小规范(2个字节)__int32具有显式尺寸规范(4个字节)的整数__int64具有显式长度规范(8个字节)__ int128具有显式宽度规范(16个字节)_BYTE为未知类型;唯一已知的信息是其大小:1字节_WORD是未知类型;唯一已知的信息是它的大小:2字节_DWORD是未知类型;唯一已知的信息是它的大小:4字节_QWORD是未知类型;唯一已知的信息是它的大小:8字节

_OWORD是未知类型;唯一已知的信息是它的大小:16字节_TBYTE 10字节浮点值_UNKNOWN没有可用的信息__pure纯函数:总是返回相同的值,并且不以

可见的方式修改内存__noreturn函数不返回

__usercall用户定义的调用约定;参见上面的

__userpurge用户定义调用约定;见上文

__destroys显式损坏的reg规范;请参阅上面的__hidden隐藏函数参数;此参数隐藏在

源代码中(例如,c++方法中的“this”参数隐藏)

__return_ptr指向返回值的指针;暗示隐藏的

__struct_ptr最初是一个结构值

__array_ptr初始是一个数组

__未使用的未使用函数参数

__cppobj是一个c++风格的结构;结构布局依赖于此关键字

__ptr32显式指针大小规范(32位)__ptr64显式指针尺寸规范(64位)__shifted shifted pointer declaration

__high high level prototype(

例如,不显式指定像“this”这样的隐藏参数)此关键字可能不是由用户,但IDA可以使用它来描述高级原型

展开阅读全文

标签:idaida反汇编工具

读者也访问过这里:
邀请您进入交流群 点击扫码
400-8765-888 kefu@makeding.com

专业销售为您服务

欢迎添加好友,了解更多IDA优惠信息,领逆向工程学习资料礼包1份!
热门文章
exe反编译工具哪个好?反编译能力强的工具盘点
随着软件技术的发展,exe(可执行文件)已经成为了电脑、手机等多个平台上的主要软件运行格式,而对于exe文件的反编译也成为了逆向工程中不可缺少的一个步骤。本文将介绍一些常用的exe反编译工具,并评价其优缺点,帮助读者选择合适的工具。
2023-04-12
idapro怎么改为中文
IDA Pro是一款功能强大的反汇编和反编译工具,广泛应用于逆向工程和软件开发领域。在使用IDA Pro时,如果我们不习惯英文界面,可以将其改为中文界面。本文将介绍IDA Pro怎么改为中文界面。IDA Pro界面改成中文主要有两种方法,下面是详细介绍。
2023-04-19
c++反编译工具有哪些
反编译C++代码的工具一般是针对可执行文件和库文件的反汇编和逆向分析工具。本文将给大家介绍c++反编译工具有哪些的内容。市面说的c++反编译工具有很多,下面介绍几款使用认识较多的软件。
2023-04-23
ida怎么查找字符串 ida字符串窗口快捷键
在数字化时代,逆向工程作为解密软件和分析程序的关键技术,正日益受到广泛关注。在逆向分析的过程中,IDA(Interactive DisAssembler)是一款备受推崇的工具,它为逆向工程师们提供了强大的功能和灵活的操作。本文将带您深入探讨如何在IDA中查找字符串,优化字符串窗口的使用,并探讨IDA如何将变量转换成字符串,帮助您更加熟练地驾驭这一工具,为逆向分析的世界增添一抹精彩。
2023-09-27
ida如何转伪代码 ida伪代码怎么看
IDA Pro是一款常用的反汇编和反编译工具,可以帮助我们分析二进制文件的实现细节和执行过程,以便更好地理解程序的执行过程和逻辑。在进行逆向工程的过程中,我们经常需要将反汇编结果转换为伪代码,以便更好地进行分析和修改。本文将介绍如何使用IDA Pro转换为伪代码,并简单讲解ida伪代码怎么看。
2023-04-14
最新文章
IDA Pro动态调试教程需要配哪些环境 IDA Pro动态调试教程里断点通常下在哪里
光靠盯着反汇编和那些近似C语言的伪代码来看,很多分叉的执行路径其实还是很难吃准;所以大家就会关心IDA Pro的动态调试流程到底需要提前配好哪些环境,在实际操作里头断点一般又该下在什么地方比较管用,从自己拥有授权的测试小软件开始练手是一条比较稳当的路。在铺排环境的时候,不妨先把操作系统、处理器架构、程序要用的依赖库和输入文件都一一备齐,然后再顺着软件大致的执行路径,循序渐进地把中断位置加上去;这么做既能比较清楚地观察到程序是怎么跑起来的,也不容易被环境方面的小毛小病把思路搅乱。
2026-06-03
IDA Pro逆向教程练什么样本更合适 IDA Pro逆向教程里先练静态还是动态
刚开始学习IDA Pro的时候,如果一上来就选了过于复杂的样本,很容易就会陷进数量庞大的函数、库代码和异常分支里面,半天都理不出一个清晰的头绪。所以,先得弄明白两个很实际的问题:在IDA Pro的逆向学习过程中,到底该选什么样的样本来练手,以及在整个学习次序上,是应该先练静态分析,还是先练动态调试。一个比较稳妥的起步办法,是从自己动手编译的小型程序开始,先把程序的整体结构看明白,之后再打开调试器去验证自己之前的那些想法。练手用的文件范围,最好就严格限定在自编译程序、公开发布的教学样本,还有已经拿到明确授权的文件上面,不要直接去分析那些没有经过授权的商业软件,也尽量不要随便运行那些来源不明的程序。
2026-06-03
IDA Pro使用教程适合零基础吗 IDA Pro使用教程里哪些窗口最常用
很多人刚接触二进制分析的时候,很容易被IDA Pro的界面弄得不知所措,它的窗口多、地址多,汇编语句也排得密密麻麻。IDA Pro的使用教程到底适不适合零基础呢,答案是可以用来入门,只是不要刚上来就指望能看明白太复杂的样本。官方的入门资料里,也把IDA View、Pseudocode、Hex Dump View、Local Types和Functions View这几个窗口列为了初学者平时用得比较多的。所以零基础阶段最好先学会怎样加载文件、定位函数、查看字符串和跟踪调用关系,然后再逐步去补汇编与数据结构的知识,这样进入状态会更顺畅一些。
2026-06-03
IDA Pro下载教程该看哪个版本 IDA Pro下载教程安装后先检查哪些环境
刚开始使用IDA Pro的时候,要是教程的版本选得不对,后面很容易碰到各种别扭的情况。不同版本的软件,界面菜单的布局、许可证管理的方式、插件该放在哪个目录,还有一些功能入口的位置,都会跟着变化。按照Hex-Rays官方最新的发布记录,IDA 9.3sp1已经当成9.3系列的一个维护版本放出来了,它主要是改进了一下V850反编译器,顺带修了一些别的问题。如果是头一回装IDA,那优先去看9.3系列的教程会更合适;要是手上还在维护一些比较老的工程,那就应该根据机器上实际装的版本来找对应的资料,这样才不容易对不上号。
2026-06-03
IDA中文乱码通常和什么设置有关 IDA中文乱码出现后编码方式该怎么调整
在分析那些带有中文资源、日志文本或者配置内容的程序时,字符串窗口里时不时就会跳出问号、方框,或者干脆是一些没法阅读的字符。要弄清楚IDA里头的中文乱码通常跟哪些设置有关,还有乱码出现后编码方式该怎么去调整,先得分辨清楚这些乱码到底是出现在反汇编里的字符串、是Hex View右侧显示的那部分文本,还是旧数据库里留下来的注释。从7.0版本开始,IDA内部已经统一换成了UTF-8,但被分析的那个程序本身的原始字节,它照样可能用的是GBK、UTF-8、UTF-16LE这些不一样的编码,一旦判断错了,显示出来的东西就会不正常。
2026-06-03
IDA配置文件放在哪个目录 IDA配置文件改错以后怎么回退
很多人改IDA配置时,前面只是想调一个分析选项、界面行为或插件相关参数,结果一改完发现启动表现不对,甚至连原来的习惯都乱了。这个问题往往不是配置项本身有多复杂,而是没先分清IDA的配置文件到底放在安装目录还是用户目录,也没先想好改错以后该从哪一层回退。Hex-Rays官方文档已经把这条线说明白了,配置文件会按固定目录顺序查找,常见文件名也比较明确,所以只要先把目录和优先级理顺,后面的回退动作就会清楚很多。
2026-06-01

通过微信咨询我们

欢迎添加好友,了解更多IDA优惠信息,领取逆向工程学习资料礼包1份!

读者也喜欢这些内容: