首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

软件调试详解

首发于奇安信攻防社区:https://forum.butian.net/share/1478 前言 在windows里面调试跟异常息息相关,如果想要对调试得心应手,异常处理的知识是必不可少的,本文主要介绍的是软件调试方面的有关知识...,讲解调试程序和被调试程序之间如何建立联系 调试对象 调试器和被调试程序 调试器与被调试程序之间建立起联系的两种方式 CreateProcess DebugActiveProcess 与调试器建立连接...,这里就要找真正的地址 获取到调试对象的地址之后还是存到ebp+Process的地方,这里之前是被调试对象的地址,现在存储的是调试对象的地址 将调试进程和被调试的PEPROCESS传入_DbgkpSetProcessDebugObject...,将调试对象和被调试进程关联起来 跟进函数,发现有判断DebugPort是否为0的操作,ebx为0,edi为被调试进程的EPROCESS,那么edi+0bc就是调试端口 然后再把调试对象的句柄放到被调试对象的...DbgkSendApiMessage是调试事件收集的总入口,如果在这里挂钩子,调试器将无法调试

64610

软件调试详解

前言 在windows里面调试跟异常息息相关,如果想要对调试得心应手,异常处理的知识是必不可少的,本文主要介绍的是软件调试方面的有关知识,讲解调试程序和被调试程序之间如何建立联系 调试对象 调试器和被调试程序..., 第一个参数为被调试对象的句柄,第二个参数为调试器的句柄 执行ObReferenceObjectByHandle,把被调试进程的句柄放到第五个参数里面,这里eax本来存储的是调试器的EPROCESS...,这里就要找真正的地址 获取到调试对象的地址之后还是存到ebp+Process的地方,这里之前是被调试对象的地址,现在存储的是调试对象的地址 将调试进程和被调试的PEPROCESS传入_DbgkpSetProcessDebugObject...,将调试对象和被调试进程关联起来 跟进函数,发现有判断DebugPort是否为0的操作,ebx为0,edi为被调试进程的EPROCESS,那么edi+0bc就是调试端口 然后再把调试对象的句柄放到被调试对象的...DbgkSendApiMessage是调试事件收集的总入口,如果在这里挂钩子,调试器将无法调试

52400

cuda编程基础(编程软件有哪些)

CUDA编程(一) 第一个CUDA程序 Kernel.cu CUDA是什么? CUDA(Compute Unified Device Architecture),是显卡厂商NVIDIA推出的运算平台。...CUDA安装 CUDA发展到现在说实话已经比较成熟了,当然在使用的时候偶尔会出现各种各样的问题(充满血与泪),但就谈安装来说已经很简单了,这里以VS2013和CUDA 7.0为例(现在已经到CUDA7.5...首先我们随便用搜索引擎搜索CUDA就会找到CUDA Toolkit的下载首页: https://developer.nvidia.com/cuda-downloads 之后选择系统下载就好: 下载结束之后一路安装就好...总之大家看到我遇到的奇葩问题就知道了,这玩意有时候还是很脆弱的,什么杀毒软件,系统更新啥的都可能随时干掉你的CUDA,所以防患于未然还是把这些玩意都关了吧。...总结: 再写下去篇幅就太长了,本篇博客主要还是介绍了CUDA的安装以及一些基本的CUDA的架构,大家趁着CUDA安装的空可以仔细看一下CUDA的结构,这对后面的编程还是很重要的,下面我会从一个很小的程序写起

2.7K10

软件调试的技巧

调试bug的九个规则列举如下,建议将这个清单打印出来,摆放在工作时候能看到的地方。 ?...调试九法 调试规则 接下来一次看下每个规则的核心理念,从名字上来看,每个规则看起来都比较明显(PS:由于翻译的问题,有些词可能没那么容易理解),但是理解这些规则和应用这些规则中间还是差了很多距离的。...在软件世界里,观察意味着设置断点、添加调试语句、监视程序值以及检查内存;在医学领域,需要测试血样和进行X光透视。 对细节的观察应该到什么程度合适呢?...在系统设计的时候,就要考虑到将来调试、排查问题的情况,将日志视为系统设计的一部分—打印一些关键日志,或者设计一些打开日志的开关,以便在生产环境针对某个case进行调试。...修复bug(解决问题)的能力,是软件工程师的核心竞争力之一。

81520

双机调试Linux内核

利用KGDB双机调试内核 1.1. 环境 1.2. 配置内核编译环境 2. 参考 双机调试Linux内核环境配置。...利用KGDB双机调试内核 环境 centos 7 VMware 全程使用root用户 配置内核编译环境 这种方式调试内核需要两台机器,一台用来运行Linux内核,另一台对内核进行调试。...可以开两个Linux系统的虚拟机;也可以在物理机系统是linux上面装虚拟机,然后虚拟机运行一个linux;再就是买开发板来调试内核。以下是在windows上开两个虚拟机的流程描述。...在https://www.kernel.org/ 下载想调试版本的内核代码(可以下载tarball格式)。...(我测试ttyS0不行,改成ttyS1可以了) 参考 http://blog.nsfocus.net/gdb-kgdb-debug-application/ 在VMware中用Kgdb调试linux内核

4.6K30

Linux调试工具

Linux下的调试工具 随着XP的流行,人们越来越注重软件的前期设计、后期的实现,以及贯穿于其中的测试工作,经过这个过程出来的自然是高质量的软件。甚至有人声称XP会淘汰调试器!...数Linux世界中少数有图形界面的程序调试工具 跨平台Web抓包分析工具 Rythem Rythem是什么 Rythem是一个与Fiddler同类的软件,和Fiddler一样具有 代理抓包/...它是一个受通用公共许可证即GPL保护的自由软件。 象所有的调试器一样,GDB可以让你调试一个程序,包括让程序在你希望的地方停下,此时 你可以查看变量,寄存器,内存及堆栈。...这些反调试技巧经常被恶意软件使用,干扰调试器工作或动态行为分析工作。...这些反调试技巧经常被恶意软件使用,干扰调试器工作或动态行为分析工作。(文/pulog) ?

9.8K43

VScode调试Linux详解

Linux上通常使用gdb命令行调试,但该方式调试不太直观,且命令行长时间不用,容易忘记,不如GUI直观和容易上手,下面介绍基于GUI的方式调试Linux。...一.Linux调试GUI方案简介 1)    Visual studio 远程调试Linux      在VS2015版本以后Visual studio就支持Linux的编译和调试。...使用熟悉的windows界面开发和调试Linux,极大的提高了开发效率,可以广泛应用的Linux服务器开发和嵌入式Linux开发。 ...本地调试Linux         因为QtCreator是跨平台的,安装一个带GUI的linux系统,就可以像VS一样开发和调试 4)    基于eclipse 远程调试Linux        ...二.基于vscode ssh远程调试Linux实战 1   软件安装 1)服务器安装gdb 注意我们是ssh+vscode方式,没有用到gdbserver,故不需要安装gdbserver。

3.7K30

Linux系统CUDA10.2+CUDNN安装教程

这里主要针对驱动已经安装好了的环境,如何安装合适的显卡驱动这里不多赘述,本文演示的系统为Ubuntu18.04,但理论上其他Linux发行版操作类似。...CUDNN的下载也类似,链接也给出,这个下载需要注册开发者账号(简单几步注册登录即可),然后如下图选择合适的CUDA版本对应的CUDNN并选择CUDNN Library for Linux。...CUDA_HOME=$CUDA_HOME:/usr/local/cuda 此时,输入nvcc -V检查安装是否成功,如下图则表示安装成功。...CUDNN安装 切换到cudnn文件所在目录,通过tar -xzvf cudnn-10.2-linux-x64-v7.6.5.32.tgz命令解压文件,会得到一个cuda文件夹,逐一执行下面的命令进行cudnn...sudo cp cuda/include/cudnn.h /usr/local/cuda/include/ sudo cp cuda/lib64/libcudnn* /usr/local/cuda/lib64

4.2K10

ubuntu卸载cuda10.2_dpkg强制卸载软件

,最好安装高版本的,这样不会受cuda版本的影响; 三、run方式 卸载用run方式安装的CUDA和驱动 参考资料 ubuntu完全卸载CUDA # cuda10.0及以下的卸载 cd /usr/local...,否则可能会安装旧版本的显卡驱动,导致重复登录的情况) Install NVIDIA Accelerated Graphics Driver for Linux-x86_64 410.48?.../cuDNN相关查询 测试cuDNN是否安装成功 参考博客 显卡/cudn/cuDNN相关查询 七、可能出现的问题 无法定位软件包 解决办法: (1)解压deb文件,找到cuda-10-0-.../sources.list.d/cuda-10-0-local-10.0.130-410.48.list (2)手动添加ppa源 软件和更新,其他软件,添加 下载显卡驱动超时 已下载 8,379 kB,...nvidia-graphics-drivers-410/nvidia-410_410.78-0ubuntu0~gpu16.04.1_amd64.deb 连接超时 [IP: 91.189.95.85 80] 失败 E: 有几个软件包无法下载

1.6K30

LinuxLinux调试器-gdb使用

前言 在前面的博客【Linux】编译器-gcc/g++使用已经分享了关于编译器的使用,而编译器的使用离不开调试,这次就来分享一下Linux调试器-gdb使用。 2....调试前准备 要调试就得先有代码,先用C语言写一段简单的代码myprocess.c,再写好Makefile: myprocess.c代码: 1 #include 2 3...myprocess:myprocess.c 2 gcc -o $@ $^ 3 .PHONY:clean 4 clean: 5 rm -f myprocess make一下没有问题: 在vs发布软件有两种模式一种是...测试用的是debug,可以被跳绳,而开发出来的release版本,是不可以调试的。 在debug版本中,编译器形成可执行程序的时候,会给可执行程序添加调试信息。...这个run的功能就类似于VS里面的F5,直接运行不调试

14910
领券