aboutsummaryrefslogtreecommitdiffstats
path: root/package/busybox/config
Commit message (Expand)AuthorAgeFilesLines
* busybox: adjust hush default configurationFelix Fietkau2009-12-091-10/+10
* update busybox to 1.15.2 (#5926)Florian Fainelli2009-12-0717-122/+295
* busybox: support 64 bit math in shell tests. this does not seem to increase t...Felix Fietkau2009-10-031-2/+2
* busybox: update to v1.14.4 (closes: #5619)Nicolas Thill2009-09-2811-106/+234
* busybox: update to v1.13.4 (closes: #4279)Nicolas Thill2009-05-2520-247/+338
* busybox: update to v1.12.4 (partially closes: #4279)Nicolas Thill2009-05-2519-337/+416
* busybox brctl does not support showmacs or showstp (#4206)Florian Fainelli2009-01-181-2/+2
* busybox: Enabled FEATURE_HTTPD_PROXY by default (cost is 580 bytes)Rod Whitby2008-12-071-1/+1
* bridge (brctl) changes: - enable brctl in busybox - disable bridge-utils - bu...Nicolas Thill2008-11-111-3/+3
* remove ipkg from busyboxFelix Fietkau2008-09-021-9/+0
* remove awx from busybox, refresh patchesFelix Fietkau2008-09-021-7/+0
* upgrade busybox to v1.11.1 and add current upstream fixesImre Kaloz2008-08-2020-259/+1117
* make opkg the default package manager, disable busybox ipkg from building by ...Travis Kemen2008-08-161-1/+1
* make busybox have hwclocjk tool enable by defaultJohn Crispin2008-01-251-1/+1
* disable use of sendfile() for httpdTravis Kemen2008-01-151-1/+1
* Make ipkg depends on tar and gunzip (#2821)Florian Fainelli2007-12-171-0/+2
* upgrade busybox to 1.8.1Felix Fietkau2007-11-108-59/+199
* enable niceFelix Fietkau2007-10-071-1/+1
* Upgrade busybox to 1.7.2 - clean up insmod crap - add some lineno/programname...Felix Fietkau2007-10-0520-275/+859
* enable ps -w by defaultFelix Fietkau2007-09-221-1/+1
* enable start-stop-daemon by default, i want to use this to clean up a few ini...Felix Fietkau2007-09-061-1/+1
* Fix the CONFIG_LFS option (#2276)Florian Fainelli2007-08-281-1/+1
* busybox: Ensure that diff is available for ipkg upgrade requirementsRod Whitby2007-07-131-0/+1
* update to busybox 1.4.2 (fixes #1653)Mike Baker2007-05-101-0/+1
* add awx (awk web extension) - experimental core for a new web interface frame...Felix Fietkau2007-03-111-0/+7
* enable httpd config option for running scripts through an interpreterFelix Fietkau2007-03-111-1/+1
* nuke mdev and replace it with hotplug2 :)Felix Fietkau2007-03-041-2/+2
* R.I.P. devfsImre Kaloz2007-03-032-3/+3
* enable httpd sighup config reload by defaultFelix Fietkau2007-01-311-1/+1
* upgrade busybox to 1.4.0Felix Fietkau2007-01-259-50/+145
* enable pretty lsmod output for linux 2.6Felix Fietkau2007-01-101-1/+1
* make telnetd standaloneFelix Fietkau2007-01-011-1/+1
* update busybox menuconfig for the latest versionFelix Fietkau2007-01-0116-112/+349
* finally move buildroot-ng to trunkFelix Fietkau2016-03-2019-0/+4627
s="cp">#include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <unistd.h> #include <errno.h> #include <sys/ioctl.h> #include <linux/i2c-dev.h> #include <linux/i2c.h> #include "flash.h" #include "programmer.h" #include "spi.h" struct mstarddc_spi_data { int fd; int addr; int doreset; }; // MSTAR DDC Commands #define MSTARDDC_SPI_WRITE 0x10 #define MSTARDDC_SPI_READ 0x11 #define MSTARDDC_SPI_END 0x12 #define MSTARDDC_SPI_RESET 0x24 /* Returns 0 upon success, a negative number upon errors. */ static int mstarddc_spi_shutdown(void *data) { struct mstarddc_spi_data *mstarddc_data = data; // Reset, disables ISP mode if (mstarddc_data->doreset == 1) { uint8_t cmd = MSTARDDC_SPI_RESET; if (write(mstarddc_data->fd, &cmd, 1) < 0) { msg_perr("Error sending reset command: errno %d.\n", errno); return -1; } } else { msg_pinfo("Info: Reset command was not sent. " "Either the noreset=1 option was used, " "or an error occurred.\n"); } if (close(mstarddc_data->fd) < 0) { msg_perr("Error closing device: errno %d.\n", errno); return -1; } free(data); return 0; } /* Returns 0 upon success, a negative number upon errors. */ static int mstarddc_spi_send_command(const struct flashctx *flash, unsigned int writecnt, unsigned int readcnt, const unsigned char *writearr, unsigned char *readarr) { struct mstarddc_spi_data *mstarddc_data = flash->mst->spi.data; int ret = 0; uint8_t *cmd = malloc((writecnt + 1) * sizeof(uint8_t)); if (cmd == NULL) { msg_perr("Error allocating memory: errno %d.\n", errno); ret = -1; } if (!ret && writecnt) { cmd[0] = MSTARDDC_SPI_WRITE; memcpy(cmd + 1, writearr, writecnt); if (write(mstarddc_data->fd, cmd, writecnt + 1) < 0) { msg_perr("Error sending write command: errno %d.\n", errno); ret = -1; } } if (!ret && readcnt) { struct i2c_rdwr_ioctl_data i2c_data; struct i2c_msg msg[2]; cmd[0] = MSTARDDC_SPI_READ; i2c_data.nmsgs = 2; i2c_data.msgs = msg; i2c_data.msgs[0].addr = mstarddc_data->addr; i2c_data.msgs[0].len = 1; i2c_data.msgs[0].flags = 0; i2c_data.msgs[0].buf = cmd; i2c_data.msgs[1].addr = mstarddc_data->addr; i2c_data.msgs[1].len = readcnt; i2c_data.msgs[1].flags = I2C_M_RD; i2c_data.msgs[1].buf = readarr; if (ioctl(mstarddc_data->fd, I2C_RDWR, &i2c_data) < 0) { msg_perr("Error sending read command: errno %d.\n", errno); ret = -1; } } if (!ret && (writecnt || readcnt)) { cmd[0] = MSTARDDC_SPI_END; if (write(mstarddc_data->fd, cmd, 1) < 0) { msg_perr("Error sending end command: errno %d.\n", errno); ret = -1; } } /* Do not reset if something went wrong, as it might prevent from * retrying flashing. */ if (ret != 0) mstarddc_data->doreset = 0; if (cmd) free(cmd); return ret; } static const struct spi_master spi_master_mstarddc = { .max_data_read = 256, .max_data_write = 256, .command = mstarddc_spi_send_command, .multicommand = default_spi_send_multicommand, .read = default_spi_read, .write_256 = default_spi_write_256, .write_aai = default_spi_write_aai, }; /* Returns 0 upon success, a negative number upon errors. */ static int mstarddc_spi_init(void) { int ret = 0; int mstarddc_fd = -1; int mstarddc_addr; int mstarddc_doreset = 1; struct mstarddc_spi_data *mstarddc_data; // Get device, address from command-line char *i2c_device = extract_programmer_param("dev"); if (i2c_device != NULL && strlen(i2c_device) > 0) { char *i2c_address = strchr(i2c_device, ':'); if (i2c_address != NULL) { *i2c_address = '\0'; i2c_address++; } if (i2c_address == NULL || strlen(i2c_address) == 0) { msg_perr("Error: no address specified.\n" "Use flashrom -p mstarddc_spi:dev=/dev/device:address.\n"); ret = -1; goto out; } mstarddc_addr = strtol(i2c_address, NULL, 16); // FIXME: error handling } else { msg_perr("Error: no device specified.\n" "Use flashrom -p mstarddc_spi:dev=/dev/device:address.\n"); ret = -1; goto out; } msg_pinfo("Info: Will try to use device %s and address 0x%02x.\n", i2c_device, mstarddc_addr); // Get noreset=1 option from command-line char *noreset = extract_programmer_param("noreset"); if (noreset != NULL && noreset[0] == '1') mstarddc_doreset = 0; free(noreset); msg_pinfo("Info: Will %sreset the device at the end.\n", mstarddc_doreset ? "" : "NOT "); // Open device if ((mstarddc_fd = open(i2c_device, O_RDWR)) < 0) { switch (errno) { case EACCES: msg_perr("Error opening %s: Permission denied.\n" "Please use sudo or run as root.\n", i2c_device); break; case ENOENT: msg_perr("Error opening %s: No such file.\n" "Please check you specified the correct device.\n", i2c_device); break; default: msg_perr("Error opening %s: %s.\n", i2c_device, strerror(errno)); } ret = -1; goto out; } // Set slave address if (ioctl(mstarddc_fd, I2C_SLAVE, mstarddc_addr) < 0) { msg_perr("Error setting slave address 0x%02x: errno %d.\n", mstarddc_addr, errno); ret = -1; goto out; } // Enable ISP mode uint8_t cmd[5] = { 'M', 'S', 'T', 'A', 'R' }; if (write(mstarddc_fd, cmd, 5) < 0) { int enable_err = errno; uint8_t end_cmd = MSTARDDC_SPI_END; // Assume device is already in ISP mode, try to send END command if (write(mstarddc_fd, &end_cmd, 1) < 0) { msg_perr("Error enabling ISP mode: errno %d & %d.\n" "Please check that device (%s) and address (0x%02x) are correct.\n", enable_err, errno, i2c_device, mstarddc_addr); ret = -1; goto out; } } mstarddc_data = calloc(1, sizeof(*mstarddc_data)); if (!mstarddc_data) { msg_perr("Unable to allocate space for SPI master data\n"); ret = -1; goto out; } mstarddc_data->fd = mstarddc_fd; mstarddc_data->addr = mstarddc_addr; mstarddc_data->doreset = mstarddc_doreset; // Register shutdown function register_shutdown(mstarddc_spi_shutdown, mstarddc_data); // Register programmer register_spi_master(&spi_master_mstarddc, mstarddc_data); out: free(i2c_device); if (ret && (mstarddc_fd >= 0)) close(mstarddc_fd); return ret; } const struct programmer_entry programmer_mstarddc_spi = { .name = "mstarddc_spi", .type = OTHER, .devs.note = "MSTAR DDC devices addressable via /dev/i2c-* on Linux.\n", .init = mstarddc_spi_init, .map_flash_region = fallback_map, .unmap_flash_region = fallback_unmap, .delay = internal_delay, }; #endif