Re: [OE-core] [PATCH 1/1] ddimage: Support Mac OS

2014-05-27 Thread Darren Hart
On 5/24/14, 7:44, Koen Kooi k...@dominion.thruhere.net wrote:


Op 23 mei 2014, om 06:28 heeft Darren Hart dvh...@linux.intel.com het
volgende geschreven:

 Update the ddimage script to allow it to work on Mac OS too. The biggest
 difference is sysfs vs diskutil and in the syntax of the stat command
 between Mac OS and Linux, unfortunately. Workarounds using ls, cut, and
 columns got really fragile really quickly. Relying on stat and switching
 on uname seemed the more robust solution.
 
 Signed-off-by: Darren Hart dvh...@linux.intel.com
 ---
 scripts/contrib/ddimage | 25 -
 1 file changed, 20 insertions(+), 5 deletions(-)
 
 diff --git a/scripts/contrib/ddimage b/scripts/contrib/ddimage
 index 93ebeaf..b66d0dd 100755
 --- a/scripts/contrib/ddimage
 +++ b/scripts/contrib/ddimage
 @@ -1,7 +1,8 @@
 #!/bin/sh
 
 -#BLACKLIST_DEVICES=/dev/sda /dev/sdb /dev/sdc /dev/sdd /dev/sde
 -BLACKLIST_DEVICES=/dev/sda
 +# Default to avoiding the first two disks on typical Linux and Mac OS
installs
 +# Better safe than sorry :-)
 +BLACKLIST_DEVICES=/dev/sda /dev/sdb /dev/disk1 /dev/disk3

s/disk3/disk2/

Bah, indeed. Local change snuck through in my patch. Thanks. Will correct.


-- 
Darren Hart Open Source Technology Center
darren.h...@intel.com   Intel Corporation



-- 
___
Openembedded-core mailing list
Openembedded-core@lists.openembedded.org
http://lists.openembedded.org/mailman/listinfo/openembedded-core


Re: [OE-core] [PATCH 1/1] ddimage: Support Mac OS

2014-05-24 Thread Koen Kooi

Op 23 mei 2014, om 06:28 heeft Darren Hart dvh...@linux.intel.com het 
volgende geschreven:

 Update the ddimage script to allow it to work on Mac OS too. The biggest
 difference is sysfs vs diskutil and in the syntax of the stat command
 between Mac OS and Linux, unfortunately. Workarounds using ls, cut, and
 columns got really fragile really quickly. Relying on stat and switching
 on uname seemed the more robust solution.
 
 Signed-off-by: Darren Hart dvh...@linux.intel.com
 ---
 scripts/contrib/ddimage | 25 -
 1 file changed, 20 insertions(+), 5 deletions(-)
 
 diff --git a/scripts/contrib/ddimage b/scripts/contrib/ddimage
 index 93ebeaf..b66d0dd 100755
 --- a/scripts/contrib/ddimage
 +++ b/scripts/contrib/ddimage
 @@ -1,7 +1,8 @@
 #!/bin/sh
 
 -#BLACKLIST_DEVICES=/dev/sda /dev/sdb /dev/sdc /dev/sdd /dev/sde
 -BLACKLIST_DEVICES=/dev/sda
 +# Default to avoiding the first two disks on typical Linux and Mac OS 
 installs
 +# Better safe than sorry :-)
 +BLACKLIST_DEVICES=/dev/sda /dev/sdb /dev/disk1 /dev/disk3

s/disk3/disk2/

-- 
___
Openembedded-core mailing list
Openembedded-core@lists.openembedded.org
http://lists.openembedded.org/mailman/listinfo/openembedded-core


[OE-core] [PATCH 1/1] ddimage: Support Mac OS

2014-05-22 Thread Darren Hart
Update the ddimage script to allow it to work on Mac OS too. The biggest
difference is sysfs vs diskutil and in the syntax of the stat command
between Mac OS and Linux, unfortunately. Workarounds using ls, cut, and
columns got really fragile really quickly. Relying on stat and switching
on uname seemed the more robust solution.

Signed-off-by: Darren Hart dvh...@linux.intel.com
---
 scripts/contrib/ddimage | 25 -
 1 file changed, 20 insertions(+), 5 deletions(-)

diff --git a/scripts/contrib/ddimage b/scripts/contrib/ddimage
index 93ebeaf..b66d0dd 100755
--- a/scripts/contrib/ddimage
+++ b/scripts/contrib/ddimage
@@ -1,7 +1,8 @@
 #!/bin/sh
 
-#BLACKLIST_DEVICES=/dev/sda /dev/sdb /dev/sdc /dev/sdd /dev/sde
-BLACKLIST_DEVICES=/dev/sda
+# Default to avoiding the first two disks on typical Linux and Mac OS installs
+# Better safe than sorry :-)
+BLACKLIST_DEVICES=/dev/sda /dev/sdb /dev/disk1 /dev/disk3
 
 # 1MB blocksize
 BLOCKSIZE=1048576
@@ -14,9 +15,15 @@ image_details() {
IMG=$1
echo Image details
echo =
-   echo image: $(stat --printf '%N\n' $IMG)
-   echo  size: $(stat -L --printf '%s bytes\n' $IMG)
-   echo  modified: $(stat -L --printf '%y\n' $IMG)
+   echo image: $(basename $IMG)
+   # stat format is different on Mac OS and Linux
+   if [ $(uname) = Darwin ]; then
+   echo  size: $(stat -L -f '%z bytes' $IMG)
+   echo  modified: $(stat -L -f '%Sm' $IMG)
+   else
+   echo  size: $(stat -L -c '%s bytes' $IMG)
+   echo  modified: $(stat -L -c '%y' $IMG)
+   fi
echo  type: $(file -L -b $IMG)
echo 
 }
@@ -27,6 +34,14 @@ device_details() {
 
echo Device details
echo ==
+
+   # Collect disk info using diskutil on Mac OS
+   if [ $(uname) = Darwin ]; then
+   diskutil info $DEVICE | egrep (Device Node|Media Name|Total 
Size)
+   return
+   fi
+
+   # Default / Linux information collection
echo   device: $DEVICE
if [ -f /sys/class/block/$DEV/device/vendor ]; then
echo   vendor: $(cat /sys/class/block/$DEV/device/vendor)
-- 
1.9.1

-- 
___
Openembedded-core mailing list
Openembedded-core@lists.openembedded.org
http://lists.openembedded.org/mailman/listinfo/openembedded-core