spi_nor_unprep(nor);
 }
 
-static u32 spi_nor_convert_addr(struct spi_nor *nor, loff_t addr)
-{
-       if (!nor->params->convert_addr)
-               return addr;
-
-       return nor->params->convert_addr(nor, addr);
-}
-
 /*
  * Initiate the erasure of a single sector
  */
 {
        int i;
 
-       addr = spi_nor_convert_addr(nor, addr);
-
        if (nor->spimem) {
                struct spi_mem_op op =
                        SPI_NOR_SECTOR_ERASE_OP(nor->erase_opcode,
        while (len) {
                loff_t addr = from;
 
-               addr = spi_nor_convert_addr(nor, addr);
-
                ret = spi_nor_read_data(nor, addr, len, buf);
                if (ret == 0) {
                        /* We shouldn't see 0-length reads */
        size_t *retlen, const u_char *buf)
 {
        struct spi_nor *nor = mtd_to_spi_nor(mtd);
-       size_t page_offset, page_remain, i;
+       size_t i;
        ssize_t ret;
        u32 page_size = nor->params->page_size;
 
        for (i = 0; i < len; ) {
                ssize_t written;
                loff_t addr = to + i;
-
-               /*
-                * If page_size is a power of two, the offset can be quickly
-                * calculated with an AND operation. On the other cases we
-                * need to do a modulus operation (more expensive).
-                */
-               if (is_power_of_2(page_size)) {
-                       page_offset = addr & (page_size - 1);
-               } else {
-                       u64 aux = addr;
-
-                       page_offset = do_div(aux, page_size);
-               }
+               size_t page_offset = addr & (page_size - 1);
                /* the size of data remaining on the first page */
-               page_remain = min_t(size_t, page_size - page_offset, len - i);
-
-               addr = spi_nor_convert_addr(nor, addr);
+               size_t page_remain = min_t(size_t, page_size - page_offset, len - i);
 
                ret = spi_nor_lock_device(nor);
                if (ret)
                spi_nor_init_params_deprecated(nor);
        }
 
-       return spi_nor_late_init_params(nor);
+       ret = spi_nor_late_init_params(nor);
+       if (ret)
+               return ret;
+
+       if (WARN_ON(!is_power_of_2(nor->params->page_size)))
+               return -EINVAL;
+
+       return 0;
 }
 
 /** spi_nor_set_octal_dtr() - enable or disable Octal DTR I/O.
 
  * @set_octal_dtr:     enables or disables SPI NOR octal DTR mode.
  * @quad_enable:       enables SPI NOR quad mode.
  * @set_4byte_addr_mode: puts the SPI NOR in 4 byte addressing mode.
- * @convert_addr:      converts an absolute address into something the flash
- *                      will understand. Particularly useful when pagesize is
- *                      not a power-of-2.
  * @setup:             (optional) configures the SPI NOR memory. Useful for
  *                     SPI NOR flashes that have peculiarities to the SPI NOR
  *                     standard e.g. different opcodes, specific address
        int (*set_octal_dtr)(struct spi_nor *nor, bool enable);
        int (*quad_enable)(struct spi_nor *nor);
        int (*set_4byte_addr_mode)(struct spi_nor *nor, bool enable);
-       u32 (*convert_addr)(struct spi_nor *nor, u32 addr);
        int (*setup)(struct spi_nor *nor, const struct spi_nor_hwcaps *hwcaps);
        int (*ready)(struct spi_nor *nor);