mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-04 04:44:37 +08:00
9bc6772e15
wl1271 driver is under heavy development but on the other hand the older wl1251 driver is currently considered more as a legacy driver. To make it easier to develop wl1271 features move wl1251 to it's own directory, drivers/net/wireless/wl1251. There are no functional changes, only moving of files. One regression is that Kconfig won't be updated automatically and user needs to enable wl1251 manually with an older config file. Signed-off-by: Kalle Valo <kvalo@adurom.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
85 lines
2.4 KiB
C
85 lines
2.4 KiB
C
/*
|
|
* This file is part of wl12xx
|
|
*
|
|
* Copyright (C) 2008 Nokia Corporation
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* version 2 as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
|
|
* 02110-1301 USA
|
|
*
|
|
*/
|
|
#ifndef __WL1251_IO_H__
|
|
#define __WL1251_IO_H__
|
|
|
|
#include "wl1251.h"
|
|
|
|
#define HW_ACCESS_MEMORY_MAX_RANGE 0x1FFC0
|
|
|
|
#define HW_ACCESS_PART0_SIZE_ADDR 0x1FFC0
|
|
#define HW_ACCESS_PART0_START_ADDR 0x1FFC4
|
|
#define HW_ACCESS_PART1_SIZE_ADDR 0x1FFC8
|
|
#define HW_ACCESS_PART1_START_ADDR 0x1FFCC
|
|
|
|
#define HW_ACCESS_REGISTER_SIZE 4
|
|
|
|
#define HW_ACCESS_PRAM_MAX_RANGE 0x3c000
|
|
|
|
static inline u32 wl1251_read32(struct wl1251 *wl, int addr)
|
|
{
|
|
u32 response;
|
|
|
|
wl->if_ops->read(wl, addr, &response, sizeof(u32));
|
|
|
|
return response;
|
|
}
|
|
|
|
static inline void wl1251_write32(struct wl1251 *wl, int addr, u32 val)
|
|
{
|
|
wl->if_ops->write(wl, addr, &val, sizeof(u32));
|
|
}
|
|
|
|
static inline u32 wl1251_read_elp(struct wl1251 *wl, int addr)
|
|
{
|
|
u32 response;
|
|
|
|
if (wl->if_ops->read_elp)
|
|
wl->if_ops->read_elp(wl, addr, &response);
|
|
else
|
|
wl->if_ops->read(wl, addr, &response, sizeof(u32));
|
|
|
|
return response;
|
|
}
|
|
|
|
static inline void wl1251_write_elp(struct wl1251 *wl, int addr, u32 val)
|
|
{
|
|
if (wl->if_ops->write_elp)
|
|
wl->if_ops->write_elp(wl, addr, val);
|
|
else
|
|
wl->if_ops->write(wl, addr, &val, sizeof(u32));
|
|
}
|
|
|
|
/* Memory target IO, address is translated to partition 0 */
|
|
void wl1251_mem_read(struct wl1251 *wl, int addr, void *buf, size_t len);
|
|
void wl1251_mem_write(struct wl1251 *wl, int addr, void *buf, size_t len);
|
|
u32 wl1251_mem_read32(struct wl1251 *wl, int addr);
|
|
void wl1251_mem_write32(struct wl1251 *wl, int addr, u32 val);
|
|
/* Registers IO */
|
|
u32 wl1251_reg_read32(struct wl1251 *wl, int addr);
|
|
void wl1251_reg_write32(struct wl1251 *wl, int addr, u32 val);
|
|
|
|
void wl1251_set_partition(struct wl1251 *wl,
|
|
u32 part_start, u32 part_size,
|
|
u32 reg_start, u32 reg_size);
|
|
|
|
#endif
|