aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMike Frysinger <vapier.adi@gmail.com>2008-07-14 04:34:05 -0400
committerBryan Wu <cooloney@kernel.org>2008-07-14 04:34:05 -0400
commit260d5d3517c67c5b68b4e28c5d3e1e3b73976a90 (patch)
tree5ebf3e3bc00a2b4116442ac974b08507d9592966
parent1f2d18690f4390ac4cf75648a5bc18fc07b3aef6 (diff)
Blackfin arch: Fix bug - do not overflow the buffer given to us which tends to happen when CONFIG_L1_MAX_PIECE is increased past its default
Singed-off-by: Mike Frysinger <vapier.adi@gmail.com> Signed-off-by: Bryan Wu <cooloney@kernel.org>
-rw-r--r--arch/blackfin/mm/blackfin_sram.c38
1 files changed, 26 insertions, 12 deletions
diff --git a/arch/blackfin/mm/blackfin_sram.c b/arch/blackfin/mm/blackfin_sram.c
index 3246f91c7baa..8f6fdc245330 100644
--- a/arch/blackfin/mm/blackfin_sram.c
+++ b/arch/blackfin/mm/blackfin_sram.c
@@ -549,13 +549,16 @@ EXPORT_SYMBOL(sram_alloc_with_lsl);
549/* Once we get a real allocator, we'll throw all of this away. 549/* Once we get a real allocator, we'll throw all of this away.
550 * Until then, we need some sort of visibility into the L1 alloc. 550 * Until then, we need some sort of visibility into the L1 alloc.
551 */ 551 */
552static void _l1sram_proc_read(char *buf, int *len, const char *desc, 552/* Need to keep line of output the same. Currently, that is 44 bytes
553 * (including newline).
554 */
555static int _l1sram_proc_read(char *buf, int *len, int count, const char *desc,
553 struct l1_sram_piece *pfree, const int array_size) 556 struct l1_sram_piece *pfree, const int array_size)
554{ 557{
555 int i; 558 int i;
556 559
557 *len += sprintf(&buf[*len], "--- L1 %-14s Size PID State\n", desc); 560 *len += sprintf(&buf[*len], "--- L1 %-14s Size PID State \n", desc);
558 for (i = 0; i < array_size; ++i) { 561 for (i = 0; i < array_size && *len < count; ++i) {
559 const char *alloc_type; 562 const char *alloc_type;
560 switch (pfree[i].flag) { 563 switch (pfree[i].flag) {
561 case SRAM_SLT_NULL: alloc_type = "NULL"; break; 564 case SRAM_SLT_NULL: alloc_type = "NULL"; break;
@@ -563,31 +566,42 @@ static void _l1sram_proc_read(char *buf, int *len, const char *desc,
563 case SRAM_SLT_ALLOCATED: alloc_type = "ALLOCATED"; break; 566 case SRAM_SLT_ALLOCATED: alloc_type = "ALLOCATED"; break;
564 default: alloc_type = "????"; break; 567 default: alloc_type = "????"; break;
565 } 568 }
566 *len += sprintf(&buf[*len], "%p-%p %8i %4i %s\n", 569 /* if we've got a lot of space to cover, omit things */
570 if ((PAGE_SIZE - 1024) < (CONFIG_L1_MAX_PIECE + 1) * 4 * 44 &&
571 pfree[i].size == 0)
572 continue;
573 *len += sprintf(&buf[*len], "%p-%p %8i %5i %-10s\n",
567 pfree[i].paddr, pfree[i].paddr + pfree[i].size, 574 pfree[i].paddr, pfree[i].paddr + pfree[i].size,
568 pfree[i].size, pfree[i].pid, alloc_type); 575 pfree[i].size, pfree[i].pid, alloc_type);
569 } 576 }
577 return (i != array_size);
570} 578}
571static int l1sram_proc_read(char *buf, char **start, off_t offset, int count, 579static int l1sram_proc_read(char *buf, char **start, off_t offset, int count,
572 int *eof, void *data) 580 int *eof, void *data)
573{ 581{
574 int len = 0; 582 int len = 0;
575 583
576 _l1sram_proc_read(buf, &len, "Scratchpad", 584 if (_l1sram_proc_read(buf, &len, count, "Scratchpad",
577 l1_ssram, ARRAY_SIZE(l1_ssram)); 585 l1_ssram, ARRAY_SIZE(l1_ssram)))
586 goto not_done;
578#if L1_DATA_A_LENGTH != 0 587#if L1_DATA_A_LENGTH != 0
579 _l1sram_proc_read(buf, &len, "Data A", 588 if (_l1sram_proc_read(buf, &len, count, "Data A",
580 l1_data_A_sram, ARRAY_SIZE(l1_data_A_sram)); 589 l1_data_A_sram, ARRAY_SIZE(l1_data_A_sram)))
590 goto not_done;
581#endif 591#endif
582#if L1_DATA_B_LENGTH != 0 592#if L1_DATA_B_LENGTH != 0
583 _l1sram_proc_read(buf, &len, "Data B", 593 if (_l1sram_proc_read(buf, &len, count, "Data B",
584 l1_data_B_sram, ARRAY_SIZE(l1_data_B_sram)); 594 l1_data_B_sram, ARRAY_SIZE(l1_data_B_sram)))
595 goto not_done;
585#endif 596#endif
586#if L1_CODE_LENGTH != 0 597#if L1_CODE_LENGTH != 0
587 _l1sram_proc_read(buf, &len, "Instruction", 598 if (_l1sram_proc_read(buf, &len, count, "Instruction",
588 l1_inst_sram, ARRAY_SIZE(l1_inst_sram)); 599 l1_inst_sram, ARRAY_SIZE(l1_inst_sram)))
600 goto not_done;
589#endif 601#endif
590 602
603 *eof = 1;
604 not_done:
591 return len; 605 return len;
592} 606}
593 607