Want to win a PS4? Go Premium and enter to win our High-Tech Treats giveaway. Enter to Win


Physical/Logical partition info - how to get?

Posted on 1998-01-24
Medium Priority
Last Modified: 2013-12-03
I have a computer with one hard disk. the disk is splited into two logical drives (C:, D:). I need to write a procedure that retrive this data (one hard disk with two logical drives).
The real task is to know how many hard disks the computer have( IDE or SCSI ) and which logical drive reside in which hard disk.
I know how to do this by reading from the registry in win95, but the NT registry is different from the win95 one, so I can't use this.
I also tried use the DeviceIOCtrl, but failed to make it work right.
There is also an int 21 service that deals with the subject but I couldn't make it work properly.
I already post this question in the delphi section but they helped none. Please answer this only if you REALLY know the answer.
Question by:TheSwine
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
LVL 32

Expert Comment

ID: 1410297
Use the DevIoControl IOCTL_DISK_GET_DRIVE_LAYOUT operation.  This gets you a DRIVE_LAYOUT_INFORMATION structure which points to a series of PARTITION_INFORMATION structutes for each partition.

Author Comment

ID: 1410298
As I wrote before, I failed make this work using DeviceIOControl. I am familiar with everything you wrote, please add some full sample code, Thanks.

Author Comment

ID: 1410299
Adjusted points to 305
Free Backup Tool for VMware and Hyper-V

Restore full virtual machine or individual guest files from 19 common file systems directly from the backup file. Schedule VM backups with PowerShell scripts. Set desired time, lean back and let the script to notify you via email upon completion.  


Expert Comment

ID: 1410300
You might recognize me, cause I already tried to answer your question
in the delphi section.
You see, I am also interessed in solving that problem.
I'm writing here now to keep the question alive ;)
Would you agree to help me solve your problem ?
May you send me the code you already tryed out ?
I will only have time to answer that question next week,
cause for now I still have exams at school :(
Unfortunately I had done a part of the answer yesterday,
but since I'm very new to using NT, I made some changes that
crashed the NT partition, so I lost the code source I wrote in temp ;).
I wrote C++ in parallel with pascal, and I did not get the same
result in pascal. this might be because I had to write the
structures by myself. How do you translate following in pascal ?

partLayout test[1];

partLayout is the type. The msdn says this is a variable array.
How do you make such a thing in pascal?

I'm waiting your suggestions ?


Expert Comment

ID: 1410301
Dear Jeurk,

The partLayout test[1]; code is a generic code that indicates the test variable may contain several partLayout structures attached end to end in the memory: The direct translation is

  test : array[0..0] of partLayout;

but I should see the actual API help fragment to correcly interpret. If need help please give the keyword for WIN32 help


Expert Comment

ID: 1410302
Hi Igor,
Your help is welcome, i'm at school for now.
I'll come back tomorrow and post the structures I need
to be translated.

CU, Jeurk
LVL 15

Accepted Solution

Tommy Hui earned 600 total points
ID: 1410303
Here's some sample code:

void CDrvLayView::AddLine(const CString& msg)
      CRichEditCtrl& ctrl = GetRichEditCtrl();

      long l = ctrl.GetTextLength();
      ctrl.SetSel(l, l);

struct _PTMAP
      int   m_PT;
      char* m_Info;
} g_PTMap[] =
      { PARTITION_ENTRY_UNUSED, "Entry unused" },
      { PARTITION_FAT_12, "Specifies a partition with 12-bit FAT entries" },
      { PARTITION_XENIX_1, "Specifies a Xenix type 1 partition" },
      { PARTITION_XENIX_2, "Specifies a Xenix type 2 partition" },
      { PARTITION_FAT_16, "Specifies a partition with 16-bit FAT entries" },
      { PARTITION_EXTENDED, "Specifies an extended partition entry" },
      { PARTITION_HUGE, "Specifies an MS-DOS V4 huge partition" },
      { PARTITION_IFS, "Specifies an IFS partition" },
      { PARTITION_PREP, "Specifies a PowerPC Reference Platform partition" },
      { PARTITION_UNIX, "Specifies a UNIX partition" },
      { VALID_NTFT, "Specifies an NTFT partition" },
      { PARTITION_XINT13, "Specifies a Windows 95 partition that uses extended int13 services" },
      { PARTITION_XINT13_EXTENDED, "Same as PARTITION_EXTENDED, but uses extended int13 services" },

CString ConvertBool(BOOL b)
      return b ? "True" : "False";

void CDrvLayView::OnDrivesSelChange()
      CString driveLetter =  g_DriveTB->GetCurrentDrive();

      CString msg;
      msg.Format("Changing to %s.\r\n", driveLetter);

      CString drive = "\\\\.\\" + driveLetter;

            OPEN_EXISTING, 0, NULL);

      if (h == INVALID_HANDLE_VALUE)
            msg.Format("Failed to open %s. GetLastError() returned %d\r\n",
                  driveLetter, GetLastError());
            DWORD bytesReturned = 0;

            if (!DeviceIoControl(h, IOCTL_DISK_GET_PARTITION_INFO, NULL, 0,
                  &pi, sizeof(pi), &bytesReturned, NULL))
                  msg.Format("Failed to obtain partition info for %s. GetLastError() returned %d\r\n",
                        driveLetter, GetLastError());
                  msg.Format("Offset at 0x%08X:0x%08X\r\n", pi.StartingOffset.HighPart,

                  msg.Format("Length at 0x%08X:0x%08X\r\n", pi.PartitionLength.HighPart,

                  msg.Format("Number of hidden sectors: %d\r\n", pi.HiddenSectors);

                  msg.Format("Number of partitions: %d\r\n", pi.PartitionNumber);

                  CString partitionType = "Unknown";

                  for (int i = 0; i < sizeof(g_PTMap) / sizeof(g_PTMap[0]); i++)
                        if (pi.PartitionType == g_PTMap[i].m_PT)
                              partitionType = g_PTMap[i].m_Info;

                  msg.Format("Type of partitions: %s\r\n", partitionType);

                  msg.Format("Bootable? %s\r\n", ConvertBool(pi.BootIndicator));

                  msg.Format("Recognized? %s\r\n", ConvertBool(pi.RecognizedPartition));

//                  msg.Format("Rewritable? %s\r\n", ConvertBool(pi.RewritePartition));
//                  AddLine(msg);



Author Comment

ID: 1410304
Thanks tui.
It will take me about a week to check it up cause I'm very busy right now. I'll get back to you in few day's

Featured Post

Tech or Treat! - Giveaway

Submit an article about your scariest tech experience—and the solution—and you’ll be automatically entered to win one of 4 fantastic tech gadgets.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

As more and more people are shifting to the latest .Net frameworks, the windows presentation framework is gaining importance by the day. Many people are now turning to WPF controls to provide a rich user experience. I have been using WPF controls fo…
For most people, the WrapPanel seems like a magic when they switch from WinForms to WPF. Most of us will think that the code that is used to write a control like that would be difficult. However, most of the work is done by the WPF engine, and the W…
This is Part 3 in a 3-part series on Experts Exchange to discuss error handling in VBA code written for Excel. Part 1 of this series discussed basic error handling code using VBA. http://www.experts-exchange.com/videos/1478/Excel-Error-Handlin…
Are you ready to place your question in front of subject-matter experts for more timely responses? With the release of Priority Question, Premium Members, Team Accounts and Qualified Experts can now identify the emergent level of their issue, signal…

618 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question