zeroplus: Add support for additional memory sizes
The zeroplus can have up to a 8M SRAM. Avoid some extensive if/else blocks by noting that all sizes except the first are related by their power of 2.
This commit is contained in:
parent
e93fb98b8a
commit
3e43da1f70
|
@ -43,10 +43,16 @@
|
||||||
#define STATUS_FLAG_READ 0x10
|
#define STATUS_FLAG_READ 0x10
|
||||||
#define STATUS_FLAG_20 0x20
|
#define STATUS_FLAG_20 0x20
|
||||||
|
|
||||||
|
/* In bytes */
|
||||||
#define MEMORY_SIZE_8K 0x00
|
#define MEMORY_SIZE_8K 0x00
|
||||||
#define MEMORY_SIZE_64K 0x01
|
#define MEMORY_SIZE_64K 0x01
|
||||||
#define MEMORY_SIZE_128K 0x02
|
#define MEMORY_SIZE_128K 0x02
|
||||||
|
#define MEMORY_SIZE_256K 0x03
|
||||||
#define MEMORY_SIZE_512K 0x04
|
#define MEMORY_SIZE_512K 0x04
|
||||||
|
#define MEMORY_SIZE_1M 0x05
|
||||||
|
#define MEMORY_SIZE_2M 0x06
|
||||||
|
#define MEMORY_SIZE_4M 0x07
|
||||||
|
#define MEMORY_SIZE_8M 0x08
|
||||||
|
|
||||||
#define STATUS_BUSY 0x01 /* WTF / ??? */
|
#define STATUS_BUSY 0x01 /* WTF / ??? */
|
||||||
#define STATUS_READY 0x02
|
#define STATUS_READY 0x02
|
||||||
|
|
|
@ -23,16 +23,38 @@ SR_PRIV unsigned int get_memory_size(int type)
|
||||||
{
|
{
|
||||||
if (type == MEMORY_SIZE_8K)
|
if (type == MEMORY_SIZE_8K)
|
||||||
return 8 * 1024;
|
return 8 * 1024;
|
||||||
else if (type == MEMORY_SIZE_64K)
|
else if (type <= MEMORY_SIZE_8M)
|
||||||
return 64 * 1024;
|
return (32 * 1024) << type;
|
||||||
else if (type == MEMORY_SIZE_128K)
|
|
||||||
return 128 * 1024;
|
|
||||||
else if (type == MEMORY_SIZE_512K)
|
|
||||||
return 512 * 1024;
|
|
||||||
else
|
else
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SR_PRIV int clz(unsigned int x)
|
||||||
|
{
|
||||||
|
int n = 0;
|
||||||
|
if (x == 0)
|
||||||
|
return 32;
|
||||||
|
if (!(x & 0xFFFF0000)) {
|
||||||
|
n = n + 16;
|
||||||
|
x = x << 16;
|
||||||
|
}
|
||||||
|
if (!(x & 0xFF000000)) {
|
||||||
|
n = n + 8;
|
||||||
|
x = x << 8;
|
||||||
|
}
|
||||||
|
if (!(x & 0xF0000000)) {
|
||||||
|
n = n + 4;
|
||||||
|
x = x << 4;
|
||||||
|
}
|
||||||
|
if (!(x & 0xC0000000)) {
|
||||||
|
n = n + 2;
|
||||||
|
x = x << 2;
|
||||||
|
}
|
||||||
|
if (!(x & 0x80000000))
|
||||||
|
n = n + 1;
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
|
||||||
SR_PRIV int set_limit_samples(struct dev_context *devc, uint64_t samples)
|
SR_PRIV int set_limit_samples(struct dev_context *devc, uint64_t samples)
|
||||||
{
|
{
|
||||||
devc->limit_samples = samples;
|
devc->limit_samples = samples;
|
||||||
|
@ -41,10 +63,8 @@ SR_PRIV int set_limit_samples(struct dev_context *devc, uint64_t samples)
|
||||||
devc->memory_size = MEMORY_SIZE_8K;
|
devc->memory_size = MEMORY_SIZE_8K;
|
||||||
else if (samples <= 16 * 1024)
|
else if (samples <= 16 * 1024)
|
||||||
devc->memory_size = MEMORY_SIZE_64K;
|
devc->memory_size = MEMORY_SIZE_64K;
|
||||||
else if (samples <= 32 * 1024 || devc->max_memory_size <= 32 * 1024)
|
|
||||||
devc->memory_size = MEMORY_SIZE_128K;
|
|
||||||
else
|
else
|
||||||
devc->memory_size = MEMORY_SIZE_512K;
|
devc->memory_size = 19 - clz(samples - 1);
|
||||||
|
|
||||||
sr_info("Setting memory size to %dK.",
|
sr_info("Setting memory size to %dK.",
|
||||||
get_memory_size(devc->memory_size) / 1024);
|
get_memory_size(devc->memory_size) / 1024);
|
||||||
|
|
Loading…
Reference in New Issue