All of lore.kernel.org
 help / color / mirror / Atom feed
From: Russell Coker <bofh@coker.com.au>
To: md@Linux.IT
Cc: linux-lvm@sistina.com
Subject: [linux-lvm] Fwd: [md@Linux.IT: LVM tools broken on PPC (and many other archs)]
Date: Sun, 17 Dec 2000 09:17:09 +0100	[thread overview]
Message-ID: <0012170917090F.00774@lyta> (raw)

This is a general LVM driver issue, and therefore something that's more 
appropriate for the main LVM developers to deal with, as don't have access to 
non-Intel hardware and I don't have the knowledge of LVM driver internals 
that these people have it doesn't make sense for me to try and deal with this.

I am sending this message to the LVM mailing list, hopefully someone there 
can resolve this issue.

----------  Forwarded Message  ----------
Subject: [md@Linux.IT: LVM tools broken on PPC (and many other archs)]
Date: Sun, 17 Dec 2000 01:39:48 +0100
From: Marco d'Itri <md@Linux.IT>
To: russell@coker.com.au


Please add this fix to your LVM package, it's needed on most
architectures.

--
ciao,
Marco
Date: Fri, 15 Dec 2000 18:07:27 +0100
From: Marco d'Itri <md@Linux.IT>
To: linux-lvm-patch@ez-darmstadt.telekom.de
Cc: andrea@suse.de
Subject: LVM tools broken on PPC (and many other archs)
Message-ID: <20001215180727.A1985@wonderland.linux.it>
Mime-Version: 1.0
Content-Type: text/plain; charset=us-ascii
Content-Disposition: inline
User-Agent: Mutt/1.3.12i

pv_get_size() tries parsing the MBR, but that fails on PPC because of
the different endianess from what the function expects.

The result is that the tools think the partition is as big as the whole
disk, and everything seems to work until you put enough data in the
file system and some of the non existent blocks are used (the kernel
will complain and return EIO, but at least it does not explode).

From the changelog I see Andrea Arcangeli contributed a very crude
workaround for the alpha platform, which has the same endianess of i386
but (I suppose) a different disk label format.
The same "fix" works for PPC too (and sparc, and so on), so I think the
#ifndef __alpha__ at the beginning of lib/pv_get_size.c should really be
#ifdef __i386__ until some better code is written (FYI, you can find
byte swapping code within fdisk).

The fix needs to be fixed too, because other code will expect something
in the buffer pointed by the second argument. I just added that at the
end of the function:

        if (dummy)
                memset(dummy, 0, sizeof (struct partition));

With this fix, everything seems to work fine.

--
ciao,
Marco

-------------------------------------------------------

-- 
http://www.coker.com.au/bonnie++/     Bonnie++ hard drive benchmark
http://www.coker.com.au/postal/       Postal SMTP/POP benchmark
http://www.coker.com.au/projects.html Projects I am working on
http://www.coker.com.au/~russell/     My home page

             reply	other threads:[~2000-12-17  8:17 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2000-12-17  8:17 Russell Coker [this message]
2000-12-17 11:01 ` [linux-lvm] Fwd: [md@Linux.IT: LVM tools broken on PPC (and many other archs)] Claudio Matsuoka

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=0012170917090F.00774@lyta \
    --to=bofh@coker.com.au \
    --cc=linux-lvm@sistina.com \
    --cc=md@Linux.IT \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.