Merge git://git.denx.de/u-boot-usb
This commit is contained in:
@@ -153,4 +153,23 @@
|
||||
#define CONFIG_G_DNL_PRODUCT_NUM 0x0d02 /* nexus one */
|
||||
#define CONFIG_G_DNL_MANUFACTURER "Broadcom Corporation"
|
||||
|
||||
/* Fastboot and USB OTG */
|
||||
#define CONFIG_USB_FUNCTION_FASTBOOT
|
||||
#define CONFIG_CMD_FASTBOOT
|
||||
#define CONFIG_FASTBOOT_FLASH
|
||||
#define CONFIG_FASTBOOT_FLASH_MMC_DEV 0
|
||||
#define CONFIG_SYS_CACHELINE_SIZE 64
|
||||
#define CONFIG_USB_FASTBOOT_BUF_SIZE (CONFIG_SYS_SDRAM_SIZE - SZ_1M)
|
||||
#define CONFIG_USB_FASTBOOT_BUF_ADDR CONFIG_SYS_SDRAM_BASE
|
||||
#define CONFIG_USB_GADGET
|
||||
#define CONFIG_USB_GADGET_DUALSPEED
|
||||
#define CONFIG_USB_GADGET_VBUS_DRAW 0
|
||||
#define CONFIG_USB_GADGET_S3C_UDC_OTG
|
||||
#define CONFIG_USB_GADGET_BCM_UDC_OTG_PHY
|
||||
#define CONFIG_USB_GADGET_DOWNLOAD
|
||||
#define CONFIG_USBID_ADDR 0x34052c46
|
||||
#define CONFIG_G_DNL_VENDOR_NUM 0x18d1 /* google */
|
||||
#define CONFIG_G_DNL_PRODUCT_NUM 0x0d02 /* nexus one */
|
||||
#define CONFIG_G_DNL_MANUFACTURER "Broadcom Corporation"
|
||||
|
||||
#endif /* __BCM28155_AP_H */
|
||||
|
||||
@@ -162,6 +162,21 @@ bool dfu_usb_get_reset(void);
|
||||
int dfu_read(struct dfu_entity *de, void *buf, int size, int blk_seq_num);
|
||||
int dfu_write(struct dfu_entity *de, void *buf, int size, int blk_seq_num);
|
||||
int dfu_flush(struct dfu_entity *de, void *buf, int size, int blk_seq_num);
|
||||
|
||||
/**
|
||||
* dfu_write_from_mem_addr - write data from memory to DFU managed medium
|
||||
*
|
||||
* This function adds support for writing data starting from fixed memory
|
||||
* address (like $loadaddr) to dfu managed medium (e.g. NAND, MMC, file system)
|
||||
*
|
||||
* @param dfu - dfu entity to which we want to store data
|
||||
* @param buf - fixed memory addres from where data starts
|
||||
* @param size - number of bytes to write
|
||||
*
|
||||
* @return - 0 on success, other value on failure
|
||||
*/
|
||||
int dfu_write_from_mem_addr(struct dfu_entity *dfu, void *buf, int size);
|
||||
|
||||
/* Device specific */
|
||||
#ifdef CONFIG_DFU_MMC
|
||||
extern int dfu_fill_entity_mmc(struct dfu_entity *dfu, char *devstr, char *s);
|
||||
@@ -207,5 +222,31 @@ static inline int dfu_fill_entity_sf(struct dfu_entity *dfu, char *devstr,
|
||||
}
|
||||
#endif
|
||||
|
||||
/**
|
||||
* dfu_tftp_write - Write TFTP data to DFU medium
|
||||
*
|
||||
* This function is storing data received via TFTP on DFU supported medium.
|
||||
*
|
||||
* @param dfu_entity_name - name of DFU entity to write
|
||||
* @param addr - address of data buffer to write
|
||||
* @param len - number of bytes
|
||||
* @param interface - destination DFU medium (e.g. "mmc")
|
||||
* @param devstring - instance number of destination DFU medium (e.g. "1")
|
||||
*
|
||||
* @return 0 on success, otherwise error code
|
||||
*/
|
||||
#ifdef CONFIG_DFU_TFTP
|
||||
int dfu_tftp_write(char *dfu_entity_name, unsigned int addr, unsigned int len,
|
||||
char *interface, char *devstring);
|
||||
#else
|
||||
static inline int dfu_tftp_write(char *dfu_entity_name, unsigned int addr,
|
||||
unsigned int len, char *interface,
|
||||
char *devstring)
|
||||
{
|
||||
puts("TFTP write support for DFU not available!\n");
|
||||
return -ENOSYS;
|
||||
}
|
||||
#endif
|
||||
|
||||
int dfu_add(struct usb_configuration *c);
|
||||
#endif /* __DFU_ENTITY_H_ */
|
||||
|
||||
@@ -813,8 +813,18 @@ void copy_filename(char *dst, const char *src, int size);
|
||||
/* get a random source port */
|
||||
unsigned int random_port(void);
|
||||
|
||||
/* Update U-Boot over TFTP */
|
||||
int update_tftp(ulong addr);
|
||||
/**
|
||||
* update_tftp - Update firmware over TFTP (via DFU)
|
||||
*
|
||||
* This function updates board's firmware via TFTP
|
||||
*
|
||||
* @param addr - memory address where data is stored
|
||||
* @param interface - the DFU medium name - e.g. "mmc"
|
||||
* @param devstring - the DFU medium number - e.g. "1"
|
||||
*
|
||||
* @return - 0 on success, other value on failure
|
||||
*/
|
||||
int update_tftp(ulong addr, char *interface, char *devstring);
|
||||
|
||||
/**********************************************************************/
|
||||
|
||||
|
||||
30
include/net/tftp.h
Normal file
30
include/net/tftp.h
Normal file
@@ -0,0 +1,30 @@
|
||||
/*
|
||||
* LiMon - BOOTP/TFTP.
|
||||
*
|
||||
* Copyright 1994, 1995, 2000 Neil Russell.
|
||||
* Copyright 2011 Comelit Group SpA
|
||||
* Luca Ceresoli <luca.ceresoli@comelit.it>
|
||||
* (See License)
|
||||
*/
|
||||
|
||||
#ifndef __TFTP_H__
|
||||
#define __TFTP_H__
|
||||
|
||||
/**********************************************************************/
|
||||
/*
|
||||
* Global functions and variables.
|
||||
*/
|
||||
|
||||
/* tftp.c */
|
||||
void tftp_start(enum proto_t protocol); /* Begin TFTP get/put */
|
||||
|
||||
#ifdef CONFIG_CMD_TFTPSRV
|
||||
void tftp_start_server(void); /* Wait for incoming TFTP put */
|
||||
#endif
|
||||
|
||||
extern ulong tftp_timeout_ms;
|
||||
extern int tftp_timeout_count_max;
|
||||
|
||||
/**********************************************************************/
|
||||
|
||||
#endif /* __TFTP_H__ */
|
||||
Reference in New Issue
Block a user