turn target runtime check of mtd into a compile-time check

SVN-Revision: 5285
This commit is contained in:
Felix Fietkau 2006-10-24 18:11:33 +00:00
parent 28a3cb3ca3
commit 426ecdecef
2 changed files with 14 additions and 19 deletions

View File

@ -7,11 +7,12 @@
# $Id$ # $Id$
include $(TOPDIR)/rules.mk include $(TOPDIR)/rules.mk
include $(INCLUDE_DIR)/kernel.mk
PKG_NAME:=mtd PKG_NAME:=mtd
PKG_RELEASE:=4 PKG_RELEASE:=4
PKG_BUILD_DIR := $(BUILD_DIR)/$(PKG_NAME) PKG_BUILD_DIR := $(KERNEL_BUILD_DIR)/$(PKG_NAME)
include $(INCLUDE_DIR)/package.mk include $(INCLUDE_DIR)/package.mk
@ -30,6 +31,12 @@ define Build/Prepare
$(CP) ./src/* $(PKG_BUILD_DIR)/ $(CP) ./src/* $(PKG_BUILD_DIR)/
endef endef
define Build/Compile
$(MAKE) -C $(PKG_BUILD_DIR) \
$(TARGET_CONFIGURE_OPTS) \
CFLAGS="$(TARGET_CFLAGS) -Dtarget_$(BOARD)=1"
endef
define Package/mtd/install define Package/mtd/install
install -d -m0755 $(1)/sbin install -d -m0755 $(1)/sbin
install -m0755 $(PKG_BUILD_DIR)/mtd $(1)/sbin/ install -m0755 $(PKG_BUILD_DIR)/mtd $(1)/sbin/

View File

@ -64,8 +64,9 @@ char buf[BUFSIZE];
int buflen; int buflen;
int quiet; int quiet;
#ifdef target_brcm
int int
image_check_bcom(int imagefd, const char *mtd) image_check_brcm(int imagefd, const char *mtd)
{ {
struct trx_header *trx = (struct trx_header *) buf; struct trx_header *trx = (struct trx_header *) buf;
struct mtd_info_user mtdInfo; struct mtd_info_user mtdInfo;
@ -121,6 +122,7 @@ image_check_bcom(int imagefd, const char *mtd)
close(fd); close(fd);
return 1; return 1;
} }
#endif /* target_brcm */
int int
image_check(int imagefd, const char *mtd) image_check(int imagefd, const char *mtd)
@ -130,23 +132,9 @@ image_check(int imagefd, const char *mtd)
char *c; char *c;
FILE *f; FILE *f;
systype = SYSTYPE_UNKNOWN; #ifdef target_brcm
f = fopen("/proc/cpuinfo", "r"); return image_check_brcm(imagefd, mtd);
while (!feof(f) && (fgets(buf, BUFSIZE - 1, f) != NULL)) { #endif
if ((strncmp(buf, "system type", 11) == 0) && (c = strchr(buf, ':'))) {
c += 2;
if (strncmp(c, "Broadcom BCM947XX", 17) == 0)
systype = SYSTYPE_BROADCOM;
}
}
fclose(f);
switch(systype) {
case SYSTYPE_BROADCOM:
return image_check_bcom(imagefd, mtd);
default:
return 1;
}
} }
int mtd_check(char *mtd) int mtd_check(char *mtd)