mirror of
https://github.com/motioneye-project/motioneyeos.git
synced 2025-07-30 14:46:31 +00:00
raspberrypi-usbboot: new package
This new package currently installs the "rpiboot" utility, which is needed to access via USB mass storage the built-in eMMC of Raspberry Pi compute modules. Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com> Signed-off-by: Peter Korsgaard <peter@korsgaard.com>
This commit is contained in:
parent
404413ec0a
commit
4c4756be6b
@ -36,6 +36,7 @@ menu "Host utilities"
|
|||||||
source "package/pru-software-support/Config.in.host"
|
source "package/pru-software-support/Config.in.host"
|
||||||
source "package/pwgen/Config.in.host"
|
source "package/pwgen/Config.in.host"
|
||||||
source "package/qemu/Config.in.host"
|
source "package/qemu/Config.in.host"
|
||||||
|
source "package/raspberrypi-usbboot/Config.in.host"
|
||||||
source "package/sam-ba/Config.in.host"
|
source "package/sam-ba/Config.in.host"
|
||||||
source "package/squashfs/Config.in.host"
|
source "package/squashfs/Config.in.host"
|
||||||
source "package/sunxi-tools/Config.in.host"
|
source "package/sunxi-tools/Config.in.host"
|
||||||
|
@ -0,0 +1,28 @@
|
|||||||
|
From 5b015e67af27679f4ca8f7f5f2f71020ec054b0c Mon Sep 17 00:00:00 2001
|
||||||
|
From: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
|
||||||
|
Date: Fri, 2 Dec 2016 23:09:44 +0100
|
||||||
|
Subject: [PATCH] Makefile: allow passing CFLAGS/LDFLAGS
|
||||||
|
|
||||||
|
This might be needed to pass some custom CFLAGS/LDFLAGS when building
|
||||||
|
rpiboot.
|
||||||
|
|
||||||
|
Submitted-upstream: https://github.com/raspberrypi/usbboot/pull/2
|
||||||
|
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
|
||||||
|
---
|
||||||
|
Makefile | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/Makefile b/Makefile
|
||||||
|
index 3e7d1e4..d9a7220 100755
|
||||||
|
--- a/Makefile
|
||||||
|
+++ b/Makefile
|
||||||
|
@@ -1,5 +1,5 @@
|
||||||
|
rpiboot: main.c
|
||||||
|
- $(CC) -g -o $@ $< -lusb-1.0
|
||||||
|
+ $(CC) -g $(CFLAGS) -o $@ $< -lusb-1.0 $(LDFLAGS)
|
||||||
|
|
||||||
|
install: rpiboot
|
||||||
|
cp rpiboot /usr/bin
|
||||||
|
--
|
||||||
|
2.7.4
|
||||||
|
|
@ -0,0 +1,49 @@
|
|||||||
|
From 905bc741b189d67160b27551b8ad01459c2707a0 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
|
||||||
|
Date: Fri, 2 Dec 2016 23:10:37 +0100
|
||||||
|
Subject: [PATCH] Makefile: add DESTDIR support
|
||||||
|
|
||||||
|
This allows installing rpiboot outside of /usr if needed.
|
||||||
|
|
||||||
|
Submitted-upstream: https://github.com/raspberrypi/usbboot/pull/2
|
||||||
|
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
|
||||||
|
---
|
||||||
|
Makefile | 20 ++++++++++----------
|
||||||
|
1 file changed, 10 insertions(+), 10 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/Makefile b/Makefile
|
||||||
|
index d9a7220..7835b7f 100755
|
||||||
|
--- a/Makefile
|
||||||
|
+++ b/Makefile
|
||||||
|
@@ -2,18 +2,18 @@ rpiboot: main.c
|
||||||
|
$(CC) -g $(CFLAGS) -o $@ $< -lusb-1.0 $(LDFLAGS)
|
||||||
|
|
||||||
|
install: rpiboot
|
||||||
|
- cp rpiboot /usr/bin
|
||||||
|
- mkdir -p /usr/share/rpiboot
|
||||||
|
- cp usbbootcode.bin /usr/share/rpiboot
|
||||||
|
- cp msd.elf /usr/share/rpiboot
|
||||||
|
- cp buildroot.elf /usr/share/rpiboot
|
||||||
|
+ cp rpiboot $(DESTDIR)/usr/bin
|
||||||
|
+ mkdir -p $(DESTDIR)//usr/share/rpiboot
|
||||||
|
+ cp usbbootcode.bin $(DESTDIR)/usr/share/rpiboot
|
||||||
|
+ cp msd.elf $(DESTDIR)/usr/share/rpiboot
|
||||||
|
+ cp buildroot.elf $(DESTDIR)/usr/share/rpiboot
|
||||||
|
|
||||||
|
uninstall:
|
||||||
|
- rm -f /usr/bin/rpiboot
|
||||||
|
- rm -f /usr/share/rpiboot/usbbootcode.bin
|
||||||
|
- rm -f /usr/share/rpiboot/msd.elf
|
||||||
|
- rm -f /usr/share/rpiboot/buildroot.elf
|
||||||
|
- rmdir --ignore-fail-on-non-empty /usr/share/rpiboot/
|
||||||
|
+ rm -f $(DESTDIR)/usr/bin/rpiboot
|
||||||
|
+ rm -f $(DESTDIR)/usr/share/rpiboot/usbbootcode.bin
|
||||||
|
+ rm -f $(DESTDIR)/usr/share/rpiboot/msd.elf
|
||||||
|
+ rm -f $(DESTDIR)/usr/share/rpiboot/buildroot.elf
|
||||||
|
+ rmdir --ignore-fail-on-non-empty $(DESTDIR)/usr/share/rpiboot/
|
||||||
|
|
||||||
|
clean:
|
||||||
|
rm rpiboot
|
||||||
|
--
|
||||||
|
2.7.4
|
||||||
|
|
@ -0,0 +1,127 @@
|
|||||||
|
From 935894908dc24acda0acea7d211a9d80e55ecadb Mon Sep 17 00:00:00 2001
|
||||||
|
From: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
|
||||||
|
Date: Fri, 2 Dec 2016 23:43:23 +0100
|
||||||
|
Subject: [PATCH] main.c: rework logic to find def1, def2 and def3 files
|
||||||
|
|
||||||
|
The current logic to find def1, def2 and def3 first tries to find them
|
||||||
|
in the local directory, and if they are not available, find them in
|
||||||
|
/usr/share.
|
||||||
|
|
||||||
|
However, this doesn't work if rpiboot and its related files are
|
||||||
|
installed, but not in /usr. In order to address this use-case, this
|
||||||
|
commit reworks the logic to find the file path.
|
||||||
|
|
||||||
|
A new function, getfilepath() is created. If the requested file is
|
||||||
|
available in the current directory, it is used. If not, then the path to
|
||||||
|
the file is inferred from the location of the currently running
|
||||||
|
program. I.e if we run /home/foo/sys/bin/rpiboot, then we will search
|
||||||
|
def1 in usbbootcode.bin in
|
||||||
|
/home/foo/sys/bin/../share/rpiboot/usbbootcode.bin.
|
||||||
|
|
||||||
|
This continues to address the case of an installation in /usr, while
|
||||||
|
allowing installation in other locations as well.
|
||||||
|
|
||||||
|
Submitted-upstream: https://github.com/raspberrypi/usbboot/pull/2
|
||||||
|
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
|
||||||
|
---
|
||||||
|
main.c | 61 ++++++++++++++++++++++++++++++++++++++++++++++++-------------
|
||||||
|
1 file changed, 48 insertions(+), 13 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/main.c b/main.c
|
||||||
|
index 1b4e042..7c571d6 100755
|
||||||
|
--- a/main.c
|
||||||
|
+++ b/main.c
|
||||||
|
@@ -1,10 +1,12 @@
|
||||||
|
-#include "libusb-1.0/libusb.h"
|
||||||
|
+#define _GNU_SOURCE
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
-
|
||||||
|
+#include <libgen.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
+#include "libusb-1.0/libusb.h"
|
||||||
|
+
|
||||||
|
int verbose = 0;
|
||||||
|
int out_ep = 1;
|
||||||
|
int in_ep = 2;
|
||||||
|
@@ -146,6 +148,37 @@ int ep_read(unsigned char *buf, int len, libusb_device_handle * usb_device)
|
||||||
|
return len;
|
||||||
|
}
|
||||||
|
|
||||||
|
+char *getfilepath(char *filename)
|
||||||
|
+{
|
||||||
|
+ char *progpath, *filepath, *progdir;
|
||||||
|
+ ssize_t len;
|
||||||
|
+
|
||||||
|
+ /* If file is available locally, use it */
|
||||||
|
+ if (access(filename, F_OK) != -1)
|
||||||
|
+ return filename;
|
||||||
|
+
|
||||||
|
+ /* Otherwise, use the installed version */
|
||||||
|
+ progpath = malloc(PATH_MAX);
|
||||||
|
+ len = readlink("/proc/self/exe", progpath, PATH_MAX - 1);
|
||||||
|
+ if (len == -1)
|
||||||
|
+ {
|
||||||
|
+ free(progpath);
|
||||||
|
+ return NULL;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ progpath[len] = '\0';
|
||||||
|
+ progdir = dirname(progpath);
|
||||||
|
+ if (asprintf(&filepath, "%s/../share/rpiboot/%s", progdir, filename) < 0)
|
||||||
|
+ {
|
||||||
|
+ free(progpath);
|
||||||
|
+ return NULL;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ free(progpath);
|
||||||
|
+
|
||||||
|
+ return filepath;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
int result;
|
||||||
|
@@ -157,13 +190,9 @@ int main(int argc, char *argv[])
|
||||||
|
int last_serial = -1;
|
||||||
|
FILE *fp1, *fp2, *fp;
|
||||||
|
|
||||||
|
- char def1_inst[] = "/usr/share/rpiboot/usbbootcode.bin";
|
||||||
|
- char def2_inst[] = "/usr/share/rpiboot/msd.elf";
|
||||||
|
- char def3_inst[] = "/usr/share/rpiboot/buildroot.elf";
|
||||||
|
-
|
||||||
|
- char def1_loc[] = "./usbbootcode.bin";
|
||||||
|
- char def2_loc[] = "./msd.elf";
|
||||||
|
- char def3_loc[] = "./buildroot.elf";
|
||||||
|
+ char def1_name[] = "usbbootcode.bin";
|
||||||
|
+ char def2_name[] = "msd.elf";
|
||||||
|
+ char def3_name[] = "buildroot.elf";
|
||||||
|
|
||||||
|
char *def1, *def2, *def3;
|
||||||
|
|
||||||
|
@@ -171,10 +200,16 @@ int main(int argc, char *argv[])
|
||||||
|
char *fatimage = NULL, *executable = NULL;
|
||||||
|
int loop = 0;
|
||||||
|
|
||||||
|
-// if local file version exists use it else use installed
|
||||||
|
- if( access( def1_loc, F_OK ) != -1 ) { def1 = def1_loc; } else { def1 = def1_inst; }
|
||||||
|
- if( access( def2_loc, F_OK ) != -1 ) { def2 = def2_loc; } else { def2 = def2_inst; }
|
||||||
|
- if( access( def3_loc, F_OK ) != -1 ) { def3 = def3_loc; } else { def3 = def3_inst; }
|
||||||
|
+ def1 = getfilepath(def1_name);
|
||||||
|
+ def2 = getfilepath(def2_name);
|
||||||
|
+ def3 = getfilepath(def3_name);
|
||||||
|
+
|
||||||
|
+ if (!def1 || !def2 || !def3)
|
||||||
|
+ {
|
||||||
|
+ fprintf(stderr, "One of %s, %s or %s cannot be found\n",
|
||||||
|
+ def1_name, def2_name, def3_name);
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
|
||||||
|
stage1 = def1;
|
||||||
|
stage2 = def2;
|
||||||
|
--
|
||||||
|
2.7.4
|
||||||
|
|
12
package/raspberrypi-usbboot/Config.in.host
Normal file
12
package/raspberrypi-usbboot/Config.in.host
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
config BR2_PACKAGE_HOST_RASPBERRYPI_USBBOOT
|
||||||
|
bool "host raspberrypi-usbboot"
|
||||||
|
depends on BR2_arm
|
||||||
|
help
|
||||||
|
This package builds and install the "rpiboot" tool for the
|
||||||
|
host machine. This tool allows to boot the Broadcom BCM
|
||||||
|
processor used in the RaspberryPi to boot over USB, and have
|
||||||
|
it expose a USB mass storage device in order to reflash the
|
||||||
|
built-in storage of the RaspberryPi (useful for the eMMC
|
||||||
|
built into the Compute module).
|
||||||
|
|
||||||
|
https://github.com/raspberrypi/usbboot
|
2
package/raspberrypi-usbboot/raspberrypi-usbboot.hash
Normal file
2
package/raspberrypi-usbboot/raspberrypi-usbboot.hash
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
# Locally calculated
|
||||||
|
sha256 a8893f8a10522bd58866eb34e7f0d7731c43200d585f122681f428cdef76e676 raspberrypi-usbboot-f4e3f0f9a3c64d846ba53ec3367e33a4f9a7d051.tar.gz
|
21
package/raspberrypi-usbboot/raspberrypi-usbboot.mk
Normal file
21
package/raspberrypi-usbboot/raspberrypi-usbboot.mk
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
################################################################################
|
||||||
|
#
|
||||||
|
# raspberrypi-usbboot
|
||||||
|
#
|
||||||
|
################################################################################
|
||||||
|
|
||||||
|
RASPBERRYPI_USBBOOT_VERSION = f4e3f0f9a3c64d846ba53ec3367e33a4f9a7d051
|
||||||
|
RASPBERRYPI_USBBOOT_SITE = $(call github,raspberrypi,usbboot,$(RASPBERRYPI_USBBOOT_VERSION))
|
||||||
|
|
||||||
|
HOST_RASPBERRYPI_USBBOOT_DEPENDENCIES = host-libusb
|
||||||
|
|
||||||
|
define HOST_RASPBERRYPI_USBBOOT_BUILD_CMDS
|
||||||
|
$(HOST_MAKE_ENV) $(MAKE) $(HOST_CONFIGURE_OPTS) -C $(@D)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define HOST_RASPBERRYPI_USBBOOT_INSTALL_CMDS
|
||||||
|
$(HOST_MAKE_ENV) $(MAKE) $(HOST_CONFIGURE_OPTS) -C $(@D) \
|
||||||
|
DESTDIR=$(HOST_DIR) install
|
||||||
|
endef
|
||||||
|
|
||||||
|
$(eval $(host-generic-package))
|
Loading…
x
Reference in New Issue
Block a user