windows 上位机与nvme盘片通讯寻求解答

weixin_43787407 2024-12-28 14:36:50
  1. #include <iostream>
  2. #include <string>
  3. #include <Windows.h>
  4. #include <nvme.h>
  5. using namespace std;
  6. int main()
  7. {
  8. // 打开设备
  9. string devicePath = "\\\\.\\PhysicalDrive0";
  10. HANDLE deviceHandle = CreateFileA(devicePath.c_str(), GENERIC_READ | GENERIC_WRITE,
  11. FILE_SHARE_READ | FILE_SHARE_WRITE, nullptr, OPEN_EXISTING, 0, nullptr);
  12. printf("deviceHandle = %d", deviceHandle);
  13. if (deviceHandle == INVALID_HANDLE_VALUE) {
  14. DWORD error = GetLastError();
  15. cout << "\r\nFailed to open device. Error code: \r\n" << error << endl;
  16. system("pause");
  17. return 0;
  18. }
  19. if (deviceHandle == INVALID_HANDLE_VALUE) {
  20. DWORD error = GetLastError();
  21. cout << "\r\nFailed to open device. Error code: \r\n" << error;
  22. system("pause");
  23. return 0;
  24. }
  25. // 构造协议命令
  26. const int bufferLength = 4096*2;
  27. char* inputbuffer = new char[bufferLength];
  28. char* outputbuffer = new char[bufferLength];
  29. //char outputbuffer[bufferLength];
  30. ZeroMemory(inputbuffer, bufferLength);
  31. ZeroMemory(outputbuffer, bufferLength);
  32. PSTORAGE_PROTOCOL_COMMAND protocolCommand = (PSTORAGE_PROTOCOL_COMMAND)inputbuffer;
  33. protocolCommand->Version = STORAGE_PROTOCOL_STRUCTURE_VERSION;
  34. protocolCommand->Length = sizeof(STORAGE_PROTOCOL_COMMAND);
  35. protocolCommand->ProtocolType = ProtocolTypeNvme;
  36. protocolCommand->Flags = STORAGE_PROTOCOL_COMMAND_FLAG_ADAPTER_REQUEST;
  37. protocolCommand->CommandLength = STORAGE_PROTOCOL_COMMAND_LENGTH_NVME;
  38. protocolCommand->ErrorInfoLength = sizeof(NVME_ERROR_INFO_LOG);
  39. protocolCommand->DataFromDeviceTransferLength = 4096;
  40. protocolCommand->TimeOutValue = 10;
  41. protocolCommand->ErrorInfoOffset = FIELD_OFFSET(STORAGE_PROTOCOL_COMMAND, Command) + STORAGE_PROTOCOL_COMMAND_LENGTH_NVME;
  42. protocolCommand->DataFromDeviceBufferOffset = protocolCommand->ErrorInfoOffset + protocolCommand->ErrorInfoLength;
  43. protocolCommand->CommandSpecific = STORAGE_PROTOCOL_SPECIFIC_NVME_ADMIN_COMMAND;
  44. //NVME_COMMAND_User *command = (PNVME_COMMAND)protocolCommand->Command;
  45. //NVME_COMMAND_User *command = new NVME_COMMAND_User();
  46. PNVME_COMMAND command = (PNVME_COMMAND)protocolCommand->Command;
  47. command->CDW0.OPC = 0x06; // 自定义操作码
  48. command->u.GENERAL.CDW10 = 0x1; // 填充数据
  49. command->u.GENERAL.CDW11 = 0x0;
  50. //command->u.GENERAL.CDW12 = 0x00000000;
  51. //command->u.GENERAL.CDW13 = 0x00000000;
  52. command->u.GENERAL.CDW14 = 0x0;
  53. // 发送命令
  54. DWORD returnedLength = 0;
  55. BOOL result = DeviceIoControl(deviceHandle,
  56. IOCTL_STORAGE_PROTOCOL_COMMAND,
  57. inputbuffer, bufferLength,
  58. inputbuffer, bufferLength,
  59. &returnedLength, nullptr);
  60. cout << "\r\n protocolCommand->ReturnStatus: " << protocolCommand->ReturnStatus<<"\n";
  61. cout << "\r\nresult: " << result<<"\n";
  62. cout << "\rreturnedLength: " << returnedLength<<"\n";
  63. if (!result) {
  64. DWORD error = GetLastError();
  65. cout << "\r\nFailed to send protocol command. Error code: \r\n" << error;
  66. CloseHandle(deviceHandle);
  67. system("pause");
  68. return 0;
  69. }
  70. else
  71. {
  72. cout << "\r\nSuccess to DeviceIoControl.\r\n" << endl;
  73. }
  74. // 打印 outputbuffer 中的数据
  75. cout << "\r\nOutput Buffer: \n";
  76. for (DWORD i = protocolCommand->ErrorInfoOffset + protocolCommand->ErrorInfoLength; i < returnedLength; ++i) {
  77. printf("%02X ", (unsigned char)inputbuffer[i]);
  78. if ((i + 1) % 32 == 0) {
  79. printf("\n"); // 每16个字节换行
  80. //break;
  81. }
  82. }
  83. // 关闭设备句柄
  84. CloseHandle(deviceHandle);
  85. system("pause");
  86. return 0;
  87. }

问题描述:
我打算开发一款上位机程序,通过windows API 的nvme部分下发nvne指令给nvme 盘片,发现有很多问题,,我无法确定这种操作是否可行。(我的代码参考微软nvme部分示例)
 

 

报错内容:

deviceHandle = 180
protocolCommand->ReturnStatus: 0

result: 0
returnedLength: 0

Failed to send protocol command. Error code:
317请按任意键继续. . .
我的初步解决思路是参数配置不对,需要继续修改参数
操作环境是:Windows
软件是visual studio 2022
我的Nvme盘片,支持的协议是M2.0

问题:
1、我想问一下,这个开发可行性怎么样,理论上可以实现不,实际上可以实现不,怎么实现?
2、开发是否需要再开发一款windows pcie驱动,从而配套开发,开发代码怎么写?
3、在visual studio直接调用windows API的话,理论上可以实现不,实际上可以实现不,怎么实现?
4、我的程序代码遇到的问题怎么解决,有没有更好的方式?
备注:希望得到非人工智能的回答方式回复

...全文
给本帖投票
67 回复 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

1,222

社区成员

发帖
与我相关
我的任务
社区描述
C++ Builder Windows SDK/API
社区管理员
  • Windows SDK/API社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧

手机看
关注公众号

关注公众号

客服 返回
顶部