用途
显示关于对象文件、可执行文件以及对象文件库里的符号信息。
语法
nm [ -A ] [ -C ] [ -X {32|64|32_64}] [ -f ] [ -h ] [ -l ] [ -p ] [ -r ] [ -T ] [ -v ] [ -B | -P ] [ -e | -g | -u ] [ -d | -o | -x | -t Format ] File ...
描述
nm 命令显示关于指定 File 中符号的信息,文件可以是对象文件、可执行文件或对象文件库。如果文件没有包含符号信息,nm 命令报告该情况,但不把它解释为出错条件。 nm 命令缺省情况下报告十进制符号表示法下的数字值。
nm 命令把以下符号信息写入标准输出:
库或对象名
如果您指定了 -A 选项,则 nm 命令只报告与该文件有关的或者库或者对象名。
符号名称
符号类型
nm 命令使用以下符号(用同样的字符表示弱符号作为全局符号)之一来表示文件符号类型:
A Global absolute 符号。
a Local absolute 符号。
B Global bss 符号。
b Local bss 符号。
D Global data 符号。
d Local data 符号。
f 源文件名称符号。
T Global text 符号。
t Local text 符号。
U 未定义符号。
值
大小
如果可应用,nm 命令报告与符号有关的大小。
标志
-A 每行或者显示全路径名称或者显示对象库名。
-B 在 Berkeley 软件分发(BSD)格式中显示输出:
值 类型 名称
-C 限制解码(demangle) C++ 名称。缺省是解码所有 C++ 符号名。
注:
C++ 对象文件中的符号在被使用前它们的名称已经被解码了。
-d 用十进制显示符号的值和大小。这是缺省的。
-e 只显示静态的和外部的(全局)符号。
-f 显示完整的输出,包括冗余的 .text、 .data 以及 .bss 符号,这些在通常都是被限制的。
-g 只显示外部的(全局)符号。
-h 限制输出头数据的显示。
-l 通过给 WEAK 符号的编码键附加一个 * 来区分 WEAK 和 GLOBAL 符号。如果和 -P 选项一起使用, WEAK 符号的符号类型显示如下:
V
Weak Data 符号
W
Weak Text 符号
w
Weak 未定义符号
Z
Weak bss 符号
-o 用八进制而不是十进制数来显示符号的值和大小。
-P 以标准可移植输出格式显示信息:
库/对象名 名称 类型 值 大小
该格式以十六进制符号表示法显示数字值,除非您用 -t、-d 或 -o 标志指定不同的格式。
如果您指定了 -A 标志 -P 标志只显示 库/对象名字段。同样,-P 标志只显示大小适用的符号大小字段。
-p 不排序。输出按符号表顺序打印。
-r 倒序排序。
-T 把可能会溢出它的列的每个名字截短,使显示的名字的最后一个字符是星号(*)。缺省情况下,nm 显示列出的符号的全名,并且一个比为其设置的列的宽度长的名称会引起名称后的每个列无法对齐。
-t Format 显示指定格式下的数字值,其中 Format 参数是以下符号表示法之一:
d
十进制符号表示法。这是 nm 命令的缺省格式。
o
八进制符号表示法。
x
十六进制符号表示法。
-u 只显示未定义符号。
-v 按值而不是按字母表顺序排序输出。
-x 用十六进制而不是十进制数来显示符号的值和大小。
-X mode 指定 nm 应该检查的对象文件的类型。 mode 必须是下列之一:
32
只处理 32 位对象文件
64
只处理 64 位对象文件
32_64
处理 32 位和 64 位对象文件
缺省是处理 32 位对象文件(忽略 64 位对象)。 mode 也可以 OBJECT_MODE 环境变量来设置。例如,OBJECT_MODE=64 使 nm 处理任何 64 位对象并且忽略 32 位对象。 -X 标志覆盖 OBJECT_MODE 变量。
注:
nm 命令支持 -- (双连字符)标志。如果文件名会被曲解为一个选项,该标志区别于 File 操作数。例如,要指定文件名以连字符开始,请使用 -- 标志。
退出状态
该命令返回下列出口值:
0 成功完成。
>0 发生错误。
示例
列出 a.out 对象文件的静态和外部符号,请输入:
nm -e a.out
以十六进制显示符号大小和值并且按值排序符号,请输入:
nm -xv a.out
显示 libc.a 中所有 64 位对象符号,忽略所有 32 位对象:
nm -X64 /usr/lib/libc.a
文件
/usr/ccs/bin/nm 包含 nm 命令。
示例:
程序源码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
|
#include <linux init.h="">
#include <linux module.h="">
#include <linux leds.h="">
#include <linux io.h="">
#include <linux semaphore.h="">
#include <linux kernel.h="">
#include <linux cdev.h="">
#include <linux types.h="">
#include <linux fs.h=""> //register_chrdev_region
#include <mach gpio.h="">
#include <plat mux.h="">
#include <linux gpio.h="">
MODULE_LICENSE(
"Dual BSD/GPL"
);
MODULE_AUTHOR(
"SM"
);
MODULE_VERSION(
"0.0.1"
);
//MODULE_DEVICE("global memory");
MODULE_DESCRIPTION(
"led ..."
);
MODULE_ALIAS(
"LED"
);
/*******************************************/
#define NAME "led"
#define GPIO_TO_PIN(bank, gpio) (32 * (bank) + (gpio))
#define LED_GPIO_1 1
#define LED_PIN_1 24
static
int
major =283;
//定义主设备号
static
struct
class
*led_class;
/*******************************************/
void
led_on(
void
)
{
gpio_set_value(GPIO_TO_PIN(LED_GPIO_1,LED_PIN_1), 1);
}
EXPORT_SYMBOL(led_on);
void
led_off(
void
)
{
gpio_set_value(GPIO_TO_PIN(LED_GPIO_1,LED_PIN_1), 0);
}
EXPORT_SYMBOL(led_off);
void
led_init(
void
)
{
int
result;
/* Allocating GPIOs and setting direction */
gpio_free(GPIO_TO_PIN(LED_GPIO_1,LED_PIN_1));
result = gpio_request(GPIO_TO_PIN(LED_GPIO_1,LED_PIN_1),
"Leds"
);
//usr1
if
(result != 0)
printk(
"gpio_request(%d_%d) failed!\n"
,LED_GPIO_1,LED_PIN_1);
result = gpio_direction_output(GPIO_TO_PIN(LED_GPIO_1,LED_PIN_1), 1);
if
(result != 0)
printk(
"gpio_direction(%d_%d) failed!\n"
,LED_GPIO_1,LED_PIN_1);
}
struct
light_dev
{
struct
cdev cdev;
unsigned
char
value;
};
struct
light_dev *light_devp;
// 打开和关闭函数
int
light_open(
struct
inode *inode,
struct
file *filp)
{
struct
light_dev *dev;
// 获得设备结构体指针
dev = container_of(inode->i_cdev,
struct
light_dev,cdev);
// 让设备结构体作为设备的私有信息
filp->private_data = dev;
return
0;
}
int
light_release(
struct
inode *inode,
struct
file *filp)
{
return
0;
}
// ioctl
long
light_ioctl(
struct
file *filp,unsigned
int
cmd,
unsigned
long
arg)
{
struct
light_dev *dev = filp->private_data;
switch
(cmd)
{
case
0:
dev->value = 0;
led_off();
break
;
case
1:
dev->value = 1;
led_on();
break
;
default
:
return
-ENOTTY;
// break;
}
return
0;
}
//set up the cdev structure for a device
static
void
led_setup_cdev(
struct
cdev* dev,
int
minor,
struct
file_operations *fops)
{
int
err, devno = MKDEV(major,minor);
cdev_init(dev,fops);
dev->owner = THIS_MODULE;
dev->ops = fops;
err = cdev_add(dev,devno,1);
if
(err)
printk(KERN_NOTICE
"Error %d adding led%d"
,err,minor);
}
struct
file_operations light_fops =
{
.owner = THIS_MODULE,
.unlocked_ioctl = light_ioctl,
.open = light_open,
.release = light_release,
};
static
struct
cdev cdev_led;
// 模块加载函数
int
light_init(
void
)
{
int
ret;
dev_t dev = MKDEV(major,0);
led_init();
printk(KERN_ALERT
"led modules is install\n"
);
// ret=register_chrdev(major,NAME,&light_fops);
if
(major)
ret = register_chrdev_region(dev,1,NAME);
else
{
ret = alloc_chrdev_region(&dev,0,1,NAME);
major = MAJOR(dev);
}
if
(ret<0)
{
printk(
"unable to register myled driver!\n"
);
return
ret;
}
printk(KERN_DEBUG
"led device number : %x\n"
,dev);
led_setup_cdev(&cdev_led,0,&light_fops);
led_class = class_create(THIS_MODULE,
"led_class"
);
if
(IS_ERR(led_class))
{
printk(KERN_INFO
"create led class error\n"
);
return
-1;
}
device_create(led_class,NULL,dev,NULL,
"led"
"%d"
,MINOR(dev));
return
0;
}
// 模块卸载函数
void
light_cleanup(
void
)
{
// unregister_chrdev(major,NAME);
device_destroy(led_class,MKDEV(major,0));
class_destroy(led_class);
cdev_del(&cdev_led);
unregister_chrdev_region(MKDEV(major,0),1);
printk(
"Goodbye,cruel world!\n"
);
}
module_init(light_init);
module_exit(light_cleanup);
</linux></plat></mach></linux></linux></linux></linux></linux></linux></linux></linux></linux>
|
结果显示: