Re: [PATCH] [PATCH v2] staging: sm750fb: Make g_fbmode truly constant
From: kernel test robot
Date: Sun Feb 23 2025 - 09:58:12 EST
Hi Madhur,
kernel test robot noticed the following build errors:
[auto build test ERROR on staging/staging-testing]
url: https://github.com/intel-lab-lkp/linux/commits/Madhur-Kumar/staging-sm750fb-Make-g_fbmode-truly-constant/20250223-041638
base: staging/staging-testing
patch link: https://lore.kernel.org/r/20250222201514.15730-1-madhurkumar004%40gmail.com
patch subject: [PATCH] [PATCH v2] staging: sm750fb: Make g_fbmode truly constant
config: sparc64-randconfig-001-20250223 (https://download.01.org/0day-ci/archive/20250223/202502232236.CRIQt4Wb-lkp@xxxxxxxxx/config)
compiler: sparc64-linux-gcc (GCC) 14.2.0
reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20250223/202502232236.CRIQt4Wb-lkp@xxxxxxxxx/reproduce)
If you fix the issue in a separate patch/commit (i.e. not just a new version of
the same patch/commit), kindly add following tags
| Reported-by: kernel test robot <lkp@xxxxxxxxx>
| Closes: https://lore.kernel.org/oe-kbuild-all/202502232236.CRIQt4Wb-lkp@xxxxxxxxx/
All errors (new ones prefixed by >>):
drivers/staging/sm750fb/sm750.c: In function 'lynxfb_set_fbinfo':
>> drivers/staging/sm750fb/sm750.c:788:33: error: assignment of read-only location 'g_fbmode[index]'
788 | g_fbmode[index] = g_def_fbmode;
| ^
drivers/staging/sm750fb/sm750.c:790:41: error: assignment of read-only location 'g_fbmode[index]'
790 | g_fbmode[index] = g_fbmode[0];
| ^
drivers/staging/sm750fb/sm750.c: In function 'sm750fb_setup':
>> drivers/staging/sm750fb/sm750.c:951:45: error: assignment of read-only location 'g_fbmode[0]'
951 | g_fbmode[0] = opt;
| ^
drivers/staging/sm750fb/sm750.c:955:45: error: assignment of read-only location 'g_fbmode[1]'
955 | g_fbmode[1] = opt;
| ^
vim +788 drivers/staging/sm750fb/sm750.c
81dee67e215b23 Sudip Mukherjee 2015-03-03 715
81dee67e215b23 Sudip Mukherjee 2015-03-03 716 static int lynxfb_set_fbinfo(struct fb_info *info, int index)
81dee67e215b23 Sudip Mukherjee 2015-03-03 717 {
81dee67e215b23 Sudip Mukherjee 2015-03-03 718 int i;
81dee67e215b23 Sudip Mukherjee 2015-03-03 719 struct lynxfb_par *par;
e359b6a863e19f Mike Rapoport 2015-10-26 720 struct sm750_dev *sm750_dev;
81dee67e215b23 Sudip Mukherjee 2015-03-03 721 struct lynxfb_crtc *crtc;
81dee67e215b23 Sudip Mukherjee 2015-03-03 722 struct lynxfb_output *output;
81dee67e215b23 Sudip Mukherjee 2015-03-03 723 struct fb_var_screeninfo *var;
81dee67e215b23 Sudip Mukherjee 2015-03-03 724 struct fb_fix_screeninfo *fix;
81dee67e215b23 Sudip Mukherjee 2015-03-03 725
81dee67e215b23 Sudip Mukherjee 2015-03-03 726 const struct fb_videomode *pdb[] = {
81dee67e215b23 Sudip Mukherjee 2015-03-03 727 lynx750_ext, NULL, vesa_modes,
81dee67e215b23 Sudip Mukherjee 2015-03-03 728 };
81dee67e215b23 Sudip Mukherjee 2015-03-03 729 int cdb[] = {ARRAY_SIZE(lynx750_ext), 0, VESA_MODEDB_SIZE};
d5d66cfea2ca28 Kelsey Skunberg 2019-04-27 730 static const char * const mdb_desc[] = {
81dee67e215b23 Sudip Mukherjee 2015-03-03 731 "driver prepared modes",
81dee67e215b23 Sudip Mukherjee 2015-03-03 732 "kernel prepared default modedb",
81dee67e215b23 Sudip Mukherjee 2015-03-03 733 "kernel HELPERS prepared vesa_modes",
81dee67e215b23 Sudip Mukherjee 2015-03-03 734 };
81dee67e215b23 Sudip Mukherjee 2015-03-03 735
70407df77665c0 Michel von Czettritz 2015-03-26 736 static const char *fixId[2] = {
81dee67e215b23 Sudip Mukherjee 2015-03-03 737 "sm750_fb1", "sm750_fb2",
81dee67e215b23 Sudip Mukherjee 2015-03-03 738 };
81dee67e215b23 Sudip Mukherjee 2015-03-03 739
81dee67e215b23 Sudip Mukherjee 2015-03-03 740 int ret, line_length;
81dee67e215b23 Sudip Mukherjee 2015-03-03 741
81dee67e215b23 Sudip Mukherjee 2015-03-03 742 ret = 0;
81dee67e215b23 Sudip Mukherjee 2015-03-03 743 par = (struct lynxfb_par *)info->par;
e359b6a863e19f Mike Rapoport 2015-10-26 744 sm750_dev = par->dev;
81dee67e215b23 Sudip Mukherjee 2015-03-03 745 crtc = &par->crtc;
81dee67e215b23 Sudip Mukherjee 2015-03-03 746 output = &par->output;
81dee67e215b23 Sudip Mukherjee 2015-03-03 747 var = &info->var;
81dee67e215b23 Sudip Mukherjee 2015-03-03 748 fix = &info->fix;
81dee67e215b23 Sudip Mukherjee 2015-03-03 749
81dee67e215b23 Sudip Mukherjee 2015-03-03 750 /* set index */
81dee67e215b23 Sudip Mukherjee 2015-03-03 751 par->index = index;
81dee67e215b23 Sudip Mukherjee 2015-03-03 752 output->channel = &crtc->channel;
81dee67e215b23 Sudip Mukherjee 2015-03-03 753 sm750fb_set_drv(par);
81dee67e215b23 Sudip Mukherjee 2015-03-03 754
d11ac7cbcc266c Sudip Mukherjee 2015-08-07 755 /*
d11ac7cbcc266c Sudip Mukherjee 2015-08-07 756 * set current cursor variable and proc pointer,
d11ac7cbcc266c Sudip Mukherjee 2015-08-07 757 * must be set after crtc member initialized
d11ac7cbcc266c Sudip Mukherjee 2015-08-07 758 */
fdc234d85210d9 Benjamin Philip 2021-07-28 759 crtc->cursor.offset = crtc->o_screen + crtc->vidmem_size - 1024;
e359b6a863e19f Mike Rapoport 2015-10-26 760 crtc->cursor.mmio = sm750_dev->pvReg +
e359b6a863e19f Mike Rapoport 2015-10-26 761 0x800f0 + (int)crtc->channel * 0x140;
81dee67e215b23 Sudip Mukherjee 2015-03-03 762
81dee67e215b23 Sudip Mukherjee 2015-03-03 763 pr_info("crtc->cursor.mmio = %p\n", crtc->cursor.mmio);
cd33da26036ea5 Christopher Carbone 2022-08-23 764 crtc->cursor.max_h = 64;
cd33da26036ea5 Christopher Carbone 2022-08-23 765 crtc->cursor.max_w = 64;
39f9137268ee3d Benjamin Philip 2021-07-26 766 crtc->cursor.size = crtc->cursor.max_h * crtc->cursor.max_w * 2 / 8;
e359b6a863e19f Mike Rapoport 2015-10-26 767 crtc->cursor.vstart = sm750_dev->pvMem + crtc->cursor.offset;
81dee67e215b23 Sudip Mukherjee 2015-03-03 768
3de08a2d14ff8c Lorenzo Stoakes 2015-03-20 769 memset_io(crtc->cursor.vstart, 0, crtc->cursor.size);
f7c8a046577e09 Thomas Zimmermann 2023-11-27 770 if (!g_hwcursor)
52d0744d751d8f Arnd Bergmann 2016-11-09 771 sm750_hw_cursor_disable(&crtc->cursor);
81dee67e215b23 Sudip Mukherjee 2015-03-03 772
81dee67e215b23 Sudip Mukherjee 2015-03-03 773 /* set info->fbops, must be set before fb_find_mode */
e359b6a863e19f Mike Rapoport 2015-10-26 774 if (!sm750_dev->accel_off) {
81dee67e215b23 Sudip Mukherjee 2015-03-03 775 /* use 2d acceleration */
f7c8a046577e09 Thomas Zimmermann 2023-11-27 776 if (!g_hwcursor)
f7c8a046577e09 Thomas Zimmermann 2023-11-27 777 info->fbops = &lynxfb_ops_accel;
f7c8a046577e09 Thomas Zimmermann 2023-11-27 778 else
f7c8a046577e09 Thomas Zimmermann 2023-11-27 779 info->fbops = &lynxfb_ops_accel_with_cursor;
f7c8a046577e09 Thomas Zimmermann 2023-11-27 780 } else {
f7c8a046577e09 Thomas Zimmermann 2023-11-27 781 if (!g_hwcursor)
81dee67e215b23 Sudip Mukherjee 2015-03-03 782 info->fbops = &lynxfb_ops;
f7c8a046577e09 Thomas Zimmermann 2023-11-27 783 else
f7c8a046577e09 Thomas Zimmermann 2023-11-27 784 info->fbops = &lynxfb_ops_with_cursor;
f7c8a046577e09 Thomas Zimmermann 2023-11-27 785 }
81dee67e215b23 Sudip Mukherjee 2015-03-03 786
81dee67e215b23 Sudip Mukherjee 2015-03-03 787 if (!g_fbmode[index]) {
81dee67e215b23 Sudip Mukherjee 2015-03-03 @788 g_fbmode[index] = g_def_fbmode;
81dee67e215b23 Sudip Mukherjee 2015-03-03 789 if (index)
81dee67e215b23 Sudip Mukherjee 2015-03-03 790 g_fbmode[index] = g_fbmode[0];
81dee67e215b23 Sudip Mukherjee 2015-03-03 791 }
81dee67e215b23 Sudip Mukherjee 2015-03-03 792
81dee67e215b23 Sudip Mukherjee 2015-03-03 793 for (i = 0; i < 3; i++) {
81dee67e215b23 Sudip Mukherjee 2015-03-03 794 ret = fb_find_mode(var, info, g_fbmode[index],
81dee67e215b23 Sudip Mukherjee 2015-03-03 795 pdb[i], cdb[i], NULL, 8);
81dee67e215b23 Sudip Mukherjee 2015-03-03 796
81dee67e215b23 Sudip Mukherjee 2015-03-03 797 if (ret == 1) {
81dee67e215b23 Sudip Mukherjee 2015-03-03 798 pr_info("success! use specified mode:%s in %s\n",
81dee67e215b23 Sudip Mukherjee 2015-03-03 799 g_fbmode[index],
81dee67e215b23 Sudip Mukherjee 2015-03-03 800 mdb_desc[i]);
81dee67e215b23 Sudip Mukherjee 2015-03-03 801 break;
81dee67e215b23 Sudip Mukherjee 2015-03-03 802 } else if (ret == 2) {
81dee67e215b23 Sudip Mukherjee 2015-03-03 803 pr_warn("use specified mode:%s in %s,with an ignored refresh rate\n",
81dee67e215b23 Sudip Mukherjee 2015-03-03 804 g_fbmode[index],
81dee67e215b23 Sudip Mukherjee 2015-03-03 805 mdb_desc[i]);
81dee67e215b23 Sudip Mukherjee 2015-03-03 806 break;
81dee67e215b23 Sudip Mukherjee 2015-03-03 807 } else if (ret == 3) {
81dee67e215b23 Sudip Mukherjee 2015-03-03 808 pr_warn("wanna use default mode\n");
4bd9503d0becdb Michel von Czettritz 2015-03-26 809 /*break;*/
81dee67e215b23 Sudip Mukherjee 2015-03-03 810 } else if (ret == 4) {
81dee67e215b23 Sudip Mukherjee 2015-03-03 811 pr_warn("fall back to any valid mode\n");
81dee67e215b23 Sudip Mukherjee 2015-03-03 812 } else {
3318bb5e945f70 Michel von Czettritz 2015-03-26 813 pr_warn("ret = %d,fb_find_mode failed,with %s\n",
3318bb5e945f70 Michel von Czettritz 2015-03-26 814 ret,
3318bb5e945f70 Michel von Czettritz 2015-03-26 815 mdb_desc[i]);
81dee67e215b23 Sudip Mukherjee 2015-03-03 816 }
81dee67e215b23 Sudip Mukherjee 2015-03-03 817 }
81dee67e215b23 Sudip Mukherjee 2015-03-03 818
81dee67e215b23 Sudip Mukherjee 2015-03-03 819 /* some member of info->var had been set by fb_find_mode */
81dee67e215b23 Sudip Mukherjee 2015-03-03 820
271dbae3c6a1da Prasant Jalan 2017-04-01 821 pr_info("Member of info->var is :\n"
271dbae3c6a1da Prasant Jalan 2017-04-01 822 "xres=%d\n"
271dbae3c6a1da Prasant Jalan 2017-04-01 823 "yres=%d\n"
271dbae3c6a1da Prasant Jalan 2017-04-01 824 "xres_virtual=%d\n"
271dbae3c6a1da Prasant Jalan 2017-04-01 825 "yres_virtual=%d\n"
271dbae3c6a1da Prasant Jalan 2017-04-01 826 "xoffset=%d\n"
271dbae3c6a1da Prasant Jalan 2017-04-01 827 "yoffset=%d\n"
271dbae3c6a1da Prasant Jalan 2017-04-01 828 "bits_per_pixel=%d\n"
271dbae3c6a1da Prasant Jalan 2017-04-01 829 " ...\n",
3318bb5e945f70 Michel von Czettritz 2015-03-26 830 var->xres,
3318bb5e945f70 Michel von Czettritz 2015-03-26 831 var->yres,
3318bb5e945f70 Michel von Czettritz 2015-03-26 832 var->xres_virtual,
3318bb5e945f70 Michel von Czettritz 2015-03-26 833 var->yres_virtual,
3318bb5e945f70 Michel von Czettritz 2015-03-26 834 var->xoffset,
3318bb5e945f70 Michel von Czettritz 2015-03-26 835 var->yoffset,
3318bb5e945f70 Michel von Czettritz 2015-03-26 836 var->bits_per_pixel);
81dee67e215b23 Sudip Mukherjee 2015-03-03 837
81dee67e215b23 Sudip Mukherjee 2015-03-03 838 /* set par */
81dee67e215b23 Sudip Mukherjee 2015-03-03 839 par->info = info;
81dee67e215b23 Sudip Mukherjee 2015-03-03 840
81dee67e215b23 Sudip Mukherjee 2015-03-03 841 /* set info */
e3a3f9f5123683 Mike Rapoport 2015-10-26 842 line_length = ALIGN((var->xres_virtual * var->bits_per_pixel / 8),
e3a3f9f5123683 Mike Rapoport 2015-10-26 843 crtc->line_pad);
81dee67e215b23 Sudip Mukherjee 2015-03-03 844
81dee67e215b23 Sudip Mukherjee 2015-03-03 845 info->pseudo_palette = &par->pseudo_palette[0];
cc59bde1c920ab Benjamin Philip 2021-07-28 846 info->screen_base = crtc->v_screen;
81dee67e215b23 Sudip Mukherjee 2015-03-03 847 pr_debug("screen_base vaddr = %p\n", info->screen_base);
81dee67e215b23 Sudip Mukherjee 2015-03-03 848 info->screen_size = line_length * var->yres_virtual;
81dee67e215b23 Sudip Mukherjee 2015-03-03 849
81dee67e215b23 Sudip Mukherjee 2015-03-03 850 /* set info->fix */
81dee67e215b23 Sudip Mukherjee 2015-03-03 851 fix->type = FB_TYPE_PACKED_PIXELS;
81dee67e215b23 Sudip Mukherjee 2015-03-03 852 fix->type_aux = 0;
81dee67e215b23 Sudip Mukherjee 2015-03-03 853 fix->xpanstep = crtc->xpanstep;
81dee67e215b23 Sudip Mukherjee 2015-03-03 854 fix->ypanstep = crtc->ypanstep;
81dee67e215b23 Sudip Mukherjee 2015-03-03 855 fix->ywrapstep = crtc->ywrapstep;
81dee67e215b23 Sudip Mukherjee 2015-03-03 856 fix->accel = FB_ACCEL_SMI;
81dee67e215b23 Sudip Mukherjee 2015-03-03 857
9c15db83a86bf8 Kumar Kartikeya Dwivedi 2021-01-31 858 strscpy(fix->id, fixId[index], sizeof(fix->id));
81dee67e215b23 Sudip Mukherjee 2015-03-03 859
fdc234d85210d9 Benjamin Philip 2021-07-28 860 fix->smem_start = crtc->o_screen + sm750_dev->vidmem_start;
81dee67e215b23 Sudip Mukherjee 2015-03-03 861 pr_info("fix->smem_start = %lx\n", fix->smem_start);
d11ac7cbcc266c Sudip Mukherjee 2015-08-07 862 /*
d11ac7cbcc266c Sudip Mukherjee 2015-08-07 863 * according to mmap experiment from user space application,
81dee67e215b23 Sudip Mukherjee 2015-03-03 864 * fix->mmio_len should not larger than virtual size
81dee67e215b23 Sudip Mukherjee 2015-03-03 865 * (xres_virtual x yres_virtual x ByPP)
81dee67e215b23 Sudip Mukherjee 2015-03-03 866 * Below line maybe buggy when user mmap fb dev node and write
81dee67e215b23 Sudip Mukherjee 2015-03-03 867 * data into the bound over virtual size
d11ac7cbcc266c Sudip Mukherjee 2015-08-07 868 */
81dee67e215b23 Sudip Mukherjee 2015-03-03 869 fix->smem_len = crtc->vidmem_size;
81dee67e215b23 Sudip Mukherjee 2015-03-03 870 pr_info("fix->smem_len = %x\n", fix->smem_len);
81dee67e215b23 Sudip Mukherjee 2015-03-03 871 info->screen_size = fix->smem_len;
81dee67e215b23 Sudip Mukherjee 2015-03-03 872 fix->line_length = line_length;
e359b6a863e19f Mike Rapoport 2015-10-26 873 fix->mmio_start = sm750_dev->vidreg_start;
81dee67e215b23 Sudip Mukherjee 2015-03-03 874 pr_info("fix->mmio_start = %lx\n", fix->mmio_start);
e359b6a863e19f Mike Rapoport 2015-10-26 875 fix->mmio_len = sm750_dev->vidreg_size;
81dee67e215b23 Sudip Mukherjee 2015-03-03 876 pr_info("fix->mmio_len = %x\n", fix->mmio_len);
b610e1193a917f Matej Dujava 2020-04-30 877
b610e1193a917f Matej Dujava 2020-04-30 878 lynxfb_set_visual_mode(info);
81dee67e215b23 Sudip Mukherjee 2015-03-03 879
81dee67e215b23 Sudip Mukherjee 2015-03-03 880 /* set var */
81dee67e215b23 Sudip Mukherjee 2015-03-03 881 var->activate = FB_ACTIVATE_NOW;
81dee67e215b23 Sudip Mukherjee 2015-03-03 882 var->accel_flags = 0;
81dee67e215b23 Sudip Mukherjee 2015-03-03 883 var->vmode = FB_VMODE_NONINTERLACED;
81dee67e215b23 Sudip Mukherjee 2015-03-03 884
81dee67e215b23 Sudip Mukherjee 2015-03-03 885 pr_debug("#1 show info->cmap :\nstart=%d,len=%d,red=%p,green=%p,blue=%p,transp=%p\n",
81dee67e215b23 Sudip Mukherjee 2015-03-03 886 info->cmap.start, info->cmap.len,
81dee67e215b23 Sudip Mukherjee 2015-03-03 887 info->cmap.red, info->cmap.green, info->cmap.blue,
81dee67e215b23 Sudip Mukherjee 2015-03-03 888 info->cmap.transp);
81dee67e215b23 Sudip Mukherjee 2015-03-03 889
61c507cf652da1 Michel von Czettritz 2015-03-26 890 ret = fb_alloc_cmap(&info->cmap, 256, 0);
61c507cf652da1 Michel von Czettritz 2015-03-26 891 if (ret < 0) {
008272072d61a8 Masanari Iida 2015-05-28 892 pr_err("Could not allocate memory for cmap.\n");
81dee67e215b23 Sudip Mukherjee 2015-03-03 893 goto exit;
81dee67e215b23 Sudip Mukherjee 2015-03-03 894 }
81dee67e215b23 Sudip Mukherjee 2015-03-03 895
81dee67e215b23 Sudip Mukherjee 2015-03-03 896 pr_debug("#2 show info->cmap :\nstart=%d,len=%d,red=%p,green=%p,blue=%p,transp=%p\n",
81dee67e215b23 Sudip Mukherjee 2015-03-03 897 info->cmap.start, info->cmap.len,
81dee67e215b23 Sudip Mukherjee 2015-03-03 898 info->cmap.red, info->cmap.green, info->cmap.blue,
81dee67e215b23 Sudip Mukherjee 2015-03-03 899 info->cmap.transp);
81dee67e215b23 Sudip Mukherjee 2015-03-03 900
81dee67e215b23 Sudip Mukherjee 2015-03-03 901 exit:
81dee67e215b23 Sudip Mukherjee 2015-03-03 902 lynxfb_ops_check_var(var, info);
81dee67e215b23 Sudip Mukherjee 2015-03-03 903 return ret;
81dee67e215b23 Sudip Mukherjee 2015-03-03 904 }
81dee67e215b23 Sudip Mukherjee 2015-03-03 905
81dee67e215b23 Sudip Mukherjee 2015-03-03 906 /* chip specific g_option configuration routine */
700591a9adc8b1 Mike Rapoport 2015-10-26 907 static void sm750fb_setup(struct sm750_dev *sm750_dev, char *src)
81dee67e215b23 Sudip Mukherjee 2015-03-03 908 {
81dee67e215b23 Sudip Mukherjee 2015-03-03 909 char *opt;
81dee67e215b23 Sudip Mukherjee 2015-03-03 910 int swap;
81dee67e215b23 Sudip Mukherjee 2015-03-03 911
81dee67e215b23 Sudip Mukherjee 2015-03-03 912 swap = 0;
81dee67e215b23 Sudip Mukherjee 2015-03-03 913
1757d106a9ce8c Mike Rapoport 2015-10-26 914 sm750_dev->initParm.chip_clk = 0;
1757d106a9ce8c Mike Rapoport 2015-10-26 915 sm750_dev->initParm.mem_clk = 0;
1757d106a9ce8c Mike Rapoport 2015-10-26 916 sm750_dev->initParm.master_clk = 0;
1757d106a9ce8c Mike Rapoport 2015-10-26 917 sm750_dev->initParm.powerMode = 0;
1757d106a9ce8c Mike Rapoport 2015-10-26 918 sm750_dev->initParm.setAllEngOff = 0;
1757d106a9ce8c Mike Rapoport 2015-10-26 919 sm750_dev->initParm.resetMemory = 1;
81dee67e215b23 Sudip Mukherjee 2015-03-03 920
81dee67e215b23 Sudip Mukherjee 2015-03-03 921 /* defaultly turn g_hwcursor on for both view */
81dee67e215b23 Sudip Mukherjee 2015-03-03 922 g_hwcursor = 3;
81dee67e215b23 Sudip Mukherjee 2015-03-03 923
81dee67e215b23 Sudip Mukherjee 2015-03-03 924 if (!src || !*src) {
c56de0967a658c Elise Lennion 2016-10-31 925 dev_warn(&sm750_dev->pdev->dev, "no specific g_option.\n");
81dee67e215b23 Sudip Mukherjee 2015-03-03 926 goto NO_PARAM;
81dee67e215b23 Sudip Mukherjee 2015-03-03 927 }
81dee67e215b23 Sudip Mukherjee 2015-03-03 928
0fa96e39279988 Sudip Mukherjee 2015-03-10 929 while ((opt = strsep(&src, ":")) != NULL && *opt != 0) {
c56de0967a658c Elise Lennion 2016-10-31 930 dev_info(&sm750_dev->pdev->dev, "opt=%s\n", opt);
c56de0967a658c Elise Lennion 2016-10-31 931 dev_info(&sm750_dev->pdev->dev, "src=%s\n", src);
81dee67e215b23 Sudip Mukherjee 2015-03-03 932
144634a6b42146 Katie Dunne 2017-02-19 933 if (!strncmp(opt, "swap", strlen("swap"))) {
81dee67e215b23 Sudip Mukherjee 2015-03-03 934 swap = 1;
144634a6b42146 Katie Dunne 2017-02-19 935 } else if (!strncmp(opt, "nocrt", strlen("nocrt"))) {
1757d106a9ce8c Mike Rapoport 2015-10-26 936 sm750_dev->nocrt = 1;
144634a6b42146 Katie Dunne 2017-02-19 937 } else if (!strncmp(opt, "36bit", strlen("36bit"))) {
1757d106a9ce8c Mike Rapoport 2015-10-26 938 sm750_dev->pnltype = sm750_doubleTFT;
144634a6b42146 Katie Dunne 2017-02-19 939 } else if (!strncmp(opt, "18bit", strlen("18bit"))) {
1757d106a9ce8c Mike Rapoport 2015-10-26 940 sm750_dev->pnltype = sm750_dualTFT;
144634a6b42146 Katie Dunne 2017-02-19 941 } else if (!strncmp(opt, "24bit", strlen("24bit"))) {
1757d106a9ce8c Mike Rapoport 2015-10-26 942 sm750_dev->pnltype = sm750_24TFT;
144634a6b42146 Katie Dunne 2017-02-19 943 } else if (!strncmp(opt, "nohwc0", strlen("nohwc0"))) {
81dee67e215b23 Sudip Mukherjee 2015-03-03 944 g_hwcursor &= ~0x1;
144634a6b42146 Katie Dunne 2017-02-19 945 } else if (!strncmp(opt, "nohwc1", strlen("nohwc1"))) {
81dee67e215b23 Sudip Mukherjee 2015-03-03 946 g_hwcursor &= ~0x2;
144634a6b42146 Katie Dunne 2017-02-19 947 } else if (!strncmp(opt, "nohwc", strlen("nohwc"))) {
81dee67e215b23 Sudip Mukherjee 2015-03-03 948 g_hwcursor = 0;
144634a6b42146 Katie Dunne 2017-02-19 949 } else {
81dee67e215b23 Sudip Mukherjee 2015-03-03 950 if (!g_fbmode[0]) {
81dee67e215b23 Sudip Mukherjee 2015-03-03 @951 g_fbmode[0] = opt;
cee9ba1c30d051 Abdul Rauf 2017-01-08 952 dev_info(&sm750_dev->pdev->dev,
cee9ba1c30d051 Abdul Rauf 2017-01-08 953 "find fbmode0 : %s\n", g_fbmode[0]);
81dee67e215b23 Sudip Mukherjee 2015-03-03 954 } else if (!g_fbmode[1]) {
81dee67e215b23 Sudip Mukherjee 2015-03-03 955 g_fbmode[1] = opt;
cee9ba1c30d051 Abdul Rauf 2017-01-08 956 dev_info(&sm750_dev->pdev->dev,
cee9ba1c30d051 Abdul Rauf 2017-01-08 957 "find fbmode1 : %s\n", g_fbmode[1]);
81dee67e215b23 Sudip Mukherjee 2015-03-03 958 } else {
c56de0967a658c Elise Lennion 2016-10-31 959 dev_warn(&sm750_dev->pdev->dev, "How many view you wann set?\n");
81dee67e215b23 Sudip Mukherjee 2015-03-03 960 }
81dee67e215b23 Sudip Mukherjee 2015-03-03 961 }
81dee67e215b23 Sudip Mukherjee 2015-03-03 962 }
81dee67e215b23 Sudip Mukherjee 2015-03-03 963
81dee67e215b23 Sudip Mukherjee 2015-03-03 964 NO_PARAM:
e359b6a863e19f Mike Rapoport 2015-10-26 965 if (sm750_dev->revid != SM750LE_REVISION_ID) {
a3f92cc94c6126 Mike Rapoport 2016-01-17 966 if (sm750_dev->fb_count > 1) {
81dee67e215b23 Sudip Mukherjee 2015-03-03 967 if (swap)
1757d106a9ce8c Mike Rapoport 2015-10-26 968 sm750_dev->dataflow = sm750_dual_swap;
81dee67e215b23 Sudip Mukherjee 2015-03-03 969 else
1757d106a9ce8c Mike Rapoport 2015-10-26 970 sm750_dev->dataflow = sm750_dual_normal;
81dee67e215b23 Sudip Mukherjee 2015-03-03 971 } else {
81dee67e215b23 Sudip Mukherjee 2015-03-03 972 if (swap)
1757d106a9ce8c Mike Rapoport 2015-10-26 973 sm750_dev->dataflow = sm750_simul_sec;
81dee67e215b23 Sudip Mukherjee 2015-03-03 974 else
1757d106a9ce8c Mike Rapoport 2015-10-26 975 sm750_dev->dataflow = sm750_simul_pri;
81dee67e215b23 Sudip Mukherjee 2015-03-03 976 }
81dee67e215b23 Sudip Mukherjee 2015-03-03 977 } else {
81dee67e215b23 Sudip Mukherjee 2015-03-03 978 /* SM750LE only have one crt channel */
1757d106a9ce8c Mike Rapoport 2015-10-26 979 sm750_dev->dataflow = sm750_simul_sec;
81dee67e215b23 Sudip Mukherjee 2015-03-03 980 /* sm750le do not have complex attributes */
1757d106a9ce8c Mike Rapoport 2015-10-26 981 sm750_dev->nocrt = 0;
81dee67e215b23 Sudip Mukherjee 2015-03-03 982 }
81dee67e215b23 Sudip Mukherjee 2015-03-03 983 }
81dee67e215b23 Sudip Mukherjee 2015-03-03 984
--
0-DAY CI Kernel Test Service
https://github.com/intel/lkp-tests/wiki