1 // SPDX-License-Identifier: GPL-2.0+
3 * Driver for Realtek PCI-Express card reader
5 * Copyright(c) 2009-2013 Realtek Semiconductor Corp. All rights reserved.
12 #include <linux/blkdev.h>
13 #include <linux/kthread.h>
14 #include <linux/sched.h>
19 static inline void spi_set_err_code(struct rtsx_chip *chip, u8 err_code)
21 struct spi_info *spi = &chip->spi;
23 spi->err_code = err_code;
26 static int spi_init(struct rtsx_chip *chip)
30 retval = rtsx_write_register(chip, SPI_CONTROL, 0xFF,
31 CS_POLARITY_LOW | DTO_MSB_FIRST
32 | SPI_MASTER | SPI_MODE0 | SPI_AUTO);
35 retval = rtsx_write_register(chip, SPI_TCTL, EDO_TIMING_MASK,
40 return STATUS_SUCCESS;
43 static int spi_set_init_para(struct rtsx_chip *chip)
45 struct spi_info *spi = &chip->spi;
48 retval = rtsx_write_register(chip, SPI_CLK_DIVIDER1, 0xFF,
49 (u8)(spi->clk_div >> 8));
52 retval = rtsx_write_register(chip, SPI_CLK_DIVIDER0, 0xFF,
57 retval = switch_clock(chip, spi->spi_clock);
58 if (retval != STATUS_SUCCESS)
61 retval = select_card(chip, SPI_CARD);
62 if (retval != STATUS_SUCCESS)
65 retval = rtsx_write_register(chip, CARD_CLK_EN, SPI_CLK_EN,
69 retval = rtsx_write_register(chip, CARD_OE, SPI_OUTPUT_EN,
76 retval = spi_init(chip);
77 if (retval != STATUS_SUCCESS)
80 return STATUS_SUCCESS;
83 static int sf_polling_status(struct rtsx_chip *chip, int msec)
89 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_COMMAND, 0xFF, SPI_RDSR);
90 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0, 0xFF,
91 SPI_TRANSFER0_START | SPI_POLLING_MODE0);
92 rtsx_add_cmd(chip, CHECK_REG_CMD, SPI_TRANSFER0, SPI_TRANSFER0_END,
95 retval = rtsx_send_cmd(chip, 0, msec);
97 rtsx_clear_spi_error(chip);
98 spi_set_err_code(chip, SPI_BUSY_ERR);
102 return STATUS_SUCCESS;
105 static int sf_enable_write(struct rtsx_chip *chip, u8 ins)
107 struct spi_info *spi = &chip->spi;
111 return STATUS_SUCCESS;
115 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_COMMAND, 0xFF, ins);
116 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_CA_NUMBER, 0xFF,
117 SPI_COMMAND_BIT_8 | SPI_ADDRESS_BIT_24);
118 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0, 0xFF,
119 SPI_TRANSFER0_START | SPI_C_MODE0);
120 rtsx_add_cmd(chip, CHECK_REG_CMD, SPI_TRANSFER0, SPI_TRANSFER0_END,
123 retval = rtsx_send_cmd(chip, 0, 100);
125 rtsx_clear_spi_error(chip);
126 spi_set_err_code(chip, SPI_HW_ERR);
130 return STATUS_SUCCESS;
133 static int sf_disable_write(struct rtsx_chip *chip, u8 ins)
135 struct spi_info *spi = &chip->spi;
139 return STATUS_SUCCESS;
143 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_COMMAND, 0xFF, ins);
144 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_CA_NUMBER, 0xFF,
145 SPI_COMMAND_BIT_8 | SPI_ADDRESS_BIT_24);
146 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0, 0xFF,
147 SPI_TRANSFER0_START | SPI_C_MODE0);
148 rtsx_add_cmd(chip, CHECK_REG_CMD, SPI_TRANSFER0, SPI_TRANSFER0_END,
151 retval = rtsx_send_cmd(chip, 0, 100);
153 rtsx_clear_spi_error(chip);
154 spi_set_err_code(chip, SPI_HW_ERR);
158 return STATUS_SUCCESS;
161 static void sf_program(struct rtsx_chip *chip, u8 ins, u8 addr_mode, u32 addr,
164 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_COMMAND, 0xFF, ins);
165 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_CA_NUMBER, 0xFF,
166 SPI_COMMAND_BIT_8 | SPI_ADDRESS_BIT_24);
167 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_LENGTH0, 0xFF, (u8)len);
168 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_LENGTH1, 0xFF, (u8)(len >> 8));
170 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR0, 0xFF, (u8)addr);
171 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR1, 0xFF,
173 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR2, 0xFF,
175 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0, 0xFF,
176 SPI_TRANSFER0_START | SPI_CADO_MODE0);
178 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0, 0xFF,
179 SPI_TRANSFER0_START | SPI_CDO_MODE0);
181 rtsx_add_cmd(chip, CHECK_REG_CMD, SPI_TRANSFER0, SPI_TRANSFER0_END,
185 static int sf_erase(struct rtsx_chip *chip, u8 ins, u8 addr_mode, u32 addr)
191 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_COMMAND, 0xFF, ins);
192 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_CA_NUMBER, 0xFF,
193 SPI_COMMAND_BIT_8 | SPI_ADDRESS_BIT_24);
195 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR0, 0xFF, (u8)addr);
196 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR1, 0xFF,
198 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR2, 0xFF,
200 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0, 0xFF,
201 SPI_TRANSFER0_START | SPI_CA_MODE0);
203 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0, 0xFF,
204 SPI_TRANSFER0_START | SPI_C_MODE0);
206 rtsx_add_cmd(chip, CHECK_REG_CMD, SPI_TRANSFER0, SPI_TRANSFER0_END,
209 retval = rtsx_send_cmd(chip, 0, 100);
211 rtsx_clear_spi_error(chip);
212 spi_set_err_code(chip, SPI_HW_ERR);
216 return STATUS_SUCCESS;
219 static int spi_init_eeprom(struct rtsx_chip *chip)
229 retval = rtsx_write_register(chip, SPI_CLK_DIVIDER1, 0xFF, 0x00);
232 retval = rtsx_write_register(chip, SPI_CLK_DIVIDER0, 0xFF, 0x27);
236 retval = switch_clock(chip, clk);
237 if (retval != STATUS_SUCCESS)
240 retval = select_card(chip, SPI_CARD);
241 if (retval != STATUS_SUCCESS)
244 retval = rtsx_write_register(chip, CARD_CLK_EN, SPI_CLK_EN,
248 retval = rtsx_write_register(chip, CARD_OE, SPI_OUTPUT_EN,
255 retval = rtsx_write_register(chip, SPI_CONTROL, 0xFF,
256 CS_POLARITY_HIGH | SPI_EEPROM_AUTO);
259 retval = rtsx_write_register(chip, SPI_TCTL, EDO_TIMING_MASK,
264 return STATUS_SUCCESS;
267 static int spi_eeprom_program_enable(struct rtsx_chip *chip)
273 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_CA_NUMBER, 0xFF, 0x86);
274 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_COMMAND, 0xFF, 0x13);
275 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0, 0xFF,
276 SPI_TRANSFER0_START | SPI_CA_MODE0);
277 rtsx_add_cmd(chip, CHECK_REG_CMD, SPI_TRANSFER0, SPI_TRANSFER0_END,
280 retval = rtsx_send_cmd(chip, 0, 100);
284 return STATUS_SUCCESS;
287 int spi_erase_eeprom_chip(struct rtsx_chip *chip)
291 retval = spi_init_eeprom(chip);
292 if (retval != STATUS_SUCCESS)
295 retval = spi_eeprom_program_enable(chip);
296 if (retval != STATUS_SUCCESS)
301 rtsx_add_cmd(chip, WRITE_REG_CMD, CARD_GPIO_DIR, 0x01, 0);
302 rtsx_add_cmd(chip, WRITE_REG_CMD, CARD_DATA_SOURCE, 0x01, RING_BUFFER);
303 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_COMMAND, 0xFF, 0x12);
304 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_CA_NUMBER, 0xFF, 0x84);
305 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0, 0xFF,
306 SPI_TRANSFER0_START | SPI_CA_MODE0);
307 rtsx_add_cmd(chip, CHECK_REG_CMD, SPI_TRANSFER0, SPI_TRANSFER0_END,
310 retval = rtsx_send_cmd(chip, 0, 100);
314 retval = rtsx_write_register(chip, CARD_GPIO_DIR, 0x01, 0x01);
318 return STATUS_SUCCESS;
321 int spi_erase_eeprom_byte(struct rtsx_chip *chip, u16 addr)
325 retval = spi_init_eeprom(chip);
326 if (retval != STATUS_SUCCESS)
329 retval = spi_eeprom_program_enable(chip);
330 if (retval != STATUS_SUCCESS)
335 rtsx_add_cmd(chip, WRITE_REG_CMD, CARD_GPIO_DIR, 0x01, 0);
336 rtsx_add_cmd(chip, WRITE_REG_CMD, CARD_DATA_SOURCE, 0x01, RING_BUFFER);
337 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_COMMAND, 0xFF, 0x07);
338 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR0, 0xFF, (u8)addr);
339 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR1, 0xFF, (u8)(addr >> 8));
340 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_CA_NUMBER, 0xFF, 0x46);
341 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0, 0xFF,
342 SPI_TRANSFER0_START | SPI_CA_MODE0);
343 rtsx_add_cmd(chip, CHECK_REG_CMD, SPI_TRANSFER0, SPI_TRANSFER0_END,
346 retval = rtsx_send_cmd(chip, 0, 100);
350 retval = rtsx_write_register(chip, CARD_GPIO_DIR, 0x01, 0x01);
354 return STATUS_SUCCESS;
357 int spi_read_eeprom(struct rtsx_chip *chip, u16 addr, u8 *val)
362 retval = spi_init_eeprom(chip);
363 if (retval != STATUS_SUCCESS)
368 rtsx_add_cmd(chip, WRITE_REG_CMD, CARD_GPIO_DIR, 0x01, 0);
369 rtsx_add_cmd(chip, WRITE_REG_CMD, CARD_DATA_SOURCE, 0x01, RING_BUFFER);
370 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_COMMAND, 0xFF, 0x06);
371 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR0, 0xFF, (u8)addr);
372 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR1, 0xFF, (u8)(addr >> 8));
373 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_CA_NUMBER, 0xFF, 0x46);
374 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_LENGTH0, 0xFF, 1);
375 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0, 0xFF,
376 SPI_TRANSFER0_START | SPI_CADI_MODE0);
377 rtsx_add_cmd(chip, CHECK_REG_CMD, SPI_TRANSFER0, SPI_TRANSFER0_END,
380 retval = rtsx_send_cmd(chip, 0, 100);
385 retval = rtsx_read_register(chip, SPI_DATA, &data);
392 retval = rtsx_write_register(chip, CARD_GPIO_DIR, 0x01, 0x01);
396 return STATUS_SUCCESS;
399 int spi_write_eeprom(struct rtsx_chip *chip, u16 addr, u8 val)
403 retval = spi_init_eeprom(chip);
404 if (retval != STATUS_SUCCESS)
407 retval = spi_eeprom_program_enable(chip);
408 if (retval != STATUS_SUCCESS)
413 rtsx_add_cmd(chip, WRITE_REG_CMD, CARD_GPIO_DIR, 0x01, 0);
414 rtsx_add_cmd(chip, WRITE_REG_CMD, CARD_DATA_SOURCE, 0x01, RING_BUFFER);
415 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_COMMAND, 0xFF, 0x05);
416 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR0, 0xFF, val);
417 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR1, 0xFF, (u8)addr);
418 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR2, 0xFF, (u8)(addr >> 8));
419 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_CA_NUMBER, 0xFF, 0x4E);
420 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0, 0xFF,
421 SPI_TRANSFER0_START | SPI_CA_MODE0);
422 rtsx_add_cmd(chip, CHECK_REG_CMD, SPI_TRANSFER0, SPI_TRANSFER0_END,
425 retval = rtsx_send_cmd(chip, 0, 100);
429 retval = rtsx_write_register(chip, CARD_GPIO_DIR, 0x01, 0x01);
433 return STATUS_SUCCESS;
436 int spi_get_status(struct scsi_cmnd *srb, struct rtsx_chip *chip)
438 struct spi_info *spi = &chip->spi;
440 dev_dbg(rtsx_dev(chip), "%s: err_code = 0x%x\n", __func__,
442 rtsx_stor_set_xfer_buf(&spi->err_code,
443 min_t(int, scsi_bufflen(srb), 1), srb);
444 scsi_set_resid(srb, scsi_bufflen(srb) - 1);
446 return STATUS_SUCCESS;
449 int spi_set_parameter(struct scsi_cmnd *srb, struct rtsx_chip *chip)
451 struct spi_info *spi = &chip->spi;
453 spi_set_err_code(chip, SPI_NO_ERR);
456 spi->spi_clock = ((u16)(srb->cmnd[8]) << 8) | srb->cmnd[9];
458 spi->spi_clock = srb->cmnd[3];
460 spi->clk_div = ((u16)(srb->cmnd[4]) << 8) | srb->cmnd[5];
461 spi->write_en = srb->cmnd[6];
463 dev_dbg(rtsx_dev(chip), "spi_clock = %d, clk_div = %d, write_en = %d\n",
464 spi->spi_clock, spi->clk_div, spi->write_en);
466 return STATUS_SUCCESS;
469 int spi_read_flash_id(struct scsi_cmnd *srb, struct rtsx_chip *chip)
475 spi_set_err_code(chip, SPI_NO_ERR);
477 len = ((u16)(srb->cmnd[7]) << 8) | srb->cmnd[8];
479 spi_set_err_code(chip, SPI_INVALID_COMMAND);
483 retval = spi_set_init_para(chip);
484 if (retval != STATUS_SUCCESS) {
485 spi_set_err_code(chip, SPI_HW_ERR);
491 rtsx_add_cmd(chip, WRITE_REG_CMD, CARD_DATA_SOURCE, 0x01,
494 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_COMMAND, 0xFF, srb->cmnd[3]);
495 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR2, 0xFF, srb->cmnd[4]);
496 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR1, 0xFF, srb->cmnd[5]);
497 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR0, 0xFF, srb->cmnd[6]);
498 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_CA_NUMBER, 0xFF,
499 SPI_COMMAND_BIT_8 | SPI_ADDRESS_BIT_24);
500 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_LENGTH1, 0xFF, srb->cmnd[7]);
501 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_LENGTH0, 0xFF, srb->cmnd[8]);
505 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0,
506 0xFF, SPI_TRANSFER0_START | SPI_CA_MODE0);
508 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0,
509 0xFF, SPI_TRANSFER0_START | SPI_C_MODE0);
513 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0, 0xFF,
514 SPI_TRANSFER0_START | SPI_CADI_MODE0);
516 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0, 0xFF,
517 SPI_TRANSFER0_START | SPI_CDI_MODE0);
521 rtsx_add_cmd(chip, CHECK_REG_CMD, SPI_TRANSFER0, SPI_TRANSFER0_END,
524 retval = rtsx_send_cmd(chip, 0, 100);
526 rtsx_clear_spi_error(chip);
527 spi_set_err_code(chip, SPI_HW_ERR);
532 buf = kmalloc(len, GFP_KERNEL);
536 retval = rtsx_read_ppbuf(chip, buf, len);
537 if (retval != STATUS_SUCCESS) {
538 spi_set_err_code(chip, SPI_READ_ERR);
543 rtsx_stor_set_xfer_buf(buf, scsi_bufflen(srb), srb);
544 scsi_set_resid(srb, 0);
549 return STATUS_SUCCESS;
552 int spi_read_flash(struct scsi_cmnd *srb, struct rtsx_chip *chip)
555 unsigned int index = 0, offset = 0;
561 spi_set_err_code(chip, SPI_NO_ERR);
564 addr = ((u32)(srb->cmnd[4]) << 16) | ((u32)(srb->cmnd[5])
565 << 8) | srb->cmnd[6];
566 len = ((u16)(srb->cmnd[7]) << 8) | srb->cmnd[8];
567 slow_read = srb->cmnd[9];
569 retval = spi_set_init_para(chip);
570 if (retval != STATUS_SUCCESS) {
571 spi_set_err_code(chip, SPI_HW_ERR);
575 buf = kmalloc(SF_PAGE_LEN, GFP_KERNEL);
580 u16 pagelen = SF_PAGE_LEN - (u8)addr;
587 trans_dma_enable(DMA_FROM_DEVICE, chip, 256, DMA_256);
589 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_COMMAND, 0xFF, ins);
592 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR0, 0xFF,
594 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR1, 0xFF,
596 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR2, 0xFF,
598 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_CA_NUMBER, 0xFF,
599 SPI_COMMAND_BIT_8 | SPI_ADDRESS_BIT_24);
601 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR1, 0xFF,
603 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR2, 0xFF,
605 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_ADDR3, 0xFF,
607 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_CA_NUMBER, 0xFF,
608 SPI_COMMAND_BIT_8 | SPI_ADDRESS_BIT_32);
611 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_LENGTH1, 0xFF,
613 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_LENGTH0, 0xFF,
616 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0, 0xFF,
617 SPI_TRANSFER0_START | SPI_CADI_MODE0);
618 rtsx_add_cmd(chip, CHECK_REG_CMD, SPI_TRANSFER0,
619 SPI_TRANSFER0_END, SPI_TRANSFER0_END);
621 rtsx_send_cmd_no_wait(chip);
623 retval = rtsx_transfer_data(chip, 0, buf, pagelen, 0,
624 DMA_FROM_DEVICE, 10000);
627 rtsx_clear_spi_error(chip);
628 spi_set_err_code(chip, SPI_HW_ERR);
632 rtsx_stor_access_xfer_buf(buf, pagelen, srb, &index, &offset,
639 scsi_set_resid(srb, 0);
642 return STATUS_SUCCESS;
645 int spi_write_flash(struct scsi_cmnd *srb, struct rtsx_chip *chip)
648 u8 ins, program_mode;
652 unsigned int index = 0, offset = 0;
654 spi_set_err_code(chip, SPI_NO_ERR);
657 addr = ((u32)(srb->cmnd[4]) << 16) | ((u32)(srb->cmnd[5])
658 << 8) | srb->cmnd[6];
659 len = ((u16)(srb->cmnd[7]) << 8) | srb->cmnd[8];
660 program_mode = srb->cmnd[9];
662 retval = spi_set_init_para(chip);
663 if (retval != STATUS_SUCCESS) {
664 spi_set_err_code(chip, SPI_HW_ERR);
668 if (program_mode == BYTE_PROGRAM) {
669 buf = kmalloc(4, GFP_KERNEL);
674 retval = sf_enable_write(chip, SPI_WREN);
675 if (retval != STATUS_SUCCESS) {
680 rtsx_stor_access_xfer_buf(buf, 1, srb, &index, &offset,
685 rtsx_add_cmd(chip, WRITE_REG_CMD, CARD_DATA_SOURCE,
686 0x01, PINGPONG_BUFFER);
687 rtsx_add_cmd(chip, WRITE_REG_CMD, PPBUF_BASE2, 0xFF,
689 sf_program(chip, ins, 1, addr, 1);
691 retval = rtsx_send_cmd(chip, 0, 100);
694 rtsx_clear_spi_error(chip);
695 spi_set_err_code(chip, SPI_HW_ERR);
699 retval = sf_polling_status(chip, 100);
700 if (retval != STATUS_SUCCESS) {
711 } else if (program_mode == AAI_PROGRAM) {
714 retval = sf_enable_write(chip, SPI_WREN);
715 if (retval != STATUS_SUCCESS)
718 buf = kmalloc(4, GFP_KERNEL);
723 rtsx_stor_access_xfer_buf(buf, 1, srb, &index, &offset,
728 rtsx_add_cmd(chip, WRITE_REG_CMD, CARD_DATA_SOURCE,
729 0x01, PINGPONG_BUFFER);
730 rtsx_add_cmd(chip, WRITE_REG_CMD, PPBUF_BASE2, 0xFF,
733 sf_program(chip, ins, 1, addr, 1);
736 sf_program(chip, ins, 0, 0, 1);
739 retval = rtsx_send_cmd(chip, 0, 100);
742 rtsx_clear_spi_error(chip);
743 spi_set_err_code(chip, SPI_HW_ERR);
747 retval = sf_polling_status(chip, 100);
748 if (retval != STATUS_SUCCESS) {
758 retval = sf_disable_write(chip, SPI_WRDI);
759 if (retval != STATUS_SUCCESS)
762 retval = sf_polling_status(chip, 100);
763 if (retval != STATUS_SUCCESS)
765 } else if (program_mode == PAGE_PROGRAM) {
766 buf = kmalloc(SF_PAGE_LEN, GFP_KERNEL);
771 u16 pagelen = SF_PAGE_LEN - (u8)addr;
776 retval = sf_enable_write(chip, SPI_WREN);
777 if (retval != STATUS_SUCCESS) {
784 trans_dma_enable(DMA_TO_DEVICE, chip, 256, DMA_256);
785 sf_program(chip, ins, 1, addr, pagelen);
787 rtsx_send_cmd_no_wait(chip);
789 rtsx_stor_access_xfer_buf(buf, pagelen, srb, &index,
790 &offset, FROM_XFER_BUF);
792 retval = rtsx_transfer_data(chip, 0, buf, pagelen, 0,
796 rtsx_clear_spi_error(chip);
797 spi_set_err_code(chip, SPI_HW_ERR);
801 retval = sf_polling_status(chip, 100);
802 if (retval != STATUS_SUCCESS) {
813 spi_set_err_code(chip, SPI_INVALID_COMMAND);
817 return STATUS_SUCCESS;
820 int spi_erase_flash(struct scsi_cmnd *srb, struct rtsx_chip *chip)
826 spi_set_err_code(chip, SPI_NO_ERR);
829 addr = ((u32)(srb->cmnd[4]) << 16) | ((u32)(srb->cmnd[5])
830 << 8) | srb->cmnd[6];
831 erase_mode = srb->cmnd[9];
833 retval = spi_set_init_para(chip);
834 if (retval != STATUS_SUCCESS) {
835 spi_set_err_code(chip, SPI_HW_ERR);
839 if (erase_mode == PAGE_ERASE) {
840 retval = sf_enable_write(chip, SPI_WREN);
841 if (retval != STATUS_SUCCESS)
844 retval = sf_erase(chip, ins, 1, addr);
845 if (retval != STATUS_SUCCESS)
847 } else if (erase_mode == CHIP_ERASE) {
848 retval = sf_enable_write(chip, SPI_WREN);
849 if (retval != STATUS_SUCCESS)
852 retval = sf_erase(chip, ins, 0, 0);
853 if (retval != STATUS_SUCCESS)
856 spi_set_err_code(chip, SPI_INVALID_COMMAND);
860 return STATUS_SUCCESS;
863 int spi_write_flash_status(struct scsi_cmnd *srb, struct rtsx_chip *chip)
866 u8 ins, status, ewsr;
869 status = srb->cmnd[4];
872 retval = spi_set_init_para(chip);
873 if (retval != STATUS_SUCCESS) {
874 spi_set_err_code(chip, SPI_HW_ERR);
878 retval = sf_enable_write(chip, ewsr);
879 if (retval != STATUS_SUCCESS)
884 rtsx_add_cmd(chip, WRITE_REG_CMD, CARD_DATA_SOURCE, 0x01,
887 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_COMMAND, 0xFF, ins);
888 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_CA_NUMBER, 0xFF,
889 SPI_COMMAND_BIT_8 | SPI_ADDRESS_BIT_24);
890 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_LENGTH1, 0xFF, 0);
891 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_LENGTH0, 0xFF, 1);
892 rtsx_add_cmd(chip, WRITE_REG_CMD, PPBUF_BASE2, 0xFF, status);
893 rtsx_add_cmd(chip, WRITE_REG_CMD, SPI_TRANSFER0, 0xFF,
894 SPI_TRANSFER0_START | SPI_CDO_MODE0);
895 rtsx_add_cmd(chip, CHECK_REG_CMD, SPI_TRANSFER0, SPI_TRANSFER0_END,
898 retval = rtsx_send_cmd(chip, 0, 100);
899 if (retval != STATUS_SUCCESS) {
900 rtsx_clear_spi_error(chip);
901 spi_set_err_code(chip, SPI_HW_ERR);
905 return STATUS_SUCCESS;